X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mcs%2Fclass%2FMakefile;h=7d9329e02da24d8cb2f7b74cfb52d703547b4933;hb=b2a11ac756f940c30b05aa0a8baf733572df4ce5;hp=fa9e99d722dfc86189a2cfa2bda0c2a669044e98;hpb=d899b02874a476290f6e8cd54d40e0eaba2ecf04;p=mono.git diff --git a/mcs/class/Makefile b/mcs/class/Makefile index fa9e99d722d..7d9329e02da 100644 --- a/mcs/class/Makefile +++ b/mcs/class/Makefile @@ -18,15 +18,10 @@ basic_SUBDIRS := \ System.ComponentModel.Composition.4.5 \ System.Numerics \ System.Xml.Linq \ - System.Runtime.InteropServices.RuntimeInformation \ Mono.Cecil \ $(MCS_MODE_dirs) \ ../tools/cil-stringreplacer -# resgen is corlib specific so we need to wait until corlib is build -# and build it just a step before first dll needs it -resgen_dir = ../tools/resgen - build_SUBDIRS := \ corlib \ Mono.Security \ @@ -37,8 +32,8 @@ build_SUBDIRS := \ System.ComponentModel.Composition.4.5 \ System.Numerics \ System.Xml.Linq \ - System.Runtime.InteropServices.RuntimeInformation \ System.IO.Compression \ + System.Drawing \ Mono.Cecil \ $(MCS_MODE_dirs) \ Mono.CompilerServices.SymbolWriter \ @@ -86,9 +81,6 @@ mobile_common_dirs := \ System.Xml.Serialization \ Mono.CSharp \ Microsoft.CSharp \ - System.Runtime.InteropServices.RuntimeInformation \ - System.Reflection.DispatchProxy \ - System.Xml.XPath.XmlDocument \ System.Reflection.Context \ System.Net.Http.WinHttpHandler @@ -111,10 +103,18 @@ monodroid_dirs := \ $(mobile_common_dirs) \ Mono.CompilerServices.SymbolWriter \ Mono.Btls.Interface \ + Mono.Posix \ $(pcl_facade_dirs) +monodroid_tools_dirs := \ + Mono.Cecil \ + ICSharpCode.SharpZipLib \ + monodoc + monotouch_dirs := \ - $(testing_aot_full_dirs) + $(mobile_common_dirs) \ + Mono.Simd \ + $(pcl_facade_dirs) monotouch_watch_dirs := $(filter-out Mono.Security Mono.Data.Tds,$(monotouch_dirs)) monotouch_tv_dirs := $(monotouch_dirs) @@ -130,7 +130,15 @@ monotouch_runtime_dirs := \ monotouch_watch_runtime_dirs := $(filter-out Mono.Security Mono.Data.Tds,$(monotouch_runtime_dirs)) monotouch_tv_runtime_dirs := $(monotouch_runtime_dirs) -winaot_dirs := $(monotouch_dirs) System.Drawing +winaot_dirs := \ + $(mobile_common_dirs) \ + System.Drawing \ + $(pcl_facade_dirs) + +unreal_dirs := \ + $(mobile_common_dirs) \ + System.Drawing \ + $(pcl_facade_dirs) xammac_4_5_dirs := \ corlib \ @@ -176,7 +184,6 @@ xammac_4_5_dirs := \ System.Data.Linq \ System.Net.Http \ System.Net.Http.WebRequest \ - System.Runtime.InteropServices.RuntimeInformation \ System.Reflection.Context \ System.Net.Http.WinHttpHandler \ $(pcl_facade_dirs) @@ -191,10 +198,9 @@ net_4_x_dirs := \ System.Core \ System.Security \ System.Configuration \ - $(resgen_dir) \ + System.Drawing \ System.IO.Compression \ System.IO.Compression.FileSystem \ - System.Drawing \ System.Transactions \ System.EnterpriseServices \ Mono.Data.Tds \ @@ -263,8 +269,7 @@ net_4_x_dirs := \ System.Net.Http.Formatting \ System.Web.Http \ System.Web.Http.SelfHost \ - System.Web.Http.WebHost \ - System.Runtime.InteropServices.RuntimeInformation + System.Web.Http.WebHost # These are the subdirs which depends on libs in net_4_x_dirs # or have proper dependencies between each other @@ -320,6 +325,7 @@ net_4_x_parallel_dirs := \ System.Workflow.ComponentModel \ System.Workflow.Runtime \ System.Reflection.Context \ + Mono.Profiler.Log \ legacy/Mono.Cecil \ $(pcl_facade_dirs) @@ -334,7 +340,13 @@ xbuild_4_0_dirs := \ $(xbuild_2_0_dirs) \ Microsoft.Build +orbis_dirs := \ + $(filter-out Microsoft.CSharp Mono.CSharp Mono.Data.Sqlite,$(mobile_common_dirs)) \ + System.Drawing \ + $(pcl_facade_dirs) + monodroid_SUBDIRS := $(monodroid_dirs) +monodroid_tools_SUBDIRS := $(monodroid_tools_dirs) monotouch_SUBDIRS := $(monotouch_dirs) monotouch_watch_SUBDIRS := $(monotouch_watch_dirs) monotouch_tv_SUBDIRS := $(monotouch_tv_dirs) @@ -351,11 +363,12 @@ net_4_x_PARALLEL_SUBDIRS := $(net_4_x_parallel_dirs) xbuild_12_SUBDIRS := $(xbuild_4_0_dirs) xbuild_14_SUBDIRS := $(xbuild_4_0_dirs) Microsoft.NuGet.Build.Tasks winaot_SUBDIRS := $(winaot_dirs) -orbis_SUBDIRS := $(monotouch_dirs) +orbis_SUBDIRS := $(orbis_dirs) +unreal_SUBDIRS := $(unreal_dirs) include ../build/rules.make -SUBDIRS = $(testing_aot_full_dirs) $(testing_aot_hybrid_dirs) $(monotouch_dirs) $(monodroid_dirs) $(xammac_dirs) $(net_4_x_dirs) $(net_4_x_parallel_dirs) $(xammac_net_4_5_SUBDIRS) +SUBDIRS = $(testing_aot_full_dirs) $(testing_aot_hybrid_dirs) $(monotouch_dirs) $(monodroid_dirs) $(monodroid_tools_dirs) $(xammac_dirs) $(net_4_x_dirs) $(net_4_x_parallel_dirs) $(xammac_net_4_5_SUBDIRS) $(unreal_dirs) DIST_ONLY_SUBDIRS = dlr aot-compiler reference-assemblies $(xbuild_4_0_dirs) Microsoft.NuGet.Build.Tasks @@ -381,8 +394,7 @@ DISTFILES = \ MicrosoftAjaxLibrary/License.htm \ test-helpers/NetworkHelpers.cs \ test-helpers/SocketResponder.cs \ - lib/$(monolite_dir)/mcs.exe \ - $(monolite_files) + $(foreach HOST_PLATFORM,darwin linux win32,lib/$(monolite_dir)/mcs.exe $(monolite_files)) .PHONY: all-local $(STD_TARGETS:=-local) all-local $(STD_TARGETS:=-local): @@ -390,11 +402,11 @@ all-local $(STD_TARGETS:=-local): all-local-aot: -monolite_dir := monolite +monolite_dir = monolite-$(HOST_PLATFORM)/$(MONO_CORLIB_VERSION) # Files needed to bootstrap C# compiler build_files = mscorlib.dll System.dll System.Xml.dll Mono.Security.dll System.Core.dll System.Security.dll System.Configuration.dll \ - System.Numerics.dll System.Xml.Linq.dll System.Runtime.InteropServices.RuntimeInformation.dll \ + System.Numerics.dll System.Xml.Linq.dll \ Facades/System.Collections.Concurrent.dll Facades/System.Linq.dll Facades/System.Runtime.dll Facades/System.Collections.dll \ Facades/System.Reflection.Extensions.dll Facades/System.Text.Encoding.Extensions.dll Facades/System.Diagnostics.Debug.dll \ Facades/System.Reflection.Primitives.dll Facades/System.Text.Encoding.dll Facades/System.Diagnostics.Tools.dll Facades/System.Reflection.dll \ @@ -413,19 +425,42 @@ lib/$(monolite_dir)/Facades: $(monolite_files): | lib/$(monolite_dir) $(monolite_files): | lib/$(monolite_dir)/Facades -$(monolite_files): lib/$(monolite_dir)/%: lib/build/% +$(monolite_files): lib/$(monolite_dir)/%: lib/build-$(HOST_PLATFORM)/% cp -p $< $@ lib/$(monolite_dir)/mcs.exe: $(MAKE) -C ../mcs PROFILE=build - cp -p lib/build/mcs.exe lib/$(monolite_dir) + cp -p lib/build-$(HOST_PLATFORM)/mcs.exe lib/$(monolite_dir) -$(build_files:%=lib/build/%): +$(build_files:%=lib/build-$(HOST_PLATFORM)/%): cd $(topdir) && $(MAKE) profile-do--build--all NO_DIR_CHECK=1 SKIP_AOT=1 dist-monolite: $(monolite_files) lib/$(monolite_dir)/mcs.exe -dist-default: dist-monolite +dist-monolite-all-platforms: + $(MAKE) dist-monolite HOST_PLATFORM=darwin + $(MAKE) dist-monolite HOST_PLATFORM=linux + $(MAKE) dist-monolite HOST_PLATFORM=win32 + +package-monolite-latest: + MONOLITE=monolite-$(HOST_PLATFORM)-$(MONO_CORLIB_VERSION)-latest; \ + $(MAKE) dist-monolite monolite_dir=$$MONOLITE; \ + tar zcvpf $$MONOLITE.tar.gz --directory=lib $$MONOLITE/ + +package-monolite-latest-all-platforms: + $(MAKE) package-monolite-latest HOST_PLATFORM=darwin + $(MAKE) package-monolite-latest HOST_PLATFORM=linux + $(MAKE) package-monolite-latest HOST_PLATFORM=win32 + +monolite_url = https://download.mono-project.com/monolite/monolite-$(BUILD_PLATFORM)-$(MONO_CORLIB_VERSION)-latest.tar.gz + +get-monolite-latest: + -rm -fr lib/monolite-$(BUILD_PLATFORM)/$(MONO_CORLIB_VERSION) + -mkdir -p lib/monolite-$(BUILD_PLATFORM) + cd lib && { (wget -O- $(monolite_url) || curl -L $(monolite_url)) | gzip -d | tar xf - ; } + cd lib && mv -f monolite-$(BUILD_PLATFORM)-$(MONO_CORLIB_VERSION)-latest monolite-$(BUILD_PLATFORM)/$(MONO_CORLIB_VERSION) + +dist-default: dist-monolite-all-platforms dist-local: dist-default