2004-11-30 Rafael Teixeira <rafaelteixeirabr@hotmail.com>
[mono.git] / Makefile.am
index 59495553046cd08ab0d20b00fbad7c6e4d64ed5c..68155a883872ee0211342b060cda0225e7885161 100644 (file)
@@ -9,6 +9,11 @@ DIST_SUBDIRS = libgc mono ikvm-jni docs data runtime scripts man samples support
 
 EXTRA_DIST= mono.pc.in mono.spec.in mint.pc.in
 
+# Distribute the 'mcs' tree too
+dist-hook:
+       test -d $(distdir)/mcs || mkdir $(distdir)/mcs
+       d=`cd $(distdir)/mcs && pwd`; cd $(mcs_topdir) && $(MAKE) distdir=$$d dist-recursive
+
 pkgconfigdir = $(libdir)/pkgconfig
 if JIT_SUPPORTED
 pkgconfig_DATA= mono.pc mint.pc
@@ -17,195 +22,32 @@ pkgconfig_DATA= mint.pc
 endif
 DISTCLEANFILES= mono.pc mint.pc
 
-#
-# The following targets are used to compile and install
-# mono and mcs without running into the out-of-sync
-# problems by doing the compilation in the right order.
-#
-
-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
-else
-mono_runtime = mono/interpreter/mint
-endif
-
-# Minimal set of directories to build, and files used to run the 'mcs' compiler
-MCS_BASIC_DIRS = jay mcs class/corlib class/System
-MCS_BASIC_FILES = \
-       $(mcs_topdir)/mcs/mcs.exe \
-       $(mcs_topdir)/class/lib/default/mscorlib.dll \
-       $(mcs_topdir)/class/lib/default/System.dll
-
-# 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 $(MONO_CSHARP_DEBUGGER_DIR)
-MCS_FILES = $(MCS_BASIC_FILES) $(mcs_topdir)/class/lib/default/System.Xml.dll $(MONO_CSHARP_DEBUGGER_FILE)
-
-tmpinst = _tmpinst
-
-if PLATFORM_WIN32
-
-populate_profiles = default:net_1_1
-
-# bootstraps using the .NET C# compiler
-bootstrap: faststrap
-
-else
-
-MONO_CSHARP_DEBUGGER_DIR = class/Mono.CSharp.Debugger
-MONO_CSHARP_DEBUGGER_FILE = $(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
-       $(MAKE) fasterstrap
-
-endif
-
-faststrap: tmpinst-mcs-short-build
-       $(MAKE) mono-do-runtime-only
-       $(MAKE) fasterstrap
-
-fasterstrap: tmpinst-mcs-full-build
-       $(MAKE) populate-runtime-subdir
-       $(MAKE)
-
-bootstrap-clean: clean mcs-do-clean-profiles
-bootstrap-check: check mcs-do-run-test
+.PHONY: get-monolite-latest mcs-do-compiler-tests compiler-tests bootstrap-world
 
 # building with monolite
-
+mcsclassdir = $(mcs_topdir)/class
+monolitedir = $(mcsclassdir)/lib/basic
 get-monolite-latest:
-       wget -O $(srcdir)/../monolite-latest.tar.gz http://www.go-mono.com/daily/monolite-latest.tar.gz
+       -rm -f $(monolitedir)/*.exe $(monolitedir)/*.dll
+       -rm -fr $(monolitedir)/monolite-*
+       cd $(monolitedir) && { wget -O- http://www.go-mono.com/daily/monolite-latest.tar.gz | gzip -d | tar xf - ; }
+       mv -f $(monolitedir)/monolite-*/*.exe $(monolitedir)/monolite-*/*.dll $(monolitedir)
+       rm -fr $(monolitedir)/monolite-*
+       cd $(mcsclassdir)/lib && { test ! -f basic.tar.gz || mv -f basic.tar.gz basic.tar.gz.old; }
+       cd $(mcsclassdir) && $(MAKE) lib/basic.tar.gz
+       -rm -f $(monolitedir)/*.exe $(monolitedir)/*.dll
+
+compiler-tests:
+       cd runtime && $(MAKE) clean-local
+       $(MAKE)
+       $(MAKE) mcs-do-compiler-tests
 
-monolite-bootstrap: tmpinst-monolite mono-do-runtime-only
-       rm -f $(MCS_FILES)
-       $(MAKE) tmpinst-mcs-short-build
-       $(MAKE) fasterstrap
+bootstrap-world: compiler-tests
+       $(MAKE) install
 
 # internal targets
-
-tmpinst-mcs-basic-build: mcs-do-basic-build tmpinst-dir
-       mv -f $(MCS_BASIC_FILES) $(tmpinst)/lib
-
-tmpinst-mcs-short-build: mcs-do-short-build tmpinst-dir
-       mv -f $(MCS_FILES) $(tmpinst)/lib
-
-tmpinst-mcs-full-build: mcs-do-full-build tmpinst-dir
-       cp -f $(MCS_FILES) $(tmpinst)/lib
-
-tmpinst-monolite: tmpinst-dir
-       -rm -f $(tmpinst)/lib/mcs.exe $(tmpinst)/lib/*.dll
-       -rm -fr $(tmpinst)/monolite-*
-       srcdir=`cd $(srcdir) && pwd` && cd $(tmpinst) && ( gzip -d -c $$srcdir/../monolite-latest.tar.gz | tar xf - )
-       mv -f $(tmpinst)/monolite-*/mcs.exe $(tmpinst)/monolite-*/*.dll $(tmpinst)/lib
-       rm -fr $(tmpinst)/monolite-*
-
-# Build enough of 'mono' to run the stage1 mcs.exe
-mono-do-runtime-only: $(CONFIG_HEADER)
-       for dir in $(libgc_dir) mono data; do \
-         (cd $$dir && $(MAKE)) || exit 1 ; \
-       done
-
-mcs-do-basic-build:
-       rm -f $(MCS_FILES)
-       for dir in $(MCS_BASIC_DIRS); do \
-         (cd $(mcs_topdir)/$$dir && $(MAKE) PROFILE=default USE_BOOT_COMPILE=yes BOOTSTRAP_MCS="mcs -d:BOOTSTRAP_WITH_OLDLIB") || exit 1 ; \
-       done
-
-mcs-do-short-build:
-       tmpinst=`cd $(tmpinst) && pwd` ; \
-       PATH=$$tmpinst/bin:$$PATH; export PATH ; \
-       for dir in $(MCS_DIRS); do \
-         (cd $(mcs_topdir)/$$dir && $(MAKE) PROFILE=default) || exit 1 ; \
-       done
-
-mcs-do-full-build:
-       tmpinst=`cd $(tmpinst) && pwd` ; \
-       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
-       cd $(mcs_topdir) && $(MAKE) all-profiles
-
-mcs-do-clean-profiles:
-       cd $(mcs_topdir) && $(MAKE) clean-profiles
-
-mcs-do-run-test: tmpinst-dir
-       tmpinst=`cd $(tmpinst) && pwd` ; \
-       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
-
-if PLATFORM_WIN32
-
-tmpinst-dir-contents: $(tmpinst)/bin/mono.bat $(tmpinst)/etc/mono/machine.config
-
-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)' >> $@
-       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_runtime)" --config "$$builddir/data/config" "$$@"' >> $@
-       chmod +x $@
-
-$(tmpinst)/bin/mcs: $(srcdir)/Makefile.am
-       (t=`cd $(tmpinst) && pwd`; echo '#! /bin/sh'; echo 'exec "'"$$t/bin/mono"'" "'"$$t/lib/mcs.exe"'" "$$@"') > $@
-       chmod +x $@
-
-$(tmpinst)/etc/mono/machine.config: $(srcdir)/data/machine.config
-       rm -f $@
-       srcdir=`cd $(srcdir) && pwd`; cd $(tmpinst)/etc/mono && $(LN_S) $$srcdir/data/machine.config machine.config
-
-# Obsolete target -- don't use.
-.PHONY: fullbuild
-fullbuild: bootstrap
-       $(MAKE) install
-       echo "*** 'fullbuild' is an obsolete target. Use 'make bootstrap && make install'."
-       exit 1
+mcs-do-compiler-tests:
+       cd runtime && $(MAKE) TEST_SUBDIRS="tests errors" check-local
 
 win32getdeps:
        wget http://www.go-mono.com/archive/pkgconfig-0.11-20020310.zip
@@ -225,3 +67,7 @@ win32getdeps:
 
 win32setup:
        makensis /DMILESTONE=$(VERSION) /DSOURCE_INSTALL_DIR=$(SOURCE_INSTALL_DIR) /DBUILDNUM=$(BUILDNUM) monowiz.win32.nsi
+
+bootstrap: all
+       @echo "*** 'make bootstrap' is obsolete.  Just run 'make' to perform a combined mono+mcs build"
+       exit 1