2004-11-19 Raja R Harinath <rharinath@novell.com>
authorRaja R Harinath <harinath@hurrynot.org>
Fri, 19 Nov 2004 13:48:51 +0000 (13:48 -0000)
committerRaja R Harinath <harinath@hurrynot.org>
Fri, 19 Nov 2004 13:48:51 +0000 (13:48 -0000)
Integrate bootstrap build into 'make all'.  Most of the bootstrap
targets are gone.
* Makefile.am (SUBDIRS): Build current directory before 'runtime'.
(tmpinst): Change location.
(all-local): New.  Just invokes the build in mcs.
(check-local): New.  Invokes 'run-test-profiles' in mcs.
(get-monolite-latest): Update.  Move the unpacking code here,
since 'monolite-bootstrap' is no more.
(mcs-do-full-build): Don't set PATH.
(tmpinst-dir-contents): Remove mcs.
($(tmpinst)/bin/mcs): Now used only during 'make check'.
($(tmpinst)/bin/mono): Don't set MONO_PATH.
* README: Update to changes.

svn path=/trunk/mono/; revision=36316

ChangeLog
Makefile.am
README

index da5310cc07688ae14266e127e900472095c60400..795ccbedc9b42e36fce722ae2743f45a27e620f2 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,19 @@
+2004-11-19  Raja R Harinath  <rharinath@novell.com>
+
+       Integrate bootstrap build into 'make all'.  Most of the bootstrap
+       targets are gone.
+       * Makefile.am (SUBDIRS): Build current directory before 'runtime'.
+       (tmpinst): Change location.
+       (all-local): New.  Just invokes the build in mcs.
+       (check-local): New.  Invokes 'run-test-profiles' in mcs.
+       (get-monolite-latest): Update.  Move the unpacking code here,
+       since 'monolite-bootstrap' is no more.
+       (mcs-do-full-build): Don't set PATH.
+       (tmpinst-dir-contents): Remove mcs.
+       ($(tmpinst)/bin/mcs): Now used only during 'make check'.
+       ($(tmpinst)/bin/mono): Don't set MONO_PATH.
+       * README: Update to changes.
+
 2004-11-18  Zoltan Varga  <vargaz@freemail.hu>
 
        * configure.in: Disable static linking of mono if --disable-static is
index a0ea58ebe1a2d1aafe61cfc21be60d6b23cfca58..92c939e6661e0d94ac8f6a564369736a5e695a32 100644 (file)
@@ -1,7 +1,7 @@
 AUTOMAKE_OPTIONS = foreign
 ACLOCAL_AMFLAGS = -I .
 
-SUBDIRS = $(libgc_dir) mono $(ikvm_jni_dir) docs data runtime scripts man 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
@@ -22,87 +22,52 @@ 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.
-#
-
-.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
+all-local: mcs-do-full-build
+       $(MAKE) populate-runtime-subdir
 
-# 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 class/Mono.CSharp.Debugger
-MCS_FILES = $(MCS_BASIC_FILES) \
-       $(mcs_topdir)/class/lib/default/System.Xml.dll \
-       $(mcs_topdir)/class/lib/default/Mono.CompilerServices.SymbolWriter.dll
+.PHONY: get-monolite-latest tmpinst-dir mcs-do-full-build mcs-do-clean-profiles mcs-do-run-test populate-runtime-subdir
 
-tmpinst = _tmpinst
+tmpinst = runtime/_tmpinst
 
 if PLATFORM_WIN32
 
 populate_profiles = default:net_1_1
 
-# bootstraps using the .NET C# compiler
-bootstrap: tmpinst-dir mono-do-runtime-only
-       $(MAKE) fasterstrap
-
 else
 
 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
+clean-local:
+       cd $(mcs_topdir) && $(MAKE) PROFILES="basic net_1_1_bootstrap default net_2_0_bootstrap net_2_0" clean-profiles
+       -rm -fr $(tmpinst)
 
-bootstrap-check: check mcs-do-run-test-profiles #mono-do-testjit
+check-local: mcs-do-run-test-profiles mono-do-testjit
 
-mono-do-testjit: $(tmpinst)/bin/ilasm
-       tmpinst=`cd $(tmpinst) && pwd` ; \
-       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
+mono-do-testjit:
        cd mono/tests && $(MAKE) test
 
 # building with monolite
 
-get-monolite-latest:
+monolitedir = $(mcs_topdir)/class/lib/basic
+get-monolite-latest: tmpinst-dir
        wget -O $(srcdir)/../monolite-latest.tar.gz http://www.go-mono.com/daily/monolite-latest.tar.gz
-
-monolite-bootstrap: tmpinst-monolite mono-do-runtime-only
-       rm -f $(MCS_FILES)
-       $(MAKE) tmpinst-mcs-short-build
-       $(MAKE) fasterstrap
+       -rm -f $(monolitedir)/mcs.exe $(monolitedir)/*.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 $(monolitedir)
+       rm -fr $(tmpinst)/monolite-*
 
 compiler-tests:
        $(MAKE) mcs-do-clean-profiles
-       $(MAKE) bootstrap
+       $(MAKE)
        $(MAKE) mcs-do-compiler-tests
 
 bootstrap-world: compiler-tests
@@ -110,68 +75,18 @@ bootstrap-world: compiler-tests
 
 # 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 NO_SIGN_ASSEMBLY=yes 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 NO_SIGN_ASSEMBLY=yes) || exit 1 ; \
-       done
-
-mcs-do-full-build:
-       tmpinst=`cd $(tmpinst) && pwd` ; \
-       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
-       cd $(mcs_topdir) && $(MAKE) NO_SIGN_ASSEMBLY=yes all-profiles
-
-mcs-do-clean-profiles:
-       cd $(mcs_topdir) && $(MAKE) clean-profiles
-
-mcs-do-run-test-profiles: tmpinst-dir $(tmpinst)/bin/mbas $(tmpinst)/bin/ilasm $(tmpinst)/bin/pedump
+mcs-do-full-build: tmpinst-dir
        tmpinst=`cd $(tmpinst) && pwd` ; \
-       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
-       cd $(mcs_topdir) && $(MAKE) run-test-profiles
-
-mcs-do-compiler-tests:
-       tmpinst=`cd $(tmpinst) && pwd` ; \
-       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
-       cd $(mcs_topdir) && $(MAKE) compiler-tests
+       cd $(mcs_topdir) && $(MAKE) RUNTIME=$$tmpinst/bin/mono all-profiles
 
 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" && \
+           echo "cd $(mcs_topdir) && $(MAKE) RUNTIME=$$tmpinst/bin/mono 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 ; \
+           $(MAKE) RUNTIME=$$tmpinst/bin/mono 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 -name '*jay*' -exec rm -f '{}' ';'
        for i in `find $(tmpinst)/prefix -type d -name '*jay*' -print`; do rm -f $$i/*; done
@@ -179,10 +94,10 @@ populate-runtime-subdir:
        rm -rf $(tmpinst)/prefix
 
 tmpinst-dir: 
-       mkdir -p $(tmpinst) $(tmpinst)/bin $(tmpinst)/lib $(tmpinst)/etc/mono/1.0 $(tmpinst)/etc/mono/2.0
+       mkdir -p $(tmpinst) $(tmpinst)/bin $(tmpinst)/etc/mono/1.0 $(tmpinst)/etc/mono/2.0
        $(MAKE) tmpinst-dir-contents
 
-tmpinst-dir-contents: $(tmpinst)/bin/mono $(tmpinst)/bin/mcs $(tmpinst)/etc/mono/1.0/machine.config $(tmpinst)/etc/mono/2.0/machine.config
+tmpinst-dir-contents: $(tmpinst)/bin/mono $(tmpinst)/etc/mono/1.0/machine.config $(tmpinst)/etc/mono/2.0/machine.config
 
 if PLATFORM_WIN32
 
@@ -190,9 +105,8 @@ $(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 'export MONO_CFG_DIR' >> $@
        echo 'exec "$$builddir/libtool" --mode=execute "$$builddir/$(mono_runtime).exe" "$$@"' >> $@
        chmod +x $@
 
@@ -201,9 +115,8 @@ else
 $(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 'export MONO_CFG_DIR' >> $@
        echo 'exec "$$builddir/libtool" --mode=execute "$$builddir/$(mono_runtime)" --config "$$builddir/data/config" "$$@"' >> $@
        chmod +x $@
 
@@ -213,12 +126,19 @@ $(tmpinst)/bin/pedump: $(srcdir)/Makefile.am
        (b=`pwd`; echo '#! /bin/sh'; echo 'exec "'"$$b/libtool"'" --mode=execute "'"$$b/mono/metadata/pedump"'" "$$@"') > $@
        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 $@
+TEST_SUPPORT_FILES = $(tmpinst)/bin/mcs $(tmpinst)/bin/mbas $(tmpinst)/bin/ilasm $(tmpinst)/bin/gmcs
+mcs-do-run-test-profiles: tmpinst-dir
+       $(MAKE) $(TEST_SUPPORT_FILES)
+       tmpinst=`cd $(tmpinst) && pwd` ; ret=: ; \
+       PATH=$$tmpinst/bin:$$PATH ; export PATH ; \
+       ( cd $(mcs_topdir) && $(MAKE) RUNTIME=$$tmpinst/bin/mono run-test-profiles ) || ret=false ; \
+       rm -f $(TEST_SUPPORT_FILES) ; $$ret
+
+mcs-do-compiler-tests:
+       $(MAKE) TEST_SUBDIRS="tests errors" mcs-do-run-test-profiles
 
-# Used only by 'bootstrap-check' -- so, can safely use runtime/.
-$(tmpinst)/bin/mbas $(tmpinst)/bin/ilasm: $(srcdir)/Makefile.am
+# Used only by 'check-local' -- so, can safely use runtime/.
+$(TEST_SUPPORT_FILES): $(srcdir)/Makefile.am
        t=`cd $(tmpinst) && pwd`; r=`cd $(srcdir)/runtime && pwd`; \
        ( echo '#! /bin/sh'; echo 'exec "'"$$t/bin/mono"'" "'"$$r/$(@F).exe"'" "$$@"' ) > $@
        chmod +x $@
@@ -231,13 +151,6 @@ $(tmpinst)/etc/mono/2.0/machine.config: $(srcdir)/data/net_2_0/machine.config
        rm -f $@
        srcdir=`cd $(srcdir) && pwd`; cd $(tmpinst)/etc/mono/2.0 && $(LN_S) $$srcdir/data/net_2_0/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
-
 win32getdeps:
        wget http://www.go-mono.com/archive/pkgconfig-0.11-20020310.zip
        wget http://www.go-mono.com/archive/glib-2.0.4-20020703.zip 
diff --git a/README b/README
index 948e1b0b718e434bf2e1aee32c24e3a949052675..6dc8fff9f6d4b54bc5b705efc233086e35656a8e 100644 (file)
--- a/README
+++ b/README
@@ -63,7 +63,7 @@ This is Mono.
                mv mcs-XXX mcs
                cd mono
                ./autogen.sh --prefix=/usr/local
-               make bootstrap 
+               make
 
     c. Building the software from CVS
     ---------------------------------
@@ -103,7 +103,7 @@ This is Mono.
 
        You are ready to start your CVS upgrade.  Compile with
 
-               make bootstrap
+               make
 
        This will automatically go into the mcs/ tree and build the
        binaries there, and copy them into the appropriate
@@ -128,19 +128,19 @@ This is Mono.
                make get-monolite-latest
 
        This should place a monolite-latest.tar.gz in the parent
-       directory of the 'mono' source tree.  You can then run:
+       directory of the 'mono' source tree.  This will automatically
+       gunzip and untar the tarball, place the files appropriately,
 
-               make monolite-bootstrap
+       You can then run:
 
-       This will automatically gunzip and untar the tarball, place the
-       files appropriately, and then complete the bootstrap.
+               make
 
        iii. Testing and Installation
             ------------------------
 
        You can run the mono and mcs testsuites with the command:
 
-               make -k bootstrap-check
+               make -k check
 
        Expect to find several testsuite failures, especially in the
        mcs/ tree.  As a sanity check, you can compare the failures you
@@ -154,30 +154,6 @@ This is Mono.
 
        Failure to follow these steps will result in a broken installation. 
 
-       iv.  Other useful "bootstrap"-like facilities
-            ----------------------------------------
-
-       If you have a CVS snapshot that you keep updating periodically,
-       and/or do your development in, you may try using a couple of
-       specialty make targets that may be slightly faster than a
-       "make bootstrap".
-
-       You can try a two-stage bootstrap with:
-
-               make faststrap
-
-       This assumes that you have already run a "make bootstrap" on the
-       tree before.
-
-       If you want to avoid waiting even for that, you can try the
-       riskier one-stage build:
-
-               make fasterstrap
-
-       This should be attempted only if you're sure that the sources of
-       the mcs compiler itself and the sources of the libraries used by
-       it have not been changed.
-
 2. Using Mono
 =============