#
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
#
# under the terms of the GNU General Public License version 2 only, as
# published by the Free Software Foundation. Oracle designates this
# particular file as subject to the "Classpath" exception as provided
# by Oracle in the LICENSE file that accompanied this code.
#
# This code is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# version 2 for more details (a copy is included in the LICENSE file that
# accompanied this code).
#
# You should have received a copy of the GNU General Public License version
# 2 along with this work; if not, write to the Free Software Foundation,
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
#
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
# or visit www.oracle.com if you need additional information or have any
# questions.
#
# Basename of any originally supplied ALT_OUTPUTDIR directory
else
export ORIG_OUTPUTDIR_BASENAME
# The three possible directories created for output (3 build flavors)
# Relative path to a debug output area
# The created jdk image directory
# Relative path from an output directory to the image directory
TOPDIR:=.
# Everything for a full product build
all_product_build:: $(INSTALL)
$(MKDIR) -p $(BUILDTIMESDIR)
# Generic build of basic repo series
$(MKDIR) -p $(JDK_IMAGE_DIR)
@$(call StartTimer)
# The debug build, fastdebug or debug. Needs special handling.
#
# Note that debug builds do NOT do INSTALL steps aside from the
# install-binaries-jdk-debug or install-binaries-jdk-debug-clobber targets.
#
# DEBUG_NAME is fastdebug or debug
# ALT_OUTPUTDIR is changed to have -debug or -fastdebug suffix
# The resulting image directory (j2sdk-image) is used by the install makefiles
# (only if debug files are present when install checks for them)
# to create a debug install bundle jdk-*-debug-** bundle (tar or zip)
# which will install in the debug or fastdebug subdirectory of the
# normal product install area.
# The install process needs to know what the DEBUG_NAME is, so
# look for INSTALL_DEBUG_NAME in the install rules.
#
# NOTE: On windows, do not use $(ABS_BOOTDIR_OUTPUTDIR)-$(DEBUG_NAME).
# Due to the use of short paths in $(ABS_OUTPUTDIR), this may
# not be the same location.
#
# Location of fresh bootdir output
GENERATE_DOCS=false \
GENERATE_DOCS=false \
GENERATE_DOCS=false \
# Create boot image?
DO_BOOT_CYCLE=true
# Create the bootdir to use in the build
# Define variables to be used now for the boot jdk
ALT_BOOTDIR=$(FRESH_BOOTDIR) \
else
# Use the supplied ALT_BOOTDIR as the boot
$(MAKE) \
SKIP_FASTDEBUG_BUILD=true \
SKIP_DEBUG_BUILD=true \
$(BOOT_CYCLE_SETTINGS) \
# NOTE: On windows, do not use $(ABS_OUTPUTDIR)-$(DEBUG_NAME).
# Due to the use of short paths in $(ABS_OUTPUTDIR), this may
# not be the same location.
$(MAKE) \
DEBUG_NAME=$(DEBUG_NAME) \
GENERATE_DOCS=false \
CREATE_DEBUGINFO_BUNDLES=true \
# Build final image
# The source tips are stored with the relative path to the repo.
# This file will be used when constructing the jdk image.
$(CAT) $<
$(SOURCE_TIPS): FRC
@$(call GetSourceTips)
clobber::
#
# Dev builds
#
#
# Quick jdk verification build
#
#
# Quick jdk verification fastdebug build
#
#
# Quick deploy verification fastdebug build
#
$(MAKE) \
BUILD_HOTSPOT=false \
BUILD_JDK=false \
BUILD_LANGTOOLS=false \
BUILD_CORBA=false \
BUILD_JAXP=false \
BUILD_JAXWS=false \
BUILD_INSTALL=false \
BUILD_SPONSORS=false \
#
# Product build (skip debug builds)
#
#
# Check target
#
#
# Help target
#
# Intro help message
@$(ECHO) "\
Makefile for the JDK builds (all the JDK). \n\
"
# Target help
@$(ECHO) "\
--- Common Targets --- \n\
all -- build the core JDK (default target) \n\
help -- Print out help information \n\
check -- Check make variable values for correctness \n\
sanity -- Perform detailed sanity checks on system and settings \n\
fastdebug_build -- build the core JDK in 'fastdebug' mode (-g -O) \n\
debug_build -- build the core JDK in 'debug' mode (-g) \n\
clean -- remove all built and imported files \n\
clobber -- same as clean \n\
"
# Variable help (only common ones used by this Makefile)
@$(ECHO) "--- Common Variables ---"
@$(ECHO) " "
# One line descriptions for the variables
# Make variables to print out (description and value)
BOOTDIR \
# Make variables that should refer to directories that exist
BOOTDIR \
# Make variables that should refer to files that exist
# Some are windows specific
# For pattern rules below, so all are treated the same
# Complete variable check
# Pattern rule for printing out a variable
%.printval:
# Pattern rule for checking to see if a variable with a directory exists
%.checkdir:
@if [ ! -d $($*) ] ; then \
fi
# Pattern rule for checking to see if a variable with a file exists
%.checkfil:
@if [ ! -f $($*) ] ; then \
fi
# Misc notes on help
@$(ECHO) "\
--- Notes --- \n\
- All builds use same output directory unless overridden with \n\
\t ALT_OUTPUTDIR=<dir>, changing from product to fastdebug you may want \n\
\t to use the clean target first. \n\
- JDK_IMPORT_PATH must refer to a compatible build, not all past promoted \n\
\t builds or previous release JDK builds will work. \n\
- The fastest builds have been when the sources and the BOOTDIR are on \n\
\t local disk. \n\
"
@$(ECHO) "\
--- Examples --- \n\
"
################################################################
# Source bundling
################################################################
################################################################
# rule to test
################################################################
test:
@$(ECHO) "#################################################"
@$(ECHO) "#################################################"
@if [ -s $< ] ; then \
$(CAT) $<; \
exit 1; \
else \
$(ECHO) "Success! No failures detected"; \
fi
# Get failure list from log
@$(RM) $@
# Get log file of all tests run
fi \
)
$(RM) $@
) | tee $@
################################################################
# JPRT rule to build
################################################################
################################################################
# PHONY
################################################################
# Force target
FRC: