File: ReadMe.txt

package info (click to toggle)
robocode 1.9.3.9-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 10,648 kB
  • sloc: java: 53,012; cs: 25,275; xml: 2,337; sh: 272; makefile: 15
file content (109 lines) | stat: -rw-r--r-- 4,979 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
====
    Copyright (c) 2001-2019 Mathew A. Nelson and Robocode contributors
    All rights reserved. This program and the accompanying materials
    are made available under the terms of the Eclipse Public License v1.0
    which accompanies this distribution, and is available at
    https://robocode.sourceforge.io/license/epl-v10.html
====

This is guide to build Robocode for .NET

REQUIRED TOOLS FOR BUILDING THE ROBOCODE .NET PLUG-IN
=====================================================

Microsoft C# Compiler and .NET SDK
----------------------------------
- You need C# compiler and .NET SDK at least 4.0:
  http://www.microsoft.com/en-us/download/details.aspx?id=17851

- Best option is to install Visual Studio C# Express 2010 or newer.

- NOTE: Make sure you have csc.exe version 3.5 on PATH.
Something like
c:\Windows\Microsoft.NET\Framework\v3.5\csc.exe 

Microsoft HTML Help 1 Compiler and Sandcastle Help File Builder
---------------------------------------------------------------
- 'HTML Help 1 compiler' must be installed on the system - required by the
  Sandcastle Help File Builder

  HTML Help 1 compiler:
  http://msdn.microsoft.com/en-us/library/ms669985(VS.85).aspx

- Sandcastle Help File Builder (SHFB) must be installed on the system.
  https://github.com/EWSoftware/SHFB/releases/tag/v2015.1.12.0

Java Development Kit (JDK) and JAVA_HOME path
---------------------------------------------
- Oracle JDK 6 or newer must be installed on the system:
  http://www.oracle.com/technetwork/java/javase/downloads

- NOTE: Make sure to install the proper version (32 or 64-bit) depending on the
        system.


HOW TO BUILD THE ROBOCODE .NET PLUG-IN
======================================

1) Build the regular part of Robocode first with 'mvn install'
  (or mvnassembly.cmd) from source code root directory of Robocode.

2) CD (change directory) to \plugins\dotnet

3) Run: tools\loadTools.cmd 

4) Run: tools\keys\gennetkey.cmd 

5) Run: mvnassembly.cmd (standing in the \plugins\dotnet directory)

9) Find the resulting distribution file for the Robocode .NET plug-in named 
   robocode.dotnet-x.x.x.x-setup.jar within this directory:
   \plugins\dotnet\robocode.dotnet.distribution\target\

   
HOW TO BUILD NEW PROXY CLASSES USING JNI4NET
============================================
Robocode uses Jni4net (http://jni4net.com/) to bridge the .NET and Java parts
of Robocode. Only the .NET plug-in is written for the Microsoft .NET platform.
The rest of Robocode is build for the Java platform.

When changing the public APIs or internal classes of Robocode it is important
that the corresponding .NET classes are updated as well. Some classes for the
.NET are handwritten. Other parts are auto-generated using the Jni4Net proxygen
tool (details are provided here: http://jni4net.com/).

In order to update all the auto-generated source files for the .NET plugin you
must:

1) CD (change directory) to \plugins\dotnet

2) Run: generateProxies.cmd

NOTE: You might need to remove the 'rem' and change the following lines inside
      the generateProxies.cmd in order to force the JAVA_HOME and PATH to the
	  correct Java version:

rem set JAVA_HOME=%JDK6_HOME%
rem set PATH=%JAVA_HOME%\bin;%PATH%


INSTALL LIBRARIES INTO THE LOCAL MAVEN REPOSITORY
=================================================
Robocode will give compiler error when running mvnassembly the first time or if the jni4net version is rolled.
Make sure to run these commands:

mvn install:install-file -DgroupId=net.sf.jni4net -DartifactId=jni4net.n -Dversion=0.8.7.0 -Dpackaging=dotnet:library -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\jni4net.n-0.8.7.0.dll

mvn install:install-file -DgroupId=net.sf.jni4net -DartifactId=jni4net.j -Dversion=0.8.7.0 -Dpackaging=jar -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\jni4net.j-0.8.7.0.jar

mvn install:install-file -DgroupId=net.sf.jni4net -DartifactId=jni4net.n.w32.v20 -Dversion=0.8.7.0 -Dpackaging=dotnet:library -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\jni4net.n.w32.v20-0.8.7.0.dll

mvn install:install-file -DgroupId=net.sf.jni4net -DartifactId=jni4net.n.w32.v40 -Dversion=0.8.7.0 -Dpackaging=dotnet:library -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\jni4net.n.w32.v40-0.8.7.0.dll

mvn install:install-file -DgroupId=net.sf.jni4net -DartifactId=jni4net.n.w64.v20 -Dversion=0.8.7.0 -Dpackaging=dotnet:library -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\jni4net.n.w64.v20-0.8.7.0.dll

mvn install:install-file -DgroupId=net.sf.jni4net -DartifactId=jni4net.n.w64.v40 -Dversion=0.8.7.0 -Dpackaging=dotnet:library -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\jni4net.n.w64.v40-0.8.7.0.dll

mvn install:install-file -DgroupId=org.nunit -DartifactId=nunit.framework -Dversion=2.4.3.0 -Dpackaging=dotnet:library -Dfile=<robocode-work-dir>\plugins\dotnet\tools\lib\nunit.framework-2.4.3.0.dll

Where <robocode-work-dir> is the directory containing your Robocode sources, e.g. D:\robocode-work