8031567: Better model for storing source revision information
Reviewed-by: erikj
This commit is contained in:
parent
d8f3239b53
commit
b58f0c97b9
@ -3,8 +3,7 @@
|
|||||||
^.idea/
|
^.idea/
|
||||||
nbproject/private/
|
nbproject/private/
|
||||||
^webrev
|
^webrev
|
||||||
^.hgtip
|
^.src-rev$
|
||||||
^.bridge2
|
|
||||||
^.jib/
|
^.jib/
|
||||||
.DS_Store
|
.DS_Store
|
||||||
.metadata/
|
.metadata/
|
||||||
|
@ -1,55 +0,0 @@
|
|||||||
#
|
|
||||||
# Copyright (c) 2016, 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.
|
|
||||||
#
|
|
||||||
|
|
||||||
default: all
|
|
||||||
|
|
||||||
include $(SPEC)
|
|
||||||
include MakeBase.gmk
|
|
||||||
|
|
||||||
define SetupCreateHgtip
|
|
||||||
|
|
||||||
$$(strip $1)/$(HGTIP_FILENAME): FRC
|
|
||||||
$(HG) tip --repository $$(strip $1) --template '{node|short}\n' > $$@.tmp
|
|
||||||
if [ ! -f $$@ ] || [ "`$(CAT) $$@`" != "`$(CAT) $$@.tmp`" ]; then \
|
|
||||||
$(MV) $$@.tmp $$@ ; \
|
|
||||||
else \
|
|
||||||
$(RM) $$@.tmp ; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
TARGETS += $$(strip $1)/$(HGTIP_FILENAME)
|
|
||||||
|
|
||||||
endef
|
|
||||||
|
|
||||||
# Only try to create the tips if finding an actual hg repository. This will be
|
|
||||||
# false if building from a source bundle.
|
|
||||||
$(foreach r, $(call FindAllReposAbs), \
|
|
||||||
$(if $(wildcard $r/.hg), $(eval $(call SetupCreateHgtip, $r))) \
|
|
||||||
)
|
|
||||||
|
|
||||||
all: $(TARGETS)
|
|
||||||
|
|
||||||
FRC:
|
|
||||||
|
|
||||||
.PHONY: all
|
|
@ -77,7 +77,7 @@ endef
|
|||||||
define create-info-file
|
define create-info-file
|
||||||
$(if $(JDK_ARCH_ABI_PROP_NAME), \
|
$(if $(JDK_ARCH_ABI_PROP_NAME), \
|
||||||
$(call info-file-item, "SUN_ARCH_ABI", "$(JDK_ARCH_ABI_PROP_NAME)"))
|
$(call info-file-item, "SUN_ARCH_ABI", "$(JDK_ARCH_ABI_PROP_NAME)"))
|
||||||
$(call info-file-item, "SOURCE", "$(strip $(ALL_SOURCE_TIPS))")
|
$(call info-file-item, "SOURCE", "$(strip $(SOURCE_REVISION))")
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# Param 1 - The file containing the MODULES list
|
# Param 1 - The file containing the MODULES list
|
||||||
@ -95,12 +95,12 @@ endef
|
|||||||
# Create a variable dependency file common for all release info files.
|
# Create a variable dependency file common for all release info files.
|
||||||
INFO_FILE_VARDEPS := $(call DependOnVariable, create-info-file)
|
INFO_FILE_VARDEPS := $(call DependOnVariable, create-info-file)
|
||||||
|
|
||||||
ALL_SOURCE_TIPS = $(shell \
|
SOURCE_REVISION = $(shell \
|
||||||
if [ -f $(SUPPORT_OUTPUTDIR)/source_tips ] ; then \
|
if [ -f $(SOURCE_REVISION_TRACKER) ] ; then \
|
||||||
$(CAT) $(SUPPORT_OUTPUTDIR)/source_tips ; \
|
$(CAT) $(SOURCE_REVISION_TRACKER) ; \
|
||||||
fi)
|
fi)
|
||||||
|
|
||||||
$(BASE_RELEASE_FILE): $(INFO_FILE_VARDEPS) $(SUPPORT_OUTPUTDIR)/source_tips
|
$(BASE_RELEASE_FILE): $(INFO_FILE_VARDEPS) $(SOURCE_REVISION_TRACKER)
|
||||||
$(info-file)
|
$(info-file)
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
@ -284,16 +284,11 @@ ALL_TARGETS += $(JMOD_TARGETS)
|
|||||||
################################################################################
|
################################################################################
|
||||||
# Images targets
|
# Images targets
|
||||||
|
|
||||||
# Stores the tips for each repository. This file is be used when constructing
|
store-source-revision:
|
||||||
# the jdk image and can be used to track the exact sources used to build that
|
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f SourceRevision.gmk store-source-revision)
|
||||||
# image.
|
|
||||||
source-tips: $(SUPPORT_OUTPUTDIR)/source_tips
|
|
||||||
$(SUPPORT_OUTPUTDIR)/source_tips: FRC
|
|
||||||
$(call MakeDir, $(@D))
|
|
||||||
$(call GetSourceTips)
|
|
||||||
|
|
||||||
create-hgtip-files:
|
create-source-revision-tracker:
|
||||||
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f CreateHgtipFiles.gmk)
|
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f SourceRevision.gmk create-source-revision-tracker)
|
||||||
|
|
||||||
BOOTCYCLE_TARGET := product-images
|
BOOTCYCLE_TARGET := product-images
|
||||||
bootcycle-images:
|
bootcycle-images:
|
||||||
@ -332,7 +327,7 @@ mac-bundles-jdk:
|
|||||||
exploded-image-optimize:
|
exploded-image-optimize:
|
||||||
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f ExplodedImageOptimize.gmk)
|
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f ExplodedImageOptimize.gmk)
|
||||||
|
|
||||||
ALL_TARGETS += source-tips create-hgtip-files bootcycle-images zip-security \
|
ALL_TARGETS += store-source-revision create-source-revision-tracker bootcycle-images zip-security \
|
||||||
zip-source jrtfs-jar jdk-image jre-image \
|
zip-source jrtfs-jar jdk-image jre-image \
|
||||||
symbols-image profiles mac-bundles-jdk \
|
symbols-image profiles mac-bundles-jdk \
|
||||||
exploded-image-optimize
|
exploded-image-optimize
|
||||||
@ -684,10 +679,11 @@ else
|
|||||||
java.base-jmod jdk-image jre-image: generate-link-opt-data
|
java.base-jmod jdk-image jre-image: generate-link-opt-data
|
||||||
endif
|
endif
|
||||||
|
|
||||||
jdk-image: jmods zip-source source-tips demos samples jrtfs-jar
|
jdk-image: jmods zip-source create-source-revision-tracker demos samples \
|
||||||
jre-image: jmods source-tips jrtfs-jar
|
jrtfs-jar
|
||||||
|
jre-image: jmods create-source-revision-tracker jrtfs-jar
|
||||||
|
|
||||||
profiles: jmods zip-source source-tips jrtfs-jar
|
profiles: jmods zip-source create-source-revision-tracker jrtfs-jar
|
||||||
|
|
||||||
mac-bundles-jdk: jdk-image jre-image
|
mac-bundles-jdk: jdk-image jre-image
|
||||||
|
|
||||||
|
132
make/SourceRevision.gmk
Normal file
132
make/SourceRevision.gmk
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2016, 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.
|
||||||
|
#
|
||||||
|
|
||||||
|
default: all
|
||||||
|
|
||||||
|
include $(SPEC)
|
||||||
|
include MakeBase.gmk
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
# Keep track of what source revision is used to create the build, by creating
|
||||||
|
# a tracker file in the output directory. This tracker file is included in the
|
||||||
|
# image, and can be used to recreate the source revision used.
|
||||||
|
#
|
||||||
|
# We're either building directly from a mercurial forest, and if so, use the
|
||||||
|
# current revision from mercurial. Otherwise, we are building from a source
|
||||||
|
# bundle. As a part of creating this source bundle, the current mercurial
|
||||||
|
# revisions of all repos will be stored in a file in the top dir, which is then
|
||||||
|
# used when creating the tracker file.
|
||||||
|
|
||||||
|
STORED_SOURCE_REVISION := $(TOPDIR)/.src-rev
|
||||||
|
|
||||||
|
# Are we using mercurial?
|
||||||
|
ifneq ($(and $(HG), $(wildcard $(TOPDIR)/.hg)), )
|
||||||
|
|
||||||
|
# Verify that the entire forest is consistent
|
||||||
|
$(foreach repo, $(call FindAllReposRel), \
|
||||||
|
$(if $(wildcard $(TOPDIR)/$(repo)/.hg),, \
|
||||||
|
$(error Inconsistent revision control: $(repo) is missing .hg directory)) \
|
||||||
|
)
|
||||||
|
|
||||||
|
# Replace "." with "_top" and "/" with "-"
|
||||||
|
MakeFilenameFromRepo = \
|
||||||
|
$(strip $(subst .,top, $(subst /,-, $1)))
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
# SetupGetRevisionForRepo defines a make rule for creating a file containing
|
||||||
|
# the name of the repository and the output of "hg id" for that repository.
|
||||||
|
# Argument 1 is the relative path to the repository from the top dir.
|
||||||
|
#
|
||||||
|
SetupGetRevisionForRepo = $(NamedParamsMacroTemplate)
|
||||||
|
define SetupGetRevisionForRepoBody
|
||||||
|
$1_REPO_PATH := $$(TOPDIR)/$$(strip $1)
|
||||||
|
$1_FILENAME := $$(call MakeFilenameFromRepo, $1)
|
||||||
|
|
||||||
|
$$(SUPPORT_OUTPUTDIR)/src-rev/$$($1_FILENAME): FRC
|
||||||
|
$(call MakeDir $$(@D))
|
||||||
|
$(ECHO) $$(strip $1):`$(HG) id -i --repository $$($1_REPO_PATH)` > $$@
|
||||||
|
|
||||||
|
REPO_REVISIONS += $$(SUPPORT_OUTPUTDIR)/src-rev/$$($1_FILENAME)
|
||||||
|
endef
|
||||||
|
|
||||||
|
# Setup rules for all repos. This makes sure all the "hg id" calls are made
|
||||||
|
# in parallel.
|
||||||
|
$(foreach repo, $(call FindAllReposRel), \
|
||||||
|
$(eval $(call SetupGetRevisionForRepo, $(repo))) \
|
||||||
|
)
|
||||||
|
|
||||||
|
# Create a complete source revision output file from all repos
|
||||||
|
# Param 1: The output file
|
||||||
|
define CreateSourceRevisionFile
|
||||||
|
$1: $$(REPO_REVISIONS)
|
||||||
|
$(call MakeDir $$(@D))
|
||||||
|
$$(ECHO) `$$(CAT) $$(REPO_REVISIONS)` > $$@.tmp
|
||||||
|
if [ ! -f $$@ ] || [ "`$$(CAT) $$@`" != "`$$(CAT) $$@.tmp`" ]; then \
|
||||||
|
$$(MV) $$@.tmp $$@ ; \
|
||||||
|
else \
|
||||||
|
$$(RM) $$@.tmp ; \
|
||||||
|
fi
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call CreateSourceRevisionFile, $(STORED_SOURCE_REVISION)))
|
||||||
|
|
||||||
|
store-source-revision: $(STORED_SOURCE_REVISION)
|
||||||
|
|
||||||
|
$(eval $(call CreateSourceRevisionFile, $(SOURCE_REVISION_TRACKER)))
|
||||||
|
|
||||||
|
create-source-revision-tracker: $(SOURCE_REVISION_TRACKER)
|
||||||
|
|
||||||
|
else
|
||||||
|
# Not using HG
|
||||||
|
|
||||||
|
ifneq ($(wildcard $(STORED_SOURCE_REVISION)), )
|
||||||
|
# We have a stored source revision (.src-rev)
|
||||||
|
|
||||||
|
store-source-revision:
|
||||||
|
$(call LogWarn, Warning: No mercurial configuration present, not updating .src-rev)
|
||||||
|
|
||||||
|
$(SOURCE_REVISION_TRACKER): $(STORED_SOURCE_REVISION)
|
||||||
|
$(install-file)
|
||||||
|
|
||||||
|
create-source-revision-tracker: $(SOURCE_REVISION_TRACKER)
|
||||||
|
else
|
||||||
|
# We don't have a stored source revision. Can't do anything, really.
|
||||||
|
|
||||||
|
store-source-revision:
|
||||||
|
$(call LogWarn, Error: No mercurial configuration present, cannot create .src-rev)
|
||||||
|
exit 2
|
||||||
|
|
||||||
|
create-source-revision-tracker:
|
||||||
|
$(call LogWarn, Error: No mercurial configuration present and no .src-rev)
|
||||||
|
exit 2
|
||||||
|
endif
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
all: store-source-revision create-source-revision-tracker
|
||||||
|
|
||||||
|
FRC: # Force target
|
||||||
|
|
||||||
|
.PHONY: all store-source-revision create-source-revision-tracker
|
@ -337,44 +337,21 @@ else # HAS_FILE_FUNCTION = false
|
|||||||
endif # HAS_FILE_FUNCTION
|
endif # HAS_FILE_FUNCTION
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
# The source tips can come from the Mercurial repository, or in the files
|
|
||||||
# $(HGTIP_FILENAME) which contains the tip but is also positioned in the same
|
# A file containing a way to uniquely identify the source code revision that
|
||||||
# directory as the original .hg directory. The hgtip files are created in
|
# the build was created from
|
||||||
# CreateHgtipFiles.gmk.
|
SOURCE_REVISION_TRACKER := $(SUPPORT_OUTPUTDIR)/src-rev/source-revision-tracker
|
||||||
HGTIP_FILENAME := .hgtip
|
|
||||||
|
# Locate all hg repositories included in the forest, as absolute paths
|
||||||
FindAllReposAbs = \
|
FindAllReposAbs = \
|
||||||
$(strip $(sort $(dir $(filter-out $(SRC_ROOT)/build/%, $(wildcard \
|
$(strip $(sort $(dir $(filter-out $(SRC_ROOT)/build/%, $(wildcard \
|
||||||
$(addprefix $(SRC_ROOT)/, \
|
$(addprefix $(SRC_ROOT)/, .hg */.hg */*/.hg */*/*/.hg) \
|
||||||
.hg */.hg */*/.hg */*/.hg */*/*/.hg \
|
|
||||||
.hgtip */.hgtip */*/.hgtip */*/.hgtip */*/*/.hgtip \
|
|
||||||
) \
|
|
||||||
)))))
|
)))))
|
||||||
|
|
||||||
|
# Locate all hg repositories included in the forest, as relative paths
|
||||||
FindAllReposRel = \
|
FindAllReposRel = \
|
||||||
$(strip $(subst $(SRC_ROOT)/,.,$(patsubst $(SRC_ROOT)/%/, %, $(FindAllReposAbs))))
|
$(strip $(subst $(SRC_ROOT)/,.,$(patsubst $(SRC_ROOT)/%/, %, $(FindAllReposAbs))))
|
||||||
|
|
||||||
# Emit the repo:tip pairs to $@, but only if they changed since last time
|
|
||||||
define GetSourceTips
|
|
||||||
$(CD) $(SRC_ROOT) ; \
|
|
||||||
for i in $(FindAllReposRel) IGNORE ; do \
|
|
||||||
if [ "$${i}" = "IGNORE" ] ; then \
|
|
||||||
continue; \
|
|
||||||
elif [ -d $${i}/.hg -a "$(HG)" != "" ] ; then \
|
|
||||||
$(PRINTF) " %s:%s" \
|
|
||||||
"$${i}" `$(HG) tip --repository $${i} --template '{node|short}\n'` ; \
|
|
||||||
elif [ -f $${i}/$(HGTIP_FILENAME) ] ; then \
|
|
||||||
$(PRINTF) " %s:%s" \
|
|
||||||
"$${i}" `$(CAT) $${i}/$(HGTIP_FILENAME)` ; \
|
|
||||||
fi; \
|
|
||||||
done > $@.tmp
|
|
||||||
$(PRINTF) "\n" >> $@.tmp
|
|
||||||
if [ ! -f $@ ] || [ "`$(CAT) $@`" != "`$(CAT) $@.tmp`" ]; then \
|
|
||||||
$(MV) $@.tmp $@ ; \
|
|
||||||
else \
|
|
||||||
$(RM) $@.tmp ; \
|
|
||||||
fi
|
|
||||||
endef
|
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
define SetupLogging
|
define SetupLogging
|
||||||
|
Loading…
x
Reference in New Issue
Block a user