X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=runtime%2FMakefile.am;h=dde00adef647541e718a6758f25cf315d16da592;hb=9c80a2dc1cf937166af0c724e36106384ef9d843;hp=62f25742be2cfe3de1d257af94067b4655a172dc;hpb=a8d90ad723014ebc7df16b3c5334462b00db5438;p=mono.git diff --git a/runtime/Makefile.am b/runtime/Makefile.am index 62f25742be2..dde00adef64 100644 --- a/runtime/Makefile.am +++ b/runtime/Makefile.am @@ -3,40 +3,86 @@ AUTOMAKE_OPTIONS = cygnus tmpinst = _tmpinst -noinst_SCRIPTS = mono-wrapper monodis-wrapper semdel-wrapper +noinst_SCRIPTS = mono-wrapper monodis-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 +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/2.0/Browsers/Compat.browser + +if INSTALL_4_0 +symlinks += etc/mono/4.0/machine.config etc/mono/4.0/web.config +endif -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 +etc/mono/2.0/Browsers/Compat.browser: $(top_srcdir)/data/net_2_0/Browsers/Compat.browser +etc/mono/4.0/machine.config: $(top_srcdir)/data/net_4_0/machine.config +etc/mono/4.0/web.config: $(top_srcdir)/data/net_4_0/web.config $(symlinks): cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ SUPPORT_FILES = $(symlinks) mono-wrapper etc/mono/config -if INSTALL_2_0 -build_profiles = default net_2_0 +if MOONLIGHT +moon-do-basic: Makefile $(SUPPORT_FILES) + cd $(mcs_topdir)/ && $(MAKE) NO_DIR_CHECK=1 PROFILE=moonlight_raw + +moon-do-basic-clean: + cd $(mcs_topdir)/ && $(MAKE) NO_DIR_CHECK=1 PROFILE=moonlight_raw clean +endif + +if ONLY_MOONLIGHT +build_profiles = moonlight_raw +test_profiles = moonlight_raw else -build_profiles = default + +build_profiles = net_2_0 net_3_5 +test_profiles = $(build_profiles) + +if MOONLIGHT +build_profiles += moonlight_raw +test_profiles += moonlight_raw + +moon-do-moonlight-raw: Makefile $(SUPPORT_FILES) + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 PROFILES='moonlight_raw' CC='$(CC)' all-profiles + +moon-do-moonlight-raw-clean: + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 PROFILES='moonlight_raw' CC='$(CC)' clean-profiles + +moon-do-build: moon-do-moonlight-raw moon-do-basic +moon-do-clean: moon-do-moonlight-raw-clean moon-do-basic-clean + +endif + +if INSTALL_4_0 +build_profiles += net_4_0 +#test_profiles += net_4_0 +endif + +if INSTALL_MONODROID +build_profiles += monodroid +endif + +if INSTALL_MONOTOUCH +build_profiles += monotouch +endif + endif if BUILD_MCS # The write check is to foil 'make distcheck' -all-local: $(SUPPORT_FILES) +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 + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 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 +install-exec: $(SUPPORT_FILES) $(TEST_SUPPORT_FILES) + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 PROFILES='$(build_profiles)' RUNTIME_HAS_CONSISTENT_GACDIR=yes prefix=$(prefix) install-profiles # override automake install-data: @@ -44,21 +90,17 @@ install-data: # override automake uninstall: - cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' RUNTIME_HAS_CONSISTENT_GACDIR=yes prefix=$(prefix) uninstall-profiles + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 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' :-) +## mono --wapi=semdel 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 + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 PROFILES='$(build_profiles)' clean-profiles + -./mono-wrapper --wapi=semdel -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 +TEST_SUPPORT_FILES = $(tmpinst)/bin/mono $(tmpinst)/bin/ilasm $(tmpinst)/bin/mcs $(tmpinst)/bin/gmcs $(tmpinst)/bin/dmcs $(tmpinst)/bin/al2 $(tmpinst)/bin/al # now a misnomer, but it'll go away soon enough. if ENABLE_NUNIT_TESTS @@ -68,27 +110,44 @@ test_select = ONLY_CENTUM_TESTS=yes endif mcs-do-test-profiles: - cd $(mcs_topdir) && $(MAKE) PROFILES='$(build_profiles)' test-profiles + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 PROFILES='$(test_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 + cd $(mcs_topdir) && $(MAKE) NO_DIR_CHECK=1 PROFILES='$(test_profiles)' run-test-profiles -if PLATFORM_WIN32 +if HOST_WIN32 +if CROSS_COMPILING +cur_dir_cmd = pwd +PLATFORM_PATH_SEPARATOR = : +else cur_dir_cmd = cygpath -w -a . PLATFORM_PATH_SEPARATOR = ; +endif else cur_dir_cmd = pwd PLATFORM_PATH_SEPARATOR = : endif -# Use --compile-all as a poor man's PEVerify to detect invalid IL +# Compile all assemblies with the verifier turned on. Code must be valid but not verifiable. +# TODO it would be nice to split assemblies without unsafe code to use the verifier with verifiable mode. +# Skip net 2.1 assemblies for now because of visibility problems 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 \ + for profile in $(test_profiles); do \ + if [ "moonlight" = "$$profile" ]; then \ + break; \ + fi; \ + if [ "net_3_5" = "$$profile" ]; then \ + MONO_PATH="$$mcs_topdir/class/lib/$$profile$(PLATFORM_PATH_SEPARATOR)$$mcs_topdir/class/lib/net_2_0$(PLATFORM_PATH_SEPARATOR)$$save_MONO_PATH"; \ + else \ + MONO_PATH="$$mcs_topdir/class/lib/$$profile$(PLATFORM_PATH_SEPARATOR)$$save_MONO_PATH"; \ + fi; \ + export MONO_PATH; \ + for i in $(mcs_topdir)/class/lib/$$profile/*.{dll,exe}; do \ + if [ ! -f $$i ] ; then \ + continue ; \ + fi ; \ + if ./mono-wrapper --compile-all --verify-all --security=validil $$i; then \ echo $$i verified OK; \ else \ echo $$i verification failed; ok=false; \ @@ -110,34 +169,48 @@ etc/mono/config: ../data/config Makefile $(symlinks) mv -f $@t $@ $(tmpinst)/bin/mono: mono-wrapper etc/mono/config + $(mkinstalldirs) $(tmpinst)/bin 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/mcs: $(tmpinst)/bin/mono Makefile + echo '#! /bin/sh' > $@ ; \ + r=`pwd`; m=`cd $(mcs_topdir) && pwd`; \ + echo 'exec "'"$$r/$(tmpinst)/bin/mono"'" "'"$$m/class/lib/build/mcs.exe"'" "$$@"' >> $@ ; \ + chmod +x $@ -$(tmpinst)/bin/gmcs: - $(MAKE) test-support-file target=$@ file=gmcs/gmcs.exe +$(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/build/mcs.exe -sdk:2"'" "$$@"' >> $@ ; \ + chmod +x $@ -$(tmpinst)/bin/ilasm: - $(MAKE) test-support-file target=$@ file=ilasm/ilasm.exe +$(tmpinst)/bin/dmcs: $(tmpinst)/bin/mono Makefile + echo '#! /bin/sh' > $@ ; \ + r=`pwd`; m=`cd $(mcs_topdir) && pwd`; \ + echo 'exec "'"$$r/$(tmpinst)/bin/mono"'" "'"$$m/class/lib/build/mcs.exe -sdk:4"'" "$$@"' >> $@ ; \ + chmod +x $@ -test-support-files: - $(mkinstalldirs) $(tmpinst)/bin - $(MAKE) $(TEST_SUPPORT_FILES) +$(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-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/al2: $(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/al.exe"'" "$$@"' >> $@ ; \ + chmod +x $@ -$(tmpinst)/bin/pedump: $(srcdir)/Makefile.am - $(mkdir_p) $(@D) - (b=`pwd`; echo '#! /bin/sh'; echo 'exec "'"$$b/libtool"'" --mode=execute "'"$$b/mono/metadata/pedump"'" "$$@"') > $@ +$(tmpinst)/bin/al: $(tmpinst)/bin/mono Makefile + echo '#! /bin/sh' > $@ ; \ + r=`pwd`; m=`cd $(mcs_topdir) && pwd`; \ + echo 'exec "'"$$r/$(tmpinst)/bin/mono"'" "'"$$m/class/lib/net_4_0/al.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)