Merge pull request #3499 from kumpera/fix_logging
[mono.git] / Makefile.am
index 6d3780e593115fad2ef84232c0bc2b33e387d6ef..aaffb9842ba9dbe36090cead00afe0d1ebe1232d 100644 (file)
@@ -1,30 +1,38 @@
 ACLOCAL_AMFLAGS = -I m4
 
-MOONLIGHT_SUBDIRS = $(libgc_dir) eglib/src mono
+AM_CFLAGS = $(WERROR_CFLAGS)
 
+MONOTOUCH_SUBDIRS = $(libgc_dir) eglib/src mono
+
+# Some tools might not build when cross-compiling
 if CROSS_COMPILING
-SUBDIRS = po $(libgc_dir) eglib mono $(ikvm_native_dir) data runtime scripts man samples msvc $(docs_dir)
-# Keep in sync with SUBDIRS
-## 'tools' is not normally built
-DIST_SUBDIRS = m4 po libgc eglib mono ikvm-native data runtime scripts man samples tools msvc docs
-else
-if ONLY_MOONLIGHT
-SUBDIRS = $(MOONLIGHT_SUBDIRS) runtime
+tools_dir =
 else
-SUBDIRS = po $(libgc_dir) eglib mono $(ikvm_native_dir) support data runtime scripts man samples msvc $(docs_dir)
-# Keep in sync with SUBDIRS
-## 'tools' is not normally built
-DIST_SUBDIRS = m4 po libgc eglib mono ikvm-native support data runtime scripts man samples tools msvc docs
-endif
+tools_dir = tools
 endif
 
+SUBDIRS = po $(libgc_dir) eglib mono $(ikvm_native_dir) support data runtime scripts man samples $(tools_dir) msvc $(docs_dir) acceptance-tests llvm
+# Keep in sync with SUBDIRS
+DIST_SUBDIRS = m4 po $(libgc_dir) eglib mono ikvm-native support data runtime scripts man samples tools msvc docs acceptance-tests llvm
+
+all: update_submodules
+
+SUBMODULE_ERROR='Could not recursively update all git submodules. You may experience compilation problems if some submodules are out of date'
+update_submodules:
+       @$(srcdir)/scripts/update_submodules
+
+.PHONY: update_submodules
+
 EXTRA_DIST= \
-           LICENSE \
-           autogen.sh \
-           build-mingw32.sh \
-           mkinstalldirs \
-           mono-uninstalled.pc.in \
-           winconfig.h
+       README.md               \
+       LICENSE                 \
+       autogen.sh              \
+       mkinstalldirs           \
+       mono-uninstalled.pc.in  \
+       winconfig.h             \
+       code_of_conduct.md      \
+       external                \
+       mcs/class/referencesource
 
 DISTCHECK_CONFIGURE_FLAGS = EXTERNAL_MCS=false EXTERNAL_RUNTIME=false
 
@@ -33,7 +41,13 @@ GIT_DIR ?= $(srcdir)/.git
 dist-hook:
        test -d $(distdir)/mcs || mkdir $(distdir)/mcs
        d=`cd $(distdir)/mcs && pwd`; cd $(mcs_topdir) && $(MAKE) distdir=$$d dist-recursive
-       test ! -d $(GIT_DIR) || ./scripts/commits-to-changelog.py --root=$(distdir) last-commit-with-compulsory-changelog-entry
+       rm -rf `find $(top_distdir)/external -path '*\.git'`
+       rm -f `find $(top_distdir)/external -path '*\.exe'`
+       rm -f `find $(top_distdir)/external -path '*\.dll' -not -path '*/binary-reference-assemblies/*'`
+       cp mcs/class/lib/basic/System.Configuration.dll mcs/class/lib/monolite/
+       cp mcs/class/lib/basic/System.Security.dll mcs/class/lib/monolite/
+# Disable this for now because it is very slow and causes wrench to timeout:
+#      test ! -d $(GIT_DIR) || ./scripts/commits-to-changelog.py --root=$(distdir) last-commit-with-compulsory-changelog-entry
 
 pkgconfigdir = $(libdir)/pkgconfig
 noinst_DATA = mono-uninstalled.pc
@@ -43,7 +57,7 @@ DISTCLEANFILES= mono-uninstalled.pc
 mcslib = $(mcs_topdir)/class/lib
 monolite = $(mcslib)/monolite
 mono_corlib_version = $(shell sed -n "s/\#define MONO_CORLIB_VERSION //p" $(srcdir)/mono/metadata/appdomain.c)
-monolite_url = http://mono.ximian.com/daily/monolite-$(mono_corlib_version)-latest.tar.gz
+monolite_url = http://download.mono-project.com/monolite/monolite-$(mono_corlib_version)-latest.tar.gz
 .PHONY: get-monolite-latest 
 get-monolite-latest:
        -rm -fr $(mcslib)/monolite-*
@@ -53,6 +67,14 @@ get-monolite-latest:
        cd $(mcslib) && { (wget -O- $(monolite_url) || curl $(monolite_url)) | gzip -d | tar xf - ; }
        cd $(mcslib) && mv -f monolite-* monolite
 
+if BITCODE
+BITCODE_CHECK=yes
+endif
+
+.PHONY: check-ci
+check-ci:
+       MONO_LLVMONLY=$(BITCODE_CHECK) $(srcdir)/scripts/ci/run-test-$(TEST_PROFILE).sh
+
 .PHONY: validate do-build-mono-mcs mcs-do-clean mcs-do-tests
 validate: do-build-mono-mcs
        $(MAKE) mcs-do-tests
@@ -75,28 +97,28 @@ mcs-do-compiler-tests:
 bootstrap-world: compiler-tests
        $(MAKE) install
 
-if MOONLIGHT
-moon-do-build: config.h
-       @list='$(MOONLIGHT_SUBDIRS)'; for subdir in $$list; do \
+if INSTALL_MONOTOUCH
+monotouch-do-build: config.h
+       @list='$(MONOTOUCH_SUBDIRS)'; for subdir in $$list; do \
          case "x$$subdir" in \
-               xmono ) target="moon-do-build";; \
+               xmono ) target="monotouch-do-build";; \
                * ) target="all";; \
          esac; \
          echo "Making $$target in $$subdir"; \
          (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$target); \
         done;
-       (cd runtime && $(MAKE) $(AM_MAKEFLAGS) moon-do-build)
+       (cd runtime && $(MAKE) $(AM_MAKEFLAGS) monotouch-do-build)
 
-moon-do-clean:
-       @list='$(MOONLIGHT_SUBDIRS)'; for subdir in $$list; do \
+monotouch-do-clean:
+       @list='$(MONOTOUCH_SUBDIRS)'; for subdir in $$list; do \
          case "x$$subdir" in \
-               xmono ) target="moon-do-clean";; \
+               xmono ) target="monotouch-do-clean";; \
                * ) target="clean";; \
          esac; \
          echo "Making $$target in $$subdir"; \
          (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$target); \
         done;
-       (cd runtime && $(MAKE) $(AM_MAKEFLAGS) moon-do-clean)
+       (cd runtime && $(MAKE) $(AM_MAKEFLAGS) monotouch-do-clean)
 
 endif
 
@@ -117,12 +139,10 @@ win32getdeps:
 win32setup:
        makensis /DMILESTONE=$(VERSION) /DSOURCE_INSTALL_DIR=$(SOURCE_INSTALL_DIR) /DBUILDNUM=$(BUILDNUM) monowiz.win32.nsi
 
-patch-quiet:
-       find mono -name Makefile -exec scripts/patch-quiet.sh {} \;
-       find libgc -name Makefile -exec scripts/patch-quiet.sh {} \;
-
 update-csproj:
        -rm msvc/scripts/order 
+       -rm msvc/scripts/order.xml
+       -rm -rf msvc/scripts/inputs
        -mkdir msvc/scripts/inputs
        (cd runtime; make V=1 extra_targets=csproj-local)
 
@@ -131,16 +151,28 @@ package-inputs:
        echo '<root>' >> msvc/scripts/order.xml
        for i in `cat msvc/scripts/order`; do \
                set `echo $$i | sed -e 's/:/ /' -e 's/.input//'`; \
-               cat msvc/scripts/inputs/$$2.input | \
+               cat msvc/scripts/inputs/$$2.input | sed -e 's/\\\\/\\/g' -e 's/\\/\\\\/g' | \
                (echo "    <project dir=\"$$1\" library=\"$$2\">"; \
                 read boot;   echo "      <boot>$$boot</boot>"; \
-                read mcs;    echo "      <mcs>$$mcs</mcs>"; \
                 read flags;  echo "      <flags>$$flags</flags>"; \
                 read output; echo "      <output>$$output</output>"; \
-                read built;  echo "      <built_sources>$$built</built_sources>"; \
+                read built;  echo "      <built_sources>`echo $$built | sed 's/\\\/\\\\/g'`</built_sources>"; \
                 read libou;  echo "      <library_output>$$libou</library_output>"; \
                 read fx_ver; echo "      <fx_version>$$fx_ver</fx_version>"; \
+                read profile; echo "      <profile>$$profile</profile>"; \
+                read resxt;  echo "      <resources>$$resxt</resources>"; \
                 read resp;   echo "      <response>$$resp</response>"; \
-               echo "    </project>") >> msvc/scripts/order.xml; \
+                echo "    </project>") >> msvc/scripts/order.xml; \
        done
        echo "</root>" >> msvc/scripts/order.xml
+
+# Update llvm version in configure.ac to the output of $LLVM_DIR/bin/llvm-config --version
+update-llvm-version:
+       if test "x$$LLVM_DIR" = "x"; then echo "Set the make variable LLVM_DIR to the directory containing the LLVM installation."; exit 1; fi
+       REV=`$(LLVM_DIR)/bin/llvm-config --version` && sed -e "s,expected_llvm_version=.*,expected_llvm_version=\"$$REV\"," < configure.ac > tmp && mv tmp configure.ac && echo "Version set to $$REV."
+
+
+update-solution-files:
+       make update-csproj
+       make package-inputs
+       (cd msvc/scripts; make genproj.exe; mono genproj.exe)