-# This is just used to copy and install the DLL files that are currently
-# being compiled on windows.
-#
-
-SUBDIRS = . net_1_1 net_2_0
-
-mcs_topdir=$(top_srcdir)/../mcs
-
-monobins_DATA = \
- monoresgen.exe \
- secutil.exe \
- ilasm.exe \
- cilc.exe \
- xsd.exe \
- wsdl.exe \
- genxs.exe \
- al.exe \
- disco.exe \
- sqlsharp.exe \
- signcode.exe \
- chktrust.exe \
- soapsuds.exe \
- monop.exe \
- mono-find-provides.exe \
- mono-find-requires.exe \
- setreg.exe \
- cert2spc.exe \
- certmgr.exe \
- MakeCert.exe \
- gacutil.exe \
- sn.exe
-
-monoone_DATA = \
- mcs.exe \
- mbas.exe
-
-monotwo_DATA = \
- gmcs.exe
-
-EXTRA_DIST= $(monobins_DATA) $(monoone_DATA) $(monotwo_DATA)
-
-MAINTAINERCLEANFILES = $(EXTRA_DIST)
-
-#
-# Keep in sync with mono/mono/metadata/Makefile.am
-#
+# hack to prevent 'check' from depending on 'all'
+AUTOMAKE_OPTIONS = cygnus
+
+tmpinst = _tmpinst
+
+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/2.0/web.config etc/mono/browscap.ini
+
+etc/mono/1.0/machine.config: $(top_srcdir)/data/net_1_1/machine.config
+etc/mono/2.0/machine.config: $(top_srcdir)/data/net_2_0/machine.config
+etc/mono/2.0/web.config: $(top_srcdir)/data/net_2_0/web.config
+etc/mono/browscap.ini: $(top_srcdir)/data/browscap.ini
+
+$(symlinks):
+ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
+
+SUPPORT_FILES = $(symlinks) mono-wrapper etc/mono/config
+
+if INSTALL_2_0
+if INSTALL_2_1
+build_profiles = default net_2_0 net_2_1
+else
+build_profiles = default net_2_0
+endif
+else
+build_profiles = default
+endif
+
+if BUILD_MCS
+
+# The write check is to foil 'make distcheck'
+all-local: $(SUPPORT_FILES) $(TEST_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) $(TEST_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:
+ cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' clean-profiles
+ -./semdel-wrapper
+ -rm -fr $(etctmp) $(tmpinst) .wapi
+
+endif BUILD_MCS
+
+TEST_SUPPORT_FILES = $(tmpinst)/bin/mono $(tmpinst)/bin/mcs $(tmpinst)/bin/ilasm $(tmpinst)/bin/gmcs
+
+# 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
+ cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' run-test-profiles
+
if PLATFORM_WIN32
-monobinsdir = $(libdir)
-monoonedir = $(libdir)
-monotwodir = $(libdir)
+cur_dir_cmd = cygpath -w -a .
+PLATFORM_PATH_SEPARATOR = ;
else
-monobinsdir = $(bindir)
-monoonedir = $(libdir)/mono/1.0/
-monotwodir = $(libdir)/mono/2.0/
+cur_dir_cmd = pwd
+PLATFORM_PATH_SEPARATOR = :
endif
-$(monoone_DATA) $(monotwo_DATA) $(monobins_DATA):
- @case "$@" in \
- mcs.exe) d=mcs ;; \
- mbas.exe) d=mbas ;; \
- monoresgen.exe) d=monoresgen ;; \
- ilasm.exe) d=ilasm ;; \
- cilc.exe) d=tools/cilc ;; \
- xsd.exe) d=tools/mono-xsd ;; \
- wsdl.exe) d=tools/wsdl ;; \
- genxs.exe) d=tools/genxs ;; \
- al.exe) d=tools/al ;; \
- disco.exe) d=tools/disco ;; \
- soapsuds.exe) d=tools/soapsuds ;; \
- sqlsharp.exe) d=tools/SqlSharp ;; \
- chktrust.exe) d=tools/security ;; \
- signcode.exe) d=tools/security ;; \
- MakeCert.exe) d=tools/security ;; \
- cert2spc.exe) d=tools/security ;; \
- certmgr.exe) d=tools/security ;; \
- secutil.exe) d=tools/security ;; \
- setreg.exe) d=tools/security ;; \
- sn.exe) d=tools/security ;; \
- monop.exe) d=tools/monop ;; \
- mono-find-provides.exe) d=tools/mono-rpm-helpers/mono-find-provides ;; \
- mono-find-requires.exe) d=tools/mono-rpm-helpers/mono-find-requires ;; \
- browsercaps-updater.exe) d=tools/browsercaps-updater ;; \
- gacutil.exe) d=tools/gacutil ;; \
- gmcs.exe) d=gmcs ;; \
- esac; \
- echo "test -f $(top_srcdir)/../mcs/$$d/$@" ; \
- test -f $(top_srcdir)/../mcs/$$d/$@ || exit 1 ; \
- echo "rm -f $(srcdir)/$@" ; \
- rm -f $(srcdir)/$@ ; \
- echo "cd $(srcdir) && $(LN_S) ../../mcs/$$d/$@ $@" ; \
- cd $(srcdir) && $(LN_S) ../../mcs/$$d/$@ $@
-
-copy_dlls:
- cp /nt/mono/mcs/class/*/*.dll .
-
-push_dlls:
- scp -o "Protocol 1" *.dll *.exe snapshot@mono-cvs.ximian.com:dlls
-
-cleanassemblies:
- find -name \*.dll -exec rm -vf {} \;
- find -name \*.exe -exec rm -vf {} \;
+# Use --compile-all as a poor man's PEVerify to detect invalid IL
+mcs-compileall: mono-wrapper etc/mono/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; 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 = etc/mono/config
+
+# depend on $(symlinks) to ensure 'etc/mono' directory exists
+etc/mono/config: ../data/config Makefile $(symlinks)
+ d=`cd ../support && pwd`; \
+ sed 's,target="libMonoPosixHelper[^"]*",target="'$$d/libMonoPosixHelper.la'",' ../data/config > $@t
+ if test -z "$(libgdiplus_loc)"; then :; else \
+ sed 's,<configuration>,& <dllmap dll="gdiplus.dll" target="$(libgdiplus_loc)" />,' $@t > $@tt; \
+ mv -f $@tt $@t; fi
+ mv -f $@t $@
+
+$(tmpinst)/bin/mono: mono-wrapper etc/mono/config
+ $(mkinstalldirs) $(tmpinst)/bin
+ cp mono-wrapper $@
+
+$(tmpinst)/bin/mcs: $(tmpinst)/bin/mono Makefile
+ echo '#! /bin/sh' > $@ ; \
+ r=`pwd`; m=`cd $(mcs_topdir) && pwd`; \
+ echo 'exec "'"$$r/$(tmpinst)/bin/mono"'" "'"$$m/class/lib/default/mcs.exe"'" "$$@"' >> $@ ; \
+ chmod +x $@
+
+$(tmpinst)/bin/gmcs: $(tmpinst)/bin/mono Makefile
+ echo '#! /bin/sh' > $@ ; \
+ r=`pwd`; m=`cd $(mcs_topdir) && pwd`; \
+ echo 'exec "'"$$r/$(tmpinst)/bin/mono"'" "'"$$m/gmcs/gmcs.exe"'" "$$@"' >> $@ ; \
+ chmod +x $@
+
+$(tmpinst)/bin/ilasm: $(tmpinst)/bin/mono Makefile
+ echo '#! /bin/sh' > $@ ; \
+ r=`pwd`; m=`cd $(mcs_topdir) && pwd`; \
+ echo 'exec "'"$$r/$(tmpinst)/bin/mono"'" "'"$$m/ilasm/ilasm.exe"'" "$$@"' >> $@ ; \
+ chmod +x $@
+
+test-support-files: $(TEST_SUPPORT_FILES)
+ @:
+
+# 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 {} ';'