Merge pull request #1659 from alexanderkyte/stringbuilder-referencesource
[mono.git] / mcs / class / corlib / Makefile
1 thisdir = class/corlib
2 SUBDIRS =
3 include ../../build/rules.make
4 export __SECURITY_BOOTSTRAP_DB=$(topdir)/class/corlib
5
6 LIBRARY = corlib.dll
7 LIBRARY_NAME = mscorlib.dll
8
9 REFERENCE_SOURCES_FLAGS = -d:FEATURE_PAL,PFX_LEGACY_3_5 -d:MONO -d:MONO_HYBRID_ENCODING_SUPPORT,PLATFORM_UNIX
10 LIB_MCS_FLAGS = $(REFERENCE_SOURCES_FLAGS) $(RESOURCE_FILES:%=-resource:%)
11
12 #LIBRARY_USE_INTERMEDIATE_FILE = yes
13
14 ifeq (2, $(FRAMEWORK_VERSION_MAJOR))
15 LIB_MCS_FLAGS += --runtime:v2
16 else
17 ifeq (4, $(FRAMEWORK_VERSION_MAJOR))
18 LIB_MCS_FLAGS += --runtime:v4
19 else
20 $(error Unknown framework version)
21 endif
22 endif
23
24 RESOURCE_STRINGS = ../../../external/referencesource/mscorlib/mscorlib.txt
25
26 LIBRARY_COMPILE = $(BOOT_COMPILE)
27 LIBRARY_INSTALL_DIR = $(mono_libdir)/mono/$(FRAMEWORK_VERSION)
28
29 RESOURCE_FILES = \
30         resources/charinfo.nlp \
31         resources/collation.core.bin \
32         resources/collation.tailoring.bin \
33         resources/collation.cjkCHS.bin \
34         resources/collation.cjkCHT.bin \
35         resources/collation.cjkJA.bin \
36         resources/collation.cjkKO.bin \
37         resources/collation.cjkKOlv2.bin
38
39 REFERENCE_SOURCES_FLAGS = -d:FEATURE_PAL,GENERICS_WORK,FEATURE_LIST_PREDICATES,FEATURE_SERIALIZATION,FEATURE_ASCII,FEATURE_LATIN1,FEATURE_UTF7,FEATURE_UTF32,MONO_HYBRID_ENCODING_SUPPORT,FEATURE_ASYNC_IO,NEW_EXPERIMENTAL_ASYNC_IO,FEATURE_UTF32,FEATURE_EXCEPTIONDISPATCHINFO,FEATURE_CORRUPTING_EXCEPTIONS,FEATURE_EXCEPTION_NOTIFICATIONS
40
41 MOBILE_STATIC := $(filter mobile_static monotouch monotouch_runtime, $(PROFILE))
42
43 ifndef MOBILE_STATIC
44 REFERENCE_SOURCES_FLAGS += -d:FEATURE_REMOTING,MONO_COM,FEATURE_STRONGNAME_MIGRATION,FEATURE_USE_LCID
45 endif
46
47 LOCAL_MCS_FLAGS = -unsafe -nostdlib -nowarn:612,618 -d:INSIDE_CORLIB,MONO_CULTURE_DATA -d:LIBC $(REFERENCE_SOURCES_FLAGS)
48 DEFAULT_REFERENCES =
49
50 # System.IO/DirectoryInfoTest.cs needs Mono.Posix
51 TEST_MCS_FLAGS = -debug -nowarn:168,219,618,672 -unsafe -r:Mono.Posix.dll -r:System.Core.dll \
52                                  -define:MONO_DATACONVERTER_STATIC_METHODS $(TEST_RESX_RESOURCES:%=-resource:%)
53
54 EXTRA_DISTFILES = \
55         Test/resources/MyResources.resources    \
56         Test/resources/MyResources.de.resources \
57         Test/resources/Empty.resources          \
58         Test/resources/AFile.txt                \
59         Test/resources/StreamTest.resources     \
60         Test/resources/StreamTest.ja.resources  \
61         Test/resources/bug81759.resources       \
62         Test/resources/415628.bin               \
63         Test/resources/Fergie.GED               \
64         Test/resources/culture-*.cs             \
65         $(RESOURCE_FILES) \
66         $(TEST_RESOURCES:.resources=.resx)
67
68 TEST_RESX_RESOURCES = \
69         Test/resources/Resources.resources
70
71 TEST_RESX_RESOURCES_SATELITE = \
72         Test/resources/Resources.es-ES.resources \
73         Test/resources/Resources.nn-NO.resources \
74
75 CLEAN_FILES += $(TEST_RESX_RESOURCES)
76
77 include $(topdir)/build/library.make
78
79 ifdef FIXME_CORLIB_CMP
80 # corlib_cmp
81 corlib_flags = -unsafe -nostdlib
82 cmplib = $(topdir)/class/lib/$(PROFILE)/corlib_cmp.dll
83 cmppdb = $(cmplib:.dll=.pdb)
84 cmp_response = $(depsdir)/$(PROFILE)_corlib_cmp.dll.response
85 cmp_makefrag = $(depsdir)/$(PROFILE)_corlib_cmp.dll.makefrag
86 cmp_flags = -r:$(PLATFORM_CORLIB) $(corlib_flags)
87
88 EXTRA_DISTFILES += corlib_cmp.dll.excludes
89 CLEAN_FILES += $(cmplib) $(cmp_response) $(cmp_makefrag) $(cmppdb)
90
91 $(cmplib): $(cmp_makefrag) $(cmp_response)
92         $(BOOT_COMPILE) $(LIBRARY_FLAGS) $(cmp_flags) -target:library -out:$@ @$(cmp_response)
93
94 $(cmp_response): $(sourcefile) corlib_cmp.dll.excludes
95         @echo Creating $@ ...
96         @sort $(sourcefile) corlib_cmp.dll.excludes | uniq -u | $(PLATFORM_CHANGE_SEPARATOR_CMD) >$@
97
98 $(cmp_makefrag): $(cmp_response)
99         @echo Creating $@ ...
100         @sed 's,^,$(cmplib): ,' $< >$@
101
102 # Since we make corlib_cmp on demand, there isn't a real need
103 # to have full dep tracking for it. Also, the generation of this
104 # file is busted on Win32 ('sort' seems to mess up line endings),
105 # leading to a broken build.
106 #
107 # -include $(cmp_makefrag)
108
109 $(cmp_response) $(cmp_makefrag): Makefile $(depsdir)/.stamp
110 endif
111
112 $(TEST_RESX_RESOURCES) $(TEST_RESX_RESOURCES_SATELITE): %.resources: %.resx
113         $(RESGEN) $< || cp $@.prebuilt $@
114
115 TEST_RESOURCES = $(TEST_RESX_RESOURCES) $(TEST_RESX_RESOURCES_SATELITE)
116
117 satellite_assembly1 = es-ES/$(patsubst %.dll,%.resources.dll,$(test_lib))
118 satellite_assembly2 = nn-NO/$(patsubst %.dll,%.resources.dll,$(test_lib))
119
120 $(test_lib): $(TEST_RESOURCES) $(satellite_assembly1) $(satellite_assembly2) 
121
122 $(satellite_assembly1): Test/resources/culture-es-ES.cs Test/resources/Resources.es-ES.resources
123         @mkdir -p es-ES
124         $(CSCOMPILE) -target:library -r:$(corlib) Test/resources/culture-es-ES.cs -resource:Test/resources/Resources.es-ES.resources -out:$@
125
126 $(satellite_assembly2): Test/resources/culture-nn-NO.cs Test/resources/Resources.nn-NO.resources
127         @mkdir -p nn-NO
128         $(CSCOMPILE) -target:library -r:$(corlib) Test/resources/culture-nn-NO.cs -resource:Test/resources/Resources.nn-NO.resources -out:$@
129
130 vtsdir = Test/System.Runtime.Serialization.Formatters.Binary/VersionTolerantSerialization
131 vtslibs = \
132         $(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll \
133         $(vtsdir)/$(PROFILE)_TestLib/2.0/Address.dll \
134         $(vtsdir)/$(PROFILE)_TestLib/3.0/Address.dll \
135         $(vtsdir)/$(PROFILE)_TestLib/4.0/Address.dll \
136         $(vtsdir)/$(PROFILE)_TestLib/5.0/Address.dll \
137         $(vtsdir)/$(PROFILE)_TestLib/6.0/Address.dll
138
139 test-vts: $(vtslibs) $(vtsdir)/$(PROFILE)_TestLib/BinarySerializationOverVersions.exe
140
141 $(vtsdir)/$(PROFILE)_TestLib/%/Address.dll: $(vtsdir)/VersionTolerantSerializationTestLib/%/Address.cs
142         @mkdir -p $(dir $@)
143         $(CSCOMPILE) -target:library -r:$(corlib) -warn:0 -out:$@ $^
144
145 $(vtsdir)/$(PROFILE)_TestLib/BinarySerializationOverVersions.exe: $(vtsdir)/BinarySerializationOverVersions.cs $(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll $(test_nunit_dep)
146         $(CSCOMPILE) $(test_nunit_ref) -warn:0 -r:$(corlib) \
147                 -r:$(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll \
148                 $(vtsdir)/BinarySerializationOverVersions.cs -out:$@
149         @cp $(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll $(vtsdir)/$(PROFILE)_TestLib
150
151 # Need to define TEST_MONO_PATH to an absolute dir since the test is ran from a subdir
152 TEST_MONO_PATH=$(PWD)/../lib/$(PROFILE)
153
154 run-test-vts: test-vts
155         @echo Running vts tests...
156         PATH="$(TEST_RUNTIME_WRAPPERS_PATH):$(PATH)" $(TEST_RUNTIME) $(RUNTIME_FLAGS) $(TEST_HARNESS) -noshadow \
157                 $(vtsdir)/$(PROFILE)_TestLib/BinarySerializationOverVersions.exe
158 ifndef NO_TEST
159 test: test-vts
160 run-test: run-test-vts
161 endif
162
163 EXTRA_DISTFILES += \
164         $(vtsdir)/VersionTolerantSerializationTestLib/1.0/Address.cs \
165         $(vtsdir)/VersionTolerantSerializationTestLib/2.0/Address.cs \
166         $(vtsdir)/VersionTolerantSerializationTestLib/3.0/Address.cs \
167         $(vtsdir)/VersionTolerantSerializationTestLib/4.0/Address.cs \
168         $(vtsdir)/VersionTolerantSerializationTestLib/5.0/Address.cs \
169         $(vtsdir)/VersionTolerantSerializationTestLib/6.0/Address.cs \
170         $(vtsdir)/BinarySerializationOverVersions.cs
171
172 #
173 # Android TimeZoneInfo testing....
174 #
175
176 tzi.exe: System/AndroidPlatform.cs $(wildcard System/TimeZone*.cs) ../../build/common/Consts.cs ../../build/common/Locale.cs ../Mono.Options/Mono.Options/Options.cs ReferenceSources/TimeZoneInfoOptions.cs
177         mcs /debug+ /out:$@ /unsafe "/d:INSIDE_CORLIB;MONODROID;MOBILE;NET_4_5;NET_4_0;LIBC;SELF_TEST" $^
178
179 android-pull-tzdb:
180         mkdir -p android/tzdb/usr/share/zoneinfo
181         mkdir -p android/tzdb/misc/zoneinfo/zoneinfo
182         android_root=`adb shell echo '$$ANDROID_ROOT' | tr -d "\r"` ; \
183         android_data=`adb shell echo '$$ANDROID_DATA' | tr -d "\r"` ; \
184         adb $(ADB_TARGET) pull $$android_root/usr/share/zoneinfo    android/tzdb/usr/share/zoneinfo ; \
185         adb $(ADB_TARGET) pull $$android_data/misc/zoneinfo/tzdata  android/tzdb/misc/zoneinfo
186
187 android-dump-tzdata: tzi.exe android-pull-tzdb
188         __XA_OVERRIDE_TIMEZONE_ID__=America/New_York ANDROID_ROOT="`pwd`/android/tzdb" ANDROID_DATA="`pwd`/android/tzdb" mono --debug tzi.exe -o android/tzdata