[Mono-devel-list] Build system
Miguel de Icaza
miguel at ximian.com
Thu May 22 20:21:33 EDT 2003
Hello everyone,
Today on IRC we were discussing a few problems we have with the build
system. The major one being that we have a dual build system: one with
nant for Windows and one with makefiles.
The elements that come into play are:
* The makefile.gnu system is pretty complete, and is only used
in Linux. The toplevel `makefile' on the other hand is used
to drive the process: on Windows it does some make, and some
nant and on Linux it does the full process using makefile.gnu
* The Nant system today is used to build not only the standard
classes, but also versions of the library for use in
CorCompare.
* We need a mechanism to pass a set of defines. The problem
arised when we tried to target both .NET 1.0 and .NET 1.1
APIs, but this problem will repeat when we target the
CompactFramework and the ECMA-only builds.
Maintaining two places with defines just does not work.
What I would like to do is:
* Move the whole build system to the makefile.gnu setup, and
drop entirely nant, and the toplevel makefile.
* Rename `makefile.gnu' everywhere to `makefile', so the process
becomes just `make' instead of the old `make -f makefile.gnu'
* We need probably help from Peter here, but I want to be able
to define at the toplevel a set of MCS flags to pass, like:
-d:CORE -d:NET_1_1, etc.
Thoughts?
Miguel
--
Miguel de Icaza <miguel at ximian.com>
More information about the Mono-devel-list
mailing list