X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=runtime%2FMakefile.am;h=779787b3ce32f3fbb8a33a0f8cbde478c31e5208;hb=efb5ca40eead93a593fd1ddb0fd035ed21774dfa;hp=1a21389ce917176a012bf2c9182f87a8545f8321;hpb=dac1a705ea8721eeff8b2a91da1747d04706f0bb;p=mono.git diff --git a/runtime/Makefile.am b/runtime/Makefile.am index 1a21389ce91..779787b3ce3 100644 --- a/runtime/Makefile.am +++ b/runtime/Makefile.am @@ -1,103 +1,143 @@ -# 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 - -if ! PLATFORM_WIN32 -gmcs_exe = gmcs.exe +# 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 -monotwo_DATA = $(gmcs_exe) +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 -EXTRA_DIST= $(monobins_DATA) $(monoone_DATA) $(monotwo_DATA) +## 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 -MAINTAINERCLEANFILES = $(EXTRA_DIST) +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 -# -# 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 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,,& ,' $@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/class/lib/net_2_0/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 {} ';'