thisdir := .
-SUBDIRS := build jay mcs monoresgen class mbas nunit20 ilasm tools tests errors docs
-DIST_ONLY_SUBDIRS := gmcs
-
-basic_SUBDIRS := jay mcs class
-net_1_1_bootstrap_SUBDIRS := jay mcs class
-net_2_0_bootstrap_SUBDIRS := class
-net_2_0_SUBDIRS := jay gmcs class tests errors tools
+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
-OVERRIDE_TARGET_ALL = yes
-
include build/rules.make
-all-recursive $(STD_TARGETS:=-recursive): platform-check profile-check
-
-# Used when OVERRIDE_TARGET_ALL is defined
-all.override:
-ifndef NO_SIGN_ASSEMBLY
- $(MAKE) NO_SIGN_ASSEMBLY=yes all.real
-endif
- $(MAKE) all.real
+all-recursive $(STD_TARGETS:=-recursive): dir-check platform-check profile-check
.PHONY: all-local $(STD_TARGETS:=-local)
all-local $(STD_TARGETS:=-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
+
# fun specialty targets
-PROFILES = default net_2_0
+PROFILES = net_2_0 net_3_5 net_4_0
.PHONY: all-profiles $(STD_TARGETS:=-profiles)
-all-profiles $(STD_TARGETS:=-profiles):
- $(MAKE) $(PROFILES:%=profile-do--%--$(@:-profiles=))
+all-profiles $(STD_TARGETS:=-profiles): %-profiles: profiles-do--%
+ @:
+
+profiles-do--%:
+ $(MAKE) $(PROFILES:%=profile-do--%--$*)
# The % below looks like profile-name--target-name
profile-do--%:
$(MAKE) PROFILE=$(subst --, ,$*)
-# Ensure these don't run in parallel, for now.
-profile-do--net_2_0--run-test: profile-do--default--run-test
-
-profile-do--net_2_0--all: profile-do--net_2_0_bootstrap--all
-profile-do--net_2_0_bootstrap--all: profile-do--default--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
+
+# 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
compiler-tests:
$(MAKE) TEST_SUBDIRS="tests errors" run-test-profiles
-test-installed-compiler:
- $(MAKE) TEST_SUBDIRS="tests errors" PROFILE=default TEST_RUNTIME=mono MCS=mcs run-test
- $(MAKE) TEST_SUBDIRS="tests errors" PROFILE=net_2_0 TEST_RUNTIME=mono MCS=gmcs run-test
-
package := mcs-$(VERSION)
DISTFILES = \
LICENSE \
LICENSE.GPL \
LICENSE.LGPL \
+ LICENSE.MPL \
Makefile \
mkinstalldirs \
MIT.X11 \
MonoIcon.png \
README \
ScalableMonoIcon.svg \
- winexe.in
+ winexe.in \
+ nunit.key
dist-local: dist-default
+csproj-local:
+
dist-pre:
rm -rf $(package)
mkdir $(package)
dist-tarball: dist-pre
$(MAKE) distdir='$(package)' dist-recursive
- tar cvzf $(package).tar.gz $(package)
+ tar cvjf $(package).tar.bz2 $(package)
dist: dist-tarball
rm -rf $(package)
$(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 ; \
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.
$(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"