X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=Makefile.am;h=5b99259a2f8b67dacfcafb7fe4bc316411fac83b;hb=5979d6f01982aba922f86e1273b0173eab7b285e;hp=587ed44b1f4e89c3a36c645b500fbc39f42dc5fa;hpb=9975a45f43793e34318e593ddacd3f332f8d91c0;p=mono.git diff --git a/Makefile.am b/Makefile.am index 587ed44b1f4..5b99259a2f8 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,74 +1,104 @@ -AUTOMAKE_OPTIONS = foreign -ACLOCAL_AMFLAGS = -I . +ACLOCAL_AMFLAGS = -I m4 -SUBDIRS = $(libgc_dir) mono $(ikvm_native_dir) support docs data runtime scripts man samples web +MOONLIGHT_SUBDIRS = $(libgc_dir) eglib/src mono +if CROSS_COMPILING +SUBDIRS = po $(libgc_dir) eglib mono $(ikvm_native_dir) data runtime scripts man samples msvc $(docs_dir) # Keep in sync with SUBDIRS ## 'tools' is not normally built -DIST_SUBDIRS = libgc mono ikvm-native support docs data runtime scripts man samples web tools - -vs_files = genmdesc.vcproj libmono.vcproj mono.vcproj mono.sln +DIST_SUBDIRS = m4 po libgc eglib mono ikvm-native data runtime scripts man samples tools msvc docs +else +if ONLY_MOONLIGHT +SUBDIRS = $(MOONLIGHT_SUBDIRS) runtime +else +SUBDIRS = po $(libgc_dir) eglib mono $(ikvm_native_dir) support data runtime scripts man samples msvc $(docs_dir) +# Keep in sync with SUBDIRS +## 'tools' is not normally built +DIST_SUBDIRS = m4 po libgc eglib mono ikvm-native support data runtime scripts man samples tools msvc docs +endif +endif -EXTRA_DIST= mono.pc.in mint.pc.in mono-uninstalled.pc.in dotnet.pc.in mono-cairo.pc.in LICENSE $(vs_files) +EXTRA_DIST= \ + LICENSE \ + autogen.sh \ + build-mingw32.sh \ + mkinstalldirs \ + mono-uninstalled.pc.in \ + winconfig.h DISTCHECK_CONFIGURE_FLAGS = EXTERNAL_MCS=false EXTERNAL_RUNTIME=false # Distribute the 'mcs' tree too +GIT_DIR ?= $(srcdir)/.git dist-hook: test -d $(distdir)/mcs || mkdir $(distdir)/mcs - d=`cd $(distdir)/mcs && pwd`; cd $(mcs_topdir) && $(MAKE) PROFILE=default distdir=$$d dist-recursive + d=`cd $(distdir)/mcs && pwd`; cd $(mcs_topdir) && $(MAKE) distdir=$$d dist-recursive + test ! -d $(GIT_DIR) || ./scripts/commits-to-changelog.py --root=$(distdir) last-commit-with-compulsory-changelog-entry pkgconfigdir = $(libdir)/pkgconfig -if JIT_SUPPORTED -if INTERP_SUPPORTED -pkgconfig_DATA= mono.pc mint.pc dotnet.pc mono-cairo.pc -else -pkgconfig_DATA= mono.pc dotnet.pc mono-cairo.pc -endif -else -pkgconfig_DATA= mint.pc mono-cairo.pc -endif noinst_DATA = mono-uninstalled.pc -DISTCLEANFILES= mono.pc mint.pc mono-uninstalled.pc dotnet.pc mono-cairo.pc - -.PHONY: get-monolite-latest mcs-do-compiler-tests compiler-tests bootstrap-world +DISTCLEANFILES= mono-uninstalled.pc # building with monolite mcslib = $(mcs_topdir)/class/lib monolite = $(mcslib)/monolite +mono_corlib_version = $(shell sed -n "s/\#define MONO_CORLIB_VERSION //p" $(srcdir)/mono/metadata/appdomain.c) +monolite_url = http://mono.ximian.com/daily/monolite-$(mono_corlib_version)-latest.tar.gz +.PHONY: get-monolite-latest get-monolite-latest: -rm -fr $(mcslib)/monolite-* + -mkdir -p $(mcslib) test ! -d $(monolite) || test ! -d $(monolite).old || rm -fr $(monolite).old test ! -d $(monolite) || mv -f $(monolite) $(monolite).old - cd $(mcslib) && { wget -O- http://www.go-mono.com/daily/monolite-latest.tar.gz | gzip -d | tar xf - ; } + 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 +.PHONY: validate do-build-mono-mcs mcs-do-clean mcs-do-tests +validate: do-build-mono-mcs + $(MAKE) mcs-do-tests +do-build-mono-mcs: mcs-do-clean $(MAKE) all - $(MAKE) build_profiles=net_2_0 mcs-do-compiler-tests +mcs-do-clean: + cd runtime && $(MAKE) clean-local + cd mono/tests && $(MAKE) clean +mcs-do-tests: + cd runtime && $(MAKE) check-local + cd mono/tests && $(MAKE) check +.PHONY: compiler-tests mcs-do-compiler-tests +compiler-tests: + $(MAKE) test_select='TEST_SUBDIRS="tests errors"' validate +mcs-do-compiler-tests: + $(MAKE) test_select='TEST_SUBDIRS="tests errors"' mcs-do-tests + +.PHONY: bootstrap-world bootstrap-world: compiler-tests $(MAKE) install -bootstrap-world-net_2_0: compiler-tests-net_2_0 - $(MAKE) install +if MOONLIGHT +moon-do-build: config.h + @list='$(MOONLIGHT_SUBDIRS)'; for subdir in $$list; do \ + case "x$$subdir" in \ + xmono ) target="moon-do-build";; \ + * ) target="all";; \ + esac; \ + echo "Making $$target in $$subdir"; \ + (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$target); \ + done; + (cd runtime && $(MAKE) $(AM_MAKEFLAGS) moon-do-build) + +moon-do-clean: + @list='$(MOONLIGHT_SUBDIRS)'; for subdir in $$list; do \ + case "x$$subdir" in \ + xmono ) target="moon-do-clean";; \ + * ) target="clean";; \ + esac; \ + echo "Making $$target in $$subdir"; \ + (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$target); \ + done; + (cd runtime && $(MAKE) $(AM_MAKEFLAGS) moon-do-clean) -# 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 +endif win32getdeps: wget http://www.go-mono.com/archive/pkgconfig-0.11-20020310.zip @@ -87,6 +117,29 @@ 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 +patch-quiet: + find mono -name Makefile -exec scripts/patch-quiet.sh {} \; + find libgc -name Makefile -exec scripts/patch-quiet.sh {} \; + +update-csproj: + -rm msvc/scripts/order + -mkdir msvc/scripts/inputs + (cd runtime; make V=1 extra_targets=csproj-local) + +package-inputs: + echo '' > msvc/scripts/order.xml + echo '' >> msvc/scripts/order.xml + for i in `cat msvc/scripts/order`; do \ + set `echo $$i | sed -e 's/:/ /' -e 's/.input//'`; \ + cat msvc/scripts/inputs/$$2.input | \ + (echo " "; \ + read boot; echo " $$boot"; \ + read mcs; echo " $$mcs"; \ + read flags; echo " $$flags"; \ + read output; echo " $$output"; \ + read built; echo " $$built"; \ + read libou; echo " $$libou"; \ + read resp; echo " $$resp"; \ + echo " ") >> msvc/scripts/order.xml; \ + done + echo "" >> msvc/scripts/order.xml