Difference between revisions of "Building mono from source"

From LSDevLinux
Jump to: navigation, search
(Dependencies: Add Mac info)
(Get, patch, build, install mono: Reflect that that binfmt is Linux-only)
Line 15: Line 15:
 
To ensure the use of the custom version of mono in <code>/usr/local</code> when you run applications, make sure <code>/usr/local/bin</code> is in your PATH before <code>/usr/bin</code> is, or (better) use <code>/usr/local/bin/mono application.exe</code> whenever you run an application. On most Linux distros, <code>/usr/local/bin</code> is already included in your PATH. You can check to see what your current PATH is by typing:
 
To ensure the use of the custom version of mono in <code>/usr/local</code> when you run applications, make sure <code>/usr/local/bin</code> is in your PATH before <code>/usr/bin</code> is, or (better) use <code>/usr/local/bin/mono application.exe</code> whenever you run an application. On most Linux distros, <code>/usr/local/bin</code> is already included in your PATH. You can check to see what your current PATH is by typing:
 
  $ echo $PATH
 
  $ 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 <code>application.exe</code>) will still use <code>/usr/bin/mono</code> unless you reconfigure it.
+
Note that the Linux ''binfmt'' system that allows you to execute interpreted programs without specifying the interpreter on the command line (eg by typing just <code>application.exe</code>) will still use <code>/usr/bin/mono</code> unless you reconfigure it.
  
 
'''Warning:''' The <code>checkout-and-build-mono</code> script runs <code>git reset --hard</code> and <code>git clean -dxf</code> in the <code>mono</code> etc. subdirectories, so if you make any of your own changes to the those trees, they will be lost.
 
'''Warning:''' The <code>checkout-and-build-mono</code> script runs <code>git reset --hard</code> and <code>git clean -dxf</code> in the <code>mono</code> etc. subdirectories, so if you make any of your own changes to the those trees, they will be lost.

Revision as of 17:37, 29 March 2011

Dependencies

On Linux:

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

On Mac:

$ sudo port install bison mono giflib git-core quilt

Note: port is the MacPorts package management command. For further information, see Build FieldWorks for Mac.

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 Linux 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