Merge pull request #4219 from marek-safar/corert-bump
[mono.git] / mcs / build / profiles / basic.make
index e8b021c289523c1c9187e7f45b41c3ca631ad686..2b822234f612322bb2a8c03290bcf2dcb120d2dd 100644 (file)
@@ -1,13 +1,49 @@
 # -*- makefile -*-
 
-BOOTSTRAP_MCS = $(EXTERNAL_MCS)
-MCS = MONO_PATH="$(topdir)/class/lib/$(PROFILE)$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" $(INTERNAL_MCS)
+with_mono_path_monolite = MONO_PATH="$(topdir)/class/lib/monolite$(PLATFORM_PATH_SEPARATOR)$(topdir)/class/lib/monolite/Facades$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH"
 
-PROFILE_MCS_FLAGS = -d:NET_1_1 -d:ONLY_1_1 -d:BOOTSTRAP_WITH_OLDLIB
+monolite_flag := $(depsdir)/use-monolite
+use_monolite := $(wildcard $(monolite_flag))
+
+MONOLITE_MSCORLIB = $(topdir)/class/lib/monolite/mscorlib.dll
+
+ifdef use_monolite
+ifdef MCS_MODE
+       CSC_LOCATION = $(topdir)/class/lib/monolite/mcs.exe
+endif
+
+PROFILE_RUNTIME = $(with_mono_path_monolite) $(RUNTIME)
+BOOTSTRAP_MCS = $(PROFILE_RUNTIME) $(RUNTIME_FLAGS) $(CSC_LOCATION)
+
+else
+PROFILE_RUNTIME = $(EXTERNAL_RUNTIME)
+ifdef MCS_MODE
+       BOOTSTRAP_MCS = mcs
+else
+       BOOTSTRAP_MCS = $(PROFILE_RUNTIME) $(RUNTIME_FLAGS) $(CSC_LOCATION)
+endif
+endif
+
+MCS = $(BOOTSTRAP_MCS)
+
+DEFAULT_REFERENCES = -r:$(topdir)/class/lib/$(PROFILE)/mscorlib.dll
+
+PROFILE_MCS_FLAGS = -d:NET_4_0 -d:NET_4_5 -d:MONO -d:WIN_PLATFORM -d:BOOTSTRAP_BASIC -nowarn:1699 -nostdlib $(DEFAULT_REFERENCES)
 NO_SIGN_ASSEMBLY = yes
 NO_TEST = yes
 NO_INSTALL = yes
-FRAMEWORK_VERSION = 1.0
+FRAMEWORK_VERSION = 4.0
+
+# Compiler all using same bootstrap compiler
+LIBRARY_COMPILE = $(BOOT_COMPILE)
+
+# Verbose basic only
+# V = 1
+
+#
+# Copy from rules.make because I don't know how to unset MCS_FLAGS
+#
+USE_MCS_FLAGS = /codepage:$(CODEPAGE) /nologo /noconfig $(LOCAL_MCS_FLAGS) $(PLATFORM_MCS_FLAGS) $(PROFILE_MCS_FLAGS)
 
 .PHONY: profile-check do-profile-check
 profile-check:
@@ -15,53 +51,66 @@ profile-check:
 
 ifeq (.,$(thisdir))
 all-recursive: do-profile-check
+all-local: post-profile-cleanup
 clean-local: clean-profile
 endif
 
 clean-profile:
-       -rm -f $(PROFILE_CS) $(PROFILE_EXE) $(PROFILE_OUT)
+       -rm -f $(PROFILE_EXE) $(PROFILE_OUT) $(monolite_flag)
+
+post-profile-cleanup:
+       @rm -f $(monolite_flag)
+
+PROFILE_EXE = $(depsdir)/basic-profile-check.exe
+PROFILE_OUT = $(PROFILE_EXE:.exe=.out)
 
-PROFILE_CS  = $(topdir)/build/deps/basic-profile-check.cs
-PROFILE_EXE = $(PROFILE_CS:.cs=.exe)
-PROFILE_OUT = $(PROFILE_CS:.cs=.out)
+MAKE_Q=$(if $(V),,-s)
 
-do-profile-check:
+do-profile-check: $(depsdir)/.stamp
        @ok=:; \
        rm -f $(PROFILE_EXE) $(PROFILE_OUT); \
-       $(MAKE) -s $(PROFILE_OUT) > /dev/null 2>&1 || ok=false; \
-       rm -f $(PROFILE_EXE) $(PROFILE_OUT); \
-       if $$ok; then :; else \
-           echo "*** The compiler '$(EXTERNAL_MCS)' doesn't appear to be usable." 1>&2 ; \
-           if test -f $(topdir)/class/lib/monolite/mcs.exe; then \
-               monolite_corlib_version=`$(ILDISASM) $(topdir)/class/lib/monolite/mscorlib.dll | sed -n 's,.*mono_corlib_version.*int32.*(\([^)]*\)),\1,p'`; \
-               source_corlib_version=`sed -n 's,.*mono_corlib_version.*=[^0-9]*\([0-9]*\)[^0-9]*$$,\1,p' $(topdir)/class/corlib/System/Environment.cs`; \
-               case $$monolite_corlib_version in \
-               0x* | 0X*) monolite_corlib_version=`echo $$monolite_corlib_version | sed s,^0[xX],,`; \
-                 monolite_corlib_version=`(echo 16; echo i; echo $$monolite_corlib_version; echo p) | dc` ;; esac ; \
-               if test x$$monolite_corlib_version = x$$source_corlib_version; then \
-                   echo "*** Falling back to using pre-compiled binaries.  Be warned, this may not work." 1>&2 ; \
-                   ( cd $(topdir)/jay && $(MAKE) ); \
-                   ( cd $(topdir)/mcs && $(MAKE) PROFILE=basic cs-parser.cs ); \
-                   ( cd $(topdir)/class/lib/monolite/ && cp *.exe *.dll ../basic ); \
-                   case `ls -1t $(topdir)/class/lib/basic/mcs.exe $(topdir)/mcs/cs-parser.cs | sed 1q` in \
-                   $(topdir)/class/lib/basic/mcs.exe) : ;; \
-                   *) sleep 5; cp $(topdir)/class/lib/monolite/mcs.exe $(topdir)/class/lib/basic ;; \
-                   esac; \
-               else \
-                   echo "*** The contents of your 'monolite' directory are out-of-date" 1>&2; \
-                   echo "*** You may want to try 'make get-monolite-latest'" 1>&2; \
-                   echo "*** The source has version $$source_corlib_version, but monolite has version $$monolite_corlib_version" 1>&2; \
-                   exit 1; fi; \
+       if [ -z '$(MAKE_Q)' ] && [ -n '$(PROFILE_RUNTIME)' ]; then $(PROFILE_RUNTIME) --version; fi; \
+       $(MAKE) $(MAKE_Q) $(PROFILE_OUT) || ok=false; \
+       if $$ok; then rm -f $(PROFILE_EXE) $(PROFILE_OUT); else \
+           if test ! -s $(MONOLITE_MSCORLIB); then \
+                       $(MAKE) $(MAKE_Q) do-get-monolite ; \
+               fi; \
+           if test -f $(MONOLITE_MSCORLIB); then \
+               $(MAKE) $(MAKE_Q) do-profile-check-monolite ; \
            else \
-                echo "*** You need a C# compiler installed to build MCS (make sure mcs works from the command line)" 1>&2 ; \
-                echo "*** Read INSTALL.txt for information on how to bootstrap a Mono installation." 1>&2 ; \
+               echo "*** The runtime '$(PROFILE_RUNTIME)' doesn't appear to be usable." 1>&2; \
+                echo "*** You need Mono version 4.8 or better installed to build MCS" 1>&2 ; \
+                echo "*** Check mono README for information on how to bootstrap a Mono installation." 1>&2 ; \
                exit 1; fi; fi
 
-$(PROFILE_CS): $(topdir)/build/profiles/basic.make
-       echo 'class X { static int Main () { return 0; } }' > $@
 
-$(PROFILE_EXE): $(PROFILE_CS)
-       $(EXTERNAL_MCS) /out:$@ $<
+ifdef use_monolite
+
+do-get-monolite:
+
+do-profile-check-monolite:
+       @echo "*** The contents of your 'monolite' directory may be out-of-date" 1>&2
+       @echo "*** You may want to try 'make get-monolite-latest'" 1>&2
+       rm -f $(monolite_flag)
+       exit 1
+
+else
+
+do-get-monolite:
+       @echo "*** Downloading bootstrap required 'monolite'" 1>&2
+       $(MAKE) $(MAKE_Q) -C $(mono_build_root) get-monolite-latest
+
+do-profile-check-monolite: $(depsdir)/.stamp
+       @echo "*** The runtime '$(PROFILE_RUNTIME)' doesn't appear to be usable." 1>&2
+       @echo "*** Trying the 'monolite' directory." 1>&2
+       @echo dummy > $(monolite_flag)
+       $(MAKE) do-profile-check
+
+endif
+
+$(PROFILE_EXE): $(topdir)/build/common/basic-profile-check.cs
+       $(MAKE) $(MAKE_Q) -C $(topdir)/packages
+       $(BOOTSTRAP_MCS) /warn:0 /noconfig /r:System.dll /r:mscorlib.dll /out:$@ $<
 
 $(PROFILE_OUT): $(PROFILE_EXE)
-       $(EXTERNAL_RUNTIME) $< > $@ 2>&1
+       $(PROFILE_RUNTIME) $< > $@ 2>&1