(run-test-lib, run-btest-lib): Unify. Give profile-specific name
[mono.git] / mcs / build / library.make
index 891683c702479fae542f12722ced6f38ddb2fea3..7d7807ba11f276ac8a568e16396a9727a293dc3b 100644 (file)
 # munge in the library name to keep the files from clashing.
 
 sourcefile = $(LIBRARY).sources
-ifdef PLATFORM_CHANGE_SEPARATOR_CMD
-response = $(depsdir)/$(PROFILE)_$(LIBRARY).response
-else
+PLATFORM_excludes := $(wildcard $(LIBRARY).$(PLATFORM)-excludes)
+
+ifndef PLATFORM_excludes
+ifeq (cat,$(PLATFORM_CHANGE_SEPARATOR_CMD))
 response = $(sourcefile)
 endif
+endif
+
+ifndef response
+response = $(depsdir)/$(PROFILE)_$(LIBRARY).response
+library_CLEAN_FILES += $(response) $(LIBRARY).mdb
+endif
+
+ifndef LIBRARY_NAME
+LIBRARY_NAME = $(LIBRARY)
+endif
+
 makefrag = $(depsdir)/$(PROFILE)_$(LIBRARY).makefrag
-stampfile = $(depsdir)/$(PROFILE)_$(LIBRARY).stamp
-the_lib = $(topdir)/class/lib/$(PROFILE)/$(LIBRARY)
-the_pdb = $(patsubst %.dll,%.pdb,$(the_lib))
+the_lib = $(topdir)/class/lib/$(PROFILE)/$(LIBRARY_NAME)
+the_lib_signature_stamp = $(makefrag:.makefrag=.was_signed)
+the_pdb = $(the_lib:.dll=.pdb)
+the_mdb = $(the_lib:.dll=.mdb)
+library_CLEAN_FILES += $(makefrag) $(the_lib) $(the_pdb) \
+                       $(the_mdb) $(the_lib_signature_stamp)
 
 ifndef NO_TEST
-test_lib = $(patsubst %.dll,%_test.dll,$(LIBRARY))
-test_pdb = $(patsubst %.dll,%.pdb,$(test_lib))
+test_nunit_lib = nunit.framework.dll nunit.core.dll nunit.util.dll
+test_nunit_dep = $(test_nunit_lib:%=$(topdir)/class/lib/$(PROFILE)/%)
+test_nunit_ref = $(test_nunit_dep:%=-r:%)
+library_CLEAN_FILES += TestResult.xml
+
+ifndef test_against
+test_against = $(the_lib)
+test_dep = $(the_lib)
+endif
+
+ifndef test_lib
+test_lib = $(LIBRARY:.dll=_test_$(PROFILE).dll)
+test_sourcefile = $(LIBRARY:.dll=_test.dll.sources)
+else
 test_sourcefile = $(test_lib).sources
-test_response = $(depsdir)/$(PROFILE)_$(test_lib).response
-test_makefrag = $(depsdir)/$(PROFILE)_$(test_lib).makefrag
-test_stampfile = $(depsdir)/$(PROFILE)_$(test_lib).stamp
-test_flags = /r:$(the_lib) /r:$(topdir)/class/lib/$(PROFILE)/NUnit.Framework.dll $(TEST_MCS_FLAGS)
+endif
+test_pdb = $(test_lib:.dll=.pdb)
+test_response = $(depsdir)/$(test_lib).response
+test_makefrag = $(depsdir)/$(test_lib).makefrag
+test_flags = /r:$(test_against) $(test_nunit_ref) $(TEST_MCS_FLAGS)
+library_CLEAN_FILES += $(LIBRARY:.dll=_test*.dll) $(LIBRARY:.dll=_test*.pdb) $(test_response) $(test_makefrag)
+
+ifndef btest_lib
+btest_lib = $(LIBRARY:.dll=_btest_$(PROFILE).dll)
+btest_sourcefile = $(LIBRARY:.dll=_btest.dll.sources)
+else
+btest_sourcefile = $(btest_lib).sources
+endif
+btest_pdb = $(btest_lib:.dll=.pdb)
+btest_response = $(depsdir)/$(btest_lib).response
+btest_makefrag = $(depsdir)/$(btest_lib).makefrag
+btest_flags = /r:$(test_against) $(test_nunit_ref) $(TEST_MBAS_FLAGS)
+library_CLEAN_FILES += $(LIBRARY:.dll=_btest*.dll) $(LIBRARY:.dll=_btest*.pdb) $(btest_response) $(btest_makefrag)
+
+ifndef HAVE_CS_TESTS
+HAVE_CS_TESTS := $(wildcard $(test_sourcefile))
+endif
+ifndef HAVE_VB_TESTS
+HAVE_VB_TESTS := $(wildcard $(btest_sourcefile))
+endif
+
 endif
 
 gacutil = $(topdir)/tools/gacutil/gacutil.exe
+sn = $(topdir)/tools/security/sn.exe
 
-all-local: $(the_lib)
+PACKAGE = 1.0
 
-install-local: $(the_lib) gacutil
-       @if test -f Assembly/AssemblyInfo.cs ; then \
-               $(PLATFORM_RUNTIME)  $(gacutil) /i $(the_lib) /f || exit 1 ; \
-       else \
-               $(MKINSTALLDIRS) $(DESTDIR)$(prefix)/lib ; \
-               $(INSTALL_LIB) $(the_lib) $(DESTDIR)$(prefix)/lib ; \
-       fi
+ifeq ($(PROFILE), net_2_0)
+PACKAGE = 2.0
+endif
 
-uninstall-local: gacutil
-       @if test -f Assembly/AssemblyInfo.cs ; then \
-               $(PLATFORM_RUNTIME)  $(gacutil) /u $(the_lib) /f ; \
-       else \
-               -rm -f $(DESTDIR)$(prefix)/lib/$(LIBRARY)
-       fi
+ifeq ($(PLATFORM), win32)
+GACDIR = `cygpath -w $(DESTDIR)$(prefix)/lib`
+else
+GACDIR = $(DESTDIR)$(prefix)/lib
+endif
 
-gacutil:
-       cd $(topdir)/tools/gacutil && $(MAKE) || exit 1 ;
+all-local install-local test-local: $(the_lib)
 
-clean-local:
-       -rm -f $(the_lib) $(makefrag) $(test_lib) \
-              $(test_makefrag) $(test_response) \
-              $(stampfile) $(test_stampfile) \
-              $(the_pdb) $(test_pdb) \
-              TestResult.xml
-ifdef PLATFORM_CHANGE_SEPARATOR_CMD
-       -rm -rf $(response)
+ifdef LIBRARY_INSTALL_DIR
+install-local:
+       $(MKINSTALLDIRS) $(DESTDIR)$(LIBRARY_INSTALL_DIR)
+       $(INSTALL_LIB) $(the_lib) $(DESTDIR)$(LIBRARY_INSTALL_DIR)/$(LIBRARY_NAME)
+       -$(INSTALL_LIB) $(the_lib).mdb $(DESTDIR)$(LIBRARY_INSTALL_DIR)/$(LIBRARY_NAME).mdb
+
+uninstall-local:
+       -rm -f $(DESTDIR)$(LIBRARY_INSTALL_DIR)/$(LIBRARY_NAME) $(DESTDIR)$(LIBRARY_INSTALL_DIR)/$(LIBRARY_NAME).mdb
+
+else
+
+install-local: $(gacutil)
+       MONO_PATH="$(topdir)/class/lib/$(PROFILE):$$MONO_PATH" $(RUNTIME) $(gacutil) /i $(the_lib) /f /root $(GACDIR) /package $(PACKAGE)
+
+uninstall-local: $(gacutil)
+       MONO_PATH="$(topdir)/class/lib/$(PROFILE):$$MONO_PATH" $(RUNTIME) $(gacutil) /u $(LIBRARY_NAME:.dll=)
+
+endif
+
+ifndef NO_SIGN_ASSEMBLY
+all-local install-local: $(the_lib_signature_stamp)
+
+ifndef LIBRARY_SNK
+LIBRARY_SNK = $(topdir)/class/mono.snk
+endif
+
+$(the_lib_signature_stamp): $(the_lib) $(sn)
+       MONO_PATH="$(topdir)/class/lib/$(PROFILE):$$MONO_PATH" $(RUNTIME) $(sn) -q -R $(the_lib) $(LIBRARY_SNK)
+       echo stamp > $@
 endif
 
+clean-local:
+       -rm -f $(library_CLEAN_FILES) $(CLEAN_FILES)
+
+test-local run-test-local run-test-ondotnet-local:
+       @:
+
 ifndef NO_TEST
-test-local: $(the_lib) $(test_lib)
+$(test_nunit_dep): $(topdir)/build/deps/nunit.stamp
+       @if test -f $@; then :; else rm -f $<; $(MAKE) $<; fi
+$(topdir)/build/deps/nunit.stamp:
+       cd ${topdir}/nunit20 && $(MAKE)
+       echo "stamp" >$@
+endif
 
-run-test-local:
-       $(TEST_RUNTIME) $(TEST_HARNESS) $(test_lib)
+test_assemblies :=
 
-else
-test-local: $(the_lib)
+ifdef HAVE_CS_TESTS
+test_assemblies += $(test_lib)
+endif
+
+ifdef HAVE_VB_TESTS
+test_assemblies += $(btest_lib)
+endif
+
+ifdef test_assemblies
+test-local: $(test_assemblies)
+run-test-local: run-test-lib
+run-test-ondotnet-local: run-test-ondotnet-lib
+
+run-test-lib: test-local
+       $(TEST_RUNTIME) $(TEST_HARNESS) /xml:TestResult-$(PROFILE).xml $(test_assemblies)
 
-run-test-local:
+run-test-ondotnet-lib: test-local
+       $(TEST_HARNESS) /xml:TestResult-ondotnet-$(PROFILE).xml $(test_assemblies)
 endif
 
 DISTFILES = $(sourcefile) $(test_sourcefile) $(EXTRA_DISTFILES)
 
-ifdef NO_TEST
 TEST_FILES = 
-else
-TEST_FILES = `cat $(test_sourcefile) |sed -e 's,^\(.\),Test/\1,'`
+
+ifdef HAVE_CS_TESTS
+TEST_FILES += `sed 's,^,Test/,' $(test_sourcefile)`
+endif
+ifdef HAVE_VB_TESTS
+TEST_FILES += `sed 's,^,Test/,' $(btest_sourcefile)`
 endif
 
 dist-local: dist-default
        for f in `cat $(sourcefile)` $(TEST_FILES) ; do \
-           dest=`dirname $(distdir)/$$f` ; \
-           $(MKINSTALLDIRS) $$dest && cp $$f $$dest || exit 1 ; \
-       done
+         case $$f in \
+         ../*) : ;; \
+         *) dest=`dirname $(distdir)/$$f` ; $(MKINSTALLDIRS) $$dest && cp $$f $$dest || exit 1 ;; \
+         esac ; done
+
+ifndef LIBRARY_COMPILE
+LIBRARY_COMPILE = $(CSCOMPILE)
+endif
+
+ifndef TEST_COMPILE
+TEST_COMPILE = $(CSCOMPILE)
+endif
+
+ifndef BTEST_COMPILE
+BTEST_COMPILE = $(BASCOMPILE)
+endif
 
-# Fun with dependency tracking
+$(gacutil) $(sn):
+       cd $(@D) && $(MAKE) $(@F)
 
-$(the_lib): $(makefrag) $(stampfile) $(response)
-       $(CSCOMPILE) $(LIBRARY_FLAGS) $(LIB_MCS_FLAGS) /target:library /out:$@ @$(response)
+# The library
+
+$(the_lib): $(response)
+ifdef LIBRARY_USE_INTERMEDIATE_FILE
+       $(LIBRARY_COMPILE) $(LIBRARY_FLAGS) $(LIB_MCS_FLAGS) /target:library /out:$(@F) @$(response)
+       mv $(@F) $@
+       -mv $(@F).mdb $@.mdb
+else
+       $(LIBRARY_COMPILE) $(LIBRARY_FLAGS) $(LIB_MCS_FLAGS) /target:library /out:$@ @$(response)
+endif
 
-# warning: embedded tab in the 'echo touch' line
 $(makefrag): $(sourcefile)
        @echo Creating $@ ...
-       @echo "HAVE_MAKEFRAG = yes" >$@.new
-       @echo "$(stampfile): \\" >>$@.new
-       @cat $< |sed -e 's,\.cs[ \t]*$$,\.cs \\,' >>$@.new
-       @cat $@.new |sed -e '$$s, \\$$,,' >$@
-       @echo " touch \$$@" >>$@
-       @rm -rf $@.new
-
-ifdef PLATFORM_CHANGE_SEPARATOR_CMD
-$(response): $(sourcefile)
+       @sed 's,^,$(the_lib): ,' $< >$@
+
+ifneq ($(response),$(sourcefile))
+$(response): $(sourcefile) $(PLATFORM_excludes)
        @echo Creating $@ ...
-       @cat $< |$(PLATFORM_CHANGE_SEPARATOR_CMD) >$@
+       @sort $(sourcefile) $(PLATFORM_excludes) | uniq -u | $(PLATFORM_CHANGE_SEPARATOR_CMD) >$@
 endif
 
 -include $(makefrag)
 
-ifndef HAVE_MAKEFRAG
-$(stampfile):
-       touch $@
-endif
-
 # for now, don't give any /lib flags or set MONO_PATH, since we
 # give a full path to the assembly.
 
-ifndef NO_TEST
-$(test_lib): $(test_makefrag) $(the_lib) $(test_response) $(test_stampfile)
-       $(CSCOMPILE) /target:library /out:$@ $(test_flags) @$(test_response)
+ifdef HAVE_CS_TESTS
+
+$(test_lib): $(test_dep) $(test_response) $(test_nunit_dep)
+       $(TEST_COMPILE) /target:library /out:$@ $(test_flags) @$(test_response)
 
 $(test_response): $(test_sourcefile)
        @echo Creating $@ ...
-ifdef PLATFORM_CHANGE_SEPARATOR_CMD
-       @cat $< |sed -e 's,^\(.\),Test/\1,' |$(PLATFORM_CHANGE_SEPARATOR_CMD) >$@
-else
-       @cat $< |sed -e 's,^\(.\),Test/\1,' >$@
-endif
+       @sed 's,^,Test/,' $(test_sourcefile) | $(PLATFORM_CHANGE_SEPARATOR_CMD) >$@
 
-# warning: embedded tab in the 'echo touch' line
 $(test_makefrag): $(test_response)
        @echo Creating $@ ...
-       @echo "HAVE_TEST_MAKEFRAG = yes" >$@.new
-       @echo "$(test_stampfile): \\" >>$@.new
-       @cat $< |sed -e 's,\.cs[ \t]*$$,\.cs \\,' >>$@.new
-       @cat $@.new |sed -e '$$s, \\$$,,' >$@
-       @echo " touch \$$@" >>$@
-       @rm -rf $@.new
+       @sed 's,^,$(test_lib): ,' $< >$@
 
 -include $(test_makefrag)
+
 endif
 
-ifndef HAVE_TEST_MAKEFRAG
-$(test_stampfile):
-       touch $@
+ifdef HAVE_VB_TESTS
+
+$(btest_lib): $(test_dep) $(btest_response) $(test_nunit_dep)
+       $(BTEST_COMPILE) /target:library /out:$@ $(btest_flags) @$(btest_response)
+
+$(btest_response): $(btest_sourcefile)
+       @echo Creating $@ ...
+       @sed 's,^,Test/,' $(btest_sourcefile) | $(PLATFORM_CHANGE_SEPARATOR_CMD) >$@
+
+$(btest_makefrag): $(btest_response)
+       @echo Creating $@ ...
+       @sed 's,^,$(btest_lib): ,' $< >$@
+
+-include $(btest_makefrag)
+
 endif
 
+all-local: $(makefrag) $(test_makefrag) $(btest_makefrag)
+$(makefrag) $(test_makefrag) $(btest_makefrag): $(topdir)/build/library.make