* class/System.Data.Linq/src/**/*,
[mono.git] / mcs / Makefile
index 3d8978be03e1497c2e5ff9f06575391980313434..1c1bf365ad94845c094d4f5aa7e32b9f4c342524 100644 (file)
 thisdir := .
-SUBDIRS := build jay mcs monoresgen class mbas nunit20 ilasm tools tests errors docs
-OVERRIDE_BARE_TARGETS = hells yeah
-include build/rules.make
-
-# Define these ourselves to that the platform checks come first
 
-#all: platform-check profile-check all-recursive #all-local
+SUBDIRS := build jay mcs class nunit24 ilasm tools tests errors docs
+
+basic_SUBDIRS := build jay mcs class tools
+net_2_0_bootstrap_SUBDIRS := build tools
+net_2_0_SUBDIRS := build mcs class nunit24 ilasm tools tests errors docs
+net_2_1_bootstrap_SUBDIRS := build mcs class
+net_2_1_raw_SUBDIRS := build mcs class tools
+net_2_1_SUBDIRS := tools tests errors
+monotouch_SUBDIRS := build mcs class
+monotouch_bootstrap_SUBDIRS := build mcs class
+net_3_5_SUBDIRS := build class
+net_4_0_bootstrap_SUBDIRS := build mcs class tools
+net_4_0_SUBDIRS := build mcs class nunit24 ilasm tools tests errors
+
+# List of test subdirs that should pass 100%
+centum_tests := \
+       class/corlib                                            \
+       class/System                                            \
+       class/System.XML                                        \
+       class/Commons.Xml.Relaxng                               \
+       class/Cscompmgd                                         \
+       class/Microsoft.JScript                                 \
+       class/Mono.Posix                                        \
+       class/Mono.Security                                     \
+       class/System.Design                                     \
+       class/System.DirectoryServices          \
+       class/System.Drawing                            \
+       class/System.Runtime.Remoting                           \
+       class/System.Runtime.Serialization.Formatters.Soap      \
+       class/System.Security                                   \
+       class/System.ServiceProcess                             \
+       class/System.Web                                                \
+       class/System.Web.Services                               \
+       tests                                                   \
+       errors
+
+default_centum_tests := \
+       $(centum_tests)         \
+       class/System.Data
+
+net_2_0_centum_tests := \
+       $(centum_tests)                         \
+       class/System.Core                       \
+       class/System.Configuration              \
+       class/System.Data.DataSetExtensions     \
+       class/System.Xml.Linq                   \
+       class/System.Transactions               \
+       class/Microsoft.Build.Framework         \
+       class/Microsoft.Build.Utilities         \
+       class/Microsoft.Build.Engine            \
+       class/System.Runtime.Serialization      \
+       class/System.IdentityModel              \
+       class/System.ServiceModel.Web           \
+       class/Mono.C5
+
+#      class/System.Web.Extensions
+#      class/Microsoft.Build.Tasks     
+
+# note that System.Xml.Linq is here to prevent this from being empty
+net_3_5_centum_tests := \
+       class/System.Xml.Linq
+
+ifdef ONLY_CENTUM_TESTS
+TEST_SUBDIRS := $($(PROFILE)_centum_tests)
+endif
+
+ifdef TEST_SUBDIRS
+$(PROFILE)_SUBDIRS := $(TEST_SUBDIRS)
+endif
 
-.PHONY: all clean all-profiles clean-profiles install uninstall test run-test testcorlib
+include build/rules.make
 
-all: platform-check profile-check all-recursive
+all-recursive $(STD_TARGETS:=-recursive): dir-check platform-check profile-check
 
-install: platform-check profile-check install-recursive #install-local
+.PHONY: all-local $(STD_TARGETS:=-local)
+all-local $(STD_TARGETS:=-local):
+       @:
 
-uninstall: platform-check profile-check uninstall-recursive #uninstall-local
+dir-check:
+       @if [ "$(NO_DIR_CHECK)" = "" -a "$(PROFILE)" != "basic" ]; then echo "Running make from the mcs directory is not supported. Run make from the parent directory (if using a tarball), or from the directory where the runtime is checked out (if using an SVN checkout)."; exit 1; fi
 
-test: platform-check profile-check test-recursive #test-local
+# fun specialty targets
 
-run-test: run-test-recursive #run-test-local
+PROFILES = net_2_0 net_3_5 net_4_0
 
-run-test-ondotnet: run-test-ondotnet-recursive # run-test-ondotnet-local
+.PHONY: all-profiles $(STD_TARGETS:=-profiles)
+all-profiles $(STD_TARGETS:=-profiles): %-profiles: profiles-do--%
+       @:
 
-clean: clean-recursive #clean-local
+profiles-do--%:
+       $(MAKE) $(PROFILES:%=profile-do--%--$*)
 
-# fun specialty targets
+# The % below looks like profile-name--target-name
+profile-do--%:
+       $(MAKE) PROFILE=$(subst --, ,$*)
 
-all-profiles:
-       $(MAKE) PROFILE=default all
-       $(MAKE) PROFILE=net_2_0 all
+# We don't want to run the tests in parallel.  We want behaviour like -k.
+profiles-do--run-test:
+       ret=:; $(foreach p,$(PROFILES), { $(MAKE) PROFILE=$(p) run-test || ret=false; }; ) $$ret
 
-clean-profiles:
-       $(MAKE) PROFILE=default clean
-       $(MAKE) PROFILE=net_2_0 clean
+# Orchestrate the bootstrap here.
+_boot_ = all clean install
+$(_boot_:%=profile-do--net_4_0--%):           profile-do--net_4_0--%:           profile-do--net_4_0_bootstrap--%
+$(_boot_:%=profile-do--net_4_0_bootstrap--%): profile-do--net_4_0_bootstrap--%: profile-do--net_2_0--%
+$(_boot_:%=profile-do--net_3_5--%):           profile-do--net_3_5--%:           profile-do--net_2_0--%
+$(_boot_:%=profile-do--net_2_1--%):           profile-do--net_2_1--%:           profile-do--net_2_1_raw--%
+$(_boot_:%=profile-do--monotouch--%):         profile-do--monotouch--%:         profile-do--monotouch_bootstrap--%
+$(_boot_:%=profile-do--monotouch_bootstrap--%): profile-do--monotouch_bootstrap--%: profile-do--net_2_0--%
+$(_boot_:%=profile-do--net_2_1_raw--%):       profile-do--net_2_1_raw--%:       profile-do--net_2_1_bootstrap--%
+$(_boot_:%=profile-do--net_2_1_bootstrap--%): profile-do--net_2_1_bootstrap--%: profile-do--net_2_0--%
+$(_boot_:%=profile-do--net_2_0--%):           profile-do--net_2_0--%:           profile-do--net_2_0_bootstrap--%
+$(_boot_:%=profile-do--net_2_0_bootstrap--%): profile-do--net_2_0_bootstrap--%: profile-do--basic--%
 
 testcorlib:
        @cd class/corlib && $(MAKE) test run-test
 
-# Disting. We need to override $(distdir) here.
+compiler-tests:
+       $(MAKE) TEST_SUBDIRS="tests errors" run-test-profiles
 
 package := mcs-$(VERSION)
-top_distdir = $(dots)/$(package)
-distdir = $(top_distdir)
-export package
 
 DISTFILES = \
        AUTHORS                 \
@@ -52,23 +130,27 @@ DISTFILES = \
        LICENSE                 \
        LICENSE.GPL             \
        LICENSE.LGPL            \
+       LICENSE.MPL             \
        Makefile                \
        mkinstalldirs           \
        MIT.X11                 \
        MonoIcon.png            \
        README                  \
        ScalableMonoIcon.svg    \
-       winexe.in
+       winexe.in               \
+       nunit.key
 
-dist-pre:
-       rm -rf $(package)
+dist-local: dist-default
 
-dist-post:
-       tar cvzf $(package).tar.gz $(package)
+csproj-local:
 
-dist-local: dist-default
+dist-pre:
+       rm -rf $(package)
+       mkdir $(package)
 
-dist-tarball: dist-pre dist-recursive dist-post
+dist-tarball: dist-pre
+       $(MAKE) distdir='$(package)' dist-recursive
+       tar cvjf $(package).tar.bz2 $(package)
 
 dist: dist-tarball
        rm -rf $(package)
@@ -80,19 +162,18 @@ dist: dist-tarball
 # We need to set prefix on make so class/System/Makefile can find
 # the installed System.Xml to build properly
 
-distcheck:
+distcheck: dist-tarball
        rm -rf InstallTest Distcheck-MCS ; \
        mkdir InstallTest ; \
        destdir=`cd InstallTest && pwd` ; \
-       $(MAKE) dist-tarball || exit 1 ; \
        mv $(package) Distcheck-MCS ; \
        (cd Distcheck-MCS && \
            $(MAKE) prefix=$(prefix) && $(MAKE) test && $(MAKE) install DESTDIR="$$destdir" && \
            $(MAKE) clean && $(MAKE) dist || exit 1) || exit 1 ; \
        mv Distcheck-MCS $(package) ; \
-       tar tzf $(package)/$(package).tar.gz |sed -e 's,/$$,,' |sort >distdist.list ; \
-       rm $(package)/$(package).tar.gz ; \
-       tar tzf $(package).tar.gz |sed -e 's,/$$,,' |sort >before.list ; \
+       tar tjf $(package)/$(package).tar.bz2 |sed -e 's,/$$,,' |sort >distdist.list ; \
+       rm $(package)/$(package).tar.bz2 ; \
+       tar tjf $(package).tar.bz2 |sed -e 's,/$$,,' |sort >before.list ; \
        find $(package) |egrep -v '(makefrag|response)' |sed -e 's,/$$,,' |sort >after.list ; \
        cmp before.list after.list || exit 1 ; \
        cmp before.list distdist.list || exit 1 ; \
@@ -104,7 +185,7 @@ monocharge:
        mkdir "$$chargedir" ; \
        DESTDIR=`cd "$$chargedir" && pwd` ; \
        $(MAKE) install DESTDIR="$$DESTDIR" || exit 1 ; \
-       tar cvzf "$$chargedir".tgz "$$chargedir" ; \
+       tar cvjf "$$chargedir".tar.bz2 "$$chargedir" ; \
        rm -rf "$$chargedir"
 
 # A bare-bones monocharge.
@@ -118,5 +199,5 @@ monocharge-lite:
        $(MAKE) -C class/System install DESTDIR="$$DESTDIR" || exit 1; \
        $(MAKE) -C class/System.XML install DESTDIR="$$DESTDIR" || exit 1; \
        $(MAKE) -C class/Mono.CSharp.Debugger install DESTDIR="$$DESTDIR" || exit 1; \
-       tar cvzf "$$chargedir".tgz "$$chargedir" ; \
+       tar cvjf "$$chargedir".tar.bz2 "$$chargedir" ; \
        rm -rf "$$chargedir"