2004-09-06 Dick Porter <dick@ximian.com>
[mono.git] / Makefile.am
index 114f3b604e8262f58e0efa957647b4b0176f39e2..eaa4952f2ce93022fb74c0b1e4dd42027b8a290d 100644 (file)
@@ -1,11 +1,11 @@
 AUTOMAKE_OPTIONS = foreign
 ACLOCAL_AMFLAGS = -I .
 
-SUBDIRS = $(libgc_dir) mono $(ikvm_jni_dir) docs runtime scripts man data samples support web 
+SUBDIRS = $(libgc_dir) mono $(ikvm_jni_dir) docs data runtime scripts man samples support web 
 
 # Keep in sync with SUBDIRS
 ## 'tools' is not normally built
-DIST_SUBDIRS = libgc mono ikvm-jni docs runtime scripts man data samples support web tools
+DIST_SUBDIRS = libgc mono ikvm-jni docs data runtime scripts man samples support web tools
 
 EXTRA_DIST= mono.pc.in mono.spec.in mint.pc.in
 
@@ -28,6 +28,7 @@ mcs_topdir=$(top_srcdir)/../mcs
 .PHONY: bootstrap faststrap fasterstrap bootstrap-clean bootstrap-check get-monolite-latest monolite-bootstrap
 .PHONY: tmpinst-dir tmpinst-mcs-basic-build tmpinst-mcs-short-build tmpinst-mcs-full-build tmpinst-monolite
 .PHONY: mono-do-runtime-only mcs-do-basic-build mcs-do-short-build mcs-do-full-build mcs-do-clean-profiles mcs-do-run-test
+.PHONY: populate-runtime-subdir
 
 if USE_JIT
 mono_runtime = mono/mini/mono
@@ -44,20 +45,24 @@ MCS_BASIC_FILES = \
 
 # Set of directories and files the 'mcs' compiler can use
 ## We build class/System twice to resolve the cyclic dependency of class/System.XML
-MCS_DIRS = $(MCS_BASIC_DIRS) class/System.XML class/System
-MCS_FILES = $(MCS_BASIC_FILES) $(mcs_topdir)/class/lib/default/System.Xml.dll
+MCS_DIRS = $(MCS_BASIC_DIRS) class/System.XML class/System class/Mono.CSharp.Debugger
+MCS_FILES = $(MCS_BASIC_FILES) \
+       $(mcs_topdir)/class/lib/default/System.Xml.dll \
+       $(mcs_topdir)/class/lib/default/Mono.CSharp.Debugger.dll
 
 tmpinst = _tmpinst
 
 if PLATFORM_WIN32
 
+populate_profiles = default:net_1_1
+
 # bootstraps using the .NET C# compiler
-bootstrap: fasterstrap
+bootstrap: tmpinst-dir mono-do-runtime-only
+       $(MAKE) fasterstrap
 
 else
 
-MCS_DIRS += class/Mono.CSharp.Debugger
-MCS_FILES += $(mcs_topdir)/class/lib/default/Mono.CSharp.Debugger.dll
+populate_profiles = default:net_1_1 net_2_0:net_2_0
 
 bootstrap: tmpinst-mcs-basic-build mono-do-runtime-only
        $(MAKE) tmpinst-mcs-short-build
@@ -69,19 +74,6 @@ faststrap: tmpinst-mcs-short-build
        $(MAKE) mono-do-runtime-only
        $(MAKE) fasterstrap
 
-.PHONY: populate-runtime-subdir
-## *** warning ***: tested only with GNU make
-populate-runtime-subdir:
-       srcdir=`cd $(srcdir) && pwd`; tmpinst=`pwd`/$(tmpinst) ; \
-       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
-       cd $(mcs_topdir) \
-       && $(MAKE) PROGRAM_INSTALL_DIR=$$srcdir/runtime LIBRARY_INSTALL_DIR=$$srcdir/runtime/net_1_1 prefix=$$tmpinst/prefix PROFILE=default install \
-       && $(MAKE) PROGRAM_INSTALL_DIR=$$srcdir/runtime LIBRARY_INSTALL_DIR=$$srcdir/runtime/net_2_0 prefix=$$tmpinst/prefix PROFILE=net_2_0 install
-       test -z "`find $(tmpinst)/prefix -name '*.dll'`"
-       test -z "`find $(tmpinst)/prefix -name '*.exe'`"
-       set fnord `find $(tmpinst)/prefix -type f | wc -l` ; test "$$2" = 9
-       rm -rf $(tmpinst)/prefix
-
 fasterstrap: tmpinst-mcs-full-build
        $(MAKE) populate-runtime-subdir
        $(MAKE)
@@ -149,34 +141,40 @@ mcs-do-run-test: tmpinst-dir
        PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
        cd $(mcs_topdir) && $(MAKE) PROFILE=default run-test
 
+populate-runtime-subdir:
+       test -n '$(populate_profiles)'
+       @srcdir=`cd $(srcdir) && pwd`; tmpinst=`pwd`/$(tmpinst) ; \
+       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
+       for profile in $(populate_profiles); do \
+         ( set fnord `echo $$profile | sed 's,:, ,g'` && \
+           echo "cd $(mcs_topdir) && $(MAKE) PROGRAM_INSTALL_DIR=$$srcdir/runtime PROFILE=$$2 LIBRARY_INSTALL_DIR=$$srcdir/runtime/$$3 prefix=$$tmpinst/prefix install" && \
+           cd $(mcs_topdir) && \
+           $(MAKE) PROGRAM_INSTALL_DIR=$$srcdir/runtime PROFILE=$$2 LIBRARY_INSTALL_DIR=$$srcdir/runtime/$$3 prefix=$$tmpinst/prefix install ) || exit 1 ; \
+       done
+       find $(tmpinst)/prefix -type f -path '*/jay*' -exec rm -f '{}' ';'
+       test -z "`find $(tmpinst)/prefix -type f -print`"
+       rm -rf $(tmpinst)/prefix
+
 tmpinst-dir: 
        mkdir -p $(tmpinst) $(tmpinst)/bin $(tmpinst)/lib $(tmpinst)/etc/mono
        $(MAKE) tmpinst-dir-contents
 
+tmpinst-dir-contents: $(tmpinst)/bin/mono $(tmpinst)/bin/mcs $(tmpinst)/etc/mono/machine.config
+
 if PLATFORM_WIN32
 
-tmpinst-dir-contents: $(tmpinst)/bin/mono.bat $(tmpinst)/etc/mono/machine.config
+$(tmpinst)/bin/mono: $(srcdir)/Makefile.am
+       echo '#! /bin/sh' > $@
+       echo 'builddir="'`pwd`'"; win_builddir="'`cygpath -w -a .`'"' >> $@
+       echo 'tmpinst="$$win_builddir\\$(tmpinst)"' >> $@
+       echo 'if test -z "$$MONO_PATH" ; then MONO_PATH="$$tmpinst\\lib"; else MONO_PATH="$${MONO_PATH};$$tmpinst\\lib" ; fi' >> $@
+       echo 'MONO_CFG_DIR="$$tmpinst\\etc"' >> $@
+       echo 'export MONO_PATH MONO_CFG_DIR' >> $@
+       echo 'exec "$$builddir/libtool" --mode=execute "$$builddir/mono.exe" "$$@"' >> $@
+       chmod +x $@
 
 else
 
-tmpinst-dir-contents: $(tmpinst)/bin/mono $(tmpinst)/bin/mcs $(tmpinst)/etc/mono/machine.config
-
-endif
-
-$(tmpinst)/bin/mono.bat: $(srcdir)/Makefile.am
-       echo '@echo off' > $@
-       echo 'set builddir="'"`pwd`"'"' >> $@
-       echo 'set win_builddir="'"`cygpath -w -a .`"'"' >> $@
-       echo 'set tmpinst="%win_builddir%\$(tmpinst)"' >> $@
-       echo 'if %MONO_PATH% == "" goto when_empty' >> $@
-       echo 'set MONO_PATH="%MONO_PATH%;%tmpinst%\lib"' >> $@
-       echo 'goto endif_empty' >> $@
-       echo ':when_empty' >> $@
-       echo 'set MONO_PATH=%tmpinst%\lib' >> $@
-       echo ':endif_empty' >> $@
-       echo 'set MONO_CFG_DIR=%tmpinst%\etc' >> $@
-       echo "`cygpath -w /bin/sh`" '"%builddir%/libtool" --mode=execute "%builddir%/$(mono_runtime)" --config "%win_builddir%\data\config" %*' >> $@
-
 $(tmpinst)/bin/mono: $(srcdir)/Makefile.am
        echo '#! /bin/sh' > $@
        echo 'builddir="'`pwd`'"; tmpinst=$$builddir/$(tmpinst)' >> $@
@@ -186,6 +184,8 @@ $(tmpinst)/bin/mono: $(srcdir)/Makefile.am
        echo 'exec "$$builddir/libtool" --mode=execute "$$builddir/$(mono_runtime)" --config "$$builddir/data/config" "$$@"' >> $@
        chmod +x $@
 
+endif
+
 $(tmpinst)/bin/mcs: $(srcdir)/Makefile.am
        (t=`cd $(tmpinst) && pwd`; echo '#! /bin/sh'; echo 'exec "'"$$t/bin/mono"'" "'"$$t/lib/mcs.exe"'" "$$@"') > $@
        chmod +x $@