include ../build/rules.make
with_mono_path = MONO_PATH="$(topdir)/class/lib/$(PROFILE)$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH"
+with_mono_path_n11b = MONO_PATH="$(topdir)/class/lib/net_1_1_bootstrap$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH"
ifeq (default, $(PROFILE))
# force this, we don't case if CSC is broken. This also
# means we can use --options, yay.
MCS = $(with_mono_path) $(INTERNAL_MCS)
+else
+EXTRA_SUPPORT_FILES = CSFriendAssembly-lib.dll GCS0122-2-lib.dll GCS0730-lib.dll GCS0733-lib.dll
endif
+ilasm = $(topdir)/class/lib/net_1_1_bootstrap/ilasm.exe
+ILASM = $(with_mono_path_n11b) $(RUNTIME) $(RUNTIME_FLAGS) $(ilasm)
+
GENERICS_COMPILE = $(CSCOMPILE) /target:library
DISTFILES = \
CONTRIBUTORS_README \
- README.tests \
errors.txt \
do-tests.pl \
$(wildcard *.cs) \
+ $(wildcard *.il) \
$(wildcard *.inc) \
$(wildcard *.pub) \
+ $(wildcard *.snk) \
$(wildcard *.response) \
- mcs-expect-no-error mcs-expect-wrong-error mcs-ignore-tests \
- gmcs-expect-no-error gmcs-expect-wrong-error gmcs-ignore-tests \
- generics-expect-no-error generics-expect-wrong-error \
$(wildcard known-issues-*)
-all-local: CS0118-2-lib.dll CS0122-10-lib.dll CS0534-3-lib.dll CS0534-4-lib.dll CS0571-3-lib.dll \
- CS0612-2-lib.dll CS0618-2-lib.dll CS0619-8-lib.dll CS0619-17-lib.dll CS0619-32-lib.dll CS0619-33-lib.dll CS0619-36-lib.dll \
- CS3005-16-lib.dll CS3013-module.dll
+TEST_SUPPORT_FILES = \
+ CS0118-2-lib.dll CS0122-10-lib.dll CS0122-14-lib.dll CS0122-15-lib.dll CS0122-19-lib.dll CS0144-3-lib.dll \
+ CS0205-3-lib.dll \
+ CS0229-3-lib.dll CS0229-4-lib.dll \
+ CS0433-lib.dll CS0433-2-lib.dll \
+ CS0534-3-lib.dll CS0534-4-lib.dll CS0571-3-lib.dll CS0571-5-lib.dll \
+ CS0612-2-lib.dll CS0618-2-lib.dll CS0619-8-lib.dll CS0619-17-lib.dll CS0619-32-lib.dll CS0619-33-lib.dll CS0619-36-lib.dll CS0619-42-lib.dll \
+ CS0619-43-lib.dll CS1546-lib.dll CS0619-51-lib.dll CS1509-module.dll CS1681-2-lib.dll \
+ CS2015-lib.dll CS3005-16-lib.dll CS3013-module.dll CSExternAlias-lib.dll \
+ $(EXTRA_SUPPORT_FILES)
-test-local: TestRunner-$(PROFILE).exe
+# mention all targets
+all-local $(STD_TARGETS:=-local):
-run-test-ondotnet-local:
+VALID_PROFILE := $(filter default net_2_0 net_2_1, $(PROFILE))
+ifdef VALID_PROFILE
+
+test-local: $(TEST_SUPPORT_FILES)
# again, run-test is when the tests actually happen, so
# don't compile on make test.
$(MAKE) PROFILE=default run-test
$(MAKE) PROFILE=net_2_0 run-test
+ifeq (net_2_1, $(PROFILE))
+COMPILER_NAME = smcs
+TEST_PATTERN = '*cs*.cs'
+LOCAL_RUNTIME_FLAGS = --security=temporary-smcs-hack
+endif
ifeq (net_2_0, $(PROFILE))
COMPILER_NAME = gmcs
-COMPILER = $(topdir)/gmcs/gmcs.exe
TEST_PATTERN = '*cs*.cs'
-else
+endif
+ifeq (default, $(PROFILE))
COMPILER_NAME = mcs
-COMPILER = $(topdir)/class/lib/$(PROFILE)/mcs.exe
TEST_PATTERN = 'cs*.cs'
endif
-ifeq (net_2_0, $(PROFILE))
+COMPILER = $(topdir)/class/lib/$(PROFILE)/$(COMPILER_NAME).exe
+TESTER = MONO_RUNTIME='$(RUNTIME)' $(TEST_RUNTIME) $(RUNTIME_FLAGS) $(LOCAL_RUNTIME_FLAGS) $(topdir)/class/lib/$(PROFILE)/compiler-tester.exe
+
+run-mcs-tests: $(TEST_SUPPORT_FILES)
+
run-mcs-tests:
- -rm -f gmcs.log
- @./do-tests.pl gmcs '$(CSCOMPILE)' "cs*.cs"
- -rm -f generics.log
- @./do-tests.pl generics '$(GENERICS_COMPILE)' "gcs*.cs"
-else
-run-mcs-tests: TestRunner-$(PROFILE).exe
- $(with_mono_path) $(RUNTIME) TestRunner-$(PROFILE).exe $(COMPILER_NAME) $(COMPILER) known-issues-$(COMPILER_NAME) $(COMPILER_NAME).log
-endif
+ rm -f *.exe
+ $(TESTER) -mode:neg -files:$(TEST_PATTERN) -compiler:$(COMPILER) -issues:known-issues-$(COMPILER_NAME) -log:$(COMPILER_NAME).log $(TESTER_OPTIONS)
clean-local:
rm -f *.exe *.dll *.log *.mdb dummy.xml *.junk
install-local uninstall-local:
%-lib.dll: %-lib.cs
- $(BOOTSTRAP_MCS) /target:library /out:$@ $<
+ $(CSCOMPILE) /target:library /out:$@ $<
%-module.dll: %-module.cs
- $(BOOTSTRAP_MCS) /target:module /out:$@ $<
+ $(CSCOMPILE) /target:module /out:$@ $<
+
+%-lib.dll: %-lib.il
+ $(ILASM) /dll /out:$@ $<
-TestRunner-$(PROFILE).exe: TestRunner.cs
- $(CSCOMPILE) /out:$@ TestRunner.cs
+endif