Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRaja R Harinath <harinath@hurrynot.org>2004-11-19 16:48:51 +0300
committerRaja R Harinath <harinath@hurrynot.org>2004-11-19 16:48:51 +0300
commitbe39e61428b18dbb7351861dac9744aa1835a5cd (patch)
tree907cc0623fa1e4bcf0af4398cb89e41b30bfb814 /Makefile.am
parenta6f48d1243bc0bf0de3d7deb006c6c66dc392d5a (diff)
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. svn path=/trunk/mono/; revision=36316
Diffstat (limited to 'Makefile.am')
-rw-r--r--Makefile.am163
1 files changed, 38 insertions, 125 deletions
diff --git a/Makefile.am b/Makefile.am
index a0ea58ebe1a..92c939e6661 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -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