Difference between revisions of "Building mono from source"

From LSDevLinux
Jump to: navigation, search
(Register in GAC: Remove explicit use of assembly version numbers)
(Register in GAC: Further simplification)
Line 20: Line 20:
 
Since you are installing mono into <code>/usr/local</code>, you will need to register some <code>/usr/lib/mono</code> assemblies into the <code>/usr/local/lib/mono</code> GAC.
 
Since you are installing mono into <code>/usr/local</code>, you will need to register some <code>/usr/lib/mono</code> assemblies into the <code>/usr/local/lib/mono</code> GAC.
  
  $ for lib in glib pango atk gtk gdk; do
+
  $ for assembly in /usr/lib/mono/gac/{glib,pango,atk,gtk,gdk}-sharp/*/*-sharp.dll; \
    for assembly in /usr/lib/mono/gac/$lib-sharp/*/$lib-sharp.dll; do \
+
    do sudo gacutil -i $assembly; done
      sudo gacutil -i $assembly; done; done
 
  
 
==Update custom mono==
 
==Update custom mono==

Revision as of 17:41, 28 March 2011

Dependencies

$ sudo aptitude install bison mono-devel libgif-dev git-core quilt

Get, patch, build, install mono

To build the custom mono, do these steps:

$ git clone git://git.lsdev.sil.org/mono-calgary.git
$ cd mono-calgary
mono-calgary$ ./checkout-and-build-mono

The script will check out the mono sources from the upstream git repo, patch them, build and install mono. The installation will prompt for your sudo password to install into /usr/local.

To ensure the use of the custom version of mono in /usr/local when you run applications, make sure /usr/local/bin is in your PATH before /usr/bin is, or (better) use /usr/local/bin/mono application.exe whenever you run an application. On most Linux distros, /usr/local/bin is already included in your PATH. You can check to see what your current PATH is by typing:

$ echo $PATH

Note that the binfmt system that allows you to execute interpreted programs without specifying the interpreter on the command line (eg by typing just application.exe) will still use /usr/bin/mono unless you reconfigure it.

Warning: The checkout-and-build-mono script runs git reset --hard and git clean -dxf in the mono etc. subdirectories, so if you make any of your own changes to the those trees, they will be lost.

If you want to develop additional changes to mono, after the initial set-up, use make and make install in the appropriate subdirectory rather than the checkout-and-build-mono script. If you then want to add these changes to the mono-calgary repository, first check them into a topic branch in the subdirectory. Then use git format-patch to create new patch(es) in the corresponding patch directory (../debian/patches) and register them in the series file.

Register in GAC

Since you are installing mono into /usr/local, you will need to register some /usr/lib/mono assemblies into the /usr/local/lib/mono GAC.

$ for assembly in /usr/lib/mono/gac/{glib,pango,atk,gtk,gdk}-sharp/*/*-sharp.dll; \
    do sudo gacutil -i $assembly; done

Update custom mono

To get the latest custom mono:

mono-calgary$ git pull
mono-calgary$ ./checkout-and-build-mono