2005-04-10 Gonzalo Paniagua Javier <gonzalo@ximian.com>
[mono.git] / runtime / Makefile.am
index 1a21389ce917176a012bf2c9182f87a8545f8321..ca2624f99d7b11be888ef0fcf64d626725e770fe 100644 (file)
 # 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
-
-if ! PLATFORM_WIN32
-gmcs_exe = gmcs.exe
+# hack to prevent 'check' from depending on 'all'
+AUTOMAKE_OPTIONS = cygnus
+
+tmpinst = _tmpinst
+
+noinst_SCRIPTS = mono-wrapper
+
+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
+etc/mono/2.0/machine.config: $(top_srcdir)/data/net_2_0/machine.config
+
+$(symlinks):
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
+
+SUPPORT_FILES = $(symlinks) mono-wrapper wrapper-config
+
+# 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
+       d=`pwd`; cd $(mcs_topdir) && $(MAKE) RUNTIME=$$d/mono-wrapper PROFILES='$(build_profiles)' all-profiles
+
+if INSTALL_2_0
+build_profiles = default net_2_0
+else
+build_profiles = default
 endif
-monotwo_DATA = $(gmcs_exe)
 
-EXTRA_DIST= $(monobins_DATA) $(monoone_DATA) $(monotwo_DATA)
+# override automake
+install: install-exec install-data
 
-MAINTAINERCLEANFILES = $(EXTRA_DIST)
+# override automake
+install-exec: $(SUPPORT_FILES)
+       d=`pwd`; \
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' \
+                                   RUNTIME=$$d/mono-wrapper RUNTIME_HAS_CONSISTENT_GACDIR=yes install-profiles
+
+# override automake
+install-data:
+       @:
+
+# override automake
+uninstall:
+       d=`pwd`; \
+       cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' \
+                                   RUNTIME=$$d/mono-wrapper RUNTIME_HAS_CONSISTENT_GACDIR=yes uninstall-profiles
+
+clean-local:
+       d=`pwd`; cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' clean-profiles
+       -rm -fr $(symlinks) $(tmpinst) .wapi
+
+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:
+       d=`pwd`; cd $(mcs_topdir) && $(MAKE) RUNTIME=$$d/mono-wrapper PROFILES='$(build_profiles)' test-profiles
+
+mcs-do-run-test-profiles: test-support-files
+       d=`pwd`; PATH=$$d/$(tmpinst)/bin:$$PATH ; export PATH ; \
+       ( cd $(mcs_topdir) && $(MAKE) RUNTIME=$$d/mono-wrapper PROFILES='$(build_profiles)' run-test-profiles ) || ret=false ; \
+       rm -fr $(tmpinst); $$ret
 
-#
-# Keep in sync with mono/mono/metadata/Makefile.am
-#
 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 wrapper-config
+       save_MONO_PATH=$$MONO_PATH; mcs_topdir=`cd $(mcs_topdir) && $(cur_dir_cmd)`; ret=:; \
+       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; ret=false; \
+           fi; done; done; \
+       $$ret
+
+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
+
+$(tmpinst)/bin/mbas:
+       $(MAKE) test-support-file target=$@ file=mbas/mbas.exe
+
+$(tmpinst)/bin/gmcs:
+       $(MAKE) test-support-file target=$@ file=gmcs/gmcs.exe
+
+$(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)
+       chmod +x $(target)
+
+$(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 = Makefile.am Makefile.in mono-wrapper.in
+distdir: $(MYDISTFILES)
+       rm -fr $(distdir)
+       mkdir $(distdir)
+       test -z '$(MYDISTFILES)' || for file in ''$(MYDISTFILES); do \
+         if test -f $$file; then d=.; else d=$(srcdir); fi; \
+         cp -p $$d/$$file $(distdir) ; done
+       find $(distdir) -type f -exec chmod a+r {} ';'