X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=runtime%2FMakefile.am;h=1b9881a2f08c33dc45b4de4f3a5533dba65f5df1;hb=b3e660af62c1ec9f73bfc0b83ab82d037e998f0b;hp=ac009256f2622de84de62c9a2163391c04d20489;hpb=3114b5f1ac552a5ddcba8f9dc15dc81b804859f6;p=mono.git diff --git a/runtime/Makefile.am b/runtime/Makefile.am index ac009256f26..1b9881a2f08 100644 --- a/runtime/Makefile.am +++ b/runtime/Makefile.am @@ -1,155 +1,146 @@ -# 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 \ - monoresgen.exe.mdb \ - secutil.exe \ - secutil.exe.mdb \ - ilasm.exe \ - ilasm.exe.mdb \ - cilc.exe \ - cilc.exe.mdb \ - xsd.exe \ - xsd.exe.mdb \ - wsdl.exe \ - wsdl.exe.mdb \ - genxs.exe \ - genxs.exe.mdb \ - al.exe \ - al.exe.mdb \ - disco.exe \ - disco.exe.mdb \ - sqlsharp.exe \ - sqlsharp.exe.mdb \ - signcode.exe \ - signcode.exe.mdb \ - chktrust.exe \ - chktrust.exe.mdb \ - soapsuds.exe \ - soapsuds.exe.mdb \ - monop.exe \ - monop.exe.mdb \ - mono-find-provides.exe \ - mono-find-provides.exe.mdb \ - mono-find-requires.exe \ - mono-find-requires.exe.mdb \ - setreg.exe \ - setreg.exe.mdb \ - cert2spc.exe \ - cert2spc.exe.mdb \ - certmgr.exe \ - certmgr.exe.mdb \ - MakeCert.exe \ - MakeCert.exe.mdb \ - gacutil.exe \ - gacutil.exe.mdb \ - sn.exe \ - sn.exe.mdb - -monoone_DATA = \ - mcs.exe \ - mcs.exe.mdb \ - mcs.exe.config \ - mbas.exe - -if ! PLATFORM_WIN32 -gmcs_exe = gmcs.exe gmcs.exe.config gmcs.exe.mdb +# 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/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 + +if INSTALL_2_0 +build_profiles = default net_2_0 +else +build_profiles = default +endif + +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: + cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' clean-profiles + -./semdel-wrapper + -rm -fr $(etctmp) $(tmpinst) .wapi + +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 -monotwo_DATA = $(gmcs_exe) -EXTRA_DIST= $(monobins_DATA) $(monoone_DATA) $(monotwo_DATA) +mcs-do-test-profiles: + cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' test-profiles -MAINTAINERCLEANFILES = $(EXTRA_DIST) +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 -# -# 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 ;; \ - mcs.exe.mdb) d=mcs ;; \ - mcs.exe.config) d=mcs ;; \ - mbas.exe) d=mbas ;; \ - mbas.exe.mdb) d=mbas ;; \ - monoresgen.exe) d=monoresgen ;; \ - monoresgen.exe.mdb) d=monoresgen ;; \ - ilasm.exe) d=ilasm ;; \ - ilasm.exe.mdb) d=ilasm ;; \ - cilc.exe) d=tools/cilc ;; \ - cilc.exe.mdb) d=tools/cilc ;; \ - xsd.exe) d=tools/mono-xsd ;; \ - xsd.exe.mdb) d=tools/mono-xsd ;; \ - wsdl.exe) d=tools/wsdl ;; \ - wsdl.exe.mdb) d=tools/wsdl ;; \ - genxs.exe) d=tools/genxs ;; \ - genxs.exe.mdb) d=tools/genxs ;; \ - al.exe) d=tools/al ;; \ - al.exe.mdb) d=tools/al ;; \ - disco.exe) d=tools/disco ;; \ - disco.exe.mdb) d=tools/disco ;; \ - soapsuds.exe) d=tools/soapsuds ;; \ - soapsuds.exe.mdb) d=tools/soapsuds ;; \ - sqlsharp.exe) d=tools/SqlSharp ;; \ - sqlsharp.exe.mdb) d=tools/SqlSharp ;; \ - chktrust.exe) d=tools/security ;; \ - chktrust.exe.mdb) d=tools/security ;; \ - signcode.exe) d=tools/security ;; \ - signcode.exe.mdb) d=tools/security ;; \ - MakeCert.exe) d=tools/security ;; \ - MakeCert.exe.mdb) d=tools/security ;; \ - cert2spc.exe) d=tools/security ;; \ - cert2spc.exe.mdb) d=tools/security ;; \ - certmgr.exe) d=tools/security ;; \ - certmgr.exe.mdb) d=tools/security ;; \ - secutil.exe) d=tools/security ;; \ - secutil.exe.mdb) d=tools/security ;; \ - setreg.exe) d=tools/security ;; \ - setreg.exe.mdb) d=tools/security ;; \ - sn.exe) d=tools/security ;; \ - sn.exe.mdb) d=tools/security ;; \ - monop.exe) d=tools/monop ;; \ - monop.exe.mdb) d=tools/monop ;; \ - mono-find-provides.exe) d=tools/mono-rpm-helpers/mono-find-provides ;; \ - mono-find.mdb-provides.exe) d=tools/mono-rpm-helpers/mono-find-provides ;; \ - mono-find-requires.exe) d=tools/mono-rpm-helpers/mono-find-requires ;; \ - mono-find.mdb-requires.exe) d=tools/mono-rpm-helpers/mono-find-requires ;; \ - browsercaps-updater.exe) d=tools/browsercaps-updater ;; \ - browsercaps-updater.mdb.exe) d=tools/browsercaps-updater ;; \ - gacutil.exe) d=tools/gacutil ;; \ - gacutil.exe.mdb) d=tools/gacutil ;; \ - gmcs.exe) d=gmcs ;; \ - gmcs.exe.mdb) d=gmcs ;; \ - gmcs.exe.config) 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)`; 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,,& ,' $@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 = $(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 {} ';'