with_mono_path = MONO_PATH="$(topdir)/class/lib/$(PROFILE)$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH"
with_mono_path_monolite = MONO_PATH="$(topdir)/class/lib/monolite$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH"
+monolite_flag := $(depsdir)/use-monolite
+use_monolite := $(wildcard $(monolite_flag))
+
+ifdef use_monolite
+PROFILE_RUNTIME = $(with_mono_path_monolite) $(RUNTIME)
+BOOTSTRAP_MCS = $(PROFILE_RUNTIME) $(RUNTIME_FLAGS) $(topdir)/class/lib/monolite/gmcs.exe
+else
+PROFILE_RUNTIME = $(EXTERNAL_RUNTIME)
BOOTSTRAP_MCS = $(EXTERNAL_MCS)
-MCS = $(with_mono_path) $(INTERNAL_MCS)
+endif
+
+MCS = $(with_mono_path) $(INTERNAL_GMCS)
-PROFILE_MCS_FLAGS = -d:NET_1_1 -d:ONLY_1_1 -d:BOOTSTRAP_WITH_OLDLIB
+PROFILE_MCS_FLAGS = -d:NET_1_1 -d:NET_2_0 -d:BOOTSTRAP_BASIC
NO_SIGN_ASSEMBLY = yes
NO_TEST = yes
NO_INSTALL = yes
-FRAMEWORK_VERSION = 1.0
+FRAMEWORK_VERSION = 2.0
+
+# Verbose basic only
+# V = 1
+
+#
+# Copy from rules.make because I don't know how to unset MCS_FLAGS
+#
+USE_MCS_FLAGS = /codepage:$(CODEPAGE) $(LOCAL_MCS_FLAGS) $(PLATFORM_MCS_FLAGS) $(PROFILE_MCS_FLAGS)
.PHONY: profile-check do-profile-check
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_CS = $(topdir)/build/deps/basic-profile-check.cs
-PROFILE_EXE = $(PROFILE_CS:.cs=.exe)
-PROFILE_OUT = $(PROFILE_CS:.cs=.out)
+PROFILE_EXE = $(depsdir)/basic-profile-check.exe
+PROFILE_OUT = $(PROFILE_EXE:.exe=.out)
-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; \
+ $(MAKE) -s $(PROFILE_OUT) > /dev/null || 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=`$(with_mono_path_monolite) $(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 test -f $(topdir)/class/lib/monolite/gmcs.exe; then \
+ $(MAKE) -s 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 "*** The compiler '$(BOOTSTRAP_MCS)' doesn't appear to be usable." 1>&2; \
+ echo "*** You need a C# compiler version 2.0 or better installed to build MCS" 1>&2 ; \
echo "*** Read INSTALL.txt 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-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-profile-check-monolite: $(depsdir)/.stamp
+ echo "*** The compiler '$(BOOTSTRAP_MCS)' 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
+ $(BOOTSTRAP_MCS) /warn:0 /out:$@ $<
+ echo -n "Bootstrap compiler: " 1>&2
+ $(BOOTSTRAP_MCS) --version 1>&2
$(PROFILE_OUT): $(PROFILE_EXE)
- $(EXTERNAL_RUNTIME) $< > $@ 2>&1
+ $(PROFILE_RUNTIME) $< > $@ 2>&1