[bcl] Add API diff targets (#4406)
[mono.git] / mcs / Makefile
1 thisdir := .
2
3 SUBDIRS := build jay mcs class nunit24 ilasm tools tests errors docs packages
4
5 # Resgen is corlib specific tool
6
7 basic_SUBDIRS := build jay class
8 build_SUBDIRS := build class class/aot-compiler tools ilasm
9 monodroid_SUBDIRS := build class
10 monotouch_SUBDIRS := build class
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 xammac_SUBDIRS := build class
17 testing_aot_hybrid_SUBDIRS := build class
18 testing_aot_full_SUBDIRS := build class
19 binary_reference_assemblies_SUBDIRS := build class
20 net_4_x_SUBDIRS := build class nunit24 ilasm tools tests errors docs mcs class/aot-compiler packages
21 xammac_net_4_5_SUBDIRS := build class
22 xbuild_12_SUBDIRS := build class tools/xbuild
23 xbuild_14_SUBDIRS := build class tools/xbuild
24 winaot_SUBDIRS := build class
25 orbis_SUBDIRS := build class
26
27 include build/rules.make
28
29 all-recursive $(STD_TARGETS:=-recursive): dir-check platform-check profile-check
30
31 .PHONY: all-local $(STD_TARGETS:=-local)
32 all-local $(STD_TARGETS:=-local):
33         @:
34
35 dir-check:
36         @if [ "$(NO_DIR_CHECK)" = "" -a "$(PROFILE)" != "basic" ]; then $(MAKE) -C ../runtime; fi
37
38 # fun specialty targets
39
40 PROFILES = net_4_x binary_reference_assemblies xbuild_12 xbuild_14
41
42 .PHONY: all-profiles $(STD_TARGETS:=-profiles)
43 all-profiles $(STD_TARGETS:=-profiles): %-profiles: profiles-do--%
44         @:
45
46 profiles-do--%:
47         $(MAKE) $(PROFILES:%=profile-do--%--$*)
48
49 # The % below looks like profile-name--target-name
50 profile-do--%:
51         $(MAKE) PROFILE=$(subst --, ,$*)
52
53 # xbuild_12 and xbuild_14 will try to install the same files, so they need
54 # to be ordered
55 profile-do--xbuild_14--install: profile-do--xbuild_12--install
56
57 # We don't want to run the tests in parallel.  We want behaviour like -k.
58 profiles-do--run-test:
59         ret=:; $(foreach p,$(PROFILES), { $(MAKE) PROFILE=$(p) run-test || ret=false; }; ) $$ret
60
61 # Orchestrate the bootstrap here.
62 _boot_ = all clean install
63 $(_boot_:%=profile-do--xbuild_14--%):         profile-do--xbuild_14--%:         profile-do--net_4_x--%
64 $(_boot_:%=profile-do--xbuild_12--%):         profile-do--xbuild_12--%:         profile-do--net_4_x--%
65 $(_boot_:%=profile-do--binary_reference_assemblies--%):           profile-do--binary_reference_assemblies--%:           profile-do--build--%
66 $(_boot_:%=profile-do--net_4_x--%):           profile-do--net_4_x--%:           profile-do--build--%
67 $(_boot_:%=profile-do--monodroid--%):         profile-do--monodroid--%:         profile-do--build--%
68 $(_boot_:%=profile-do--monotouch--%):         profile-do--monotouch--%:         profile-do--build--%
69 $(_boot_:%=profile-do--monotouch_watch--%):   profile-do--monotouch_watch--%:   profile-do--build--%
70 $(_boot_:%=profile-do--monotouch_tv--%):      profile-do--monotouch_tv--%:      profile-do--build--%
71 $(_boot_:%=profile-do--monotouch_runtime--%):  profile-do--monotouch_runtime--%:  profile-do--build--%
72 $(_boot_:%=profile-do--monotouch_watch_runtime--%):  profile-do--monotouch_watch_runtime--%:  profile-do--build--%
73 $(_boot_:%=profile-do--monotouch_tv_runtime--%):     profile-do--monotouch_tv_runtime--%:     profile-do--build--%
74 $(_boot_:%=profile-do--xammac--%):            profile-do--xammac--%:            profile-do--build--%
75 $(_boot_:%=profile-do--xammac_net_4_5--%):    profile-do--xammac_net_4_5--%:           profile-do--build--%
76 $(_boot_:%=profile-do--testing_aot_hybrid--%):        profile-do--testing_aot_hybrid--%:        profile-do--build--%
77 $(_boot_:%=profile-do--testing_aot_full--%):          profile-do--testing_aot_full--%:          profile-do--build--%
78 $(_boot_:%=profile-do--winaot--%):              profile-do--winaot--%:              profile-do--build--%
79 $(_boot_:%=profile-do--orbis--%):              profile-do--orbis--%:              profile-do--build--%
80 $(_boot_:%=profile-do--build--%):             profile-do--build--%:             profile-do--basic--%
81
82 testcorlib:
83         @cd class/corlib && $(MAKE) test run-test
84
85 compiler-tests:
86         $(MAKE) TEST_SUBDIRS="tests errors" run-test-profiles
87
88 package := mcs-$(VERSION)
89
90 DISTFILES = \
91         AUTHORS                 \
92         COPYING                 \
93         INSTALL.txt             \
94         Makefile                \
95         mkinstalldirs           \
96         MonoIcon.png            \
97         README                  \
98         ScalableMonoIcon.svg    \
99         winexe.in
100
101 dist-local: dist-default
102
103 csproj-local:
104
105 dist-pre:
106         rm -rf $(package)
107         mkdir $(package)
108
109 dist-tarball: dist-pre
110         $(MAKE) distdir='$(package)' dist-recursive
111         tar cvjf $(package).tar.bz2 $(package)
112
113 dist: dist-tarball
114         rm -rf $(package)
115
116 # the egrep -v is kind of a hack (to get rid of the makefrags)
117 # but otherwise we have to make dist then make clean which
118 # is sort of not kosher. And it breaks with DIST_ONLY_SUBDIRS.
119 #
120 # We need to set prefix on make so class/System/Makefile can find
121 # the installed System.Xml to build properly
122
123 distcheck: dist-tarball
124         rm -rf InstallTest Distcheck-MCS ; \
125         mkdir InstallTest ; \
126         destdir=`cd InstallTest && pwd` ; \
127         mv $(package) Distcheck-MCS ; \
128         (cd Distcheck-MCS && \
129             $(MAKE) prefix=$(prefix) && $(MAKE) test && $(MAKE) install DESTDIR="$$destdir" && \
130             $(MAKE) clean && $(MAKE) dist || exit 1) || exit 1 ; \
131         mv Distcheck-MCS $(package) ; \
132         tar tjf $(package)/$(package).tar.bz2 |sed -e 's,/$$,,' |sort >distdist.list ; \
133         rm $(package)/$(package).tar.bz2 ; \
134         tar tjf $(package).tar.bz2 |sed -e 's,/$$,,' |sort >before.list ; \
135         find $(package) |egrep -v '(makefrag|response)' |sed -e 's,/$$,,' |sort >after.list ; \
136         cmp before.list after.list || exit 1 ; \
137         cmp before.list distdist.list || exit 1 ; \
138         rm -f before.list after.list distdist.list ; \
139         rm -rf $(package) InstallTest
140
141 monocharge:
142         chargedir=monocharge-`date -u +%Y%m%d` ; \
143         mkdir "$$chargedir" ; \
144         DESTDIR=`cd "$$chargedir" && pwd` ; \
145         $(MAKE) install DESTDIR="$$DESTDIR" || exit 1 ; \
146         tar cvjf "$$chargedir".tar.bz2 "$$chargedir" ; \
147         rm -rf "$$chargedir"
148
149 # A bare-bones monocharge.
150
151 monocharge-lite:
152         chargedir=monocharge-lite-`date -u +%Y%m%d` ; \
153         mkdir "$$chargedir" ; \
154         DESTDIR=`cd "$$chargedir" && pwd` ; \
155         $(MAKE) -C mcs install DESTDIR="$$DESTDIR" || exit 1; \
156         $(MAKE) -C class/corlib install DESTDIR="$$DESTDIR" || exit 1; \
157         $(MAKE) -C class/System install DESTDIR="$$DESTDIR" || exit 1; \
158         $(MAKE) -C class/System.XML install DESTDIR="$$DESTDIR" || exit 1; \
159         $(MAKE) -C class/Mono.CSharp.Debugger install DESTDIR="$$DESTDIR" || exit 1; \
160         tar cvjf "$$chargedir".tar.bz2 "$$chargedir" ; \
161         rm -rf "$$chargedir"
162
163 # Targets for creating API diffs of the framework
164
165 MONO_API_SNAPSHOT_PATH := $(topdir)../external/api-snapshot/
166 GENAPI := $(MONO_API_SNAPSHOT_PATH)tools/genapi/GenAPI.exe
167 MONO_API_SNAPSHOT_PROFILE_PATH := $(MONO_API_SNAPSHOT_PATH)profiles/$(PROFILE)/
168 MONO_API_ASSEMBLIES_IGNORED := $(addprefix $(topdir)class/lib/$(PROFILE)/, SystemWebTestShim.dll standalone-runner-support.dll nunit.core.dll nunit.core.extensions.dll nunit.core.interfaces.dll nunit.framework.dll nunit.framework.extensions.dll nunit.mocks.dll nunit.util.dll nunit-console-runner.dll nunitlite.dll)
169 MONO_API_ASSEMBLIES := $(filter-out $(MONO_API_ASSEMBLIES_IGNORED), $(wildcard $(topdir)class/lib/$(PROFILE)/*.dll)) $(wildcard $(topdir)class/lib/$(PROFILE)/Facades/*.dll)
170 MONO_API_ASSEMBLIES_CS := $(MONO_API_ASSEMBLIES:$(topdir)class/lib/$(PROFILE)/%.dll=$(MONO_API_SNAPSHOT_PROFILE_PATH)%.cs)
171
172 $(MONO_API_SNAPSHOT_PROFILE_PATH)%.cs: $(topdir)class/lib/$(PROFILE)/%.dll $(GENAPI) $(MONO_API_SNAPSHOT_PATH)profiles/license-header.txt
173         @mkdir -p $(dir $@)
174         $(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 -assembly:$< || echo "Couldn't process assembly." > $@
175
176 mono-api-current: $(MONO_API_ASSEMBLIES_CS)
177
178 mono-api-diff:
179         @echo "Regenerating API snapshot..."
180         $(Q) rm -rf "$(MONO_API_SNAPSHOT_PROFILE_PATH)"
181         $(Q) $(MAKE) mono-api-current
182         @echo "Checking public API differences..."
183         $(Q) cd $(MONO_API_SNAPSHOT_PATH); git add -A .
184         $(Q) cd $(MONO_API_SNAPSHOT_PATH); git diff --no-renames HEAD > $(abspath $(topdir))/temp.patch
185         @mkdir -p apidiff
186         $(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
187         $(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