[mobile_static] Skip verifying ilasm.exe on mobile_static
authorAlexander Kyte <alexmkyte@fastmail.com>
Mon, 6 Jun 2016 14:52:19 +0000 (10:52 -0400)
committerAlexander Kyte <alexmkyte@gmail.com>
Mon, 18 Jul 2016 19:03:43 +0000 (15:03 -0400)
ILASM.exe has features which a mobile_static runtime will not support.
It is invoked with an external mono when used in the runtime.
We skip it here because otherwise it will fail to verify.

runtime/Makefile.am

index 223b73852dcbf3762ccd27934beb22ddf5e87687..068bb1d3dc0269bc87633813b76bae786ca0ac63 100644 (file)
@@ -109,10 +109,20 @@ cur_dir_cmd = pwd
 PLATFORM_PATH_SEPARATOR = :
 endif
 
+if INSTALL_MOBILE_STATIC
+#  ILASM.exe has features which a mobile_static runtime will not support.
+#  It is invoked with an external mono when used in the runtime.
+#  We skip it here because otherwise it will fail to verify.
+MOBILE_STATIC_FILTER=grep -v ilasm
+else
+MOBILE_STATIC_FILTER=echo
+endif
+
 # 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 binary_reference_assemblies because they contain metadata only
 mcs-compileall: mono-wrapper etc/mono/config
+       export verifiable_files=`ls "$(mcs_topdir)/class/lib/$$profile/" | grep -E '\.(dll|exe)$$' | $(MOBILE_STATIC_FILTER)` ; \
        save_MONO_PATH=$$MONO_PATH; mcs_topdir=`cd $(mcs_topdir) && $(cur_dir_cmd)`; ok=:; \
        for profile in $(test_profiles); do \
          if [ "binary_reference_assemblies" = "$$profile" ]; then \
@@ -126,7 +136,9 @@ mcs-compileall: mono-wrapper etc/mono/config
                  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 \
+         for stub in $$verifiable_files; do \
+         i=$(mcs_topdir)/class/lib/$$profile/$$stub ; \
+         echo $$i ; \
                if [ ! -f $$i ] ; then \
                        continue ; \
                fi ;  \