3 SUBDIRS
:= build jay mcs class ilasm tools tests errors docs packages
5 # Resgen is corlib specific tool
7 build_SUBDIRS
:= build jay tools
/gensources class class
/aot-compiler tools
8 monodroid_SUBDIRS
:= build class tools
9 monodroid_tools_SUBDIRS
:= build class tools
10 monotouch_SUBDIRS
:= build class tools
11 monotouch_watch_SUBDIRS
:= build class
12 monotouch_tv_SUBDIRS
:= build class
13 monotouch_runtime_SUBDIRS
:= build class
14 monotouch_watch_runtime_SUBDIRS
:= build class
15 monotouch_tv_runtime_SUBDIRS
:= build class
16 monotouch_tools_SUBDIRS
:= build class tools
17 xammac_SUBDIRS
:= build class
18 testing_aot_full_interp_SUBDIRS
:= build class
19 testing_aot_hybrid_SUBDIRS
:= build class
20 testing_aot_full_SUBDIRS
:= build class
21 binary_reference_assemblies_SUBDIRS
:= build class
22 net_4_x_SUBDIRS
:= build class ilasm tools tests errors docs mcs class
/aot-compiler packages
23 xammac_net_4_5_SUBDIRS
:= build class
24 xbuild_12_SUBDIRS
:= build class tools
/xbuild
25 xbuild_14_SUBDIRS
:= build class tools
/xbuild
26 winaot_SUBDIRS
:= build class
27 testing_winaot_interp_SUBDIRS
:= build class
28 orbis_SUBDIRS
:= build class
29 unreal_SUBDIRS
:= build class
30 wasm_SUBDIRS
:= build class
31 wasm_tools_SUBDIRS
:= build class tools
32 netcore_SUBDIRS
:= build class
34 include build
/rules.make
36 all-recursive
$(STD_TARGETS
:=-recursive
): dir-check platform-check profile-check
38 .PHONY
: all-local
$(STD_TARGETS
:=-local
)
39 all-local
$(STD_TARGETS
:=-local
):
43 @if
[ "$(NO_DIR_CHECK)" = "" ]; then
$(MAKE
) -C ..
/runtime
; fi
45 # fun specialty targets
47 PROFILES
= net_4_x binary_reference_assemblies xbuild_12 xbuild_14
49 .PHONY
: all-profiles compiler-test-profiles run-compiler-test-profiles
$(STD_TARGETS
:=-profiles
)
50 all-profiles compiler-test-profiles run-compiler-test-profiles
$(STD_TARGETS
:=-profiles
): %-profiles
: profiles-do--
%
54 $(if
$(PROFILES
),$(MAKE
) $(PROFILES
:%=profile-do--
%--$*))
56 # The % below looks like profile-name--target-name
58 $(MAKE
) PROFILE
=$(subst --, ,$*)
60 # xbuild_12 and xbuild_14 will try to install the same files, so they need
62 profile-do--xbuild_14--install
: profile-do--xbuild_12--install
64 # We don't want to run the tests in parallel. We want behaviour like -k.
65 profiles-do--run-test
:
66 ret
=:; $(foreach p
,$(PROFILES
), { $(MAKE
) PROFILE
=$(p
) run-test || ret
=false
; }; ) $$ret
68 # Orchestrate the bootstrap here.
69 _boot_
= all clean install
70 $(_boot_
:%=profile-do--xbuild_14--
%): profile-do--xbuild_14--
%: profile-do--net_4_x--
%
71 $(_boot_
:%=profile-do--xbuild_12--
%): profile-do--xbuild_12--
%: profile-do--net_4_x--
%
72 $(_boot_
:%=profile-do--binary_reference_assemblies--
%): profile-do--binary_reference_assemblies--
%: profile-do--build--
%
73 $(_boot_
:%=profile-do--net_4_x--
%): profile-do--net_4_x--
%: profile-do--build--
%
74 $(_boot_
:%=profile-do--monodroid--
%): profile-do--monodroid--
%: profile-do--build--
%
75 $(_boot_
:%=profile-do--monodroid_tools--
%): profile-do--monodroid_tools--
%: profile-do--build--
%
76 $(_boot_
:%=profile-do--monotouch--
%): profile-do--monotouch--
%: profile-do--build--
%
77 $(_boot_
:%=profile-do--monotouch_watch--
%): profile-do--monotouch_watch--
%: profile-do--build--
%
78 $(_boot_
:%=profile-do--monotouch_tv--
%): profile-do--monotouch_tv--
%: profile-do--build--
%
79 $(_boot_
:%=profile-do--monotouch_runtime--
%): profile-do--monotouch_runtime--
%: profile-do--build--
%
80 $(_boot_
:%=profile-do--monotouch_watch_runtime--
%): profile-do--monotouch_watch_runtime--
%: profile-do--build--
%
81 $(_boot_
:%=profile-do--monotouch_tv_runtime--
%): profile-do--monotouch_tv_runtime--
%: profile-do--build--
%
82 $(_boot_
:%=profile-do--monotouch_tools--
%): profile-do--monotouch_tools--
%: profile-do--build--
%
83 $(_boot_
:%=profile-do--xammac--
%): profile-do--xammac--
%: profile-do--build--
%
84 $(_boot_
:%=profile-do--xammac_net_4_5--
%): profile-do--xammac_net_4_5--
%: profile-do--build--
%
85 $(_boot_
:%=profile-do--testing_aot_full_interp--
%): profile-do--testing_aot_full_interp--
%: profile-do--build--
%
86 $(_boot_
:%=profile-do--testing_aot_hybrid--
%): profile-do--testing_aot_hybrid--
%: profile-do--build--
%
87 $(_boot_
:%=profile-do--testing_aot_full--
%): profile-do--testing_aot_full--
%: profile-do--build--
%
88 $(_boot_
:%=profile-do--winaot--
%): profile-do--winaot--
%: profile-do--build--
%
89 $(_boot_
:%=profile-do--testing_winaot_interp--
%): profile-do--testing_winaot_interp--
%: profile-do--build--
%
90 $(_boot_
:%=profile-do--orbis--
%): profile-do--orbis--
%: profile-do--build--
%
91 $(_boot_
:%=profile-do--unreal--
%): profile-do--unreal--
%: profile-do--build--
%
92 $(_boot_
:%=profile-do--wasm--
%): profile-do--wasm--
%: profile-do--build--
%
93 $(_boot_
:%=profile-do--wasm_tools--
%): profile-do--wasm_tools--
%: profile-do--build--
%
97 $(MAKE
) -C errors
test
100 $(MAKE
) -C tests run-test
101 $(MAKE
) -C errors run-test
103 package
:= mcs-
$(VERSION
)
115 dist-local
: dist-default
123 dist-tarball
: dist-pre
124 $(MAKE
) distdir
='$(package)' dist-recursive
125 tar cvjf
$(package
).
tar.bz2
$(package
)
130 # the egrep -v is kind of a hack (to get rid of the makefrags)
131 # but otherwise we have to make dist then make clean which
132 # is sort of not kosher. And it breaks with DIST_ONLY_SUBDIRS.
134 # We need to set prefix on make so class/System/Makefile can find
135 # the installed System.Xml to build properly
137 distcheck
: dist-tarball
138 rm -rf InstallTest Distcheck-MCS
; \
139 mkdir InstallTest
; \
140 destdir
=`cd InstallTest && pwd` ; \
141 mv
$(package
) Distcheck-MCS
; \
142 (cd Distcheck-MCS
&& \
143 $(MAKE
) prefix=$(prefix) && $(MAKE
) test && $(MAKE
) install DESTDIR
="$$destdir" && \
144 $(MAKE
) clean && $(MAKE
) dist || exit
1) || exit
1 ; \
145 mv Distcheck-MCS
$(package
) ; \
146 tar tjf
$(package
)/$(package
).
tar.bz2 |sed
-e
's,/$$,,' |
sort >distdist.list
; \
147 rm $(package
)/$(package
).
tar.bz2
; \
148 tar tjf
$(package
).
tar.bz2 |sed
-e
's,/$$,,' |
sort >before.list
; \
149 find
$(package
) |egrep
-v
'(makefrag|response)' |sed
-e
's,/$$,,' |
sort >after.list
; \
150 cmp before.list after.list || exit
1 ; \
151 cmp before.list distdist.list || exit
1 ; \
152 rm -f before.list after.list distdist.list
; \
153 rm -rf
$(package
) InstallTest
155 # Targets for creating API diffs of the framework
157 MONO_API_SNAPSHOT_PATH
:= $(topdir
)..
/external
/api-snapshot
/
158 GENAPI
:= $(MONO_API_SNAPSHOT_PATH
)tools
/genapi
/Microsoft.DotNet.GenAPI.exe
159 MONO_API_SNAPSHOT_PROFILE_PATH
:= $(MONO_API_SNAPSHOT_PATH
)profiles
/$(PROFILE
)/
160 MONO_API_ASSEMBLIES_IGNORED
:= $(addprefix $(topdir
)class
/lib
/$(PROFILE
)/, Mono.CSharp.dll SystemWebTestShim.dll standalone-runner-support.dll nunitlite.dll Mono.Profiler.Log.dll
)
161 MONO_API_ASSEMBLIES
:= $(filter-out $(MONO_API_ASSEMBLIES_IGNORED
), $(wildcard $(topdir
)class
/lib
/$(PROFILE
)/*.dll
)) $(wildcard $(topdir
)class
/lib
/$(PROFILE
)/Facades
/*.dll
)
162 MONO_API_ASSEMBLIES_CS
:= $(MONO_API_ASSEMBLIES
:$(topdir
)class
/lib
/$(PROFILE
)/%.dll
=$(MONO_API_SNAPSHOT_PROFILE_PATH
)%.cs
)
164 apidiff
/ignored-attr.txt
:
166 @echo
"T:System.Runtime.CompilerServices.CompilerGeneratedAttribute" > $@
168 $(MONO_API_SNAPSHOT_PROFILE_PATH
)%.cs
: $(topdir
)class
/lib
/$(PROFILE
)/%.dll
$(GENAPI
) $(MONO_API_SNAPSHOT_PATH
)profiles
/license-header.txt apidiff
/ignored-attr.txt
170 $(Q
) MONO_PATH
=$(topdir
)class
/lib
/$(BUILD_TOOLS_PROFILE
) $(RUNTIME
) $(GENAPI
) -libPath
:$(topdir
)class
/lib
/$(PROFILE
),$(topdir
)class
/lib
/$(PROFILE
)/Facades
-out
:$(dir $@
) -headerFile
:$(MONO_API_SNAPSHOT_PATH
)profiles
/license-header.txt
-assemblyAttributes
-typeForwardedTo
-assemblyVersion
-excludeAttributesList
:apidiff
/ignored-attr.txt
-assembly
:$< || echo
"Couldn't process assembly." > $@
172 mono-api-current
: $(MONO_API_ASSEMBLIES_CS
)
174 mono-api-current-clean
:
175 $(Q
) find
"$(MONO_API_SNAPSHOT_PROFILE_PATH)" -name
"*.cs" -type f
-delete
178 @echo
"Regenerating API snapshot..."
179 $(Q
) $(MAKE
) mono-api-current-clean PROFILE
=net_4_x
180 $(Q
) $(MAKE
) mono-api-current-clean PROFILE
=monotouch
181 $(Q
) $(MAKE
) mono-api-current-clean PROFILE
=monodroid
182 $(Q
) $(MAKE
) mono-api-current PROFILE
=net_4_x
183 $(Q
) $(MAKE
) mono-api-current PROFILE
=monotouch
184 $(Q
) $(MAKE
) mono-api-current PROFILE
=monodroid
185 @echo
"Checking public API differences..."
186 $(Q
) cd
$(MONO_API_SNAPSHOT_PATH
); git add
-A .
187 $(Q
) cd
$(MONO_API_SNAPSHOT_PATH
); git diff
--no-renames HEAD
> $(abspath
$(topdir
))/temp.patch
189 $(Q
) sed
-e
"/@diffdata@/r temp.patch" -e
"/@diffdata@/d" -e
"s/@title@/Public API Diff/g" -e
"s/@description@/If the changes are intentional, run <code>make -C mcs mono-api-diff<\/code> locally and commit changes in external\/api-snapshot./g" diff.html.in
> apidiff
/index.html
190 $(Q
) if
[ -s temp.patch
]; then echo
"Error: Found public API differences, see mcs/apidiff/index.html. If the changes are intentional, please go to external/api-snapshot and commit them."; rm -f temp.patch
; exit
1; else echo
"No differences found."; rm -f temp.patch
; fi
193 @echo
"Generating csproj diff..."
194 $(Q
) git add
-A
"*.csproj" $(topdir
)..
/bcl.sln
195 $(Q
) git diff
--no-renames HEAD
"*.csproj" $(topdir
)..
/bcl.sln
> $(abspath
$(topdir
))/temp.patch
197 $(Q
) sed
-e
"/@diffdata@/r temp.patch" -e
"/@diffdata@/d" -e
"s/@title@/Project Files Diff/g" -e
"s/@description@/Use <code>@monojenkins commit csproj<\/code> to commit them./g" diff.html.in
> csprojdiff
/index.html
198 $(Q
) if
[ -s temp.patch
]; then echo
"Error: Found csproj differences, see mcs/csprojdiff/index.html. If the changes are intentional, please commit them."; rm -f temp.patch
; exit
1; else echo
"No differences found."; rm -f temp.patch
; fi