2004-12-20 Ben Maurer <bmaurer@ximian.com>
[mono-project.git] / README
blob6d257c99df310772741bdd2e00c2615f4aeab765
2 This is Mono.
4 1. Installation
5 2. Using Mono
6 3. Directory Roadmap
8 1. Compilation and Installation
9 ===============================
11    a. Build Requirements
12    ---------------------
14         To build Mono, you will need the following components:
16                 * pkg-config
18                   Available from: http://www.freedesktop.org/Software/pkgconfig
20                 * glib 2.0
22                   Available from: http://www.gtk.org/
24         Optional dependencies:
26                 * ICU library
28                   http://oss.software.ibm.com/icu/index.html
30                   You will need this one to get complete support for the international
31                   features of the .NET Framework.
33                 * Cairo and libgdiplus
35                   If you want to get support for System.Drawing, you will need to get
36                   both Libgdiplus and Cairo.
38     b. Building the Software
39     ------------------------
40         
41         If you obtained this package as an officially released tarball,
42         this is very simple, use configure and make:
44                 ./configure --prefix=/usr/local
45                 make
46                 make install
48         Mono supports a JIT engine on x86, SPARC and PowerPC systems.
49         The various commands that ship with Mono default to the JIT engine
50         on x86 and SPARC, to turn it on for PPC systems, use the --with-jit=yes 
51         command line option to configure.
53         MacOS X Users: you will need to download the latest Boehm GC
54         Alpha release for garbage collection to work properly.
56         If you obtained this as a snapshot, you will need an existing
57         Mono installation.  To upgrade your installation, unpack both
58         mono and mcs:
60                 tar xzf mcs-XXXX.tar.gz
61                 tar xzf mono-XXXX.tar.gz
62                 mv mono-XXX mono
63                 mv mcs-XXX mcs
64                 cd mono
65                 ./autogen.sh --prefix=/usr/local
66                 make
68     c. Building the software from SVN
69     ---------------------------------
71         If you are building the software from SVN, make sure that you
72         have up-to-date mcs and mono sources:
74                 svn co svn+ssh://USER@mono-cvs.ximian.com/source/trunk/mono
75                 svn co svn+ssh://USER@mono-cvs.ximian.com/source/trunk/mcs
77         Then, go into the mono directory, and configure:
79                 cd mono
80                 ./autogen.sh --prefix=/usr/local
81                 make
83         This will automatically go into the mcs/ tree and build the
84         binaries there.
86         This assumes that you have a working mono installation, and that
87         there's a C# compiler named 'mcs', and a corresponding IL
88         runtime called 'mono'.  You can use two make variables
89         EXTERNAL_MCS and EXTERNAL_RUNTIME to override these.  e.g., you
90         can say
92           make EXTERNAL_MCS=/foo/bar/mcs EXTERNAL_RUNTIME=/somewhere/else/mono
93         
94         If you don't have a working Mono installation
95         ---------------------------------------------
97         If you don't have a working Mono installation, an obvious choice
98         is to install the latest released packages of 'mono' for your
99         distribution and try from the beginning.
101         You can also try a slightly more risky approach that should work
102         almost all the time.  
104         This works by first getting the latest version of the 'monolite'
105         distribution, which contains just enough to run the 'mcs'
106         compiler.  You do this with:
108                 make get-monolite-latest
110         This will download and automatically gunzip and untar the
111         tarball, and place the files appropriately so that you can then
112         just run:
114                 make
116         To ensure that you're using the 'monolite' distribution, you can
117         also try passing EXTERNAL_MCS=false on the make command-line.
119         Testing and Installation
120          ------------------------
122         You can run (part of) the mono and mcs testsuites with the command:
124                 make check
126         All tests should pass.  
128         If you want more extensive tests, including those that test the
129         class libraries, you need to re-run 'configure' with the
130         '--enable-nunit-tests' flag, and try
132                 make -k check
134         Expect to find a few testsuite failures.  As a sanity check, you
135         can compare the failures you got with
137                 http://go-mono.com/tests/displayTestResults.php
139         You can now install mono with:
141                 make install
143         Failure to follow these steps may result in a broken installation. 
145 2. Using Mono
146 =============
148         Once you have installed the software, you can run a few programs:
150         * runtime engine
152                 mono program.exe
153           or
154                 mint program.exe
156         * C# compiler
158                 mcs program.cs
160         * CIL Disassembler
162                 monodis program.exe
164         See the man pages for mono(1), mint(1), monodis(1) and mcs(2)
165         for further details.
167 3. Directory Roadmap
168 ====================
170         doc/
171                 Contains the web site contents.
173         docs/
174                 Technical documents about the Mono runtime.
176         data/
177                 Configuration files installed as part of the Mono runtime.
179         mono/
180                 The core of the Mono Runtime.
182                 metadata/
183                         The object system and metadata reader.
185                 jit/
186                         The Just in Time Compiler.
188                 dis/
189                         CIL executable Disassembler
191                 cli/
192                         Common code for the JIT and the interpreter.
194                 io-layer/
195                         The I/O layer and system abstraction for 
196                         emulating the .NET IO model.
198                 cil/
199                         Common Intermediate Representation, XML
200                         definition of the CIL bytecodes.
202                 interp/
203                         Interpreter for CLI executables.
205                 arch/
206                         Architecture specific portions.
208         man/
210                 Manual pages for the various Mono commands and programs.
212         scripts/
214                 Scripts used to invoke Mono and the corresponding program.
216         runtime/
218                 A directory that contains the Makefiles that link the
219                 mono/ and mcs/ build systems.