[xbuild] Clean up test logs.
[mono.git] / Makefile.am
index efef751ba711ca9f97e18c51d85122b3c0af9466..b5079153b8e860031a83b0cfd7280824caf092e7 100644 (file)
@@ -1,32 +1,54 @@
 AUTOMAKE_OPTIONS = foreign
 ACLOCAL_AMFLAGS = -I .
 
-SUBDIRS = po $(libgc_dir) $(eglib_dir) mono $(ikvm_native_dir) support data runtime scripts man samples web msvc docs
+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 = po libgc $(eglib_dir) mono ikvm-native support data runtime scripts man samples web tools msvc docs
-
-EXTRA_DIST= nls.m4 po.m4 progtest.m4 mono-uninstalled.pc.in dtrace-prelink.sh build-mingw32.sh LICENSE mkinstalldirs
+DIST_SUBDIRS = 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 = po libgc eglib mono ikvm-native support data runtime scripts man samples tools msvc docs
+endif
+endif
+
+EXTRA_DIST= \
+           LICENSE \
+           autogen.sh \
+           build-mingw32.sh \
+           mkinstalldirs \
+           mono-uninstalled.pc.in \
+           nls.m4 \
+           po.m4 \
+           progtest.m4 \
+           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=net_1_1 distdir=$$d dist-recursive
-       d=`cd $(distdir)/mcs && pwd`; cd $(mcs_topdir) && $(MAKE) PROFILE=net_2_0 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
 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
+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)
@@ -35,33 +57,53 @@ get-monolite-latest:
        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
-
-bootstrap-world: compiler-tests
-       $(MAKE) install
-
-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
+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
+
+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)
+
+endif
+
 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 
@@ -79,10 +121,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 '<?xml version="1.0" encoding="utf-8"?>' > msvc/scripts/order.xml
+       echo '<root>' >> 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 "    <project dir=\"$$1\" library=\"$$2\">"; \
+                read boot;   echo "      <boot>$$boot</boot>"; \
+                read mcs;    echo "      <mcs>$$mcs</mcs>"; \
+                read flags;  echo "      <flags>$$flags</flags>"; \
+                read output; echo "      <output>$$output</output>"; \
+                read built;  echo "      <built_sources>$$built</built_sources>"; \
+                read libou;  echo "      <library_output>$$libou</library_output>"; \
+                read resp;   echo "      <response>$$resp</response>"; \
+               echo "    </project>") >> msvc/scripts/order.xml; \
+       done
+       echo "</root>" >> msvc/scripts/order.xml