X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=Makefile.am;h=2f1435fd26d5cc1b6720682f6e861b7eb3d64573;hb=addb0c10a31c12b49f8261bfa86a94c86b6b59b6;hp=46b82dd0c2f961edbb132c377598d1ed74405c7d;hpb=9c6c9ea44b2e148e141330e3907c7a07db19ce11;p=mono.git diff --git a/Makefile.am b/Makefile.am index 46b82dd0c2f..2f1435fd26d 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,106 +1,64 @@ AUTOMAKE_OPTIONS = foreign +ACLOCAL_AMFLAGS = -I . -SUBDIRS = @libgc_dir@ mono @ikvm_jni_dir@ docs runtime scripts man data samples support web +SUBDIRS = $(libgc_dir) $(eglib_dir) mono $(ikvm_native_dir) support docs data runtime scripts man samples web msvc # Keep in sync with SUBDIRS -DIST_SUBDIRS = libgc mono ikvm-jni docs runtime scripts man data samples support web +## 'tools' is not normally built +DIST_SUBDIRS = libgc $(eglib_dir) mono ikvm-native support docs data runtime scripts man samples web tools msvc -EXTRA_DIST= mono.pc.in mono.spec.in mint.pc.in +EXTRA_DIST= mono-uninstalled.pc.in LICENSE + +DISTCHECK_CONFIGURE_FLAGS = EXTERNAL_MCS=false EXTERNAL_RUNTIME=false + +# Distribute the 'mcs' tree too +dist-hook: + test -d $(distdir)/mcs || mkdir $(distdir)/mcs + d=`cd $(distdir)/mcs && pwd`; cd $(mcs_topdir) && $(MAKE) PROFILE=default distdir=$$d dist-recursive pkgconfigdir = $(libdir)/pkgconfig -if JIT_SUPPORTED -pkgconfig_DATA= mono.pc mint.pc -else -pkgconfig_DATA= mint.pc -endif -DISTCLEANFILES= mono.pc mint.pc - -# -# The following target is 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: tmpinst-dir tmpinst-runtime bootstrap stage1 stage2 stage3 stage1-mono stage1-mcs - -if USE_JIT -mono_runtime = mono/mini/mono -else -mono_runtime = mono/interpreter/mint -endif - -bootstrap: stage3 - rm -f $(top_srcdir)/runtime/*/*.dll $(top_srcdir)/runtime/*.exe - $(MAKE) - -# Build stripped down versions of 'mcs', 'mscorlib.dll' and 'System.dll' with installed 'mcs' -## remove System.Xml.dll since it's a soft-dependency of System.dll -stage1-mcs: - rm -f $(mcs_topdir)/mcs/mcs.exe $(mcs_topdir)/class/lib/default/mscorlib.dll - rm -f $(mcs_topdir)/class/lib/default/System.dll $(mcs_topdir)/class/lib/default/System.Xml.dll - cd $(mcs_topdir)/jay && $(MAKE) - cd $(mcs_topdir)/mcs && $(MAKE) PROFILE=default BOOTSTRAP_MCS="mcs -d:BOOTSTRAP_WITH_OLDLIB" - cd $(mcs_topdir)/class/corlib && $(MAKE) PROFILE=default BOOTSTRAP_MCS="mcs -d:BOOTSTRAP_WITH_OLDLIB" - cd $(mcs_topdir)/class/System && $(MAKE) PROFILE=default BOOTSTRAP_MCS="mcs -d:BOOTSTRAP_WITH_OLDLIB" MCS="mcs -d:BOOTSTRAP_WITH_OLDLIB" - -# Build enough of 'mono' to run the stage1 mcs.exe -stage1-mono: $(CONFIG_HEADER) - if test -z "$(libgc_dir)"; then :; else cd libgc && $(MAKE) ; fi - cd mono && $(MAKE) - -# (takes advantage of 'make -j': independent subtasks are separate dependencies) -stage1: stage1-mcs stage1-mono tmpinst-dir - $(MAKE) tmpinst-runtime - -# Use stage1 'mcs', 'mscorlib.dll' and 'System.dll' to build fuller versions -# FIXME: Mono.CSharp.Debugger is built only on Linux in the MCS tree. -# At least the SymbolWriter stuff seems portable enough. So either -# fix the MCS tree, or fix it here -stage2: stage1 - set -e ; \ - tmpinst=`cd _tmpinst && pwd` ; mcs_topdir=`cd $(mcs_topdir) && pwd` ; \ - PATH=$$tmpinst/bin:$$PATH; export PATH ; \ - cd $$mcs_topdir/mcs && $(MAKE) PROFILE=default ; \ - cd $$mcs_topdir/class/corlib && $(MAKE) PROFILE=default ; \ - cd $$mcs_topdir/class/System && $(MAKE) PROFILE=default ; \ - cd $$mcs_topdir/class/Mono.CSharp.Debugger && $(MAKE) PROFILE=default - $(MAKE) tmpinst-runtime - -# Use stage2 binaries to build the whole tree -stage3: stage2 - tmpinst=`cd _tmpinst && pwd` ; \ - PATH=$$tmpinst/bin:$$PATH ; export PATH ; \ - cd $(mcs_topdir) && $(MAKE) - -rm -fr _tmpinst - -tmpinst-dir: - set -e ; \ - rootme=`pwd`; tmpinst=$$rootme/_tmpinst ; \ - mkdir -p $$tmpinst $$tmpinst/bin $$tmpinst/lib ; \ - echo '#! /bin/sh' > $$tmpinst/bin/mono ; \ - echo 'if test -z "$$MONO_PATH" ; then MONO_PATH="'"$$tmpinst/lib"'"' >> $$tmpinst/bin/mono ; \ - echo 'else MONO_PATH=$${MONO_PATH}:"'"$$tmpinst/lib"'" ; fi' >> $$tmpinst/bin/mono ; \ - echo 'export MONO_PATH' >> $$tmpinst/bin/mono ; \ - echo 'exec "'"$$rootme/libtool"'" --mode=execute "'"$$rootme/$(mono_runtime)"'" "$$@"' >> $$tmpinst/bin/mono ; \ - echo '#! /bin/sh' > $$tmpinst/bin/mcs ; \ - echo 'exec "'"$$tmpinst/bin/mono"'" "'"$$tmpinst/lib/mcs.exe"'" "$$@"' >> $$tmpinst/bin/mcs ; \ - chmod +x $$tmpinst/bin/mono $$tmpinst/bin/mcs - -tmpinst-runtime: - tmpinst=`cd _tmpinst && pwd` && \ - mv -f $(mcs_topdir)/mcs/mcs.exe $$tmpinst/lib && \ - mv -f $(mcs_topdir)/class/lib/default/mscorlib.dll $(mcs_topdir)/class/lib/default/System.dll $$tmpinst/lib && \ - if test -f $(mcs_topdir)/class/lib/default/Mono.CSharp.Debugger.dll; then \ - mv -f $(mcs_topdir)/class/lib/default/Mono.CSharp.Debugger.dll $$tmpinst/lib ; else : ; fi - -# Obsolete target -- don't use. -.PHONY: fullbuild -fullbuild: bootstrap +noinst_DATA = mono-uninstalled.pc +DISTCLEANFILES= mono-uninstalled.pc + +.PHONY: get-monolite-latest mcs-do-compiler-tests compiler-tests bootstrap-world + +# building with monolite +mcslib = $(mcs_topdir)/class/lib +monolite = $(mcslib)/monolite +monolite_url = http://mono.ximian.com/daily/monolite-latest.tar.gz +get-monolite-latest: + -rm -fr $(mcslib)/monolite-* + test ! -d $(monolite) || test ! -d $(monolite).old || rm -fr $(monolite).old + test ! -d $(monolite) || mv -f $(monolite) $(monolite).old + cd $(mcslib) && { (wget -O- $(monolite_url) || curl $(monolite_url)) | gzip -d | tar xf - ; } + cd $(mcslib) && mv -f monolite-* monolite + +compiler-tests: mcs-do-clean + $(MAKE) all + $(MAKE) mcs-do-compiler-tests + +compiler-tests-net_2_0: + -rm -f $(mcs_topdir)/build/common/Consts.cs.save + -mv -f $(mcs_topdir)/build/common/Consts.cs $(mcs_topdir)/build/common/Consts.cs.save + cd $(mcs_topdir) && $(MAKE) PROFILE=net_2_0_bootstrap clean + cd $(mcs_topdir) && $(MAKE) PROFILE=net_2_0 clean + -mv -f $(mcs_topdir)/build/common/Consts.cs.save $(mcs_topdir)/build/common/Consts.cs + $(MAKE) all + $(MAKE) build_profiles=net_2_0 mcs-do-compiler-tests + +bootstrap-world: compiler-tests $(MAKE) install - echo "*** 'fullbuild' is an obsolete target. Use 'make bootstrap && make install'." - exit 1 + +bootstrap-world-net_2_0: compiler-tests-net_2_0 + $(MAKE) install + +# internal targets +mcs-do-clean: + cd runtime && $(MAKE) clean-local + cd mono/tests && $(MAKE) clean +mcs-do-compiler-tests: + cd runtime && $(MAKE) test_select='TEST_SUBDIRS="tests errors"' check-local + cd mono/tests && $(MAKE) check win32getdeps: wget http://www.go-mono.com/archive/pkgconfig-0.11-20020310.zip @@ -109,20 +67,16 @@ win32getdeps: wget http://www.go-mono.com/archive/libiconv-1.7.zip wget http://www.go-mono.com/archive/libiconv-dev-1.7.zip wget http://www.go-mono.com/archive/libintl-0.10.40-20020101.zip - wget http://www.jroith.de/nsis4cygwin.zip unzip -n -d / pkgconfig-0.11-20020310.zip unzip -n -d / glib-2.0.4-20020703.zip unzip -n -d / glib-dev-2.0.4-20020703.zip unzip -n -d / libiconv-1.7.zip unzip -n -d / libiconv-dev-1.7.zip unzip -n -d / libintl-0.10.40-20020101.zip - unzip -n -d / nsis4cygwin.zip win32setup: - cp /usr/lib/libglib-2.0-0.dll @prefix@/lib - cp /usr/lib/iconv.dll @prefix@/lib - cp /usr/lib/libgmodule-2.0-0.dll @prefix@/lib - cp /usr/lib/libgobject-2.0-0.dll @prefix@/lib - cp /usr/lib/libgthread-2.0-0.dll @prefix@/lib - cp /usr/lib/libintl-1.dll @prefix@/lib - makensis /DMILESTONE=@VERSION@ /DSOURCE_INSTALL_DIR=`cygpath -a -w @prefix@`\\* monowiz.win32.nsi + 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