author | sundar |
Mon, 28 Mar 2016 23:05:01 +0530 | |
changeset 36764 | 298caeee3757 |
parent 36050 | f6590b6e5e97 |
child 37649 | 3809534d4531 |
permissions | -rw-r--r-- |
0 | 1 |
# |
29662 | 2 |
# Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. |
0 | 3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
# |
|
5 |
# This code is free software; you can redistribute it and/or modify it |
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
|
5499 | 7 |
# published by the Free Software Foundation. Oracle designates this |
0 | 8 |
# particular file as subject to the "Classpath" exception as provided |
5499 | 9 |
# by Oracle in the LICENSE file that accompanied this code. |
0 | 10 |
# |
11 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
|
12 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
13 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
14 |
# version 2 for more details (a copy is included in the LICENSE file that |
|
15 |
# accompanied this code). |
|
16 |
# |
|
17 |
# You should have received a copy of the GNU General Public License version |
|
18 |
# 2 along with this work; if not, write to the Free Software Foundation, |
|
19 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
20 |
# |
|
5499 | 21 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
22 |
# or visit www.oracle.com if you need additional information or have any |
|
23 |
# questions. |
|
0 | 24 |
# |
25 |
||
29662 | 26 |
################################################################################ |
27 |
# This is the bootstrapping part of the build. This file is included from the |
|
28 |
# top level Makefile, and is responsible for launching the Main.gmk file with |
|
29 |
# the proper make and the proper make arguments. |
|
30 |
################################################################################ |
|
31 |
||
21759 | 32 |
# This must be the first rule |
33 |
default: |
|
29662 | 34 |
.PHONY: default |
17
bb9f330cd95a
6649672: Adjustments to OUTPUTDIR default and mkdirs to avoid empty directory clutter
ohair
parents:
16
diff
changeset
|
35 |
|
21759 | 36 |
# Inclusion of this pseudo-target will cause make to execute this file |
29662 | 37 |
# serially, regardless of -j. |
21759 | 38 |
.NOTPARALLEL: |
9618 | 39 |
|
29788 | 40 |
ifeq ($(HAS_SPEC),) |
29662 | 41 |
############################################################################## |
29788 | 42 |
# This is the default mode. We have not been recursively called with a SPEC. |
29662 | 43 |
############################################################################## |
44 |
||
29788 | 45 |
# Include our helper functions. |
46 |
include $(topdir)/make/InitSupport.gmk |
|
8441 | 47 |
|
29788 | 48 |
# Here are "global" targets, i.e. targets that can be executed without having |
49 |
# a configuration. This will define ALL_GLOBAL_TARGETS. |
|
50 |
include $(topdir)/make/Help.gmk |
|
29662 | 51 |
|
29788 | 52 |
# Targets provided by Init.gmk. |
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
53 |
ALL_INIT_TARGETS := print-modules print-targets print-configuration \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
54 |
reconfigure pre-compare-build post-compare-build |
25854 | 55 |
|
29662 | 56 |
# CALLED_TARGETS is the list of targets that the user provided, |
57 |
# or "default" if unspecified. |
|
58 |
CALLED_TARGETS := $(if $(MAKECMDGOALS), $(MAKECMDGOALS), default) |
|
29788 | 59 |
|
60 |
# Extract non-global targets that require a spec file. |
|
61 |
CALLED_SPEC_TARGETS := $(filter-out $(ALL_GLOBAL_TARGETS), $(CALLED_TARGETS)) |
|
62 |
||
63 |
# If we have only global targets, or if we are called with -qp (assuming an |
|
64 |
# external part, e.g. bash completion, is trying to understand our targets), |
|
65 |
# we will skip SPEC location and the sanity checks. |
|
66 |
ifeq ($(CALLED_SPEC_TARGETS), ) |
|
67 |
ONLY_GLOBAL_TARGETS := true |
|
68 |
endif |
|
69 |
ifneq ($(findstring qp, $(MAKEFLAGS)),) |
|
70 |
ONLY_GLOBAL_TARGETS := true |
|
71 |
endif |
|
72 |
||
73 |
ifeq ($(ONLY_GLOBAL_TARGETS), true) |
|
74 |
############################################################################ |
|
75 |
# We have only global targets, or are called with -pq. |
|
76 |
############################################################################ |
|
77 |
||
78 |
ifeq ($(wildcard $(SPEC)), ) |
|
79 |
# If we have no SPEC provided, we will just make a "best effort" target list. |
|
80 |
# First try to grab any available pre-existing main-targets.gmk. |
|
81 |
main_targets_file := $(firstword $(wildcard $(build_dir)/*/make-support/main-targets.gmk)) |
|
82 |
ifneq ($(main_targets_file), ) |
|
83 |
# Extract the SPEC that corresponds to this main-targets.gmk file. |
|
84 |
SPEC := $(patsubst %/make-support/main-targets.gmk, %/spec.gmk, $(main_targets_file)) |
|
85 |
else |
|
86 |
# None found, pick an arbitrary SPEC for which to generate a file |
|
87 |
SPEC := $(firstword $(all_spec_files)) |
|
88 |
endif |
|
89 |
endif |
|
90 |
||
91 |
ifneq ($(wildcard $(SPEC)), ) |
|
92 |
$(eval $(call DefineMainTargets, LAZY, $(SPEC))) |
|
93 |
else |
|
94 |
# If we have no configurations we can not provide any main targets. |
|
95 |
ALL_MAIN_TARGETS := |
|
96 |
endif |
|
97 |
||
98 |
ALL_TARGETS := $(sort $(ALL_GLOBAL_TARGETS) $(ALL_MAIN_TARGETS) $(ALL_INIT_TARGETS)) |
|
99 |
||
100 |
# Just list all our targets. |
|
101 |
$(ALL_TARGETS): |
|
102 |
||
103 |
.PHONY: $(ALL_TARGETS) |
|
104 |
||
105 |
else |
|
106 |
############################################################################ |
|
107 |
# This is the normal case, we have been called from the command line by the |
|
108 |
# user and we need to call ourself back with a proper SPEC. |
|
109 |
# We have at least one non-global target, so we need to find a spec file. |
|
110 |
############################################################################ |
|
111 |
||
112 |
# Basic checks on environment and command line. |
|
113 |
$(eval $(call CheckControlVariables)) |
|
114 |
$(eval $(call CheckDeprecatedEnvironment)) |
|
115 |
$(eval $(call CheckInvalidMakeFlags)) |
|
116 |
||
117 |
# Check that CONF_CHECK is valid. |
|
118 |
$(eval $(call ParseConfCheckOption)) |
|
119 |
||
120 |
# Check that the LOG given is valid, and set LOG_LEVEL, LOG_NOFILE and MAKE_LOG_FLAGS. |
|
121 |
$(eval $(call ParseLogLevel)) |
|
122 |
||
123 |
# After this SPECS contain 1..N spec files (otherwise ParseConfAndSpec fails). |
|
29662 | 124 |
$(eval $(call ParseConfAndSpec)) |
25854 | 125 |
|
29788 | 126 |
# Extract main targets from Main.gmk using the spec(s) provided. In theory, |
127 |
# with multiple specs, we should find the intersection of targets provided |
|
128 |
# by all specs, but we approximate this by an arbitrary spec from the list. |
|
129 |
# This will setup ALL_MAIN_TARGETS. |
|
130 |
$(eval $(call DefineMainTargets, FORCE, $(firstword $(SPECS)))) |
|
131 |
||
132 |
# Separate called targets depending on type. |
|
29662 | 133 |
INIT_TARGETS := $(filter $(ALL_INIT_TARGETS), $(CALLED_SPEC_TARGETS)) |
29788 | 134 |
MAIN_TARGETS := $(filter $(ALL_MAIN_TARGETS), $(CALLED_SPEC_TARGETS)) |
135 |
SEQUENTIAL_TARGETS := $(filter dist-clean clean%, $(MAIN_TARGETS)) |
|
136 |
PARALLEL_TARGETS := $(filter-out $(SEQUENTIAL_TARGETS), $(MAIN_TARGETS)) |
|
874
638ddad10e12
6728161: Add SKIP_BOOT_CYCLE feature to create boot jdk and use it during build
ohair
parents:
668
diff
changeset
|
137 |
|
29662 | 138 |
# The spec files depend on the autoconf source code. This check makes sure |
139 |
# the configuration is up to date after changes to configure. |
|
33051
2cb885613d7a
8140277: Configuration out-of-date check should also check closed sources
ihse
parents:
32920
diff
changeset
|
140 |
CUSTOM_CONFIG_DIR ?= $(topdir)/closed/autoconf |
2cb885613d7a
8140277: Configuration out-of-date check should also check closed sources
ihse
parents:
32920
diff
changeset
|
141 |
|
2cb885613d7a
8140277: Configuration out-of-date check should also check closed sources
ihse
parents:
32920
diff
changeset
|
142 |
$(SPECS): $(wildcard $(topdir)/common/autoconf/*) $(wildcard $(CUSTOM_CONFIG_DIR)/*) |
29662 | 143 |
ifeq ($(CONF_CHECK), fail) |
144 |
@echo "Error: The configuration is not up to date for '$(lastword $(subst /, , $(dir $@)))'." |
|
145 |
$(call PrintConfCheckFailed) |
|
146 |
@exit 2 |
|
147 |
else ifeq ($(CONF_CHECK), auto) |
|
148 |
@echo "Note: The configuration is not up to date for '$(lastword $(subst /, , $(dir $@)))'." |
|
149 |
@( cd $(topdir) && \ |
|
29788 | 150 |
$(MAKE) $(MFLAGS) $(MAKE_LOG_FLAGS) -r -R -f $(topdir)/make/Init.gmk \ |
151 |
SPEC=$@ HAS_SPEC=true ACTUAL_TOPDIR=$(topdir) \ |
|
29662 | 152 |
reconfigure ) |
153 |
else ifeq ($(CONF_CHECK), ignore) |
|
154 |
# Do nothing |
|
26398
ca1f84f97e20
8057537: Serialize reconfigure and fix make clean-foo foo
erikj
parents:
26128
diff
changeset
|
155 |
endif |
25854 | 156 |
|
36050
f6590b6e5e97
8150203: Incremental update from build-infra project
ihse
parents:
35744
diff
changeset
|
157 |
# Do not let make delete spec files even if aborted while doing a reconfigure |
f6590b6e5e97
8150203: Incremental update from build-infra project
ihse
parents:
35744
diff
changeset
|
158 |
.PRECIOUS: $(SPECS) |
f6590b6e5e97
8150203: Incremental update from build-infra project
ihse
parents:
35744
diff
changeset
|
159 |
|
29788 | 160 |
# Unless reconfigure is explicitely called, let all main targets depend on |
161 |
# the spec files to be up to date. |
|
162 |
ifeq ($(findstring reconfigure, $(INIT_TARGETS)), ) |
|
163 |
$(MAIN_TARGETS): $(SPECS) |
|
29662 | 164 |
endif |
874
638ddad10e12
6728161: Add SKIP_BOOT_CYCLE feature to create boot jdk and use it during build
ohair
parents:
668
diff
changeset
|
165 |
|
29788 | 166 |
make-info: |
167 |
ifneq ($(findstring $(LOG_LEVEL),info debug trace),) |
|
168 |
$(info Running make as '$(strip $(MAKE) $(MFLAGS) \ |
|
169 |
$(COMMAND_LINE_VARIABLES) $(MAKECMDGOALS))') |
|
170 |
endif |
|
171 |
||
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
172 |
MAKE_INIT_WITH_SPEC_ARGUMENTS := ACTUAL_TOPDIR=$(topdir) \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
173 |
USER_MAKE_VARS="$(USER_MAKE_VARS)" MAKE_LOG_FLAGS=$(MAKE_LOG_FLAGS) \ |
35444 | 174 |
LOG_LEVEL=$(LOG_LEVEL) LOG_NOFILE=$(LOG_NOFILE) LOG_CMDLINES=$(LOG_CMDLINES) \ |
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
175 |
INIT_TARGETS="$(INIT_TARGETS)" \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
176 |
SEQUENTIAL_TARGETS="$(SEQUENTIAL_TARGETS)" \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
177 |
PARALLEL_TARGETS="$(PARALLEL_TARGETS)" |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
178 |
|
29788 | 179 |
# Now the init and main targets will be called, once for each SPEC. The |
180 |
# recipe will be run once for every target specified, but we only want to |
|
181 |
# execute the recipe a single time, hence the TARGET_DONE with a dummy |
|
182 |
# command if true. |
|
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
183 |
# The COMPARE_BUILD part implements special support for makefile development. |
29788 | 184 |
$(ALL_INIT_TARGETS) $(ALL_MAIN_TARGETS): make-info |
29662 | 185 |
@$(if $(TARGET_DONE), \ |
186 |
true \ |
|
187 |
, \ |
|
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
188 |
( cd $(topdir) && \ |
29662 | 189 |
$(foreach spec, $(SPECS), \ |
29788 | 190 |
$(MAKE) $(MFLAGS) $(MAKE_LOG_FLAGS) -r -R -j 1 -f $(topdir)/make/Init.gmk \ |
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
191 |
SPEC=$(spec) HAS_SPEC=true $(MAKE_INIT_WITH_SPEC_ARGUMENTS) \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
192 |
main && \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
193 |
$(if $(and $(COMPARE_BUILD), $(PARALLEL_TARGETS)), \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
194 |
$(MAKE) $(MFLAGS) $(MAKE_LOG_FLAGS) -r -R -f $(topdir)/make/Init.gmk \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
195 |
SPEC=$(spec) HAS_SPEC=true ACTUAL_TOPDIR=$(topdir) \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
196 |
COMPARE_BUILD="$(COMPARE_BUILD)" pre-compare-build && \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
197 |
$(MAKE) $(MFLAGS) $(MAKE_LOG_FLAGS) -r -R -j 1 -f $(topdir)/make/Init.gmk \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
198 |
SPEC=$(spec) HAS_SPEC=true $(MAKE_INIT_WITH_SPEC_ARGUMENTS) \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
199 |
COMPARE_BUILD="$(COMPARE_BUILD)" main && \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
200 |
$(MAKE) $(MFLAGS) $(MAKE_LOG_FLAGS) -r -R -f $(topdir)/make/Init.gmk \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
201 |
SPEC=$(spec) HAS_SPEC=true ACTUAL_TOPDIR=$(topdir) \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
202 |
COMPARE_BUILD="$(COMPARE_BUILD)" post-compare-build && \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
203 |
) \ |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
204 |
) true ) \ |
29662 | 205 |
$(eval TARGET_DONE=true) \ |
206 |
) |
|
207 |
||
208 |
.PHONY: $(ALL_MAIN_TARGETS) $(ALL_INIT_TARGETS) |
|
0 | 209 |
|
29788 | 210 |
endif # $(ONLY_GLOBAL_TARGETS)!=true |
29662 | 211 |
|
212 |
else # HAS_SPEC=true |
|
213 |
||
214 |
############################################################################## |
|
215 |
# Now we have a spec. This part provides the "main" target that acts as a |
|
216 |
# trampoline to call the Main.gmk with the value of $(MAKE) found in the spec |
|
217 |
# file. |
|
218 |
############################################################################## |
|
219 |
||
29788 | 220 |
include $(SPEC) |
221 |
||
222 |
# Our helper functions. |
|
223 |
include $(TOPDIR)/make/InitSupport.gmk |
|
224 |
||
225 |
# Verify that the spec file we included seems okay. |
|
226 |
$(eval $(call CheckSpecSanity)) |
|
227 |
||
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
228 |
# Parse COMPARE_BUILD (for makefile development) |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
229 |
$(eval $(call ParseCompareBuild)) |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
230 |
|
29662 | 231 |
ifeq ($(LOG_NOFILE), true) |
35008 | 232 |
# Disable build log if LOG=[level,]nofile was given |
233 |
override BUILD_LOG_PIPE := |
|
29662 | 234 |
endif |
235 |
||
236 |
ifeq ($(OUTPUT_SYNC_SUPPORTED), true) |
|
237 |
OUTPUT_SYNC_FLAG := -O$(OUTPUT_SYNC) |
|
238 |
endif |
|
239 |
||
29788 | 240 |
############################################################################## |
241 |
# Init targets |
|
242 |
############################################################################## |
|
243 |
||
244 |
print-modules: |
|
245 |
( cd $(TOPDIR) && \ |
|
246 |
$(MAKE) $(MAKE_ARGS) -j 1 -f make/Main.gmk $(USER_MAKE_VARS) \ |
|
247 |
NO_RECIPES=true print-modules ) |
|
248 |
||
249 |
print-targets: |
|
250 |
( cd $(TOPDIR) && \ |
|
251 |
$(MAKE) $(MAKE_ARGS) -j 1 -f make/Main.gmk $(USER_MAKE_VARS) \ |
|
252 |
NO_RECIPES=true print-targets ) |
|
28902
0c09b47449c8
8069064: Various improvements and fixes in build system
ihse
parents:
28286
diff
changeset
|
253 |
|
32461
e1cfbafc4e9c
8135180: Print configure arguments using make print-configuration
ihse
parents:
32344
diff
changeset
|
254 |
print-configuration: |
e1cfbafc4e9c
8135180: Print configure arguments using make print-configuration
ihse
parents:
32344
diff
changeset
|
255 |
$(ECHO) $(CONFIGURE_COMMAND_LINE) |
e1cfbafc4e9c
8135180: Print configure arguments using make print-configuration
ihse
parents:
32344
diff
changeset
|
256 |
|
29662 | 257 |
reconfigure: |
258 |
ifneq ($(CONFIGURE_COMMAND_LINE), ) |
|
259 |
$(ECHO) "Re-running configure using arguments '$(CONFIGURE_COMMAND_LINE)'" |
|
260 |
else |
|
261 |
$(ECHO) "Re-running configure using default settings" |
|
262 |
endif |
|
263 |
( cd $(OUTPUT_ROOT) && PATH="$(ORIGINAL_PATH)" \ |
|
264 |
$(BASH) $(TOPDIR)/configure $(CONFIGURE_COMMAND_LINE) ) |
|
265 |
||
29788 | 266 |
############################################################################## |
267 |
# The main target, for delegating into Main.gmk |
|
268 |
############################################################################## |
|
29662 | 269 |
|
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
270 |
MAIN_TARGETS := $(SEQUENTIAL_TARGETS) $(PARALLEL_TARGETS) $(COMPARE_BUILD_MAKE) |
29788 | 271 |
TARGET_DESCRIPTION := target$(if $(word 2, $(MAIN_TARGETS)),s) \ |
272 |
'$(strip $(MAIN_TARGETS))' in configuration '$(CONF_NAME)' |
|
29662 | 273 |
|
274 |
# MAKEOVERRIDES is automatically set and propagated by Make to sub-Make calls. |
|
275 |
# We need to clear it of the init-specific variables. The user-specified |
|
276 |
# variables are explicitely propagated using $(USER_MAKE_VARS). |
|
277 |
main: MAKEOVERRIDES := |
|
0 | 278 |
|
29788 | 279 |
main: $(INIT_TARGETS) |
280 |
ifneq ($(SEQUENTIAL_TARGETS)$(PARALLEL_TARGETS), ) |
|
281 |
$(call RotateLogFiles) |
|
32344
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
282 |
$(call PrepareFailureLogs) |
35008 | 283 |
$(PRINTF) "Building $(TARGET_DESCRIPTION)\n" $(BUILD_LOG_PIPE) |
29788 | 284 |
ifneq ($(SEQUENTIAL_TARGETS), ) |
285 |
# Don't touch build output dir since we might be cleaning. That |
|
35008 | 286 |
# means no log pipe. |
29788 | 287 |
( cd $(TOPDIR) && \ |
288 |
$(MAKE) $(MAKE_ARGS) -j 1 -f make/Main.gmk $(USER_MAKE_VARS) \ |
|
289 |
$(SEQUENTIAL_TARGETS) ) |
|
290 |
endif |
|
291 |
ifneq ($(PARALLEL_TARGETS), ) |
|
292 |
$(call StartGlobalTimer) |
|
293 |
$(call PrepareSmartJavac) |
|
294 |
( cd $(TOPDIR) && \ |
|
35008 | 295 |
$(NICE) $(MAKE) $(MAKE_ARGS) $(OUTPUT_SYNC_FLAG) \ |
32344
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
296 |
-j $(JOBS) -f make/Main.gmk $(USER_MAKE_VARS) \ |
35008 | 297 |
$(PARALLEL_TARGETS) $(COMPARE_BUILD_MAKE) $(BUILD_LOG_PIPE) || \ |
298 |
( exitcode=$$? && \ |
|
299 |
$(PRINTF) "\nERROR: Build failed for $(TARGET_DESCRIPTION) (exit code $$exitcode) \n" \ |
|
300 |
$(BUILD_LOG_PIPE) && \ |
|
32344
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
301 |
cd $(TOPDIR) && $(MAKE) $(MAKE_ARGS) -j 1 -f make/Init.gmk \ |
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
302 |
HAS_SPEC=true on-failure ; \ |
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
303 |
exit $$exitcode ) ) |
29788 | 304 |
$(call CleanupSmartJavac) |
305 |
$(call StopGlobalTimer) |
|
306 |
$(call ReportBuildTimes) |
|
307 |
endif |
|
35008 | 308 |
$(PRINTF) "Finished building $(TARGET_DESCRIPTION)\n" $(BUILD_LOG_PIPE) |
29662 | 309 |
endif |
310 |
||
32344
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
311 |
on-failure: |
33572 | 312 |
$(call PrintFailureReports) |
313 |
$(call PrintBuildLogFailures) |
|
314 |
$(PRINTF) "Hint: If caused by a warning, try configure --disable-warnings-as-errors.\n\n" |
|
315 |
ifneq ($(COMPARE_BUILD), ) |
|
316 |
$(call CleanupCompareBuild) |
|
32344
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
317 |
endif |
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
318 |
|
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
319 |
# Support targets for COMPARE_BUILD, used for makefile development |
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
320 |
pre-compare-build: |
35370
f9b430645a18
8148120: Incremental update from build-infra project
ihse
parents:
35008
diff
changeset
|
321 |
$(call WaitForSmartJavacFinish) |
33572 | 322 |
$(call PrepareCompareBuild) |
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
323 |
|
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
324 |
post-compare-build: |
35744
4f5e0998b6e9
8149479: Fix compare.sh to have a clean baseline with COMPARE_BUILD
erikj
parents:
35444
diff
changeset
|
325 |
$(call WaitForSmartJavacFinish) |
33572 | 326 |
$(call CleanupCompareBuild) |
327 |
$(call CompareBuildDoComparison) |
|
32715
4d558a41a1ec
8136695: Automatic build comparison with COMPARE_BUILD
ihse
parents:
32461
diff
changeset
|
328 |
|
32344
0b288e0efcfa
8062618: Create a build failure summary at end of build log
ihse
parents:
30415
diff
changeset
|
329 |
.PHONY: print-targets print-modules reconfigure main on-failure |
29662 | 330 |
endif |