1 # 2 # Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. 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 7 # published by the Free Software Foundation. Oracle designates this 8 # particular file as subject to the "Classpath" exception as provided 9 # by Oracle in the LICENSE file that accompanied this code. 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 # 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. 24 # 25 26 ################################################################################ 27 # This is the main makefile containing most actual top level targets. It needs 28 # to be called with a SPEC file defined. 29 30 # Declare default target 31 default: 32 33 # Now load the spec 34 include $(SPEC) 35 36 include $(SRC_ROOT)/make/MakeHelpers.gmk 37 38 # Load the vital tools for all the makefiles. 39 include $(SRC_ROOT)/make/common/MakeBase.gmk 40 include $(SRC_ROOT)/make/common/Modules.gmk 41 42 # Declare ALL_TARGETS as an immediate variable. This variable is a list of all 43 # valid top level targets. It's used to declare them all as PHONY and to 44 # generate the -only targets. 45 ALL_TARGETS := 46 47 # Hook to include the corresponding custom file, if present. 48 $(eval $(call IncludeCustomExtension, , Main.gmk)) 49 50 # All modules for the current target platform. 51 # Manually add jdk.hotspot.agent for now. 52 ALL_MODULES := $(call FindAllModules) jdk.hotspot.agent 53 54 ################################################################################ 55 ################################################################################ 56 # 57 # Recipes for all targets. Only recipes, dependencies are declared later. 58 # 59 ################################################################################ 60 61 ################################################################################ 62 # Interim/build tools targets, compiling tools used during the build 63 64 buildtools-langtools: 65 +($(CD) $(LANGTOOLS_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Tools.gmk) 66 67 interim-langtools: 68 +($(CD) $(LANGTOOLS_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterim.gmk) 69 70 interim-corba: 71 +($(CD) $(CORBA_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterim.gmk) 72 73 interim-rmic: 74 +($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterimRmic.gmk) 75 76 buildtools-jdk: 77 +($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Tools.gmk java-tools) 78 79 ALL_TARGETS += buildtools-langtools interim-langtools interim-corba \ 80 interim-rmic buildtools-jdk 81 82 ################################################################################ 83 # Special targets for certain modules 84 85 import-hotspot: 86 +($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Import.gmk) 87 88 unpack-sec: 89 +($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f UnpackSecurity.gmk) 90 91 ALL_TARGETS += import-hotspot unpack-sec 92 93 ################################################################################ 94 # Gensrc targets, generating source before java compilation can be done 95 $(eval $(call DeclareRecipesForPhase, GENSRC, \ 96 TARGET_SUFFIX := gensrc, \ 97 FILE_PREFIX := Gensrc, \ 98 MAKE_SUBDIR := gensrc, \ 99 CHECK_MODULES := $(ALL_MODULES), \ 100 MULTIPLE_MAKEFILES := true)) 101 102 JDK_GENSRC_TARGETS := $(filter %-gensrc-jdk, $(GENSRC_TARGETS)) 103 LANGTOOLS_GENSRC_TARGETS := $(filter %-gensrc-langtools, $(GENSRC_TARGETS)) 104 CORBA_GENSRC_TARGETS := $(filter %-gensrc-corba, $(GENSRC_TARGETS)) 105 106 ALL_TARGETS += $(GENSRC_TARGETS) 107 108 ################################################################################ 109 # Generate data targets 110 $(eval $(call DeclareRecipesForPhase, GENDATA, \ 111 TARGET_SUFFIX := gendata, \ 112 FILE_PREFIX := Gendata, \ 113 MAKE_SUBDIR := gendata, \ 114 CHECK_MODULES := $(ALL_MODULES), \ 115 USE_WRAPPER := true)) 116 117 ALL_TARGETS += $(GENDATA_TARGETS) 118 119 ################################################################################ 120 # Copy files targets 121 $(eval $(call DeclareRecipesForPhase, COPY, \ 122 TARGET_SUFFIX := copy, \ 123 FILE_PREFIX := Copy, \ 124 MAKE_SUBDIR := copy, \ 125 CHECK_MODULES := $(ALL_MODULES), \ 126 USE_WRAPPER := true)) 127 128 ALL_TARGETS += $(COPY_TARGETS) 129 130 ################################################################################ 131 # Targets for compiling all java modules. Nashorn is treated separately. 132 JAVA_MODULES := $(call FindJavaModules) 133 JAVA_TARGETS := $(addsuffix -java, $(JAVA_MODULES)) 134 135 define DeclareCompileJavaRecipe 136 $1-java: 137 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f CompileJavaModules.gmk \ 138 $1 JAVA_MODULES=$1) 139 endef 140 141 $(foreach m, $(filter-out jdk.scripting.nashorn, $(JAVA_MODULES)), \ 142 $(eval $(call DeclareCompileJavaRecipe,$m))) 143 144 # Build nashorn. Needs to be compiled separately from the rest of the modules 145 # due to nasgen. 146 jdk.scripting.nashorn-java: 147 +($(CD) $(NASHORN_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f BuildNashorn.gmk compile) 148 149 ALL_TARGETS += $(JAVA_TARGETS) 150 151 ################################################################################ 152 # Targets for running rmic. 153 $(eval $(call DeclareRecipesForPhase, RMIC, \ 154 TARGET_SUFFIX := rmic, \ 155 FILE_PREFIX := Rmic, \ 156 MAKE_SUBDIR := rmic, \ 157 CHECK_MODULES := $(ALL_MODULES))) 158 159 ALL_TARGETS += $(RMIC_TARGETS) 160 161 ################################################################################ 162 # Targets for compiling native libraries 163 $(eval $(call DeclareRecipesForPhase, LIBS, \ 164 TARGET_SUFFIX := libs, \ 165 FILE_PREFIX := Lib, \ 166 MAKE_SUBDIR := lib, \ 167 CHECK_MODULES := $(ALL_MODULES), \ 168 USE_WRAPPER := true)) 169 170 ALL_TARGETS += $(LIBS_TARGETS) 171 172 ################################################################################ 173 # Targets for compiling native executables 174 $(eval $(call DeclareRecipesForPhase, LAUNCHER, \ 175 TARGET_SUFFIX := launchers, \ 176 FILE_PREFIX := Launcher, \ 177 MAKE_SUBDIR := launcher, \ 178 CHECK_MODULES := $(ALL_MODULES), \ 179 USE_WRAPPER := true)) 180 181 ALL_TARGETS += $(LAUNCHER_TARGETS) 182 183 ################################################################################ 184 # Build hotspot target 185 186 ifeq ($(BUILD_HOTSPOT),true) 187 hotspot: 188 ($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f HotspotWrapper.gmk) 189 endif 190 191 ALL_TARGETS += hotspot 192 193 ################################################################################ 194 # Build demos and samples targets 195 196 demos: 197 +($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileDemos.gmk) 198 199 samples: 200 +($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CopySamples.gmk) 201 202 ALL_TARGETS += demos samples 203 204 ################################################################################ 205 # Image targets 206 207 # Stores the tips for each repository. This file is be used when constructing the jdk image and can be 208 # used to track the exact sources used to build that image. 209 source-tips: $(SUPPORT_OUTPUTDIR)/source_tips 210 $(SUPPORT_OUTPUTDIR)/source_tips: FRC 211 @$(MKDIR) -p $(@D) 212 @$(RM) $@ 213 @$(call GetSourceTips) 214 215 BOOTCYCLE_TARGET := product-images 216 bootcycle-images: 217 @$(ECHO) Boot cycle build step 2: Building a new JDK image using previously built image 218 +$(MAKE) $(MAKE_ARGS) -f Main.gmk SPEC=$(dir $(SPEC))bootcycle-spec.gmk $(BOOTCYCLE_TARGET) 219 220 zip-security: 221 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f ZipSecurity.gmk) 222 223 zip-source: 224 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f ZipSource.gmk) 225 226 strip-binaries: 227 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f StripBinaries.gmk) 228 229 jrtfs-jar: 230 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f JrtfsJar.gmk) 231 232 jimages: 233 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk jimages) 234 235 profiles: 236 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk profiles) 237 238 mac-bundles: 239 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f MacBundles.gmk) 240 241 prepare-test-image: 242 $(MKDIR) -p $(TEST_IMAGE_DIR) 243 $(ECHO) > $(TEST_IMAGE_DIR)/Readme.txt 'JDK test image' 244 245 ALL_TARGETS += source-tips bootcycle-images zip-security zip-source strip-binaries \ 246 jrtfs-jar jimages profiles mac-bundles prepare-test-image 247 248 ################################################################################ 249 # Docs targets 250 251 docs-javadoc: 252 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk docs) 253 254 docs-jvmtidoc: 255 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk jvmtidocs) 256 257 ALL_TARGETS += docs-javadoc docs-jvmtidoc 258 259 ################################################################################ 260 # Test target 261 262 test: 263 ($(CD) $(SRC_ROOT)/test && $(MAKE) $(MAKE_ARGS) -j1 -k MAKEFLAGS= \ 264 JT_HOME=$(JT_HOME) PRODUCT_HOME=$(JDK_IMAGE_DIR) \ 265 ALT_OUTPUTDIR=$(OUTPUT_ROOT) CONCURRENCY=$(JOBS) $(TEST)) || true 266 267 test-make: 268 ($(CD) $(SRC_ROOT)/test/make && $(MAKE) $(MAKE_ARGS) -f TestMake.gmk $(TEST_TARGET)) 269 270 ALL_TARGETS += test test-make 271 272 ################################################################################ 273 # Verification targets 274 275 verify-modules: 276 @$(call TargetEnter) 277 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f CheckModules.gmk) 278 @$(call TargetExit) 279 280 ALL_TARGETS += verify-modules 281 282 ################################################################################ 283 # Install targets 284 285 install: 286 +($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Install.gmk) 287 288 ALL_TARGETS += install 289 290 ################################################################################ 291 # 292 # Dependency declarations between targets. 293 # 294 # These are declared in two groups. First all dependencies between targets that 295 # have recipes above as these dependencies may be disabled. Then the aggregator 296 # targets that do not have recipes of their own, which will never have their 297 # dependencies disabled. 298 # 299 ################################################################################ 300 # Targets with recipes above 301 302 # If running an *-only target, parallel execution and dependencies between 303 # recipe targets are disabled. This makes it possible to run a select set of 304 # recipe targets in order. It's the responsibility of the user to make sure 305 # all prerequisites are fulfilled. 306 ifneq ($(findstring -only, $(MAKECMDGOALS)), ) 307 .NOTPARALLEL: 308 else 309 $(LANGTOOLS_GENSRC_TARGETS): buildtools-langtools 310 311 interim-langtools: $(LANGTOOLS_GENSRC_TARGETS) 312 313 buildtools-jdk: interim-langtools 314 315 $(CORBA_GENSRC_TARGETS): interim-langtools 316 317 $(JDK_GENSRC_TARGETS): interim-langtools buildtools-jdk 318 319 interim-corba: $(CORBA_GENSRC_TARGETS) 320 321 $(GENDATA_TARGETS): interim-langtools buildtools-jdk 322 323 interim-rmic: interim-langtools 324 325 $(RMIC_TARGETS): interim-langtools interim-corba interim-rmic 326 327 import-hotspot: hotspot 328 329 $(LIBS_TARGETS): import-hotspot 330 331 $(LAUNCHER_TARGETS): java.base-libs 332 333 # The demos are currently linking to libjvm and libjava, just like all other 334 # jdk libs, even though they don't need to. To avoid warnings, make sure they 335 # aren't built until after libjava and libjvm are available to link to. 336 demos: $(JAVA_TARGETS) 337 338 # Declare dependency from <module>-java to <module>-gensrc 339 $(foreach m, $(GENSRC_MODULES), $(eval $m-java: $m-gensrc)) 340 341 # Declare dependencies between java modules 342 $(foreach m, $(JAVA_MODULES), \ 343 $(eval $m-java: $(addsuffix -java, $(filter $(JAVA_MODULES), \ 344 $(call FindDepsForModule,$m))))) 345 346 # Declare dependencies between <module>-rmic to <module>-java 347 $(foreach m, $(RMIC_MODULES), $(eval $m-rmic: $m-java)) 348 349 # Declare dependencies from <module>-lib to <module>-java 350 # Skip jdk.jdwp.agent as it contains no java code. 351 $(foreach m, $(filter-out jdk.jdwp.agent, $(LIBS_MODULES)), $(eval $m-libs: $m-java)) 352 353 # Declare dependencies from all other <module>-lib to java.base-lib 354 $(foreach t, $(filter-out java.base-libs, $(LIBS_TARGETS)), \ 355 $(eval $t: java.base-libs)) 356 # Declare the special case dependency for jdk.deploy.osx where libosx 357 # links against libosxapp. 358 jdk.deploy.osx-libs: java.desktop-libs 359 360 # This dependency needs to be explicitly declared. jdk.jdi-gensrc generates a 361 # header file used by jdk.jdwp.agent-libs. The jdk.jdwp.agent-gensrc is a 362 # virtual target. 363 jdk.jdwp.agent-libs: jdk.jdwp.agent-gensrc 364 365 # Until the module system is in place, jdk.jdi-gensrc needs to combine service 366 # loader configuration with jdk.hotspot.agent so is dependent on importing 367 # hotspot. 368 jdk.jdi-gensrc-jdk: import-hotspot 369 370 # The swing beans need to have java base properly generated to avoid errors 371 # in javadoc. 372 java.desktop-gensrc-jdk: java.base-gensrc 373 374 # Explicitly add dependencies for special targets 375 java.base-java: unpack-sec 376 377 jdk.dev-gendata: java rmic 378 379 zip-security: java.base-java java.security.jgss-java java.security.jgss-libs \ 380 $(filter jdk.crypto%, $(JAVA_TARGETS)) 381 382 zip-source: gensrc rmic 383 384 strip-binaries: libs launchers gendata copy 385 386 jrtfs-jar: buildtools-jdk 387 388 jimages: exploded-image zip-source strip-binaries source-tips demos samples \ 389 jrtfs-jar 390 391 profiles: exploded-image strip-binaries source-tips 392 393 mac-bundles: jimages 394 395 bootcycle-images: jimages 396 397 docs-javadoc: gensrc rmic 398 399 docs-jvmtidoc: hotspot 400 401 test: jimages 402 403 verify-modules: exploded-image 404 405 test-make: clean-test-make 406 407 endif 408 409 ################################################################################ 410 # Virtual targets without recipes 411 412 buildtools: buildtools-langtools interim-langtools interim-corba interim-rmic \ 413 buildtools-jdk 414 415 gensrc: $(GENSRC_TARGETS) 416 417 gendata: $(GENDATA_TARGETS) 418 419 copy: $(COPY_TARGETS) 420 421 java: $(JAVA_TARGETS) 422 423 rmic: $(RMIC_TARGETS) 424 425 libs: $(LIBS_TARGETS) 426 427 launchers: $(LAUNCHER_TARGETS) 428 429 # Explicitly declare dependency for virtual target jdk.jdwp.agent-gensrc which 430 # is actually handled by jdk.jdi-gensrc 431 jdk.jdwp.agent-gensrc: jdk.jdi-gensrc 432 433 # Declare dependencies from <module> to all the individual targets specific 434 # to that module <module>-*. 435 $(foreach m, $(GENSRC_MODULES), $(eval $m: $m-gensrc)) 436 $(foreach m, $(JAVA_MODULES), $(eval $m: $m-java)) 437 $(foreach m, $(GENDATA_MODULES), $(eval $m: $m-gendata)) 438 $(foreach m, $(RMIC_MODULES), $(eval $m: $m-rmic)) 439 $(foreach m, $(LIBS_MODULES), $(eval $m: $m-libs)) 440 $(foreach m, $(LAUNCHER_MODULES), $(eval $m: $m-launchers)) 441 $(foreach m, $(COPY_MODULES), $(eval $m: $m-copy)) 442 443 ALL_MODULE_TARGETS := $(sort $(GENSRC_MODULES) $(JAVA_MODULES) \ 444 $(GENDATA_MODULES) $(LIBS_MODULES) $(LAUNCHER_MODULES) $(COPY_MODULES)) 445 446 # The "exploded image" is a locally runnable JDK in $(BUILD_OUTPUT)/jdk. 447 exploded-image: $(ALL_MODULE_TARGETS) 448 449 # The $(BUILD_OUTPUT)/images directory contain the resulting deliverables, 450 # and in line with this, our targets for creating these are named *-image[s]. 451 452 # This target builds the product images, e.g. the JRE and JDK image 453 # (and possibly other, more specific versions) 454 product-images: jimages demos samples zip-security verify-modules 455 456 ifeq ($(OPENJDK_TARGET_OS), macosx) 457 product-images: mac-bundles 458 endif 459 460 # This target builds the documentation image 461 docs-image: docs-javadoc docs-jvmtidoc 462 463 # This target builds the test image 464 test-image: prepare-test-image 465 466 # all-images is the top-most target, it builds all our deliverables ("images"). 467 all-images: product-images test-image docs-image 468 469 ALL_TARGETS += buildtools gensrc gendata copy java rmic libs launchers \ 470 jdk.jdwp.agent-gensrc $(ALL_MODULE_TARGETS) exploded-image \ 471 product-images docs-image test-image all-images 472 473 ################################################################################ 474 475 # Traditional targets typically run by users. 476 # These can now be considered alias for the targets now named by a more 477 # "modern" naming scheme. 478 default: exploded-image 479 jdk: exploded-image 480 images: product-images 481 docs: docs-image 482 all: all-images 483 484 ALL_TARGETS += default jdk images docs all 485 486 ################################################################################ 487 ################################################################################ 488 # 489 # Clean targets 490 # 491 ################################################################################ 492 # Clean targets are automatically run serially by the Makefile calling this 493 # file. 494 495 CLEAN_DIRS += hotspot jdk bootcycle-build test buildtools support \ 496 images make-support test-make 497 CLEAN_DIR_TARGETS := $(addprefix clean-, $(CLEAN_DIRS)) 498 CLEAN_PHASES := gensrc java native include 499 CLEAN_PHASE_TARGETS := $(addprefix clean-, $(CLEAN_PHASES)) 500 CLEAN_MODULE_TARGETS := $(addprefix clean-, $(ALL_MODULES)) 501 # Construct targets of the form clean-$module-$phase 502 CLEAN_MODULE_PHASE_TARGETS := $(addprefix clean-, $(foreach m, $(ALL_MODULES), \ 503 $(addprefix $m-, $(CLEAN_PHASES)))) 504 505 # Remove everything, except the output from configure. 506 clean: $(CLEAN_DIR_TARGETS) 507 ($(CD) $(OUTPUT_ROOT) && $(RM) -r source_tips build.log* build-trace*.log*) 508 $(ECHO) Cleaned all build artifacts. 509 510 $(CLEAN_DIR_TARGETS): 511 $(call CleanDir,$(patsubst clean-%, %, $@)) 512 513 $(CLEAN_PHASE_TARGETS): 514 $(call Clean-$(patsubst clean-%,%, $@)) 515 516 $(CLEAN_MODULE_TARGETS): 517 $(call CleanModule,$(patsubst clean-%, %, $@)) 518 519 $(CLEAN_MODULE_PHASE_TARGETS): 520 $(call Clean-$(word 3, $(subst -,$(SPACE),$@)), \ 521 $(word 2, $(subst -,$(SPACE),$@))) 522 523 # When removing the support dir, we must also remove jdk. Building classes has 524 # the side effect of generating native headers. The headers end up in support 525 # while classes and touch files end up in jdk. 526 clean-support: clean-jdk 527 528 clean-docs: clean-docstemp 529 530 # Remove everything, including configure configuration. 531 # If the output directory was created by configure and now becomes empty, remove it as well. 532 dist-clean: clean 533 ($(CD) $(OUTPUT_ROOT) && $(RM) -r *spec.gmk config.* configure-arguments \ 534 Makefile compare.sh tmp javacservers) 535 $(if $(filter $(CONF_NAME),$(notdir $(OUTPUT_ROOT))), \ 536 if test "x`$(LS) $(OUTPUT_ROOT)`" != x; then \ 537 $(ECHO) "Warning: Not removing non-empty configuration directory for '$(CONF_NAME)'" ; \ 538 else \ 539 ($(CD) $(SRC_ROOT) && $(ECHO) "Removing configuration directory for '$(CONF_NAME)'" \ 540 && $(RM) -r $(OUTPUT_ROOT)) \ 541 fi \ 542 ) 543 $(ECHO) Cleaned everything, you will have to re-run configure. 544 545 ALL_TARGETS += clean dist-clean $(CLEAN_DIR_TARGETS) $(CLEAN_PHASE_TARGETS) \ 546 $(CLEAN_MODULE_TARGETS) $(CLEAN_MODULE_PHASE_TARGETS) 547 548 ################################################################################ 549 550 # Setup a rule for SPEC file that fails if executed. This check makes sure the 551 # configuration is up to date after changes to configure. 552 ifeq ($(findstring reconfigure, $(MAKECMDGOALS)), ) 553 $(SPEC): $(wildcard $(SRC_ROOT)/common/autoconf/*) 554 @$(ECHO) "ERROR: $(SPEC) is not up to date." 555 @$(ECHO) "Please rerun configure! Easiest way to do this is by running" 556 @$(ECHO) "'make reconfigure'." 557 @$(ECHO) "It may also be ignored by setting IGNORE_OLD_CONFIG=true" 558 @if test "x$(IGNORE_OLD_CONFIG)" != "xtrue"; then exit 1; fi 559 endif 560 561 # The reconfigure target is automatically run serially from everything else 562 # by the Makefile calling this file. 563 564 reconfigure: 565 ifneq ($(CONFIGURE_COMMAND_LINE), ) 566 @$(ECHO) "Re-running configure using arguments '$(CONFIGURE_COMMAND_LINE)'" 567 else 568 @$(ECHO) "Re-running configure using default settings" 569 endif 570 @( cd $(OUTPUT_ROOT) && PATH="$(ORIGINAL_PATH)" \ 571 $(BASH) $(TOPDIR)/configure $(CONFIGURE_COMMAND_LINE) ) 572 573 ALL_TARGETS += reconfigure 574 575 ################################################################################ 576 # Declare *-only targets for each normal target 577 $(foreach t, $(ALL_TARGETS), $(eval $(t)-only: $(t))) 578 579 ALL_TARGETS += $(addsuffix -only, $(filter-out clean%, $(ALL_TARGETS))) 580 581 ################################################################################ 582 583 .PHONY: $(ALL_TARGETS) 584 585 include $(SRC_ROOT)/make/Jprt.gmk 586 587 FRC: # Force target