* XmlCodeExporterTests.cs: Added tests for arrays. Fixed usage of
[mono.git] / runtime / Makefile.am
index 94ebc1097bc26c762b6cdf6f3d2e48a23570a424..1b9881a2f08c33dc45b4de4f3a5533dba65f5df1 100644 (file)
@@ -1,11 +1,11 @@
-# This is just used to copy and install the DLL files that are currently
-# being compiled on windows.
-#
+# hack to prevent 'check' from depending on 'all'
+AUTOMAKE_OPTIONS = cygnus
 
 tmpinst = _tmpinst
 
-noinst_SCRIPTS = mono-wrapper
+noinst_SCRIPTS = mono-wrapper monodis-wrapper semdel-wrapper
 
+etctmp = etc
 symlinks = etc/mono/1.0/machine.config etc/mono/2.0/machine.config
 
 etc/mono/1.0/machine.config: $(top_srcdir)/data/net_1_1/machine.config
@@ -14,30 +14,101 @@ etc/mono/2.0/machine.config: $(top_srcdir)/data/net_2_0/machine.config
 $(symlinks):
        cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
 
-all-local: $(symlinks) mono-wrapper
-       d=`pwd`; cd $(mcs_topdir) && $(MAKE) RUNTIME=$$d/mono-wrapper all-profiles
+SUPPORT_FILES = $(symlinks) mono-wrapper wrapper-config
 
 if INSTALL_2_0
-install_profiles = default net_2_0
+build_profiles = default net_2_0
 else
-install_profiles = default
+build_profiles = default
 endif
 
-install-exec-local:
-       d=`pwd`; cd $(mcs_topdir) && $(MAKE) RUNTIME=$$d/mono-wrapper prefix=$(exec_prefix) PROFILES='$(install_profiles)' install-profiles
+if BUILD_MCS
 
+# The write check is to foil 'make distcheck'
+all-local: $(SUPPORT_FILES)
+       if test -w $(mcs_topdir); then :; else chmod -R +w $(mcs_topdir); fi
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' CC='$(CC)' all-profiles
+
+# override automake
+install: install-exec install-data
+
+# override automake
+install-exec: $(SUPPORT_FILES)
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' RUNTIME_HAS_CONSISTENT_GACDIR=yes prefix=$(prefix) install-profiles
+
+# override automake
+install-data:
+       @:
+
+# override automake
+uninstall:
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' RUNTIME_HAS_CONSISTENT_GACDIR=yes prefix=$(prefix) uninstall-profiles
+
+## semdel-wrapper will probably not delete the semaphore if someone is crazy enough to do a 'make -j distclean' :-)
 clean-local:
-       -rm -fr $(symlinks)
-       d=`pwd`; cd $(mcs_topdir) && $(MAKE) PROFILES='basic net_1_1_bootstrap default net_2_0_bootstrap net_2_0' clean-profiles
-       -rm -fr $(tmpinst)
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' clean-profiles
+       -./semdel-wrapper
+       -rm -fr $(etctmp) $(tmpinst) .wapi
 
-TEST_SUPPORT_FILES = $(tmpinst)/bin/mcs $(tmpinst)/bin/mbas $(tmpinst)/bin/ilasm $(tmpinst)/bin/gmcs
-check-local:
-       $(mkdir_p) $(tmpinst)/bin
-       $(MAKE) $(TEST_SUPPORT_FILES)
-       d=`pwd`; PATH=$$d/$(tmpinst)/bin:$$PATH ; export PATH ; \
-       ( cd $(mcs_topdir) && $(MAKE) RUNTIME=$$d/mono-wrapper run-test-profiles ) || ret=false ; \
-       rm -f $(tmpinst) ; $$ret
+endif BUILD_MCS
+
+if INSTALL_2_0
+TEST_SUPPORT_FILES = $(tmpinst)/bin/mono $(tmpinst)/bin/mcs $(tmpinst)/bin/mbas $(tmpinst)/bin/ilasm $(tmpinst)/bin/gmcs
+else
+TEST_SUPPORT_FILES = $(tmpinst)/bin/mono $(tmpinst)/bin/mcs $(tmpinst)/bin/mbas $(tmpinst)/bin/ilasm
+endif
+
+# now a misnomer, but it'll go away soon enough.
+if ENABLE_NUNIT_TESTS
+test_select =
+else
+test_select = ONLY_CENTUM_TESTS=yes
+endif
+
+mcs-do-test-profiles:
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' test-profiles
+
+mcs-do-run-test-profiles: test-support-files
+       d=`cd $(tmpinst) && pwd`; PATH=$$d/bin:$$PATH ; export PATH ; \
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' run-test-profiles
+
+if PLATFORM_WIN32
+cur_dir_cmd = cygpath -w -a .
+PLATFORM_PATH_SEPARATOR = ;
+else
+cur_dir_cmd = pwd
+PLATFORM_PATH_SEPARATOR = :
+endif
+
+# Use --compile-all as a poor man's PEVerify to detect invalid IL
+mcs-compileall: mono-wrapper wrapper-config
+       save_MONO_PATH=$$MONO_PATH; mcs_topdir=`cd $(mcs_topdir) && $(cur_dir_cmd)`; ok=:; \
+       for profile in $(build_profiles); do \
+         MONO_PATH="$$mcs_topdir/class/lib/$$profile$(PLATFORM_PATH_SEPARATOR)$$save_MONO_PATH"; export MONO_PATH; \
+         for i in $(mcs_topdir)/class/lib/$$profile/*.dll $(mcs_topdir)/class/lib/$$profile/*.exe $(mcs_topdir)/class/Microsoft.VisualBasic/fixup/$$profile/*.dll; do \
+           if ./mono-wrapper --compile-all $$i; then \
+             echo $$i verified OK; \
+           else \
+             echo $$i verification failed; ok=false; \
+           fi; done; done; \
+       $$ok
+
+check-local: mcs-compileall mcs-do-test-profiles
+       $(MAKE) $(test_select) mcs-do-run-test-profiles
+
+CLEANFILES = wrapper-config
+
+wrapper-config: ../data/config Makefile
+       d=`cd ../support && pwd`; \
+       sed 's,target="libMonoPosixHelper[^"]*",target="'$$d/libMonoPosixHelper.la'",' ../data/config > $@
+       if test -z "$(libgdiplus_loc)"; then :; else \
+         mv $@ $@t; \
+         sed 's,<configuration>,& <dllmap dll="gdiplus.dll" target="$(libgdiplus_loc)" />,' $@t > $@; \
+         rm -f $@t; \
+       fi
+
+$(tmpinst)/bin/mono: mono-wrapper wrapper-config
+       cp mono-wrapper $@
 
 $(tmpinst)/bin/mcs:
        $(MAKE) test-support-file target=$@ file=class/lib/default/mcs.exe
@@ -51,6 +122,10 @@ $(tmpinst)/bin/gmcs:
 $(tmpinst)/bin/ilasm:
        $(MAKE) test-support-file target=$@ file=ilasm/ilasm.exe
 
+test-support-files:
+       $(mkinstalldirs) $(tmpinst)/bin
+       $(MAKE) $(TEST_SUPPORT_FILES)
+
 test-support-file:
        echo '#! /bin/sh' > $(target)
        r=`pwd`; m=`cd $(mcs_topdir) && pwd`; echo 'exec "'"$$r/mono-wrapper"'" "'"$$m/$(file)"'" "$$@"' >> $(target)
@@ -60,3 +135,12 @@ $(tmpinst)/bin/pedump: $(srcdir)/Makefile.am
        $(mkdir_p) $(@D)
        (b=`pwd`; echo '#! /bin/sh'; echo 'exec "'"$$b/libtool"'" --mode=execute "'"$$b/mono/metadata/pedump"'" "$$@"') > $@
        chmod +x $@
+
+# the 'cygnus' option also disables the default 'distdir:' target, which we _do_ want
+MYDISTFILES = $(DIST_COMMON)
+distdir: $(MYDISTFILES)
+       rm -fr $(distdir)
+       mkdir $(distdir)
+       test -z '$(MYDISTFILES)' || for file in ''$(MYDISTFILES); do \
+         cp -p $$file $(distdir) ; done
+       find $(distdir) -type f -exec chmod a+r {} ';'