Merge
This commit is contained in:
commit
675e3578b4
5
Makefile
5
Makefile
@ -26,6 +26,11 @@
|
|||||||
# If NEWBUILD is defined, use the new build-infra Makefiles and configure.
|
# If NEWBUILD is defined, use the new build-infra Makefiles and configure.
|
||||||
# See NewMakefile.gmk for more information.
|
# See NewMakefile.gmk for more information.
|
||||||
|
|
||||||
|
# If not specified, select what the default build is
|
||||||
|
ifndef NEWBUILD
|
||||||
|
NEWBUILD=true
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(NEWBUILD),true)
|
ifeq ($(NEWBUILD),true)
|
||||||
|
|
||||||
# The new top level Makefile
|
# The new top level Makefile
|
||||||
|
350
NewMakefile.gmk
350
NewMakefile.gmk
@ -23,273 +23,109 @@
|
|||||||
# questions.
|
# questions.
|
||||||
#
|
#
|
||||||
|
|
||||||
# Utilities used in this Makefile
|
# This must be the first rule
|
||||||
BASENAME=basename
|
default:
|
||||||
CAT=cat
|
|
||||||
CD=cd
|
# Inclusion of this pseudo-target will cause make to execute this file
|
||||||
CMP=cmp
|
# serially, regardless of -j. Recursively called makefiles will not be
|
||||||
CP=cp
|
# affected, however. This is required for correct dependency management.
|
||||||
ECHO=echo
|
.NOTPARALLEL:
|
||||||
MKDIR=mkdir
|
|
||||||
PRINTF=printf
|
# The shell code below will be executed on /usr/ccs/bin/make on Solaris, but not in GNU make.
|
||||||
PWD=pwd
|
# /usr/ccs/bin/make lacks basically every other flow control mechanism.
|
||||||
TAR=tar
|
TEST_FOR_NON_GNUMAKE:sh=echo You are not using GNU make/gmake, this is a requirement. Check your path. 1>&2 && exit 1
|
||||||
ifeq ($(PLATFORM),windows)
|
|
||||||
ZIP=zip
|
# Assume we have GNU make, but check version.
|
||||||
|
ifeq (,$(findstring 3.81,$(MAKE_VERSION)))
|
||||||
|
ifeq (,$(findstring 3.82,$(MAKE_VERSION)))
|
||||||
|
$(error This version of GNU Make is too low ($(MAKE_VERSION)). Check your path, or upgrade to 3.81 or newer.)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Locate this Makefile
|
||||||
|
ifeq ($(filter /%,$(lastword $(MAKEFILE_LIST))),)
|
||||||
|
makefile_path:=$(CURDIR)/$(lastword $(MAKEFILE_LIST))
|
||||||
else
|
else
|
||||||
# store symbolic links as the link
|
makefile_path:=$(lastword $(MAKEFILE_LIST))
|
||||||
ZIP=zip -y
|
|
||||||
endif
|
endif
|
||||||
# Insure we have a path that looks like it came from pwd
|
root_dir:=$(dir $(makefile_path))
|
||||||
# (This is mostly for Windows sake and drive letters)
|
|
||||||
define UnixPath # path
|
|
||||||
$(shell (cd "$1" && $(PWD)))
|
|
||||||
endef
|
|
||||||
|
|
||||||
# Current root directory
|
# ... and then we can include our helper functions
|
||||||
CURRENT_DIRECTORY := $(shell $(PWD))
|
include $(root_dir)/common/makefiles/MakeHelpers.gmk
|
||||||
|
|
||||||
# Build directory root
|
$(eval $(call ParseLogLevel))
|
||||||
BUILD_DIR_ROOT = $(CURRENT_DIRECTORY)/build
|
$(eval $(call ParseConfAndSpec))
|
||||||
|
|
||||||
# All configured Makefiles to run
|
# Now determine if we have zero, one or several configurations to build.
|
||||||
ALL_MAKEFILES = $(wildcard $(BUILD_DIR_ROOT)/*-*/Makefile)
|
ifeq ($(SPEC),)
|
||||||
|
# Since we got past ParseConfAndSpec, we must be building a global target. Do nothing.
|
||||||
|
else
|
||||||
|
ifeq ($(words $(SPEC)),1)
|
||||||
|
# We are building a single configuration. This is the normal case. Execute the Main.gmk file.
|
||||||
|
include $(root_dir)/common/makefiles/Main.gmk
|
||||||
|
else
|
||||||
|
# We are building multiple configurations.
|
||||||
|
# First, find out the valid targets
|
||||||
|
# Run the makefile with an arbitraty SPEC using -p -q (quiet dry-run and dump rules) to find
|
||||||
|
# available PHONY targets. Use this list as valid targets to pass on to the repeated calls.
|
||||||
|
all_phony_targets=$(filter-out $(global_targets), $(strip $(shell \
|
||||||
|
$(MAKE) -p -q -f common/makefiles SPEC=$(firstword $(SPEC)) | \
|
||||||
|
grep ^.PHONY: | head -n 1 | cut -d " " -f 2-)))
|
||||||
|
|
||||||
# All bundles to create
|
$(all_phony_targets):
|
||||||
ALL_IMAGE_DIRS = $(wildcard $(BUILD_DIR_ROOT)/*-*/images/*-image)
|
@$(foreach spec,$(SPEC),($(MAKE) -f NewMakefile.gmk SPEC=$(spec) $(VERBOSE) VERBOSE=$(VERBOSE) $@) &&) true
|
||||||
|
|
||||||
# Build all the standard 'all', 'images', and 'clean' targets
|
endif
|
||||||
all images clean: checks
|
|
||||||
@if [ "$(ALL_MAKEFILES)" = "" ] ; then \
|
|
||||||
$(ECHO) "ERROR: No configurations to build"; exit 1; \
|
|
||||||
fi
|
|
||||||
@for bdir in $(dir $(ALL_MAKEFILES)) ; do \
|
|
||||||
$(ECHO) "$(CD) $${bdir} && $(MAKE) $@" ; \
|
|
||||||
$(CD) $${bdir} && $(MAKE) $@ ; \
|
|
||||||
done
|
|
||||||
|
|
||||||
# TBD: Deploy input
|
|
||||||
$(BUILD_DIR_ROOT)/.deploy_input:
|
|
||||||
@if [ "$(ALL_MAKEFILES)" = "" ] ; then \
|
|
||||||
$(ECHO) "ERROR: No configurations to build"; exit 1; \
|
|
||||||
fi
|
|
||||||
@for bdir in $(dir $(ALL_MAKEFILES)) ; do \
|
|
||||||
if [ deploy/make/Makefile ] ; then \
|
|
||||||
echo "Attempting deploy build." ; \
|
|
||||||
( \
|
|
||||||
$(RM) -r $${bdir}/deploy_input ; \
|
|
||||||
$(MKDIR) -p $${bdir}/deploy_input ; \
|
|
||||||
( $(CD) $${bdir}/images && $(TAR) -cf - j2sdk-image j2re-image ) \
|
|
||||||
| ( $(CD) $${bdir}/deploy_input && $(TAR) -xf - ) ; \
|
|
||||||
) ; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
# TBD: Deploy images
|
|
||||||
deploy: $(BUILD_DIR_ROOT)/.deploy_input
|
|
||||||
@if [ "$(ALL_MAKEFILES)" = "" ] ; then \
|
|
||||||
$(ECHO) "ERROR: No configurations to build"; exit 1; \
|
|
||||||
fi
|
|
||||||
@for bdir in $(dir $(ALL_MAKEFILES)) ; do \
|
|
||||||
if [ deploy/make/Makefile ] ; then \
|
|
||||||
echo "Attempting deploy build." ; \
|
|
||||||
( \
|
|
||||||
$(CD) deploy/make && \
|
|
||||||
$(MAKE) \
|
|
||||||
ABS_OUTPUTDIR=$${bdir}/deploy_input \
|
|
||||||
OUTPUTDIR=$${bdir}/deploy_input \
|
|
||||||
) ; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
|
|
||||||
# TBD: Install bundles
|
|
||||||
install:
|
|
||||||
|
|
||||||
# Bundle creation
|
|
||||||
bundles:
|
|
||||||
@if [ "$(ALL_IMAGE_DIRS)" = "" ] ; then \
|
|
||||||
$(ECHO) "ERROR: No images to bundle"; exit 1; \
|
|
||||||
fi
|
|
||||||
@for i in $(ALL_IMAGE_DIRS) ; do \
|
|
||||||
$(MKDIR) -p $${i}/../../bundles && \
|
|
||||||
$(RM) $${i}/../../bundles/`$(BASENAME) $${i}`.zip && \
|
|
||||||
$(ECHO) "$(CD) $${i} && $(ZIP) -q -r ../../bundles/`$(BASENAME) $${i}`.zip ." && \
|
|
||||||
$(CD) $${i} && $(ZIP) -q -r ../../bundles/`$(BASENAME) $${i}`.zip . ; \
|
|
||||||
done
|
|
||||||
|
|
||||||
# Clobber all the built files
|
|
||||||
clobber::
|
|
||||||
$(RM) -r $(BUILD_DIR_ROOT)
|
|
||||||
|
|
||||||
# Make various checks to insure the build will be successful
|
|
||||||
# Possibilities:
|
|
||||||
# * Check that if any closed repo is provided, they all must be.
|
|
||||||
# * Check that all open repos exist, at least until we are ready for some
|
|
||||||
# kind of partial build.
|
|
||||||
checks:
|
|
||||||
@$(ECHO) "No checks yet"
|
|
||||||
|
|
||||||
# Keep track of user targets
|
|
||||||
USER_TARGETS += all deploy install images clean clobber checks
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# To help in adoption of the new configure&&make build process, a bridge
|
|
||||||
# build will use the old settings to run configure and do the build.
|
|
||||||
|
|
||||||
# Build with the configure bridge
|
|
||||||
bridgeBuild: bridge2configure images
|
|
||||||
|
|
||||||
# Bridge from old Makefile ALT settings to configure options
|
|
||||||
bridge2configure: $(BUILD_DIR_ROOT)/.bridge2configureOpts
|
|
||||||
bash ./configure $(strip $(shell $(CAT) $<))
|
|
||||||
|
|
||||||
# Create a file with configure options created from old Makefile mechanisms.
|
|
||||||
$(BUILD_DIR_ROOT)/.bridge2configureOpts: $(BUILD_DIR_ROOT)/.bridge2configureOptsLatest
|
|
||||||
$(RM) $@
|
|
||||||
$(CP) $< $@
|
|
||||||
|
|
||||||
# Use this file to only change when obvious things have changed
|
|
||||||
$(BUILD_DIR_ROOT)/.bridge2configureOptsLatest: FRC
|
|
||||||
$(RM) $@.tmp
|
|
||||||
$(MKDIR) -p $(BUILD_DIR_ROOT)
|
|
||||||
@$(ECHO) " --with-debug-level=$(if $(DEBUG_LEVEL),$(DEBUG_LEVEL),release) " >> $@.tmp
|
|
||||||
ifdef ARCH_DATA_MODEL
|
|
||||||
@$(ECHO) " --with-target-bits=$(ARCH_DATA_MODEL) " >> $@.tmp
|
|
||||||
endif
|
|
||||||
ifdef ALT_PARALLEL_COMPILE_JOBS
|
|
||||||
@$(ECHO) " --with-num-cores=$(ALT_PARALLEL_COMPILE_JOBS) " >> $@.tmp
|
|
||||||
endif
|
|
||||||
ifdef ALT_BOOTDIR
|
|
||||||
@$(ECHO) " --with-boot-jdk=$(call UnixPath,$(ALT_BOOTDIR)) " >> $@.tmp
|
|
||||||
endif
|
|
||||||
ifdef ALT_CUPS_HEADERS_PATH
|
|
||||||
@$(ECHO) " --with-cups-include=$(call UnixPath,$(ALT_CUPS_HEADERS_PATH)) " >> $@.tmp
|
|
||||||
endif
|
|
||||||
ifdef ALT_FREETYPE_HEADERS_PATH
|
|
||||||
@$(ECHO) " --with-freetype=$(call UnixPath,$(ALT_FREETYPE_HEADERS_PATH)/..) " >> $@.tmp
|
|
||||||
endif
|
|
||||||
@if [ -f $@ ] ; then \
|
|
||||||
if ! $(CMP) $@ $@.tmp > /dev/null ; then \
|
|
||||||
$(CP) $@.tmp $@ ; \
|
|
||||||
fi ; \
|
|
||||||
else \
|
|
||||||
$(CP) $@.tmp $@ ; \
|
|
||||||
fi
|
|
||||||
$(RM) $@.tmp
|
|
||||||
|
|
||||||
# Clobber all the built files
|
|
||||||
clobber:: bridge2clobber
|
|
||||||
bridge2clobber::
|
|
||||||
$(RM) $(BUILD_DIR_ROOT)/.bridge2*
|
|
||||||
$(RM) $(BUILD_DIR_ROOT)/.deploy_input
|
|
||||||
|
|
||||||
# Keep track of phony targets
|
|
||||||
PHONY_LIST += bridge2configure bridgeBuild bridge2clobber
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Sanity checks (history target)
|
|
||||||
#
|
|
||||||
|
|
||||||
sanity: checks
|
|
||||||
|
|
||||||
# Keep track of user targets
|
|
||||||
USER_TARGETS += sanity
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Javadocs
|
|
||||||
#
|
|
||||||
|
|
||||||
javadocs:
|
|
||||||
cd common/makefiles && $(MAKE) -f MakefileJavadoc.gmk
|
|
||||||
|
|
||||||
# Keep track of user targets
|
|
||||||
USER_TARGETS += javadocs
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# JPRT targets
|
|
||||||
|
|
||||||
ifndef JPRT_ARCHIVE_BUNDLE
|
|
||||||
JPRT_ARCHIVE_BUNDLE=/tmp/jprt_bundles/j2sdk-image.zip
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
jprt_build_product: DEBUG_LEVEL=release
|
# Include this after a potential spec file has been included so that the bundles target
|
||||||
jprt_build_product: BUILD_DIRNAME=*-release
|
# has access to the spec variables.
|
||||||
jprt_build_product: jprt_build_generic
|
include $(root_dir)/common/makefiles/Jprt.gmk
|
||||||
|
|
||||||
jprt_build_fastdebug: DEBUG_LEVEL=fastdebug
|
# Here are "global" targets, i.e. targets that can be executed without specifying a single configuration.
|
||||||
jprt_build_fastdebug: BUILD_DIRNAME=*-fastdebug
|
# If you addd more global targets, please update the variable global_targets in MakeHelpers.
|
||||||
jprt_build_fastdebug: jprt_build_generic
|
|
||||||
|
|
||||||
jprt_build_debug: DEBUG_LEVEL=slowdebug
|
|
||||||
jprt_build_debug: BUILD_DIRNAME=*-debug
|
|
||||||
jprt_build_debug: jprt_build_generic
|
|
||||||
|
|
||||||
jprt_build_generic: $(JPRT_ARCHIVE_BUNDLE)
|
|
||||||
|
|
||||||
$(JPRT_ARCHIVE_BUNDLE): bridgeBuild bundles
|
|
||||||
$(MKDIR) -p $(@D)
|
|
||||||
$(RM) $@
|
|
||||||
$(CP) $(BUILD_DIR_ROOT)/$(BUILD_DIRNAME)/bundles/j2sdk-image.zip $@
|
|
||||||
|
|
||||||
# Keep track of phony targets
|
|
||||||
PHONY_LIST += jprt_build_product jprt_build_fastdebug jprt_build_debug \
|
|
||||||
jprt_build_generic
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Help target
|
|
||||||
|
|
||||||
HELP_FORMAT=%12s%s\n
|
|
||||||
|
|
||||||
help:
|
help:
|
||||||
@$(PRINTF) "# JDK Makefile\n"
|
$(info )
|
||||||
@$(PRINTF) "#\n"
|
$(info OpenJDK Makefile help)
|
||||||
@$(PRINTF) "# Usage: make [Target]\n"
|
$(info =====================)
|
||||||
@$(PRINTF) "#\n"
|
$(info )
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "Target " "Description"
|
$(info Common make targets)
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "------ " "-----------"
|
$(info . make [default] # Compile all product in langtools, hotspot, jaxp, jaxws,)
|
||||||
@for i in $(USER_TARGETS) ; do \
|
$(info . # corba and jdk)
|
||||||
$(MAKE) help_$${i} ; \
|
$(info . make all # Compile everything, all repos and images)
|
||||||
done
|
$(info . make images # Create complete j2sdk and j2re images)
|
||||||
@$(PRINTF) "#\n"
|
$(info . make overlay-images # Create limited images for sparc 64 bit platforms)
|
||||||
|
$(info . make bootcycle-images # Build images twice, second time with newly build JDK)
|
||||||
|
$(info . make install # Install the generated images locally)
|
||||||
|
$(info . make clean # Remove all files generated by make, but not those)
|
||||||
|
$(info . # generated by configure)
|
||||||
|
$(info . make dist-clean # Remove all files, including configuration)
|
||||||
|
$(info . make help # Give some help on using make)
|
||||||
|
$(info . make test # Run tests, default is all tests (see TEST below))
|
||||||
|
$(info )
|
||||||
|
$(info Targets for specific components)
|
||||||
|
$(info (Component is any of langtools, corba, jaxp, jaxws, hotspot, jdk, images or overlay-images))
|
||||||
|
$(info . make <component> # Build <component> and everything it depends on. )
|
||||||
|
$(info . make <component>-only # Build <component> only, without dependencies. This)
|
||||||
|
$(info . # is faster but can result in incorrect build results!)
|
||||||
|
$(info . make clean-<component> # Remove files generated by make for <component>)
|
||||||
|
$(info )
|
||||||
|
$(info Useful make variables)
|
||||||
|
$(info . make CONF= # Build all configurations (note, assignment is empty))
|
||||||
|
$(info . make CONF=<substring> # Build the configuration(s) with a name matching)
|
||||||
|
$(info . # <substring>)
|
||||||
|
$(info )
|
||||||
|
$(info . make LOG=<loglevel> # Change the log level from warn to <loglevel>)
|
||||||
|
$(info . # Available log levels are:)
|
||||||
|
$(info . # 'warn' (default), 'info', 'debug' and 'trace')
|
||||||
|
$(info . # To see executed command lines, use LOG=debug)
|
||||||
|
$(info )
|
||||||
|
$(info . make JOBS=<n> # Run <n> parallel make jobs)
|
||||||
|
$(info . # Note that -jN does not work as expected!)
|
||||||
|
$(info )
|
||||||
|
$(info . make test TEST=<test> # Only run the given test or tests, e.g.)
|
||||||
|
$(info . # make test TEST="jdk_lang jdk_net")
|
||||||
|
$(info )
|
||||||
|
|
||||||
help_all:
|
.PHONY: help
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Build the entire jdk but not the images"
|
|
||||||
help_images:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Create the jdk images for the builds"
|
|
||||||
help_deploy:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Create the jdk deploy images from the jdk images"
|
|
||||||
help_install:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Create the jdk install bundles from the deploy images"
|
|
||||||
help_clean:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Clean and prepare for a fresh build from scratch"
|
|
||||||
help_clobber:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Clean and also purge any hidden derived data"
|
|
||||||
help_checks:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Perform various checks to make sure we can build"
|
|
||||||
help_sanity:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Same as 'make checks'"
|
|
||||||
help_javadocs:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Build the javadocs"
|
|
||||||
help_help:
|
|
||||||
@$(PRINTF) "# $(HELP_FORMAT)" "$(subst help_,,$@) - " \
|
|
||||||
"Print out the help messages"
|
|
||||||
|
|
||||||
# Keep track of user targets
|
|
||||||
USER_TARGETS += help
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Phony targets
|
|
||||||
.PHONY: $(PHONY_LIST) $(USER_TARGETS)
|
|
||||||
|
|
||||||
# Force target
|
|
||||||
FRC:
|
|
||||||
|
@ -24,4 +24,4 @@
|
|||||||
# This Makefile was generated by configure @DATE_WHEN_CONFIGURED@
|
# This Makefile was generated by configure @DATE_WHEN_CONFIGURED@
|
||||||
# GENERATED FILE, DO NOT EDIT
|
# GENERATED FILE, DO NOT EDIT
|
||||||
SPEC:=@OUTPUT_ROOT@/spec.gmk
|
SPEC:=@OUTPUT_ROOT@/spec.gmk
|
||||||
include @SRC_ROOT@/common/makefiles/Makefile
|
include @SRC_ROOT@/NewMakefile.gmk
|
||||||
|
@ -26,9 +26,11 @@ script_dir=`dirname $0`
|
|||||||
|
|
||||||
# Create a timestamp as seconds since epoch
|
# Create a timestamp as seconds since epoch
|
||||||
if test "x`uname -s`" = "xSunOS"; then
|
if test "x`uname -s`" = "xSunOS"; then
|
||||||
# date +%s is not available on Solaris, use this workaround
|
TIMESTAMP=`date +%s`
|
||||||
# from http://solarisjedi.blogspot.co.uk/2006/06/solaris-date-command-and-epoch-time.html
|
if test "x$TIMESTAMP" = "x%s"; then
|
||||||
TIMESTAMP=`/usr/bin/truss /usr/bin/date 2>&1 | nawk -F= '/^time\(\)/ {gsub(/ /,"",$2);print $2}'`
|
# date +%s not available on this Solaris, use workaround from nawk(1):
|
||||||
|
TIMESTAMP=`nawk 'BEGIN{print srand()}'`
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
TIMESTAMP=`date +%s`
|
TIMESTAMP=`date +%s`
|
||||||
fi
|
fi
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -234,7 +234,9 @@ BASIC_REQUIRE_PROG(BASH, bash)
|
|||||||
BASIC_REQUIRE_PROG(CAT, cat)
|
BASIC_REQUIRE_PROG(CAT, cat)
|
||||||
BASIC_REQUIRE_PROG(CHMOD, chmod)
|
BASIC_REQUIRE_PROG(CHMOD, chmod)
|
||||||
BASIC_REQUIRE_PROG(CMP, cmp)
|
BASIC_REQUIRE_PROG(CMP, cmp)
|
||||||
|
BASIC_REQUIRE_PROG(COMM, comm)
|
||||||
BASIC_REQUIRE_PROG(CP, cp)
|
BASIC_REQUIRE_PROG(CP, cp)
|
||||||
|
BASIC_REQUIRE_PROG(CPIO, cpio)
|
||||||
BASIC_REQUIRE_PROG(CUT, cut)
|
BASIC_REQUIRE_PROG(CUT, cut)
|
||||||
BASIC_REQUIRE_PROG(DATE, date)
|
BASIC_REQUIRE_PROG(DATE, date)
|
||||||
BASIC_REQUIRE_PROG(DIFF, [gdiff diff])
|
BASIC_REQUIRE_PROG(DIFF, [gdiff diff])
|
||||||
@ -633,6 +635,18 @@ AC_DEFUN([BASIC_CHECK_DIR_ON_LOCAL_DISK],
|
|||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# Check that source files have basic read permissions set. This might
|
||||||
|
# not be the case in cygwin in certain conditions.
|
||||||
|
AC_DEFUN_ONCE([BASIC_CHECK_SRC_PERMS],
|
||||||
|
[
|
||||||
|
if test x"$OPENJDK_BUILD_OS" = xwindows; then
|
||||||
|
file_to_test="$SRC_ROOT/LICENSE"
|
||||||
|
if test `$STAT -c '%a' "$file_to_test"` -lt 400; then
|
||||||
|
AC_MSG_ERROR([Bad file permissions on src files. This is usually caused by cloning the repositories with a non cygwin hg in a directory not created in cygwin.])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
AC_DEFUN_ONCE([BASIC_TEST_USABILITY_ISSUES],
|
AC_DEFUN_ONCE([BASIC_TEST_USABILITY_ISSUES],
|
||||||
[
|
[
|
||||||
|
|
||||||
@ -642,6 +656,8 @@ BASIC_CHECK_DIR_ON_LOCAL_DISK($OUTPUT_ROOT,
|
|||||||
[OUTPUT_DIR_IS_LOCAL="no"])
|
[OUTPUT_DIR_IS_LOCAL="no"])
|
||||||
AC_MSG_RESULT($OUTPUT_DIR_IS_LOCAL)
|
AC_MSG_RESULT($OUTPUT_DIR_IS_LOCAL)
|
||||||
|
|
||||||
|
BASIC_CHECK_SRC_PERMS
|
||||||
|
|
||||||
# Check if the user has any old-style ALT_ variables set.
|
# Check if the user has any old-style ALT_ variables set.
|
||||||
FOUND_ALT_VARIABLES=`env | grep ^ALT_`
|
FOUND_ALT_VARIABLES=`env | grep ^ALT_`
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_CYGWIN],
|
|||||||
# bat and cmd files are not always considered executable in cygwin causing which
|
# bat and cmd files are not always considered executable in cygwin causing which
|
||||||
# to not find them
|
# to not find them
|
||||||
if test "x$new_path" = x \
|
if test "x$new_path" = x \
|
||||||
&& test "x`$ECHO \"$path\" | $GREP -e \"\\.bat$\" -e \"\\.cmd$\"`" != x \
|
&& test "x`$ECHO \"$path\" | $GREP -i -e \"\\.bat$\" -e \"\\.cmd$\"`" != x \
|
||||||
&& test "x`$LS \"$path\" 2>/dev/null`" != x; then
|
&& test "x`$LS \"$path\" 2>/dev/null`" != x; then
|
||||||
new_path=`$CYGPATH -u "$path"`
|
new_path=`$CYGPATH -u "$path"`
|
||||||
fi
|
fi
|
||||||
@ -191,7 +191,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_CYGWIN],
|
|||||||
# bat and cmd files are not always considered executable in cygwin causing which
|
# bat and cmd files are not always considered executable in cygwin causing which
|
||||||
# to not find them
|
# to not find them
|
||||||
if test "x$new_path" = x \
|
if test "x$new_path" = x \
|
||||||
&& test "x`$ECHO \"$path\" | $GREP -e \"\\.bat$\" -e \"\\.cmd$\"`" != x \
|
&& test "x`$ECHO \"$path\" | $GREP -i -e \"\\.bat$\" -e \"\\.cmd$\"`" != x \
|
||||||
&& test "x`$LS \"$path\" 2>/dev/null`" != x; then
|
&& test "x`$LS \"$path\" 2>/dev/null`" != x; then
|
||||||
new_path=`$CYGPATH -u "$path"`
|
new_path=`$CYGPATH -u "$path"`
|
||||||
fi
|
fi
|
||||||
|
@ -1,4 +1,29 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
|
#
|
||||||
|
# Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
|
||||||
# Attempt to guess a canonical system name.
|
# Attempt to guess a canonical system name.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
||||||
# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
||||||
|
26
common/autoconf/build-aux/config.sub
vendored
26
common/autoconf/build-aux/config.sub
vendored
@ -1,4 +1,30 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
|
||||||
# Configuration validation subroutine script.
|
# Configuration validation subroutine script.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
||||||
# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
||||||
|
@ -1,4 +1,30 @@
|
|||||||
# pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*-
|
# pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*-
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright © 2004 Scott James Remnant <scott@netsplit.com>.
|
# Copyright © 2004 Scott James Remnant <scott@netsplit.com>.
|
||||||
#
|
#
|
||||||
|
@ -1,32 +0,0 @@
|
|||||||
#
|
|
||||||
# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
#
|
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
|
||||||
# under the terms of the GNU General Public License version 2 only, as
|
|
||||||
# published by the Free Software Foundation.
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
|
|
||||||
LAUNCHER_NAME=java
|
|
||||||
PRODUCT_NAME="Java(TM)"
|
|
||||||
PRODUCT_SUFFIX="SE Runtime Environment"
|
|
||||||
JDK_RC_PLATFORM_NAME="Platform SE"
|
|
||||||
COMPANY_NAME="Oracle Corporation"
|
|
||||||
|
|
||||||
# Might need better names for these
|
|
||||||
MACOSX_BUNDLE_NAME_BASE="Java SE"
|
|
||||||
MACOSX_BUNDLE_ID_BASE="com.oracle.java"
|
|
@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2012, 2013 Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,6 +48,7 @@ GREP="@GREP@"
|
|||||||
JAVAP="@FIXPATH@ @BOOT_JDK@/bin/javap"
|
JAVAP="@FIXPATH@ @BOOT_JDK@/bin/javap"
|
||||||
LDD="@LDD@"
|
LDD="@LDD@"
|
||||||
MKDIR="@MKDIR@"
|
MKDIR="@MKDIR@"
|
||||||
|
NAWK="@NAWK@"
|
||||||
NM="@NM@"
|
NM="@NM@"
|
||||||
OBJDUMP="@OBJDUMP@"
|
OBJDUMP="@OBJDUMP@"
|
||||||
OTOOL="@OTOOL@"
|
OTOOL="@OTOOL@"
|
||||||
|
@ -83,6 +83,9 @@ PLATFORM_SETUP_OPENJDK_BUILD_AND_TARGET
|
|||||||
BASIC_SETUP_PATHS
|
BASIC_SETUP_PATHS
|
||||||
BASIC_SETUP_LOGGING
|
BASIC_SETUP_LOGGING
|
||||||
|
|
||||||
|
# Check if it's a pure open build or if custom sources are to be used.
|
||||||
|
JDKOPT_SETUP_OPEN_OR_CUSTOM
|
||||||
|
|
||||||
# These are needed to be able to create a configuration name (and thus the output directory)
|
# These are needed to be able to create a configuration name (and thus the output directory)
|
||||||
JDKOPT_SETUP_JDK_VARIANT
|
JDKOPT_SETUP_JDK_VARIANT
|
||||||
JDKOPT_SETUP_JVM_VARIANTS
|
JDKOPT_SETUP_JVM_VARIANTS
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -235,7 +235,7 @@ HOTSPOT_TARGET="$HOTSPOT_TARGET docs export_$HOTSPOT_EXPORT"
|
|||||||
# from configure, but only server is valid anyway. Fix this
|
# from configure, but only server is valid anyway. Fix this
|
||||||
# when hotspot makefiles are rewritten.
|
# when hotspot makefiles are rewritten.
|
||||||
if test "x$MACOSX_UNIVERSAL" = xtrue; then
|
if test "x$MACOSX_UNIVERSAL" = xtrue; then
|
||||||
HOTSPOT_TARGET=universal_product
|
HOTSPOT_TARGET=universal_${HOTSPOT_EXPORT}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#####
|
#####
|
||||||
@ -247,46 +247,50 @@ AC_SUBST(DEBUG_CLASSFILES)
|
|||||||
AC_SUBST(BUILD_VARIANT_RELEASE)
|
AC_SUBST(BUILD_VARIANT_RELEASE)
|
||||||
])
|
])
|
||||||
|
|
||||||
AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_OPTIONS],
|
|
||||||
[
|
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
# Should we build only OpenJDK even if closed sources are present?
|
# Should we build only OpenJDK even if closed sources are present?
|
||||||
#
|
#
|
||||||
AC_ARG_ENABLE([openjdk-only], [AS_HELP_STRING([--enable-openjdk-only],
|
AC_DEFUN_ONCE([JDKOPT_SETUP_OPEN_OR_CUSTOM],
|
||||||
[supress building closed source even if present @<:@disabled@:>@])],,[enable_openjdk_only="no"])
|
[
|
||||||
|
AC_ARG_ENABLE([openjdk-only], [AS_HELP_STRING([--enable-openjdk-only],
|
||||||
|
[suppress building custom source even if present @<:@disabled@:>@])],,[enable_openjdk_only="no"])
|
||||||
|
|
||||||
AC_MSG_CHECKING([for presence of closed sources])
|
AC_MSG_CHECKING([for presence of closed sources])
|
||||||
if test -d "$SRC_ROOT/jdk/src/closed"; then
|
if test -d "$SRC_ROOT/jdk/src/closed"; then
|
||||||
CLOSED_SOURCE_PRESENT=yes
|
CLOSED_SOURCE_PRESENT=yes
|
||||||
else
|
|
||||||
CLOSED_SOURCE_PRESENT=no
|
|
||||||
fi
|
|
||||||
AC_MSG_RESULT([$CLOSED_SOURCE_PRESENT])
|
|
||||||
|
|
||||||
AC_MSG_CHECKING([if closed source is supressed (openjdk-only)])
|
|
||||||
SUPRESS_CLOSED_SOURCE="$enable_openjdk_only"
|
|
||||||
AC_MSG_RESULT([$SUPRESS_CLOSED_SOURCE])
|
|
||||||
|
|
||||||
if test "x$CLOSED_SOURCE_PRESENT" = xno; then
|
|
||||||
OPENJDK=true
|
|
||||||
if test "x$SUPRESS_CLOSED_SOURCE" = "xyes"; then
|
|
||||||
AC_MSG_WARN([No closed source present, --enable-openjdk-only makes no sense])
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if test "x$SUPRESS_CLOSED_SOURCE" = "xyes"; then
|
|
||||||
OPENJDK=true
|
|
||||||
else
|
else
|
||||||
OPENJDK=false
|
CLOSED_SOURCE_PRESENT=no
|
||||||
fi
|
fi
|
||||||
fi
|
AC_MSG_RESULT([$CLOSED_SOURCE_PRESENT])
|
||||||
|
|
||||||
if test "x$OPENJDK" = "xtrue"; then
|
AC_MSG_CHECKING([if closed source is suppressed (openjdk-only)])
|
||||||
|
SUPPRESS_CLOSED_SOURCE="$enable_openjdk_only"
|
||||||
|
AC_MSG_RESULT([$SUPPRESS_CLOSED_SOURCE])
|
||||||
|
|
||||||
|
if test "x$CLOSED_SOURCE_PRESENT" = xno; then
|
||||||
|
OPENJDK=true
|
||||||
|
if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then
|
||||||
|
AC_MSG_WARN([No closed source present, --enable-openjdk-only makes no sense])
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then
|
||||||
|
OPENJDK=true
|
||||||
|
else
|
||||||
|
OPENJDK=false
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "x$OPENJDK" = "xtrue"; then
|
||||||
SET_OPENJDK="OPENJDK=true"
|
SET_OPENJDK="OPENJDK=true"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
AC_SUBST(SET_OPENJDK)
|
AC_SUBST(SET_OPENJDK)
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_OPTIONS],
|
||||||
|
[
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
@ -369,13 +373,51 @@ COMPRESS_JARS=false
|
|||||||
AC_SUBST(COMPRESS_JARS)
|
AC_SUBST(COMPRESS_JARS)
|
||||||
])
|
])
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
#
|
||||||
|
# Setup version numbers
|
||||||
|
#
|
||||||
AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_VERSION_NUMBERS],
|
AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_VERSION_NUMBERS],
|
||||||
[
|
[
|
||||||
# Source the version numbers
|
# Source the version numbers
|
||||||
. $AUTOCONF_DIR/version.numbers
|
. $AUTOCONF_DIR/version-numbers
|
||||||
if test "x$OPENJDK" = "xfalse"; then
|
|
||||||
. $AUTOCONF_DIR/closed.version.numbers
|
# Get the settings from parameters
|
||||||
|
AC_ARG_WITH(milestone, [AS_HELP_STRING([--with-milestone],
|
||||||
|
[Set milestone value for build @<:@internal@:>@])])
|
||||||
|
if test "x$with_milestone" = xyes; then
|
||||||
|
AC_MSG_ERROR([Milestone must have a value])
|
||||||
|
elif test "x$with_milestone" != x; then
|
||||||
|
MILESTONE="$with_milestone"
|
||||||
|
else
|
||||||
|
MILESTONE=internal
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
AC_ARG_WITH(build-number, [AS_HELP_STRING([--with-build-number],
|
||||||
|
[Set build number value for build @<:@b00@:>@])])
|
||||||
|
if test "x$with_build_number" = xyes; then
|
||||||
|
AC_MSG_ERROR([Build number must have a value])
|
||||||
|
elif test "x$with_build_number" != x; then
|
||||||
|
JDK_BUILD_NUMBER="$with_build_number"
|
||||||
|
fi
|
||||||
|
if test "x$JDK_BUILD_NUMBER" = x; then
|
||||||
|
JDK_BUILD_NUMBER=b00
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_ARG_WITH(user-release-suffix, [AS_HELP_STRING([--with-user-release-suffix],
|
||||||
|
[Add a custom string to the version string if build number isn't set.@<:@username_builddateb00@:>@])])
|
||||||
|
if test "x$with_user_release_suffix" = xyes; then
|
||||||
|
AC_MSG_ERROR([Release suffix must have a value])
|
||||||
|
elif test "x$with_user_release_suffix" != x; then
|
||||||
|
USER_RELEASE_SUFFIX="$with_user_release_suffix"
|
||||||
|
else
|
||||||
|
BUILD_DATE=`date '+%Y_%m_%d_%H_%M'`
|
||||||
|
# Avoid [:alnum:] since it depends on the locale.
|
||||||
|
CLEAN_USERNAME=`echo "$USER" | $TR -d -c 'abcdefghijklmnopqrstuvqxyz0123456789'`
|
||||||
|
USER_RELEASE_SUFFIX=`echo "${CLEAN_USERNAME}_${BUILD_DATE}" | $TR 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
||||||
|
fi
|
||||||
|
AC_SUBST(USER_RELEASE_SUFFIX)
|
||||||
|
|
||||||
# Now set the JDK version, milestone, build number etc.
|
# Now set the JDK version, milestone, build number etc.
|
||||||
AC_SUBST(JDK_MAJOR_VERSION)
|
AC_SUBST(JDK_MAJOR_VERSION)
|
||||||
AC_SUBST(JDK_MINOR_VERSION)
|
AC_SUBST(JDK_MINOR_VERSION)
|
||||||
@ -394,34 +436,13 @@ AC_SUBST(MACOSX_BUNDLE_ID_BASE)
|
|||||||
COPYRIGHT_YEAR=`date +'%Y'`
|
COPYRIGHT_YEAR=`date +'%Y'`
|
||||||
AC_SUBST(COPYRIGHT_YEAR)
|
AC_SUBST(COPYRIGHT_YEAR)
|
||||||
|
|
||||||
RUNTIME_NAME="$PRODUCT_NAME $PRODUCT_SUFFIX"
|
|
||||||
AC_SUBST(RUNTIME_NAME)
|
|
||||||
|
|
||||||
if test "x$JDK_UPDATE_VERSION" != x; then
|
if test "x$JDK_UPDATE_VERSION" != x; then
|
||||||
JDK_VERSION="${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_MICRO_VERSION}_${JDK_UPDATE_VERSION}"
|
JDK_VERSION="${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_MICRO_VERSION}_${JDK_UPDATE_VERSION}"
|
||||||
else
|
else
|
||||||
JDK_VERSION="${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_MICRO_VERSION}"
|
JDK_VERSION="${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_MICRO_VERSION}"
|
||||||
fi
|
fi
|
||||||
AC_SUBST(JDK_VERSION)
|
AC_SUBST(JDK_VERSION)
|
||||||
|
|
||||||
if test "x$MILESTONE" != x; then
|
|
||||||
RELEASE="${JDK_VERSION}-${MILESTONE}${BUILD_VARIANT_RELEASE}"
|
|
||||||
else
|
|
||||||
RELEASE="${JDK_VERSION}${BUILD_VARIANT_RELEASE}"
|
|
||||||
fi
|
|
||||||
AC_SUBST(RELEASE)
|
|
||||||
|
|
||||||
if test "x$JDK_BUILD_NUMBER" != x; then
|
|
||||||
FULL_VERSION="${RELEASE}-${JDK_BUILD_NUMBER}"
|
|
||||||
else
|
|
||||||
JDK_BUILD_NUMBER=b00
|
|
||||||
BUILD_DATE=`date '+%Y_%m_%d_%H_%M'`
|
|
||||||
# Avoid [:alnum:] since it depends on the locale.
|
|
||||||
CLEAN_USERNAME=`echo "$USER" | $TR -d -c 'abcdefghijklmnopqrstuvqxyz0123456789'`
|
|
||||||
USER_RELEASE_SUFFIX=`echo "${CLEAN_USERNAME}_${BUILD_DATE}" | $TR 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
|
||||||
FULL_VERSION="${RELEASE}-${USER_RELEASE_SUFFIX}-${JDK_BUILD_NUMBER}"
|
|
||||||
fi
|
|
||||||
AC_SUBST(FULL_VERSION)
|
|
||||||
COOKED_BUILD_NUMBER=`$ECHO $JDK_BUILD_NUMBER | $SED -e 's/^b//' -e 's/^0//'`
|
COOKED_BUILD_NUMBER=`$ECHO $JDK_BUILD_NUMBER | $SED -e 's/^b//' -e 's/^0//'`
|
||||||
AC_SUBST(COOKED_BUILD_NUMBER)
|
AC_SUBST(COOKED_BUILD_NUMBER)
|
||||||
])
|
])
|
||||||
@ -434,7 +455,7 @@ AC_SUBST(HOTSPOT_MAKE_ARGS)
|
|||||||
# The name of the Service Agent jar.
|
# The name of the Service Agent jar.
|
||||||
SALIB_NAME="${LIBRARY_PREFIX}saproc${SHARED_LIBRARY_SUFFIX}"
|
SALIB_NAME="${LIBRARY_PREFIX}saproc${SHARED_LIBRARY_SUFFIX}"
|
||||||
if test "x$OPENJDK_TARGET_OS" = "xwindows"; then
|
if test "x$OPENJDK_TARGET_OS" = "xwindows"; then
|
||||||
SALIB_NAME="${LIBRARY_PREFIX}sawindbg${SHARED_LIBRARY_SUFFIX}"
|
SALIB_NAME="${LIBRARY_PREFIX}sawindbg${SHARED_LIBRARY_SUFFIX}"
|
||||||
fi
|
fi
|
||||||
AC_SUBST(SALIB_NAME)
|
AC_SUBST(SALIB_NAME)
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -163,11 +163,22 @@ MACOSX_BUNDLE_ID_BASE=@MACOSX_BUNDLE_ID_BASE@
|
|||||||
|
|
||||||
# Different version strings generated from the above information.
|
# Different version strings generated from the above information.
|
||||||
JDK_VERSION:=@JDK_VERSION@
|
JDK_VERSION:=@JDK_VERSION@
|
||||||
RUNTIME_NAME:=@RUNTIME_NAME@
|
RUNTIME_NAME=$(PRODUCT_NAME) $(PRODUCT_SUFFIX)
|
||||||
FULL_VERSION:=@FULL_VERSION@
|
|
||||||
JRE_RELEASE_VERSION:=@FULL_VERSION@
|
|
||||||
RELEASE:=@RELEASE@
|
|
||||||
COOKED_BUILD_NUMBER:=@COOKED_BUILD_NUMBER@
|
COOKED_BUILD_NUMBER:=@COOKED_BUILD_NUMBER@
|
||||||
|
# These variables need to be generated here so that MILESTONE and
|
||||||
|
# JDK_BUILD_NUMBER can be overridden on the make command line.
|
||||||
|
ifeq ($(MILESTONE),)
|
||||||
|
RELEASE=$(JDK_VERSION)$(BUILD_VARIANT_RELEASE)
|
||||||
|
else
|
||||||
|
RELEASE=$(JDK_VERSION)-$(MILESTONE)$(BUILD_VARIANT_RELEASE)
|
||||||
|
endif
|
||||||
|
ifeq ($(JDK_BUILD_NUMBER),b00)
|
||||||
|
USER_RELEASE_SUFFIX=@USER_RELEASE_SUFFIX@
|
||||||
|
FULL_VERSION=$(RELEASE)-$(USER_RELEASE_SUFFIX)-$(JDK_BUILD_NUMBER)
|
||||||
|
else
|
||||||
|
FULL_VERSION=$(RELEASE)-$(JDK_BUILD_NUMBER)
|
||||||
|
endif
|
||||||
|
JRE_RELEASE_VERSION:=$(FULL_VERSION)
|
||||||
|
|
||||||
# How to compile the code: release, fastdebug or slowdebug
|
# How to compile the code: release, fastdebug or slowdebug
|
||||||
DEBUG_LEVEL:=@DEBUG_LEVEL@
|
DEBUG_LEVEL:=@DEBUG_LEVEL@
|
||||||
@ -220,6 +231,7 @@ JAXWS_OUTPUTDIR=$(BUILD_OUTPUT)/jaxws
|
|||||||
HOTSPOT_OUTPUTDIR=$(BUILD_OUTPUT)/hotspot
|
HOTSPOT_OUTPUTDIR=$(BUILD_OUTPUT)/hotspot
|
||||||
JDK_OUTPUTDIR=$(BUILD_OUTPUT)/jdk
|
JDK_OUTPUTDIR=$(BUILD_OUTPUT)/jdk
|
||||||
IMAGES_OUTPUTDIR=$(BUILD_OUTPUT)/images
|
IMAGES_OUTPUTDIR=$(BUILD_OUTPUT)/images
|
||||||
|
JCE_OUTPUTDIR=$(BUILD_OUTPUT)/jce-release
|
||||||
|
|
||||||
LANGTOOLS_DIST=$(LANGTOOLS_OUTPUTDIR)/dist
|
LANGTOOLS_DIST=$(LANGTOOLS_OUTPUTDIR)/dist
|
||||||
CORBA_DIST=$(CORBA_OUTPUTDIR)/dist
|
CORBA_DIST=$(CORBA_OUTPUTDIR)/dist
|
||||||
@ -420,6 +432,8 @@ RMIC=@FIXPATH@ $(BOOT_JDK)/bin/rmic
|
|||||||
|
|
||||||
NATIVE2ASCII=@FIXPATH@ $(BOOT_JDK)/bin/native2ascii
|
NATIVE2ASCII=@FIXPATH@ $(BOOT_JDK)/bin/native2ascii
|
||||||
|
|
||||||
|
JARSIGNER=@FIXPATH@ $(BOOT_JDK)/bin/jarsigner
|
||||||
|
|
||||||
# Base flags for RC
|
# Base flags for RC
|
||||||
# Guarding this against resetting value. Legacy make files include spec multiple
|
# Guarding this against resetting value. Legacy make files include spec multiple
|
||||||
# times.
|
# times.
|
||||||
@ -440,10 +454,13 @@ CCACHE:=@CCACHE@
|
|||||||
# CD is going away, but remains to cater for legacy makefiles.
|
# CD is going away, but remains to cater for legacy makefiles.
|
||||||
CD:=cd
|
CD:=cd
|
||||||
CHMOD:=@CHMOD@
|
CHMOD:=@CHMOD@
|
||||||
|
COMM:=@COMM@
|
||||||
CP:=@CP@
|
CP:=@CP@
|
||||||
|
CPIO:=@CPIO@
|
||||||
CUT:=@CUT@
|
CUT:=@CUT@
|
||||||
DATE:=@DATE@
|
DATE:=@DATE@
|
||||||
DIFF:=@DIFF@
|
DIFF:=@DIFF@
|
||||||
|
DIRNAME:=@DIRNAME@
|
||||||
FIND:=@FIND@
|
FIND:=@FIND@
|
||||||
FIND_DELETE:=@FIND_DELETE@
|
FIND_DELETE:=@FIND_DELETE@
|
||||||
ECHO:=@ECHO@
|
ECHO:=@ECHO@
|
||||||
@ -468,6 +485,7 @@ TEE:=@TEE@
|
|||||||
TIME:=@TIME@
|
TIME:=@TIME@
|
||||||
TR:=@TR@
|
TR:=@TR@
|
||||||
TOUCH:=@TOUCH@
|
TOUCH:=@TOUCH@
|
||||||
|
UNIQ:=@UNIQ@
|
||||||
WC:=@WC@
|
WC:=@WC@
|
||||||
XARGS:=@XARGS@
|
XARGS:=@XARGS@
|
||||||
ZIPEXE:=@ZIP@
|
ZIPEXE:=@ZIP@
|
||||||
@ -600,5 +618,21 @@ OS_VERSION_MAJOR:=@OS_VERSION_MAJOR@
|
|||||||
OS_VERSION_MINOR:=@OS_VERSION_MINOR@
|
OS_VERSION_MINOR:=@OS_VERSION_MINOR@
|
||||||
OS_VERSION_MICRO:=@OS_VERSION_MICRO@
|
OS_VERSION_MICRO:=@OS_VERSION_MICRO@
|
||||||
|
|
||||||
|
# Images directory definitions
|
||||||
|
JDK_IMAGE_SUBDIR:=j2sdk-image
|
||||||
|
JRE_IMAGE_SUBDIR:=j2re-image
|
||||||
|
JDK_OVERLAY_IMAGE_SUBDIR:=j2sdk-overlay-image
|
||||||
|
JRE_OVERLAY_IMAGE_SUBDIR:=j2re-overlay-image
|
||||||
|
JDK_IMAGE_DIR:=$(IMAGES_OUTPUTDIR)/$(JDK_IMAGE_SUBDIR)
|
||||||
|
JRE_IMAGE_DIR:=$(IMAGES_OUTPUTDIR)/$(JRE_IMAGE_SUBDIR)
|
||||||
|
JDK_OVERLAY_IMAGE_DIR:=$(IMAGES_OUTPUTDIR)/$(JDK_OVERLAY_IMAGE_SUBDIR)
|
||||||
|
JRE_OVERLAY_IMAGE_DIR:=$(IMAGES_OUTPUTDIR)/$(JRE_OVERLAY_IMAGE_SUBDIR)
|
||||||
|
|
||||||
|
# Macosx bundles directory definitions
|
||||||
|
JDK_BUNDLE_SUBDIR:=j2sdk-bundle/jdk$(JDK_VERSION).jdk/Contents
|
||||||
|
JRE_BUNDLE_SUBDIR:=j2re-bundle/jre$(JDK_VERSION).jre/Contents
|
||||||
|
JDK_BUNDLE_DIR:=$(IMAGES_OUTPUTDIR)/$(JDK_BUNDLE_SUBDIR)
|
||||||
|
JRE_BUNDLE_DIR:=$(IMAGES_OUTPUTDIR)/$(JRE_BUNDLE_SUBDIR)
|
||||||
|
|
||||||
# Include the custom-spec.gmk file if it exists
|
# Include the custom-spec.gmk file if it exists
|
||||||
-include $(dir @SPEC@)/custom-spec.gmk
|
-include $(dir @SPEC@)/custom-spec.gmk
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,8 +27,6 @@ JDK_MAJOR_VERSION=1
|
|||||||
JDK_MINOR_VERSION=8
|
JDK_MINOR_VERSION=8
|
||||||
JDK_MICRO_VERSION=0
|
JDK_MICRO_VERSION=0
|
||||||
JDK_UPDATE_VERSION=
|
JDK_UPDATE_VERSION=
|
||||||
JDK_BUILD_NUMBER=
|
|
||||||
MILESTONE=internal
|
|
||||||
LAUNCHER_NAME=openjdk
|
LAUNCHER_NAME=openjdk
|
||||||
PRODUCT_NAME=OpenJDK
|
PRODUCT_NAME=OpenJDK
|
||||||
PRODUCT_SUFFIX="Runtime Environment"
|
PRODUCT_SUFFIX="Runtime Environment"
|
@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2012, 2013 Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -98,24 +98,30 @@ diff_text() {
|
|||||||
if test "x$SUFFIX" = "xclass"; then
|
if test "x$SUFFIX" = "xclass"; then
|
||||||
# To improve performance when large diffs are found, do a rough filtering of classes
|
# To improve performance when large diffs are found, do a rough filtering of classes
|
||||||
# elibeble for these exceptions
|
# elibeble for these exceptions
|
||||||
if $GREP -R -e '[0-9]\{4\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}-b[0-9]\{2\}' -e thePoint -e aPoint -e setItemsPtr ${THIS_FILE} > /dev/null; then
|
if $GREP -R -e '[0-9]\{4\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}-b[0-9]\{2\}' \
|
||||||
|
-e '[0-9]\{2\}/[0-9]\{2\}/[0-9]\{4\}' \
|
||||||
|
-e thePoint -e aPoint -e setItemsPtr ${THIS_FILE} > /dev/null; then
|
||||||
$JAVAP -c -constants -l -p ${OTHER_FILE} > ${OTHER_FILE}.javap
|
$JAVAP -c -constants -l -p ${OTHER_FILE} > ${OTHER_FILE}.javap
|
||||||
$JAVAP -c -constants -l -p ${THIS_FILE} > ${THIS_FILE}.javap
|
$JAVAP -c -constants -l -p ${THIS_FILE} > ${THIS_FILE}.javap
|
||||||
TMP=$($DIFF ${OTHER_FILE}.javap ${THIS_FILE}.javap | \
|
TMP=$($DIFF ${OTHER_FILE}.javap ${THIS_FILE}.javap | \
|
||||||
$GREP '^[<>]' | \
|
$GREP '^[<>]' | \
|
||||||
$SED -e '/[<>].*[0-9]\{4\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}-b[0-9]\{2\}.*/d' \
|
$SED -e '/[<>].*[0-9]\{4\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}_[0-9]\{2\}-b[0-9]\{2\}.*/d' \
|
||||||
|
-e '/[0-9]\{2\}\/[0-9]\{2\}\/[0-9]\{4\}/d' \
|
||||||
-e '/[<>].*Point Lcom\/apple\/jobjc\/foundation\/NSPoint;/d' \
|
-e '/[<>].*Point Lcom\/apple\/jobjc\/foundation\/NSPoint;/d' \
|
||||||
-e '/[<>].*public com\.apple\.jobjc\.Pointer<com\.apple\.jobjc\..*itemsPtr();/d' \
|
-e '/[<>].*public com\.apple\.jobjc\.Pointer<com\.apple\.jobjc\..*itemsPtr();/d' \
|
||||||
-e '/[<>].*public void setItemsPtr(com\.apple\.jobjc\.Pointer<com\.apple\.jobjc\..*);/d')
|
-e '/[<>].*public void setItemsPtr(com\.apple\.jobjc\.Pointer<com\.apple\.jobjc\..*);/d')
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if test "x$SUFFIX" = "xproperties"; then
|
if test "x$SUFFIX" = "xproperties"; then
|
||||||
$CAT $OTHER_FILE | $SED -e 's/\([^\\]\):/\1\\:/g' -e 's/\([^\\]\)=/\1\\=/g' -e 's/#.*/#/g' \
|
# Run through nawk to add possibly missing newline at end of file.
|
||||||
| $SED -f "$SRC_ROOT/common/makefiles/support/unicode2x.sed" \
|
$CAT $OTHER_FILE | $NAWK '{ print }' > $OTHER_FILE.cleaned
|
||||||
| $SED -e '/^#/d' -e '/^$/d' \
|
# Disable this exception since we aren't changing the properties cleaning method yet.
|
||||||
-e :a -e '/\\$/N; s/\\\n//; ta' \
|
# $CAT $OTHER_FILE | $SED -e 's/\([^\\]\):/\1\\:/g' -e 's/\([^\\]\)=/\1\\=/g' -e 's/#.*/#/g' \
|
||||||
-e 's/^[ \t]*//;s/[ \t]*$//' \
|
# | $SED -f "$SRC_ROOT/common/makefiles/support/unicode2x.sed" \
|
||||||
-e 's/\\=/=/' | LANG=C $SORT > $OTHER_FILE.cleaned
|
# | $SED -e '/^#/d' -e '/^$/d' \
|
||||||
|
# -e :a -e '/\\$/N; s/\\\n//; ta' \
|
||||||
|
# -e 's/^[ \t]*//;s/[ \t]*$//' \
|
||||||
|
# -e 's/\\=/=/' | LANG=C $SORT > $OTHER_FILE.cleaned
|
||||||
TMP=$(LANG=C $DIFF $OTHER_FILE.cleaned $THIS_FILE)
|
TMP=$(LANG=C $DIFF $OTHER_FILE.cleaned $THIS_FILE)
|
||||||
fi
|
fi
|
||||||
if test -n "$TMP"; then
|
if test -n "$TMP"; then
|
||||||
@ -305,14 +311,17 @@ compare_general_files() {
|
|||||||
THIS_FILE=$WORK_DIR/$f.this
|
THIS_FILE=$WORK_DIR/$f.this
|
||||||
$MKDIR -p $(dirname $OTHER_FILE)
|
$MKDIR -p $(dirname $OTHER_FILE)
|
||||||
$MKDIR -p $(dirname $THIS_FILE)
|
$MKDIR -p $(dirname $THIS_FILE)
|
||||||
|
#Note that | doesn't work on mac sed.
|
||||||
$CAT $OTHER_DIR/$f | $SED -e 's/\(-- Generated by javadoc \).*\( --\)/\1(removed)\2/' \
|
$CAT $OTHER_DIR/$f | $SED -e 's/\(-- Generated by javadoc \).*\( --\)/\1(removed)\2/' \
|
||||||
-e 's/\(<meta name="date" content="\).*\(">\)/\1(removed)\2/' \
|
-e 's/\(<meta name="date" content="\).*\(">\)/\1(removed)\2/' \
|
||||||
-e 's/\(Monday\|Tuesday\|Wednesday\|Thursday\|Friday\|Saturday\|Sunday\), [A-Z][a-z]* [0-9][0-9]*, [12][0-9]* [0-9][0-9:]* \(AM\|PM\) [A-Z][A-Z]*/(removed)/' \
|
-e 's/[A-Z][a-z]*, [A-Z][a-z]* [0-9][0-9]*, [12][0-9]* [0-9][0-9:]* [AMP]\{2,2\} [A-Z][A-Z]*/(removed)/' \
|
||||||
|
-e 's/[A-Z][a-z]* [A-Z][a-z]* [0-9][0-9] [0-9][0-9:]* [A-Z][A-Z]* [12][0-9]*/(removed)/' \
|
||||||
-e 's/^\( from \).*\(\.idl\)$/\1(removed)\2/' \
|
-e 's/^\( from \).*\(\.idl\)$/\1(removed)\2/' \
|
||||||
> $OTHER_FILE
|
> $OTHER_FILE
|
||||||
$CAT $THIS_DIR/$f | $SED -e 's/\(-- Generated by javadoc \).*\( --\)/\1(removed)\2/' \
|
$CAT $THIS_DIR/$f | $SED -e 's/\(-- Generated by javadoc \).*\( --\)/\1(removed)\2/' \
|
||||||
-e 's/\(<meta name="date" content="\).*\(">\)/\1(removed)\2/' \
|
-e 's/\(<meta name="date" content="\).*\(">\)/\1(removed)\2/' \
|
||||||
-e 's/\(Monday\|Tuesday\|Wednesday\|Thursday\|Friday\|Saturday\|Sunday\), [A-Z][a-z]* [0-9][0-9]*, [12][0-9]* [0-9][0-9:]* \(AM\|PM\) [A-Z][A-Z]*/(removed)/' \
|
-e 's/[A-Z][a-z]*, [A-Z][a-z]* [0-9][0-9]*, [12][0-9]* [0-9][0-9:]* [AMP]\{2,2\} [A-Z][A-Z]*/(removed)/' \
|
||||||
|
-e 's/[A-Z][a-z]* [A-Z][a-z]* [0-9][0-9] [0-9][0-9:]* [A-Z][A-Z]* [12][0-9]*/(removed)/' \
|
||||||
-e 's/^\( from \).*\(\.idl\)$/\1(removed)\2/' \
|
-e 's/^\( from \).*\(\.idl\)$/\1(removed)\2/' \
|
||||||
> $THIS_FILE
|
> $THIS_FILE
|
||||||
else
|
else
|
||||||
@ -370,14 +379,14 @@ compare_zip_file() {
|
|||||||
(cd $OTHER_UNZIPDIR && $UNARCHIVE $OTHER_ZIP)
|
(cd $OTHER_UNZIPDIR && $UNARCHIVE $OTHER_ZIP)
|
||||||
|
|
||||||
# Find all archives inside and unzip them as well to compare the contents rather than
|
# Find all archives inside and unzip them as well to compare the contents rather than
|
||||||
# the archives.
|
# the archives. pie.jar.pack.gz i app3.war is corrupt, skip it.
|
||||||
EXCEPTIONS=""
|
EXCEPTIONS="pie.jar.pack.gz"
|
||||||
for pack in $($FIND $THIS_UNZIPDIR -name "*.pack" -o -name "*.pack.gz"); do
|
for pack in $($FIND $THIS_UNZIPDIR \( -name "*.pack" -o -name "*.pack.gz" \) -a ! -name pie.jar.pack.gz); do
|
||||||
($UNPACK200 $pack $pack.jar)
|
($UNPACK200 $pack $pack.jar)
|
||||||
# Filter out the unzipped archives from the diff below.
|
# Filter out the unzipped archives from the diff below.
|
||||||
EXCEPTIONS="$EXCEPTIONS $pack $pack.jar"
|
EXCEPTIONS="$EXCEPTIONS $pack $pack.jar"
|
||||||
done
|
done
|
||||||
for pack in $($FIND $OTHER_UNZIPDIR -name "*.pack" -o -name "*.pack.gz"); do
|
for pack in $($FIND $OTHER_UNZIPDIR \( -name "*.pack" -o -name "*.pack.gz" \) -a ! -name pie.jar.pack.gz); do
|
||||||
($UNPACK200 $pack $pack.jar)
|
($UNPACK200 $pack $pack.jar)
|
||||||
EXCEPTIONS="$EXCEPTIONS $pack $pack.jar"
|
EXCEPTIONS="$EXCEPTIONS $pack $pack.jar"
|
||||||
done
|
done
|
||||||
@ -1073,7 +1082,11 @@ fi
|
|||||||
|
|
||||||
|
|
||||||
# Figure out the layout of the this build. Which kinds of images have been produced
|
# Figure out the layout of the this build. Which kinds of images have been produced
|
||||||
if [ -d "$THIS/deploy/j2sdk-image" ]; then
|
if [ -d "$THIS/install/j2sdk-image" ]; then
|
||||||
|
THIS_J2SDK="$THIS/install/j2sdk-image"
|
||||||
|
THIS_J2RE="$THIS/install/j2re-image"
|
||||||
|
echo "Comparing install images"
|
||||||
|
elif [ -d "$THIS/deploy/j2sdk-image" ]; then
|
||||||
THIS_J2SDK="$THIS/deploy/j2sdk-image"
|
THIS_J2SDK="$THIS/deploy/j2sdk-image"
|
||||||
THIS_J2RE="$THIS/deploy/j2re-image"
|
THIS_J2RE="$THIS/deploy/j2re-image"
|
||||||
echo "Comparing deploy images"
|
echo "Comparing deploy images"
|
||||||
@ -1081,9 +1094,16 @@ elif [ -d "$THIS/images/j2sdk-image" ]; then
|
|||||||
THIS_J2SDK="$THIS/images/j2sdk-image"
|
THIS_J2SDK="$THIS/images/j2sdk-image"
|
||||||
THIS_J2RE="$THIS/images/j2re-image"
|
THIS_J2RE="$THIS/images/j2re-image"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d "$THIS/images/j2sdk-overlay-image" ]; then
|
if [ -d "$THIS/images/j2sdk-overlay-image" ]; then
|
||||||
THIS_J2SDK_OVERLAY="$THIS/images/j2sdk-overlay-image"
|
if [ -d "$THIS/install/j2sdk-image" ]; then
|
||||||
THIS_J2RE_OVERLAY="$THIS/images/j2re-overlay-image"
|
# If there is an install image, prefer that, it's also overlay
|
||||||
|
THIS_J2SDK_OVERLAY="$THIS/install/j2sdk-image"
|
||||||
|
THIS_J2RE_OVERLAY="$THIS/install/j2re-image"
|
||||||
|
else
|
||||||
|
THIS_J2SDK_OVERLAY="$THIS/images/j2sdk-overlay-image"
|
||||||
|
THIS_J2RE_OVERLAY="$THIS/images/j2re-overlay-image"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d "$THIS/images/j2sdk-bundle" ]; then
|
if [ -d "$THIS/images/j2sdk-bundle" ]; then
|
||||||
@ -1100,7 +1120,9 @@ if [ -d "$OTHER/j2sdk-image" ]; then
|
|||||||
OTHER_J2SDK_OVERLAY="$OTHER/j2sdk-image"
|
OTHER_J2SDK_OVERLAY="$OTHER/j2sdk-image"
|
||||||
OTHER_J2RE_OVERLAY="$OTHER/j2re-image"
|
OTHER_J2RE_OVERLAY="$OTHER/j2re-image"
|
||||||
fi
|
fi
|
||||||
|
elif [ -d "$OTHER/images/j2sdk-image" ]; then
|
||||||
|
OTHER_J2SDK="$OTHER/images/j2sdk-image"
|
||||||
|
OTHER_J2RE="$OTHER/images/j2re-image"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d "$OTHER/j2sdk-bundle" ]; then
|
if [ -d "$OTHER/j2sdk-bundle" ]; then
|
||||||
@ -1144,6 +1166,26 @@ if [ -z "$OTHER_DOCS" ]; then
|
|||||||
echo "WARNING! Other build doesn't contain docs, skipping doc compare."
|
echo "WARNING! Other build doesn't contain docs, skipping doc compare."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -d "$OTHER/images" ]; then
|
||||||
|
OTHER_SEC_DIR="$OTHER/images"
|
||||||
|
else
|
||||||
|
OTHER_SEC_DIR="$OTHER/tmp"
|
||||||
|
fi
|
||||||
|
OTHER_SEC_BIN="$OTHER_SEC_DIR/sec-bin.zip"
|
||||||
|
THIS_SEC_DIR="$THIS/images"
|
||||||
|
THIS_SEC_BIN="$THIS_SEC_DIR/sec-bin.zip"
|
||||||
|
if [ "$OPENJDK_TARGET_OS" = "windows" ]; then
|
||||||
|
if [ "$OPENJDK_TARGET_CPU" = "x86_64" ]; then
|
||||||
|
JGSS_WINDOWS_BIN="jgss-windows-x64-bin.zip"
|
||||||
|
else
|
||||||
|
JGSS_WINDOWS_BIN="jgss-windows-i586-bin.zip"
|
||||||
|
fi
|
||||||
|
OTHER_SEC_WINDOWS_BIN="$OTHER_SEC_DIR/sec-windows-bin.zip"
|
||||||
|
OTHER_JGSS_WINDOWS_BIN="$OTHER_SEC_DIR/$JGSS_WINDOWS_BIN"
|
||||||
|
THIS_SEC_WINDOWS_BIN="$THIS_SEC_DIR/sec-windows-bin.zip"
|
||||||
|
THIS_JGSS_WINDOWS_BIN="$THIS_SEC_DIR/$JGSS_WINDOWS_BIN"
|
||||||
|
fi
|
||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
# Do the work
|
# Do the work
|
||||||
|
|
||||||
@ -1260,6 +1302,24 @@ if [ "$CMP_ZIPS" = "true" ]; then
|
|||||||
if [ -n "$THIS_J2SDK" ] && [ -n "$OTHER_J2SDK" ]; then
|
if [ -n "$THIS_J2SDK" ] && [ -n "$OTHER_J2SDK" ]; then
|
||||||
compare_all_zip_files $THIS_J2SDK $OTHER_J2SDK $COMPARE_ROOT/j2sdk
|
compare_all_zip_files $THIS_J2SDK $OTHER_J2SDK $COMPARE_ROOT/j2sdk
|
||||||
fi
|
fi
|
||||||
|
if [ -n "$THIS_SEC_BIN" ] && [ -n "$OTHER_SEC_BIN" ]; then
|
||||||
|
if [ -n "$(echo $THIS_SEC_BIN | $FILTER)" ]; then
|
||||||
|
echo "sec-bin.zip..."
|
||||||
|
compare_zip_file $THIS_SEC_DIR $OTHER_SEC_DIR $COMPARE_ROOT/sec-bin sec-bin.zip
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ -n "$THIS_SEC_WINDOWS_BIN" ] && [ -n "$OTHER_SEC_WINDOWS_BIN" ]; then
|
||||||
|
if [ -n "$(echo $THIS_SEC_WINDOWS_BIN | $FILTER)" ]; then
|
||||||
|
echo "sec-windows-bin.zip..."
|
||||||
|
compare_zip_file $THIS_SEC_DIR $OTHER_SEC_DIR $COMPARE_ROOT/sec-bin sec-windows-bin.zip
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ -n "$THIS_JGSS_WINDOWS_BIN" ] && [ -n "$OTHER_JGSS_WINDOWS_BIN" ]; then
|
||||||
|
if [ -n "$(echo $THIS_JGSS_WINDOWS_BIN | $FILTER)" ]; then
|
||||||
|
echo "$JGSS_WINDOWS_BIN..."
|
||||||
|
compare_zip_file $THIS_SEC_DIR $OTHER_SEC_DIR $COMPARE_ROOT/sec-bin $JGSS_WINDOWS_BIN
|
||||||
|
fi
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$CMP_JARS" = "true" ]; then
|
if [ "$CMP_JARS" = "true" ]; then
|
||||||
|
@ -813,6 +813,10 @@ fi
|
|||||||
|
|
||||||
if [ "$OPENJDK_TARGET_OS" = "windows" ]; then
|
if [ "$OPENJDK_TARGET_OS" = "windows" ]; then
|
||||||
|
|
||||||
|
ACCEPTED_JARZIP_CONTENTS="
|
||||||
|
/bin/w2k_lsa_auth.dll
|
||||||
|
"
|
||||||
|
|
||||||
# Probably should add all libs here
|
# Probably should add all libs here
|
||||||
ACCEPTED_SMALL_SIZE_DIFF="
|
ACCEPTED_SMALL_SIZE_DIFF="
|
||||||
./demo/jvmti/gctest/lib/gctest.dll
|
./demo/jvmti/gctest/lib/gctest.dll
|
||||||
@ -821,6 +825,7 @@ ACCEPTED_SMALL_SIZE_DIFF="
|
|||||||
./jre/bin/attach.dll
|
./jre/bin/attach.dll
|
||||||
./jre/bin/java_crw_demo.dll
|
./jre/bin/java_crw_demo.dll
|
||||||
./jre/bin/jsoundds.dll
|
./jre/bin/jsoundds.dll
|
||||||
|
./jre/bin/server/jvm.dll
|
||||||
./bin/appletviewer.exe
|
./bin/appletviewer.exe
|
||||||
./bin/extcheck.exe
|
./bin/extcheck.exe
|
||||||
./bin/idlj.exe
|
./bin/idlj.exe
|
||||||
|
@ -87,7 +87,7 @@ $(if $(16),$(error Internal makefile error: Too many arguments to SetupIdlCompil
|
|||||||
$1_SRC := $$(abspath $$($1_SRC))
|
$1_SRC := $$(abspath $$($1_SRC))
|
||||||
$1_BIN := $$(abspath $$($1_BIN))
|
$1_BIN := $$(abspath $$($1_BIN))
|
||||||
# Find all existing java files and existing class files.
|
# Find all existing java files and existing class files.
|
||||||
$$(shell $(MKDIR) -p $$($1_SRC) $$($1_BIN))
|
$$(eval $$(call MakeDir,$$($1_BIN)))
|
||||||
$1_SRCS := $$(shell find $$($1_SRC) -name "*.idl")
|
$1_SRCS := $$(shell find $$($1_SRC) -name "*.idl")
|
||||||
$1_BINS := $$(shell find $$($1_BIN) -name "*.java")
|
$1_BINS := $$(shell find $$($1_BIN) -name "*.java")
|
||||||
# Prepend the source/bin path to the filter expressions.
|
# Prepend the source/bin path to the filter expressions.
|
||||||
|
@ -111,9 +111,9 @@ define SetupArchive
|
|||||||
ifeq ($$(word 20,$$($1_GREP_INCLUDE_PATTERNS)),)
|
ifeq ($$(word 20,$$($1_GREP_INCLUDE_PATTERNS)),)
|
||||||
$1_GREP_INCLUDES:=| $(GREP) $$(patsubst %,$(SPACE)-e$(SPACE)$(DQUOTE)%$(DQUOTE),$$($1_GREP_INCLUDE_PATTERNS))
|
$1_GREP_INCLUDES:=| $(GREP) $$(patsubst %,$(SPACE)-e$(SPACE)$(DQUOTE)%$(DQUOTE),$$($1_GREP_INCLUDE_PATTERNS))
|
||||||
else
|
else
|
||||||
$$(shell $(MKDIR) -p $$($1_BIN) && $(RM) $$($1_BIN)/_the.$$($1_JARNAME)_include)
|
$1_GREP_INCLUDE_OUTPUT:=$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_include && \
|
||||||
$$(eval $$(call ListPathsSafelyNow,$1_GREP_INCLUDE_PATTERNS,\n, \
|
$$(strip $$(call ListPathsSafely,$1_GREP_INCLUDE_PATTERNS,\n, \
|
||||||
>> $$($1_BIN)/_the.$$($1_JARNAME)_include))
|
>> $$($1_BIN)/_the.$$($1_JARNAME)_include))
|
||||||
$1_GREP_INCLUDES:=| $(GREP) -f $$($1_BIN)/_the.$$($1_JARNAME)_include
|
$1_GREP_INCLUDES:=| $(GREP) -f $$($1_BIN)/_the.$$($1_JARNAME)_include
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@ -124,9 +124,9 @@ define SetupArchive
|
|||||||
ifeq ($$(word 20,$$($1_GREP_EXCLUDE_PATTERNS)),)
|
ifeq ($$(word 20,$$($1_GREP_EXCLUDE_PATTERNS)),)
|
||||||
$1_GREP_EXCLUDES:=| $(GREP) -v $$(patsubst %,$(SPACE)-e$(SPACE)$(DQUOTE)%$(DQUOTE),$$($1_GREP_EXCLUDE_PATTERNS))
|
$1_GREP_EXCLUDES:=| $(GREP) -v $$(patsubst %,$(SPACE)-e$(SPACE)$(DQUOTE)%$(DQUOTE),$$($1_GREP_EXCLUDE_PATTERNS))
|
||||||
else
|
else
|
||||||
$$(shell $(MKDIR) -p $$($1_BIN) && $(RM) $$($1_BIN)/_the.$$($1_JARNAME)_exclude)
|
$1_GREP_EXCLUDE_OUTPUT=$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_exclude && \
|
||||||
$$(eval $$(call ListPathsSafelyNow,$1_GREP_EXCLUDE_PATTERNS,\n, \
|
$$(strip $$(call ListPathsSafely,$1_GREP_EXCLUDE_PATTERNS,\n, \
|
||||||
>> $$($1_BIN)/_the.$$($1_JARNAME)_exclude))
|
>> $$($1_BIN)/_the.$$($1_JARNAME)_exclude))
|
||||||
$1_GREP_EXCLUDES:=| $(GREP) -v -f $$($1_BIN)/_the.$$($1_JARNAME)_exclude
|
$1_GREP_EXCLUDES:=| $(GREP) -v -f $$($1_BIN)/_the.$$($1_JARNAME)_exclude
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@ -137,19 +137,25 @@ define SetupArchive
|
|||||||
else
|
else
|
||||||
$1_JARINDEX = true
|
$1_JARINDEX = true
|
||||||
endif
|
endif
|
||||||
# When this macro is run in the same makefile as the java compilation, dependencies are transfered
|
# When this macro is run in the same makefile as the java compilation, dependencies are
|
||||||
# in make variables. When the macro is run in a different makefile than the java compilation, the
|
# transfered in make variables. When the macro is run in a different makefile than the
|
||||||
# dependencies need to be found in the filesystem.
|
# java compilation, the dependencies need to be found in the filesystem.
|
||||||
ifneq (,$2)
|
ifneq (,$2)
|
||||||
$1_DEPS:=$2
|
$1_DEPS:=$2
|
||||||
else
|
else
|
||||||
|
$1_DEPS:=$$(filter $$(addprefix %,$$($1_FIND_PATTERNS)),\
|
||||||
|
$$(call CacheFind $$($1_SRCS)))
|
||||||
|
ifneq (,$$($1_GREP_INCLUDE_PATTERNS))
|
||||||
|
$1_DEPS:=$$(filter $$(addsuffix %,$$($1_GREP_INCLUDE_PATTERNS)),$$($1_DEPS))
|
||||||
|
endif
|
||||||
|
ifneq (,$$($1_GREP_EXCLUDE_PATTERNS))
|
||||||
|
$1_DEPS:=$$(filter-out $$(addsuffix %,$$($1_GREP_EXCLUDE_PATTERNS)),$$($1_DEPS))
|
||||||
|
endif
|
||||||
# The subst of \ is needed because $ has to be escaped with \ in EXTRA_FILES for the command
|
# The subst of \ is needed because $ has to be escaped with \ in EXTRA_FILES for the command
|
||||||
# lines, but not here for use in make dependencies.
|
# lines, but not here for use in make dependencies.
|
||||||
$1_DEPS:=$$(shell $(FIND) $$($1_SRCS) -type f -a \( $$($1_FIND_PATTERNS) \) \
|
$1_DEPS+=$$(subst \,,$$(foreach src,$$($1_SRCS),$$(addprefix $$(src)/,$$($1_EXTRA_FILES))))
|
||||||
$$($1_GREP_INCLUDES) $$($1_GREP_EXCLUDES)) \
|
|
||||||
$$(subst \,,$$(foreach src,$$($1_SRCS),$$(addprefix $$(src)/,$$($1_EXTRA_FILES))))
|
|
||||||
ifeq (,$$($1_SKIP_METAINF))
|
ifeq (,$$($1_SKIP_METAINF))
|
||||||
$1_DEPS+=$$(shell $(FIND) $$(addsuffix /META-INF,$$($1_SRCS)) -type f 2> /dev/null)
|
$1_DEPS+=$$(call CacheFind $$(wildcard $$(addsuffix /META-INF,$$($1_SRCS))))
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -210,6 +216,8 @@ define SetupArchive
|
|||||||
# Here is the rule that creates/updates the jar file.
|
# Here is the rule that creates/updates the jar file.
|
||||||
$$($1_JAR) : $$($1_DEPS)
|
$$($1_JAR) : $$($1_DEPS)
|
||||||
$(MKDIR) -p $$($1_BIN)
|
$(MKDIR) -p $$($1_BIN)
|
||||||
|
$$($1_GREP_INCLUDE_OUTPUT)
|
||||||
|
$$($1_GREP_EXCLUDE_OUTPUT)
|
||||||
$$(if $$($1_MANIFEST),\
|
$$(if $$($1_MANIFEST),\
|
||||||
$(SED) -e "s#@@RELEASE@@#$(RELEASE)#" \
|
$(SED) -e "s#@@RELEASE@@#$(RELEASE)#" \
|
||||||
-e "s#@@COMPANY_NAME@@#$(COMPANY_NAME)#" $$($1_MANIFEST) > $$($1_MANIFEST_FILE) \
|
-e "s#@@COMPANY_NAME@@#$(COMPANY_NAME)#" $$($1_MANIFEST) > $$($1_MANIFEST_FILE) \
|
||||||
@ -242,14 +250,14 @@ endef
|
|||||||
define SetupZipArchive
|
define SetupZipArchive
|
||||||
# param 1 is for example ZIP_MYSOURCE
|
# param 1 is for example ZIP_MYSOURCE
|
||||||
# param 2,3,4,5,6,7,8,9 are named args.
|
# param 2,3,4,5,6,7,8,9 are named args.
|
||||||
# SRC,ZIP,INCLUDES,EXCLUDES,EXCLUDE_FILES,SUFFIXES,EXTRA_DEPS
|
# SRC,ZIP,INCLUDES,INCLUDE_FILES,EXCLUDES,EXCLUDE_FILES,SUFFIXES,EXTRA_DEPS
|
||||||
$(foreach i,2 3 4 5 6 7 8 9 10 11 12 13 14 15, $(if $($i),$1_$(strip $($i)))$(NEWLINE))
|
$(foreach i,2 3 4 5 6 7 8 9 10 11 12 13 14 15, $(if $($i),$1_$(strip $($i)))$(NEWLINE))
|
||||||
$(call LogSetupMacroEntry,SetupZipArchive($1),$2,$3,$4,$5,$6,$7,$8,$9,$(10),$(11),$(12),$(13),$(14),$(15))
|
$(call LogSetupMacroEntry,SetupZipArchive($1),$2,$3,$4,$5,$6,$7,$8,$9,$(10),$(11),$(12),$(13),$(14),$(15))
|
||||||
$(if $(16),$(error Internal makefile error: Too many arguments to SetupZipArchive, please update JavaCompilation.gmk))
|
$(if $(16),$(error Internal makefile error: Too many arguments to SetupZipArchive, please update JavaCompilation.gmk))
|
||||||
|
|
||||||
# Find all files in the source tree.
|
# Find all files in the source tree.
|
||||||
$1_SUFFIX_FILTER := $$(patsubst %,-o -name $(DQUOTE)*%$(DQUOTE),$$($1_SUFFIXES))
|
$1_ALL_SRCS := $$(call not-containing,_the.,\
|
||||||
$1_ALL_SRCS := $$(foreach i,$$($1_SRC), $$(shell $(FIND) $$i -type f -a ! -name "_the.*" \( -name FALSE_DUMMY $$($1_SUFFIX_FILTER) \) ))
|
$$(filter $$(addprefix %,$$($1_SUFFIXES)),$$(call CacheFind $$($1_SRC))))
|
||||||
|
|
||||||
ifneq ($$($1_INCLUDES),)
|
ifneq ($$($1_INCLUDES),)
|
||||||
$1_SRC_INCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_INCLUDES))))
|
$1_SRC_INCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_INCLUDES))))
|
||||||
@ -259,6 +267,12 @@ define SetupZipArchive
|
|||||||
else
|
else
|
||||||
$1_ZIP_INCLUDES := $$(addprefix -i$(SPACE)$(DQUOTE),$$(addsuffix /*$(DQUOTE),$$($1_INCLUDES)))
|
$1_ZIP_INCLUDES := $$(addprefix -i$(SPACE)$(DQUOTE),$$(addsuffix /*$(DQUOTE),$$($1_INCLUDES)))
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
ifneq ($$($1_INCLUDE_FILES),)
|
||||||
|
$1_SRC_INCLUDES += $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_INCLUDE_FILES)))
|
||||||
|
$1_ZIP_INCLUDES += $$(addprefix -i$(SPACE),$$($1_INCLUDE_FILES))
|
||||||
|
endif
|
||||||
|
ifneq ($$($1_SRC_INCLUDES),)
|
||||||
$1_ALL_SRCS := $$(filter $$($1_SRC_INCLUDES),$$($1_ALL_SRCS))
|
$1_ALL_SRCS := $$(filter $$($1_SRC_INCLUDES),$$($1_ALL_SRCS))
|
||||||
endif
|
endif
|
||||||
ifneq ($$($1_EXCLUDES),)
|
ifneq ($$($1_EXCLUDES),)
|
||||||
@ -376,7 +390,7 @@ define SetupJavaCompilation
|
|||||||
$$(foreach d,$$($1_SRC), $$(if $$(wildcard $$d),,$$(error SRC specified to SetupJavaCompilation $1 contains missing directory $$d)))
|
$$(foreach d,$$($1_SRC), $$(if $$(wildcard $$d),,$$(error SRC specified to SetupJavaCompilation $1 contains missing directory $$d)))
|
||||||
$$(eval $$(call MakeDir,$$($1_BIN)))
|
$$(eval $$(call MakeDir,$$($1_BIN)))
|
||||||
# Find all files in the source trees.
|
# Find all files in the source trees.
|
||||||
$1_ALL_SRCS := $$(filter-out $(OVR_SRCS),$$(shell $(FIND) $$($1_SRC) -type f))
|
$1_ALL_SRCS += $$(filter-out $(OVR_SRCS),$$(call CacheFind,$$($1_SRC)))
|
||||||
# Extract the java files.
|
# Extract the java files.
|
||||||
ifneq ($$($1_EXCLUDE_FILES),)
|
ifneq ($$($1_EXCLUDE_FILES),)
|
||||||
$1_EXCLUDE_FILES_PATTERN:=$$(addprefix %,$$($1_EXCLUDE_FILES))
|
$1_EXCLUDE_FILES_PATTERN:=$$(addprefix %,$$($1_EXCLUDE_FILES))
|
||||||
@ -408,8 +422,6 @@ define SetupJavaCompilation
|
|||||||
|
|
||||||
# Find all files to be copied from source to bin.
|
# Find all files to be copied from source to bin.
|
||||||
ifneq (,$$($1_COPY))
|
ifneq (,$$($1_COPY))
|
||||||
# Rewrite list of patterns into a find statement.
|
|
||||||
$1_COPY_PATTERN:=$(FALSE_FIND_PATTERN) $$(patsubst %,$(SPACE)-o$(SPACE)-name$(SPACE)$(DQUOTE)*%$(DQUOTE),$$($1_COPY))
|
|
||||||
# Search for all files to be copied.
|
# Search for all files to be copied.
|
||||||
$1_ALL_COPIES := $$(filter $$(addprefix %,$$($1_COPY)),$$($1_ALL_SRCS))
|
$1_ALL_COPIES := $$(filter $$(addprefix %,$$($1_COPY)),$$($1_ALL_SRCS))
|
||||||
# Copy these explicitly
|
# Copy these explicitly
|
||||||
@ -436,8 +448,6 @@ define SetupJavaCompilation
|
|||||||
|
|
||||||
# Find all property files to be copied and cleaned from source to bin.
|
# Find all property files to be copied and cleaned from source to bin.
|
||||||
ifneq (,$$($1_CLEAN))
|
ifneq (,$$($1_CLEAN))
|
||||||
# Rewrite list of patterns into a find statement.
|
|
||||||
$1_CLEAN_PATTERN:=$(FALSE_FIND_PATTERN) $$(patsubst %,$(SPACE)-o$(SPACE)-name$(SPACE)$(DQUOTE)*%$(DQUOTE),$$($1_CLEAN))
|
|
||||||
# Search for all files to be copied.
|
# Search for all files to be copied.
|
||||||
$1_ALL_CLEANS := $$(filter $$(addprefix %,$$($1_CLEAN)),$$($1_ALL_SRCS))
|
$1_ALL_CLEANS := $$(filter $$(addprefix %,$$($1_CLEAN)),$$($1_ALL_SRCS))
|
||||||
# Copy and clean must also respect filters.
|
# Copy and clean must also respect filters.
|
||||||
|
199
common/makefiles/Jprt.gmk
Normal file
199
common/makefiles/Jprt.gmk
Normal file
@ -0,0 +1,199 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
|
||||||
|
# This file is included by the root NewerMakefile and contains targets
|
||||||
|
# and utilities needed by JPRT.
|
||||||
|
|
||||||
|
# Utilities used in this Makefile. Most of this makefile executes without
|
||||||
|
# the context of a spec file from configure.
|
||||||
|
CAT=cat
|
||||||
|
CMP=cmp
|
||||||
|
CP=cp
|
||||||
|
ECHO=echo
|
||||||
|
MKDIR=mkdir
|
||||||
|
PRINTF=printf
|
||||||
|
PWD=pwd
|
||||||
|
# Insure we have a path that looks like it came from pwd
|
||||||
|
# (This is mostly for Windows sake and drive letters)
|
||||||
|
define UnixPath # path
|
||||||
|
$(shell (cd "$1" && $(PWD)))
|
||||||
|
endef
|
||||||
|
|
||||||
|
BUILD_DIR_ROOT:=$(root_dir)/build
|
||||||
|
|
||||||
|
# Appears to be an open build
|
||||||
|
OPEN_BUILD := \
|
||||||
|
$(shell \
|
||||||
|
if [ -d $(root_dir)/jdk/src/closed \
|
||||||
|
-o -d $(root_dir)/jdk/make/closed \
|
||||||
|
-o -d $(root_dir)/jdk/test/closed \
|
||||||
|
-o -d $(root_dir)/hotspot/src/closed \
|
||||||
|
-o -d $(root_dir)/hotspot/make/closed \
|
||||||
|
-o -d $(root_dir)/hotspot/test/closed ] ; then \
|
||||||
|
echo "false"; \
|
||||||
|
else \
|
||||||
|
echo "true"; \
|
||||||
|
fi \
|
||||||
|
)
|
||||||
|
ifdef OPENJDK
|
||||||
|
OPEN_BUILD=true
|
||||||
|
endif
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# To help in adoption of the new configure&&make build process, a bridge
|
||||||
|
# build will use the old settings to run configure and do the build.
|
||||||
|
|
||||||
|
# Build with the configure bridge. After running configure, restart make
|
||||||
|
# to parse the new spec file.
|
||||||
|
BRIDGE_TARGETS := all
|
||||||
|
bridgeBuild: bridge2configure
|
||||||
|
@cd $(root_dir) && $(MAKE) -f NewMakefile.gmk $(BRIDGE_TARGETS)
|
||||||
|
|
||||||
|
# Bridge from old Makefile ALT settings to configure options
|
||||||
|
bridge2configure: $(BUILD_DIR_ROOT)/.bridge2configureOpts
|
||||||
|
bash ./configure $(strip $(shell $(CAT) $<))
|
||||||
|
|
||||||
|
# Create a file with configure options created from old Makefile mechanisms.
|
||||||
|
$(BUILD_DIR_ROOT)/.bridge2configureOpts: $(BUILD_DIR_ROOT)/.bridge2configureOptsLatest
|
||||||
|
$(RM) $@
|
||||||
|
$(CP) $< $@
|
||||||
|
|
||||||
|
# Use this file to only change when obvious things have changed
|
||||||
|
$(BUILD_DIR_ROOT)/.bridge2configureOptsLatest: FRC
|
||||||
|
$(RM) $@.tmp
|
||||||
|
$(MKDIR) -p $(BUILD_DIR_ROOT)
|
||||||
|
@$(ECHO) " --with-debug-level=$(if $(DEBUG_LEVEL),$(DEBUG_LEVEL),release) " >> $@.tmp
|
||||||
|
ifdef ARCH_DATA_MODEL
|
||||||
|
@$(ECHO) " --with-target-bits=$(ARCH_DATA_MODEL) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifeq ($(ARCH_DATA_MODEL),32)
|
||||||
|
@$(ECHO) " --with-jvm-variants=client,server " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_PARALLEL_COMPILE_JOBS
|
||||||
|
@$(ECHO) " --with-num-cores=$(ALT_PARALLEL_COMPILE_JOBS) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_BOOTDIR
|
||||||
|
@$(ECHO) " --with-boot-jdk=$(call UnixPath,$(ALT_BOOTDIR)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_CUPS_HEADERS_PATH
|
||||||
|
@$(ECHO) " --with-cups-include=$(call UnixPath,$(ALT_CUPS_HEADERS_PATH)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_FREETYPE_HEADERS_PATH
|
||||||
|
@$(ECHO) " --with-freetype=$(call UnixPath,$(ALT_FREETYPE_HEADERS_PATH)/..) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifeq ($(OPEN_BUILD),true)
|
||||||
|
@$(ECHO) " --enable-openjdk-only " >> $@.tmp
|
||||||
|
else
|
||||||
|
# Todo: move to closed?
|
||||||
|
ifdef ALT_MOZILLA_HEADERS_PATH
|
||||||
|
@$(ECHO) " --with-mozilla-headers=$(call UnixPath,$(ALT_MOZILLA_HEADERS_PATH)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_JUNIT_DIR
|
||||||
|
@$(ECHO) " --with-junit-dir=$(call UnixPath,$(ALT_JUNIT_DIR)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ANT_HOME
|
||||||
|
@$(ECHO) " --with-ant-home=$(call UnixPath,$(ANT_HOME)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_JAVAFX_ZIP_DIR
|
||||||
|
@$(ECHO) " --with-javafx-zip-dir=$(call UnixPath,$(ALT_JAVAFX_ZIP_DIR)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_WIXDIR
|
||||||
|
@$(ECHO) " --with-wix=$(call UnixPath,$(ALT_WIXDIR)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_CCSS_SIGNING_DIR
|
||||||
|
@$(ECHO) " --with-ccss-signing=$(call UnixPath,$(ALT_CCSS_SIGNING_DIR)) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
ifdef ALT_SLASH_JAVA
|
||||||
|
@$(ECHO) " --with-java-devtools=$(call UnixPath,$(ALT_SLASH_JAVA)/devtools) " >> $@.tmp
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
@if [ -f $@ ] ; then \
|
||||||
|
if ! $(CMP) $@ $@.tmp > /dev/null ; then \
|
||||||
|
$(CP) $@.tmp $@ ; \
|
||||||
|
fi ; \
|
||||||
|
else \
|
||||||
|
$(CP) $@.tmp $@ ; \
|
||||||
|
fi
|
||||||
|
$(RM) $@.tmp
|
||||||
|
|
||||||
|
PHONY_LIST += bridge2configure bridgeBuild
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# JPRT targets
|
||||||
|
|
||||||
|
ifndef JPRT_ARCHIVE_BUNDLE
|
||||||
|
JPRT_ARCHIVE_BUNDLE=/tmp/jprt_bundles/j2sdk-image.zip
|
||||||
|
endif
|
||||||
|
|
||||||
|
# These targets execute in a SPEC free context, before calling bridgeBuild
|
||||||
|
# to generate the SPEC.
|
||||||
|
jprt_build_product: DEBUG_LEVEL=release
|
||||||
|
jprt_build_product: BUILD_DIRNAME=*-release
|
||||||
|
jprt_build_product: jprt_build_generic
|
||||||
|
|
||||||
|
jprt_build_fastdebug: DEBUG_LEVEL=fastdebug
|
||||||
|
jprt_build_fastdebug: BUILD_DIRNAME=*-fastdebug
|
||||||
|
jprt_build_fastdebug: jprt_build_generic
|
||||||
|
|
||||||
|
jprt_build_debug: DEBUG_LEVEL=slowdebug
|
||||||
|
jprt_build_debug: BUILD_DIRNAME=*-debug
|
||||||
|
jprt_build_debug: jprt_build_generic
|
||||||
|
|
||||||
|
jprt_build_generic: BRIDGE_TARGETS+=jprt_bundle
|
||||||
|
jprt_build_generic: bridgeBuild
|
||||||
|
|
||||||
|
# This target must be called in the context of a SPEC file
|
||||||
|
jprt_bundle: $(JPRT_ARCHIVE_BUNDLE)
|
||||||
|
@$(call CheckIfMakeAtEnd)
|
||||||
|
|
||||||
|
# This target must be called in the context of a SPEC file
|
||||||
|
$(JPRT_ARCHIVE_BUNDLE): bundles
|
||||||
|
$(MKDIR) -p $(@D)
|
||||||
|
$(RM) $@
|
||||||
|
$(CP) $(BUILD_OUTPUT)/bundles/j2sdk-image.zip $@
|
||||||
|
|
||||||
|
# This target must be called in the context of a SPEC file
|
||||||
|
bundles: all
|
||||||
|
@$(call TargetEnter)
|
||||||
|
$(MKDIR) -p $(BUILD_OUTPUT)/bundles
|
||||||
|
ifeq ($(OPENJDK_TARGET_OS)-$(OPENJDK_TARGET_CPU_BITS),solaris-64)
|
||||||
|
$(CD) $(JDK_OVERLAY_IMAGE_DIR) && $(ZIP) -q -r $(BUILD_OUTPUT)/bundles/j2sdk-image.zip .
|
||||||
|
$(CD) $(JRE_OVERLAY_IMAGE_DIR) && $(ZIP) -q -r $(BUILD_OUTPUT)/bundles/j2re-image.zip .
|
||||||
|
else
|
||||||
|
$(CD) $(JDK_IMAGE_DIR) && $(ZIP) -q -r $(BUILD_OUTPUT)/bundles/j2sdk-image.zip .
|
||||||
|
$(CD) $(JRE_IMAGE_DIR) && $(ZIP) -q -r $(BUILD_OUTPUT)/bundles/j2re-image.zip .
|
||||||
|
endif
|
||||||
|
@$(call TargetExit)
|
||||||
|
|
||||||
|
# Keep track of phony targets
|
||||||
|
PHONY_LIST += jprt_build_product jprt_build_fastdebug jprt_build_debug \
|
||||||
|
jprt_build_generic bundles jprt_bundle
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Phony targets
|
||||||
|
.PHONY: $(PHONY_LIST)
|
||||||
|
|
||||||
|
# Force target
|
||||||
|
FRC:
|
@ -65,7 +65,15 @@ MAKE_ARGS:=$(MAKE_ARGS) -j$(JOBS)
|
|||||||
|
|
||||||
### Main targets
|
### Main targets
|
||||||
|
|
||||||
all: jdk
|
default: jdk
|
||||||
|
@$(call CheckIfMakeAtEnd)
|
||||||
|
|
||||||
|
all: images docs
|
||||||
|
@$(call CheckIfMakeAtEnd)
|
||||||
|
|
||||||
|
ifeq ($(OPENJDK_TARGET_OS)-$(OPENJDK_TARGET_CPU_BITS),solaris-64)
|
||||||
|
all: overlay-images
|
||||||
|
endif
|
||||||
|
|
||||||
start-make:
|
start-make:
|
||||||
@$(call AtMakeStart)
|
@$(call AtMakeStart)
|
||||||
@ -126,12 +134,6 @@ overlay-images-only: start-make
|
|||||||
@($(CD) $(JDK_TOPDIR)/makefiles && $(BUILD_LOG_WRAPPER) $(MAKE) $(MAKE_ARGS) -f BuildJdk.gmk overlay-images)
|
@($(CD) $(JDK_TOPDIR)/makefiles && $(BUILD_LOG_WRAPPER) $(MAKE) $(MAKE_ARGS) -f BuildJdk.gmk overlay-images)
|
||||||
@$(call TargetExit)
|
@$(call TargetExit)
|
||||||
|
|
||||||
bundles: images bundles-only
|
|
||||||
bundles-only: start-make
|
|
||||||
@$(call TargetEnter)
|
|
||||||
@($(CD) $(JDK_TOPDIR)/makefiles && $(BUILD_LOG_WRAPPER) $(MAKE) $(MAKE_ARGS) -f BuildJdk.gmk bundles)
|
|
||||||
@$(call TargetExit)
|
|
||||||
|
|
||||||
install: images install-only
|
install: images install-only
|
||||||
install-only: start-make
|
install-only: start-make
|
||||||
@$(call TargetEnter)
|
@$(call TargetEnter)
|
||||||
@ -144,6 +146,12 @@ docs-only: start-make
|
|||||||
@($(CD) $(SRC_ROOT)/common/makefiles/javadoc && $(BUILD_LOG_WRAPPER) $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk docs)
|
@($(CD) $(SRC_ROOT)/common/makefiles/javadoc && $(BUILD_LOG_WRAPPER) $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk docs)
|
||||||
@$(call TargetExit)
|
@$(call TargetExit)
|
||||||
|
|
||||||
|
sign-jars: jdk sign-jars-only
|
||||||
|
sign-jars-only: start-make
|
||||||
|
@$(call TargetEnter)
|
||||||
|
@($(CD) $(JDK_TOPDIR)/makefiles && $(BUILD_LOG_WRAPPER) $(MAKE) $(MAKE_ARGS) -f BuildJdk.gmk sign-jars)
|
||||||
|
@$(call TargetExit)
|
||||||
|
|
||||||
bootcycle-images:
|
bootcycle-images:
|
||||||
@$(ECHO) Boot cycle build step 1: Building the JDK image normally
|
@$(ECHO) Boot cycle build step 1: Building the JDK image normally
|
||||||
@($(CD) $(SRC_ROOT)/common/makefiles && $(BUILD_LOG_WRAPPER) $(MAKE) SPEC=$(SPEC) images)
|
@($(CD) $(SRC_ROOT)/common/makefiles && $(BUILD_LOG_WRAPPER) $(MAKE) SPEC=$(SPEC) images)
|
||||||
|
@ -391,4 +391,46 @@ define install-file
|
|||||||
endef
|
endef
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Convenience functions for working around make's limitations with $(filter ).
|
||||||
|
containing = $(foreach v,$2,$(if $(findstring $1,$v),$v))
|
||||||
|
not-containing = $(foreach v,$2,$(if $(findstring $1,$v),,$v))
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
# In Cygwin, finds are very costly, both because of expensive forks and because
|
||||||
|
# of bad file system caching. Find is used extensively in $(shell) commands to
|
||||||
|
# find source files. This makes rerunning make with no or few changes rather
|
||||||
|
# expensive. To speed this up, these two macros are used to cache the results
|
||||||
|
# of simple find commands for reuse.
|
||||||
|
#
|
||||||
|
# Runs a find and stores both the directories where it was run and the results.
|
||||||
|
# This macro can be called multiple times to add to the cache. Only finds files
|
||||||
|
# with no filters.
|
||||||
|
#
|
||||||
|
# Needs to be called with $(eval )
|
||||||
|
#
|
||||||
|
# Param 1 - Dir to find in
|
||||||
|
ifeq ($(OPENJDK_BUILD_OS),windows)
|
||||||
|
define FillCacheFind
|
||||||
|
FIND_CACHE_DIR += $1
|
||||||
|
FIND_CACHE := $$(sort $$(FIND_CACHE) $$(shell $(FIND) $1 -type f -o -type l))
|
||||||
|
endef
|
||||||
|
else
|
||||||
|
define FillCacheFind
|
||||||
|
endef
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Mimics find by looking in the cache if all of the directories have been cached.
|
||||||
|
# Otherwise reverts to shell find. This is safe to call on all platforms, even if
|
||||||
|
# cache is deactivated.
|
||||||
|
#
|
||||||
|
# The extra - is needed when FIND_CACHE_DIR is empty but should be harmless.
|
||||||
|
# Param 1 - Dirs to find in
|
||||||
|
define CacheFind
|
||||||
|
$(if $(filter-out $(addsuffix %,- $(FIND_CACHE_DIR)),$1),\
|
||||||
|
$(shell $(FIND) $1 -type f -o -type l),\
|
||||||
|
$(filter $(addsuffix %,$1),$(FIND_CACHE)))
|
||||||
|
endef
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
|
||||||
endif # _MAKEBASE_GMK
|
endif # _MAKEBASE_GMK
|
||||||
|
@ -50,7 +50,7 @@ BUILDTIMESDIR=$(OUTPUT_ROOT)/tmp/buildtimes
|
|||||||
|
|
||||||
# Global targets are possible to run either with or without a SPEC. The prototypical
|
# Global targets are possible to run either with or without a SPEC. The prototypical
|
||||||
# global target is "help".
|
# global target is "help".
|
||||||
global_targets=help configure
|
global_targets=help jprt% bridgeBuild
|
||||||
|
|
||||||
##############################
|
##############################
|
||||||
# Functions
|
# Functions
|
||||||
@ -112,7 +112,7 @@ endef
|
|||||||
|
|
||||||
# Do not indent this function, this will add whitespace at the start which the caller won't handle
|
# Do not indent this function, this will add whitespace at the start which the caller won't handle
|
||||||
define GetRealTarget
|
define GetRealTarget
|
||||||
$(strip $(if $(MAKECMDGOALS),$(MAKECMDGOALS),all))
|
$(strip $(if $(MAKECMDGOALS),$(MAKECMDGOALS),default))
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# Do not indent this function, this will add whitespace at the start which the caller won't handle
|
# Do not indent this function, this will add whitespace at the start which the caller won't handle
|
||||||
@ -126,10 +126,7 @@ define CheckIfMakeAtEnd
|
|||||||
# Check if the current target is the last goal
|
# Check if the current target is the last goal
|
||||||
$(if $(filter $@,$(call LastGoal)),$(call AtMakeEnd))
|
$(if $(filter $@,$(call LastGoal)),$(call AtMakeEnd))
|
||||||
# If the target is 'foo-only', check if our goal was stated as 'foo'
|
# If the target is 'foo-only', check if our goal was stated as 'foo'
|
||||||
$(if $(filter $(patsubst %-only,%,$@),$(call LastGoal)),$(call AtMakeEnd))
|
$(if $(filter $@,$(call LastGoal)-only),$(call AtMakeEnd))
|
||||||
# If no goal is given, 'all' is default, but the last target executed for all is 'jdk-only'. Check for that, too.
|
|
||||||
# At most one of the tests can be true.
|
|
||||||
$(if $(subst all,,$(call LastGoal)),,$(if $(filter $@,jdk-only),$(call AtMakeEnd)))
|
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# Hook to be called when starting to execute a top-level target
|
# Hook to be called when starting to execute a top-level target
|
||||||
|
@ -23,109 +23,4 @@
|
|||||||
# questions.
|
# questions.
|
||||||
#
|
#
|
||||||
|
|
||||||
# This must be the first rule
|
include ../../NewMakefile.gmk
|
||||||
all:
|
|
||||||
|
|
||||||
# Inclusion of this pseudo-target will cause make to execute this file
|
|
||||||
# serially, regardless of -j. Recursively called makefiles will not be
|
|
||||||
# affected, however. This is required for correct dependency management.
|
|
||||||
.NOTPARALLEL:
|
|
||||||
|
|
||||||
# The shell code below will be executed on /usr/ccs/bin/make on Solaris, but not in GNU make.
|
|
||||||
# /usr/ccs/bin/make lacks basically every other flow control mechanism.
|
|
||||||
TEST_FOR_NON_GNUMAKE:sh=echo You are not using GNU make/gmake, this is a requirement. Check your path. 1>&2 && exit 1
|
|
||||||
|
|
||||||
# Assume we have GNU make, but check version.
|
|
||||||
ifeq (,$(findstring 3.81,$(MAKE_VERSION)))
|
|
||||||
ifeq (,$(findstring 3.82,$(MAKE_VERSION)))
|
|
||||||
$(error This version of GNU Make is too low ($(MAKE_VERSION)). Check your path, or upgrade to 3.81 or newer.)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Locate this Makefile
|
|
||||||
ifeq ($(filter /%,$(lastword $(MAKEFILE_LIST))),)
|
|
||||||
makefile_path:=$(CURDIR)/$(lastword $(MAKEFILE_LIST))
|
|
||||||
else
|
|
||||||
makefile_path:=$(lastword $(MAKEFILE_LIST))
|
|
||||||
endif
|
|
||||||
root_dir:=$(patsubst %/common/makefiles/Makefile,%,$(makefile_path))
|
|
||||||
|
|
||||||
# ... and then we can include our helper functions
|
|
||||||
include $(dir $(makefile_path))/MakeHelpers.gmk
|
|
||||||
|
|
||||||
$(eval $(call ParseLogLevel))
|
|
||||||
$(eval $(call ParseConfAndSpec))
|
|
||||||
|
|
||||||
# Now determine if we have zero, one or several configurations to build.
|
|
||||||
ifeq ($(SPEC),)
|
|
||||||
# Since we got past ParseConfAndSpec, we must be building a global target. Do nothing.
|
|
||||||
else
|
|
||||||
ifeq ($(words $(SPEC)),1)
|
|
||||||
# We are building a single configuration. This is the normal case. Execute the Main.gmk file.
|
|
||||||
include $(dir $(makefile_path))/Main.gmk
|
|
||||||
else
|
|
||||||
# We are building multiple configurations.
|
|
||||||
# First, find out the valid targets
|
|
||||||
# Run the makefile with an arbitraty SPEC using -p -q (quiet dry-run and dump rules) to find
|
|
||||||
# available PHONY targets. Use this list as valid targets to pass on to the repeated calls.
|
|
||||||
all_phony_targets=$(filter-out $(global_targets), $(strip $(shell \
|
|
||||||
$(MAKE) -p -q -f $(makefile_path) SPEC=$(firstword $(SPEC)) | \
|
|
||||||
grep ^.PHONY: | head -n 1 | cut -d " " -f 2-)))
|
|
||||||
|
|
||||||
$(all_phony_targets):
|
|
||||||
@$(foreach spec,$(SPEC),($(MAKE) -f $(makefile_path) SPEC=$(spec) $(VERBOSE) VERBOSE=$(VERBOSE) $@) &&) true
|
|
||||||
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Here are "global" targets, i.e. targets that can be executed without specifying a single configuration.
|
|
||||||
# If you addd more global targets, please update the variable global_targets in MakeHelpers.
|
|
||||||
|
|
||||||
help:
|
|
||||||
$(info )
|
|
||||||
$(info OpenJDK Makefile help)
|
|
||||||
$(info =====================)
|
|
||||||
$(info )
|
|
||||||
$(info Common make targets)
|
|
||||||
$(info . make [all] # Compile all code but do not create images)
|
|
||||||
$(info . make images # Create complete j2sdk and j2re images)
|
|
||||||
$(info . make overlay-images # Create limited images for sparc 64 bit platforms)
|
|
||||||
$(info . make bootcycle-images # Build images twice, second time with newly build JDK)
|
|
||||||
$(info . make install # Install the generated images locally)
|
|
||||||
$(info . make clean # Remove all files generated by make, but not those)
|
|
||||||
$(info . # generated by configure)
|
|
||||||
$(info . make dist-clean # Remove all files, including configuration)
|
|
||||||
$(info . make help # Give some help on using make)
|
|
||||||
$(info . make test # Run tests, default is all tests (see TEST below))
|
|
||||||
$(info )
|
|
||||||
$(info Targets for specific components)
|
|
||||||
$(info (Component is any of langtools, corba, jaxp, jaxws, hotspot, jdk, images or overlay-images))
|
|
||||||
$(info . make <component> # Build <component> and everything it depends on. )
|
|
||||||
$(info . make <component>-only # Build <component> only, without dependencies. This)
|
|
||||||
$(info . # is faster but can result in incorrect build results!)
|
|
||||||
$(info . make clean-<component> # Remove files generated by make for <component>)
|
|
||||||
$(info )
|
|
||||||
$(info Useful make variables)
|
|
||||||
$(info . make CONF= # Build all configurations (note, assignment is empty))
|
|
||||||
$(info . make CONF=<substring> # Build the configuration(s) with a name matching)
|
|
||||||
$(info . # <substring>)
|
|
||||||
$(info )
|
|
||||||
$(info . make LOG=<loglevel> # Change the log level from warn to <loglevel>)
|
|
||||||
$(info . # Available log levels are:)
|
|
||||||
$(info . # 'warn' (default), 'info', 'debug' and 'trace')
|
|
||||||
$(info . # To see executed command lines, use LOG=debug)
|
|
||||||
$(info )
|
|
||||||
$(info . make JOBS=<n> # Run <n> parallel make jobs)
|
|
||||||
$(info . # Note that -jN does not work as expected!)
|
|
||||||
$(info )
|
|
||||||
$(info . make test TEST=<test> # Only run the given test or tests, e.g.)
|
|
||||||
$(info . # make test TEST="jdk_lang jdk_net")
|
|
||||||
$(info )
|
|
||||||
|
|
||||||
configure:
|
|
||||||
@$(SHELL) $(root_dir)/configure $(CONFIGURE_ARGS)
|
|
||||||
@echo ====================================================
|
|
||||||
@echo "Note: This is a non-recommended way of running configure."
|
|
||||||
@echo "Instead, run 'sh configure' in the top-level directory"
|
|
||||||
|
|
||||||
.PHONY: help configure
|
|
||||||
|
@ -236,7 +236,7 @@ define SetupNativeCompilation
|
|||||||
$$(foreach d,$$($1_SRC), $$(if $$(wildcard $$d),,$$(error SRC specified to SetupNativeCompilation $1 contains missing directory $$d)))
|
$$(foreach d,$$($1_SRC), $$(if $$(wildcard $$d),,$$(error SRC specified to SetupNativeCompilation $1 contains missing directory $$d)))
|
||||||
|
|
||||||
# Find all files in the source trees. Sort to remove duplicates.
|
# Find all files in the source trees. Sort to remove duplicates.
|
||||||
$1_ALL_SRCS := $$(sort $$(shell $(FIND) $$($1_SRC) -type f))
|
$1_ALL_SRCS := $$(sort $$(call CacheFind,$$($1_SRC)))
|
||||||
# Extract the C/C++ files.
|
# Extract the C/C++ files.
|
||||||
$1_EXCLUDE_FILES:=$$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_EXCLUDE_FILES)))
|
$1_EXCLUDE_FILES:=$$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_EXCLUDE_FILES)))
|
||||||
$1_INCLUDE_FILES:=$$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_INCLUDE_FILES)))
|
$1_INCLUDE_FILES:=$$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_INCLUDE_FILES)))
|
||||||
|
@ -32,8 +32,6 @@ include MakeBase.gmk
|
|||||||
# Definitions for $(DOCSDIR), $(MKDIR), $(BINDIR), etc.
|
# Definitions for $(DOCSDIR), $(MKDIR), $(BINDIR), etc.
|
||||||
#
|
#
|
||||||
|
|
||||||
CLASSPATH_SEPARATOR = :
|
|
||||||
|
|
||||||
DOCSDIR=$(OUTPUT_ROOT)/docs
|
DOCSDIR=$(OUTPUT_ROOT)/docs
|
||||||
TEMPDIR=$(OUTPUT_ROOT)/docstemp
|
TEMPDIR=$(OUTPUT_ROOT)/docstemp
|
||||||
|
|
||||||
@ -137,7 +135,7 @@ $(FULL_COMPANY_NAME) in the US and other countries.
|
|||||||
# List of all possible directories for javadoc to look for sources
|
# List of all possible directories for javadoc to look for sources
|
||||||
# NOTE: Quotes are required around sourcepath argument only on Windows.
|
# NOTE: Quotes are required around sourcepath argument only on Windows.
|
||||||
# Otherwise, you get "No packages or classes specified." due
|
# Otherwise, you get "No packages or classes specified." due
|
||||||
# to $(CLASSPATH_SEPARATOR) being interpreted as an end of
|
# to $(PATH_SEP) being interpreted as an end of
|
||||||
# command (newline or shell ; character)
|
# command (newline or shell ; character)
|
||||||
ALL_SOURCE_DIRS = $(JDK_SHARE_CLASSES) \
|
ALL_SOURCE_DIRS = $(JDK_SHARE_CLASSES) \
|
||||||
$(JDK_IMPSRC) \
|
$(JDK_IMPSRC) \
|
||||||
@ -154,7 +152,7 @@ ALL_EXISTING_SOURCE_DIRS := $(wildcard $(ALL_SOURCE_DIRS))
|
|||||||
EMPTY:=
|
EMPTY:=
|
||||||
SPACE:= $(EMPTY) $(EMPTY)
|
SPACE:= $(EMPTY) $(EMPTY)
|
||||||
RELEASEDOCS_SOURCEPATH = \
|
RELEASEDOCS_SOURCEPATH = \
|
||||||
$(subst $(SPACE),$(CLASSPATH_SEPARATOR),$(strip $(ALL_SOURCE_DIRS)))
|
$(subst $(SPACE),$(PATH_SEP),$(strip $(ALL_SOURCE_DIRS)))
|
||||||
|
|
||||||
define prep-target
|
define prep-target
|
||||||
$(MKDIR) -p $(@D)
|
$(MKDIR) -p $(@D)
|
||||||
|
@ -29,6 +29,29 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
|
|
||||||
|
void report_error()
|
||||||
|
{
|
||||||
|
LPVOID lpMsgBuf;
|
||||||
|
DWORD dw = GetLastError();
|
||||||
|
|
||||||
|
FormatMessage(
|
||||||
|
FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
||||||
|
FORMAT_MESSAGE_FROM_SYSTEM |
|
||||||
|
FORMAT_MESSAGE_IGNORE_INSERTS,
|
||||||
|
NULL,
|
||||||
|
dw,
|
||||||
|
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
|
||||||
|
(LPTSTR) &lpMsgBuf,
|
||||||
|
0,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
fprintf(stderr,
|
||||||
|
"Could not start process! Failed with error %d: %s\n",
|
||||||
|
dw, lpMsgBuf);
|
||||||
|
|
||||||
|
LocalFree(lpMsgBuf);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Test if pos points to /cygdrive/_/ where _ can
|
* Test if pos points to /cygdrive/_/ where _ can
|
||||||
* be any character.
|
* be any character.
|
||||||
@ -256,7 +279,7 @@ int main(int argc, char **argv)
|
|||||||
DWORD exitCode;
|
DWORD exitCode;
|
||||||
|
|
||||||
if (argc<3 || argv[1][0] != '-' || (argv[1][1] != 'c' && argv[1][1] != 'm')) {
|
if (argc<3 || argv[1][0] != '-' || (argv[1][1] != 'c' && argv[1][1] != 'm')) {
|
||||||
fprintf(stderr, "Usage: fixpath -c|m<path@path@...> /cygdrive/c/WINDOWS/notepad.exe /cygdrive/c/x/test.txt");
|
fprintf(stderr, "Usage: fixpath -c|m<path@path@...> /cygdrive/c/WINDOWS/notepad.exe /cygdrive/c/x/test.txt\n");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -308,11 +331,10 @@ int main(int argc, char **argv)
|
|||||||
0,
|
0,
|
||||||
&si,
|
&si,
|
||||||
&pi);
|
&pi);
|
||||||
if(!rc)
|
if(!rc) {
|
||||||
{
|
// Could not start process for some reason. Try to report why:
|
||||||
//Could not start process;
|
report_error();
|
||||||
fprintf(stderr, "Could not start process!\n");
|
exit(rc);
|
||||||
exit(-1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
WaitForSingleObject(pi.hProcess,INFINITE);
|
WaitForSingleObject(pi.hProcess,INFINITE);
|
||||||
|
@ -28,6 +28,9 @@
|
|||||||
# Locked down to jdk8
|
# Locked down to jdk8
|
||||||
jprt.tools.default.release=jdk8
|
jprt.tools.default.release=jdk8
|
||||||
|
|
||||||
|
# Unix toolkit to use for building on windows
|
||||||
|
jprt.windows.jdk8.build.unix.toolkit=cygwin
|
||||||
|
|
||||||
# The different build flavors we want, we override here so we just get these 2
|
# The different build flavors we want, we override here so we just get these 2
|
||||||
jprt.build.flavors=product,fastdebug
|
jprt.build.flavors=product,fastdebug
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user