author | zyao |
Wed, 20 Sep 2017 18:30:32 +0800 | |
changeset 47591 | d78db2ebce5e |
parent 47253 | 92fd0e04e0e1 |
child 47314 | 743814386712 |
permissions | -rw-r--r-- |
27560 | 1 |
# |
43176
1da1ffe0c6fd
8172527: Rename jdk.crypto.token to jdk.crypto.cryptoki
ascarpino
parents:
43043
diff
changeset
|
2 |
# Copyright (c) 2014, 2017, Oracle and/or its affiliates. All rights reserved. |
27560 | 3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
# |
|
5 |
# This code is free software; you can redistribute it and/or modify it |
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
|
7 |
# published by the Free Software Foundation. Oracle designates this |
|
8 |
# particular file as subject to the "Classpath" exception as provided |
|
9 |
# by Oracle in the LICENSE file that accompanied this code. |
|
10 |
# |
|
11 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
|
12 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
13 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
14 |
# version 2 for more details (a copy is included in the LICENSE file that |
|
15 |
# accompanied this code). |
|
16 |
# |
|
17 |
# You should have received a copy of the GNU General Public License version |
|
18 |
# 2 along with this work; if not, write to the Free Software Foundation, |
|
19 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
20 |
# |
|
21 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
|
22 |
# or visit www.oracle.com if you need additional information or have any |
|
23 |
# questions. |
|
24 |
# |
|
25 |
||
26 |
default: all |
|
27 |
||
28 |
include $(SPEC) |
|
29 |
include MakeBase.gmk |
|
34116
b746e382da18
8142336: Convert the SA agent build to modular build-infra makefiles
erikj
parents:
33437
diff
changeset
|
30 |
include Modules.gmk |
27560 | 31 |
|
32 |
TOOL_TARGETS := |
|
28356 | 33 |
JDK_TARGETS := |
27560 | 34 |
JRE_TARGETS := |
35 |
||
36 |
# Hook to include the corresponding custom file, if present. |
|
37 |
$(eval $(call IncludeCustomExtension, , Images-pre.gmk)) |
|
38 |
||
39 |
############################################################################ |
|
40 |
||
36543
a8ce27ddc757
8152197: Single place to specify module-specific information for images build
mchung
parents:
36506
diff
changeset
|
41 |
# All modules for the current target platform. |
a8ce27ddc757
8152197: Single place to specify module-specific information for images build
mchung
parents:
36506
diff
changeset
|
42 |
ALL_MODULES := $(call FindAllModules) |
27560 | 43 |
|
36725 | 44 |
$(eval $(call ReadImportMetaData)) |
27560 | 45 |
|
37978
2614022b9fa5
8157348: Build fails with certain source configurations
erikj
parents:
37865
diff
changeset
|
46 |
JRE_MODULES += $(filter $(ALL_MODULES), $(BOOT_MODULES) \ |
2614022b9fa5
8157348: Build fails with certain source configurations
erikj
parents:
37865
diff
changeset
|
47 |
$(PLATFORM_MODULES) $(JRE_TOOL_MODULES)) |
2614022b9fa5
8157348: Build fails with certain source configurations
erikj
parents:
37865
diff
changeset
|
48 |
JDK_MODULES += $(ALL_MODULES) |
36506 | 49 |
|
42514 | 50 |
# Modules list for compact builds |
51 |
JRE_COMPACT1_MODULES := \ |
|
52 |
java.logging \ |
|
53 |
java.scripting \ |
|
54 |
jdk.localedata \ |
|
43176
1da1ffe0c6fd
8172527: Rename jdk.crypto.token to jdk.crypto.cryptoki
ascarpino
parents:
43043
diff
changeset
|
55 |
jdk.crypto.cryptoki \ |
42514 | 56 |
jdk.crypto.ec \ |
57 |
jdk.unsupported \ |
|
58 |
# |
|
59 |
||
60 |
JRE_COMPACT2_MODULES := \ |
|
61 |
$(JRE_COMPACT1_MODULES) \ |
|
62 |
java.rmi \ |
|
63 |
java.sql \ |
|
64 |
java.xml \ |
|
65 |
jdk.xml.dom \ |
|
66 |
jdk.httpserver \ |
|
67 |
# |
|
36543
a8ce27ddc757
8152197: Single place to specify module-specific information for images build
mchung
parents:
36506
diff
changeset
|
68 |
|
42514 | 69 |
JRE_COMPACT3_MODULES := \ |
70 |
$(JRE_COMPACT2_MODULES) \ |
|
71 |
java.smartcardio \ |
|
72 |
java.compiler \ |
|
73 |
java.instrument \ |
|
74 |
java.management \ |
|
43384
0a0861e1db57
8173607: JMX RMI connector should be in its own module
dfuchs
parents:
43176
diff
changeset
|
75 |
java.management.rmi \ |
42514 | 76 |
java.naming \ |
77 |
java.prefs \ |
|
78 |
java.security.jgss \ |
|
79 |
java.security.sasl \ |
|
80 |
java.sql.rowset \ |
|
81 |
java.xml.crypto \ |
|
82 |
jdk.management \ |
|
83 |
jdk.naming.dns \ |
|
84 |
jdk.naming.rmi \ |
|
85 |
jdk.sctp \ |
|
86 |
jdk.security.auth \ |
|
87 |
# |
|
27560 | 88 |
|
37770 | 89 |
JRE_MODULES_LIST := $(call CommaList, $(JRE_MODULES)) |
90 |
JDK_MODULES_LIST := $(call CommaList, $(JDK_MODULES)) |
|
91 |
JRE_COMPACT1_MODULES_LIST := $(call CommaList, $(JRE_COMPACT1_MODULES)) |
|
92 |
JRE_COMPACT2_MODULES_LIST := $(call CommaList, $(JRE_COMPACT2_MODULES)) |
|
93 |
JRE_COMPACT3_MODULES_LIST := $(call CommaList, $(JRE_COMPACT3_MODULES)) |
|
36506 | 94 |
|
95 |
################################################################################ |
|
96 |
||
97 |
BASE_RELEASE_FILE := $(JDK_OUTPUTDIR)/release |
|
98 |
||
99 |
JMODS := $(wildcard $(IMAGES_OUTPUTDIR)/jmods/*.jmod) |
|
27560 | 100 |
|
101 |
# Use this file inside the image as target for make rule |
|
102 |
JIMAGE_TARGET_FILE := bin/java$(EXE_SUFFIX) |
|
103 |
||
38845
6d03072cdab8
8158402: jlink: should use regex for all pattern operations (--order-resources or --exclude-resources)
jlaskey
parents:
38546
diff
changeset
|
104 |
JLINK_ORDER_RESOURCES := **module-info.class |
40612
cec3daf6324a
8164858: Enable build-time use of java.lang.invoke resolve tracing
redestad
parents:
40241
diff
changeset
|
105 |
JLINK_JLI_CLASSES := |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
106 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41532
diff
changeset
|
107 |
JLINK_ORDER_RESOURCES += @$(SUPPORT_OUTPUTDIR)/link_opt/classlist |
43783
35fe9d6f5075
8175026: Capture build-time parameters to --generate-jli-classes
redestad
parents:
43384
diff
changeset
|
108 |
JLINK_JLI_CLASSES := --generate-jli-classes=@$(SUPPORT_OUTPUTDIR)/link_opt/default_jli_trace.txt |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
109 |
endif |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
110 |
JLINK_ORDER_RESOURCES += \ |
38845
6d03072cdab8
8158402: jlink: should use regex for all pattern operations (--order-resources or --exclude-resources)
jlaskey
parents:
38546
diff
changeset
|
111 |
/java.base/java/** \ |
6d03072cdab8
8158402: jlink: should use regex for all pattern operations (--order-resources or --exclude-resources)
jlaskey
parents:
38546
diff
changeset
|
112 |
/java.base/jdk/** \ |
6d03072cdab8
8158402: jlink: should use regex for all pattern operations (--order-resources or --exclude-resources)
jlaskey
parents:
38546
diff
changeset
|
113 |
/java.base/sun/** \ |
6d03072cdab8
8158402: jlink: should use regex for all pattern operations (--order-resources or --exclude-resources)
jlaskey
parents:
38546
diff
changeset
|
114 |
/java.base/com/** \ |
6d03072cdab8
8158402: jlink: should use regex for all pattern operations (--order-resources or --exclude-resources)
jlaskey
parents:
38546
diff
changeset
|
115 |
/jdk.localedata/** \ |
37865
94ea10488f02
8156756: Enable build-time use of resource ordering plugin
redestad
parents:
37770
diff
changeset
|
116 |
# |
94ea10488f02
8156756: Enable build-time use of resource ordering plugin
redestad
parents:
37770
diff
changeset
|
117 |
|
42287
925cf8cf736c
8160359: Improve jlink logging for cases when a plugin throws exception
sundar
parents:
42286
diff
changeset
|
118 |
JLINK_TOOL := $(JLINK) -J-Djlink.debug=true \ |
925cf8cf736c
8160359: Improve jlink logging for cases when a plugin throws exception
sundar
parents:
42286
diff
changeset
|
119 |
--module-path $(IMAGES_OUTPUTDIR)/jmods \ |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
120 |
--endian $(OPENJDK_BUILD_CPU_ENDIAN) \ |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
121 |
--release-info $(BASE_RELEASE_FILE) \ |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
122 |
--order-resources=$(call CommaList, $(JLINK_ORDER_RESOURCES)) \ |
42505
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42293
diff
changeset
|
123 |
--dedup-legal-notices=error-if-not-same-content \ |
40612
cec3daf6324a
8164858: Enable build-time use of java.lang.invoke resolve tracing
redestad
parents:
40241
diff
changeset
|
124 |
$(JLINK_JLI_CLASSES) \ |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37978
diff
changeset
|
125 |
# |
36506 | 126 |
|
42140
a2ea75dd99dc
8170280: Enable -g for all java compilation in the build
erikj
parents:
41875
diff
changeset
|
127 |
JLINK_JRE_EXTRA_OPTS := --no-man-pages --no-header-files --strip-debug |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
128 |
|
36506 | 129 |
ifeq ($(JLINK_KEEP_PACKAGED_MODULES), true) |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
130 |
JLINK_JDK_EXTRA_OPTS := --keep-packaged-modules $(JDK_IMAGE_DIR)/jmods |
36506 | 131 |
endif |
132 |
||
133 |
$(JDK_IMAGE_DIR)/$(JIMAGE_TARGET_FILE): $(JMODS) \ |
|
134 |
$(call DependOnVariable, JDK_MODULES_LIST) $(BASE_RELEASE_FILE) |
|
27560 | 135 |
$(ECHO) Creating jdk jimage |
36506 | 136 |
$(RM) -r $(JDK_IMAGE_DIR) |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
137 |
$(JLINK_TOOL) --add-modules $(JDK_MODULES_LIST) \ |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41532
diff
changeset
|
138 |
$(JLINK_JDK_EXTRA_OPTS) \ |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
139 |
--output $(JDK_IMAGE_DIR) |
27560 | 140 |
$(TOUCH) $@ |
141 |
||
36506 | 142 |
$(JRE_IMAGE_DIR)/$(JIMAGE_TARGET_FILE): $(JMODS) \ |
143 |
$(call DependOnVariable, JRE_MODULES_LIST) $(BASE_RELEASE_FILE) |
|
27560 | 144 |
$(ECHO) Creating jre jimage |
36506 | 145 |
$(RM) -r $(JRE_IMAGE_DIR) |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
146 |
$(JLINK_TOOL) --add-modules $(JRE_MODULES_LIST) \ |
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
147 |
$(JLINK_JRE_EXTRA_OPTS) \ |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41532
diff
changeset
|
148 |
--output $(JRE_IMAGE_DIR) |
27560 | 149 |
$(TOUCH) $@ |
150 |
||
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
151 |
|
36506 | 152 |
$(JRE_COMPACT1_IMAGE_DIR)/$(JIMAGE_TARGET_FILE): $(JMODS) \ |
153 |
$(call DependOnVariable, JRE_COMPACT1_MODULES_LIST) $(BASE_RELEASE_FILE) |
|
27560 | 154 |
$(ECHO) Creating jre compact1 jimage |
36506 | 155 |
$(RM) -r $(JRE_COMPACT1_IMAGE_DIR) |
40241
59abac94e4f2
8136930: Simplify use of module-system options by custom launchers
mchung
parents:
39954
diff
changeset
|
156 |
$(JLINK_TOOL) --add-modules $(JRE_COMPACT1_MODULES_LIST) \ |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
157 |
$(JLINK_JRE_EXTRA_OPTS) \ |
36506 | 158 |
--output $(JRE_COMPACT1_IMAGE_DIR) |
27560 | 159 |
$(TOUCH) $@ |
160 |
||
36506 | 161 |
$(JRE_COMPACT2_IMAGE_DIR)/$(JIMAGE_TARGET_FILE): $(JMODS) \ |
162 |
$(call DependOnVariable, JRE_COMPACT2_MODULES_LIST) $(BASE_RELEASE_FILE) |
|
27560 | 163 |
$(ECHO) Creating jre compact2 jimage |
36506 | 164 |
$(RM) -r $(JRE_COMPACT2_IMAGE_DIR) |
40241
59abac94e4f2
8136930: Simplify use of module-system options by custom launchers
mchung
parents:
39954
diff
changeset
|
165 |
$(JLINK_TOOL) --add-modules $(JRE_COMPACT2_MODULES_LIST) \ |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
166 |
$(JLINK_JRE_EXTRA_OPTS) \ |
36506 | 167 |
--output $(JRE_COMPACT2_IMAGE_DIR) |
27560 | 168 |
$(TOUCH) $@ |
169 |
||
36506 | 170 |
$(JRE_COMPACT3_IMAGE_DIR)/$(JIMAGE_TARGET_FILE): $(JMODS) \ |
171 |
$(call DependOnVariable, JRE_COMPACT3_MODULES_LIST) $(BASE_RELEASE_FILE) |
|
27560 | 172 |
$(ECHO) Creating jre compact3 jimage |
36506 | 173 |
$(RM) -r $(JRE_COMPACT3_IMAGE_DIR) |
40241
59abac94e4f2
8136930: Simplify use of module-system options by custom launchers
mchung
parents:
39954
diff
changeset
|
174 |
$(JLINK_TOOL) --add-modules $(JRE_COMPACT3_MODULES_LIST) \ |
41532
76dffc133464
8167558: Add new JMOD section for header files and man pages
mchung
parents:
41458
diff
changeset
|
175 |
$(JLINK_JRE_EXTRA_OPTS) \ |
36506 | 176 |
--output $(JRE_COMPACT3_IMAGE_DIR) |
27560 | 177 |
$(TOUCH) $@ |
178 |
||
179 |
TOOL_JRE_TARGETS := $(JRE_IMAGE_DIR)/$(JIMAGE_TARGET_FILE) |
|
180 |
TOOL_JDK_TARGETS := $(JDK_IMAGE_DIR)/$(JIMAGE_TARGET_FILE) |
|
181 |
TOOL_JRE_COMPACT1_TARGETS := $(JRE_COMPACT1_IMAGE_DIR)/$(JIMAGE_TARGET_FILE) |
|
182 |
TOOL_JRE_COMPACT2_TARGETS := $(JRE_COMPACT2_IMAGE_DIR)/$(JIMAGE_TARGET_FILE) |
|
183 |
TOOL_JRE_COMPACT3_TARGETS := $(JRE_COMPACT3_IMAGE_DIR)/$(JIMAGE_TARGET_FILE) |
|
184 |
||
185 |
################################################################################ |
|
186 |
# /man dir |
|
187 |
# |
|
188 |
# All variables in this section are assigned with simple =, without :, to enable |
|
189 |
# more selective overriding from the custom version of this file. |
|
190 |
# |
|
191 |
# Avoid evaluating this whole section on windows for speed and stability |
|
192 |
ifneq ($(OPENJDK_TARGET_OS), windows) |
|
193 |
JRE_MAN_PAGES += \ |
|
194 |
java.1 \ |
|
195 |
jjs.1 \ |
|
196 |
keytool.1 \ |
|
197 |
orbd.1 \ |
|
198 |
pack200.1 \ |
|
199 |
rmid.1 \ |
|
200 |
rmiregistry.1 \ |
|
201 |
servertool.1 \ |
|
202 |
tnameserv.1 \ |
|
203 |
unpack200.1 |
|
204 |
||
205 |
JDK_MAN_PAGES += \ |
|
206 |
$(JRE_MAN_PAGES) \ |
|
207 |
appletviewer.1 \ |
|
208 |
idlj.1 \ |
|
209 |
jar.1 \ |
|
210 |
jarsigner.1 \ |
|
211 |
javac.1 \ |
|
212 |
javadoc.1 \ |
|
213 |
javah.1 \ |
|
214 |
javap.1 \ |
|
215 |
jconsole.1 \ |
|
216 |
jcmd.1 \ |
|
217 |
jdb.1 \ |
|
218 |
jdeps.1 \ |
|
219 |
jinfo.1 \ |
|
220 |
jmap.1 \ |
|
221 |
jps.1 \ |
|
222 |
jrunscript.1 \ |
|
223 |
jstack.1 \ |
|
224 |
jstat.1 \ |
|
225 |
jstatd.1 \ |
|
226 |
rmic.1 \ |
|
227 |
schemagen.1 \ |
|
228 |
serialver.1 \ |
|
229 |
wsgen.1 \ |
|
230 |
wsimport.1 \ |
|
231 |
xjc.1 |
|
232 |
||
233 |
# This variable is potentially overridden in the closed makefile. |
|
47217 | 234 |
MAN_SRC_BASEDIR ?= $(TOPDIR)/src |
27560 | 235 |
|
236 |
ifeq ($(OPENJDK_TARGET_OS), linux) |
|
237 |
MAN_SRC_DIR = $(MAN_SRC_BASEDIR)/linux/doc |
|
238 |
MAN1_SUBDIR = man |
|
239 |
endif |
|
240 |
ifeq ($(OPENJDK_TARGET_OS), solaris) |
|
241 |
MAN_SRC_DIR = $(MAN_SRC_BASEDIR)/solaris/doc |
|
242 |
MAN1_SUBDIR = sun/man/man1 |
|
243 |
endif |
|
244 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
|
245 |
MAN_SRC_DIR = $(MAN_SRC_BASEDIR)/bsd/doc |
|
246 |
MAN1_SUBDIR = man |
|
247 |
endif |
|
248 |
||
249 |
$(JRE_IMAGE_DIR)/man/man1/%: $(MAN_SRC_DIR)/$(MAN1_SUBDIR)/% |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
250 |
$(call LogInfo, Copying $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 251 |
$(install-file) |
252 |
||
253 |
$(JDK_IMAGE_DIR)/man/man1/%: $(MAN_SRC_DIR)/$(MAN1_SUBDIR)/% |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
254 |
$(call LogInfo, Copying $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 255 |
$(install-file) |
256 |
||
257 |
$(JRE_IMAGE_DIR)/man/ja_JP.UTF-8/man1/%: $(MAN_SRC_DIR)/$(MAN1_SUBDIR)/ja/% |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
258 |
$(call LogInfo, Copying $(patsubst $(OUTPUTDIR)/%,%,$@)) |
30093
c8c926543552
8077992: Eliminate JDK build dependency of native2ascii and update Japanese nroff man pages to UTF-8 encoding
ihse
parents:
30091
diff
changeset
|
259 |
$(install-file) |
27560 | 260 |
|
261 |
$(JDK_IMAGE_DIR)/man/ja_JP.UTF-8/man1/%: $(MAN_SRC_DIR)/$(MAN1_SUBDIR)/ja/% |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
262 |
$(call LogInfo, Copying $(patsubst $(OUTPUTDIR)/%,%,$@)) |
30093
c8c926543552
8077992: Eliminate JDK build dependency of native2ascii and update Japanese nroff man pages to UTF-8 encoding
ihse
parents:
30091
diff
changeset
|
263 |
$(install-file) |
27560 | 264 |
|
265 |
ifeq ($(OPENJDK_TARGET_OS), solaris) |
|
266 |
$(JRE_IMAGE_DIR)/man/ja/man1/%: $(MAN_SRC_DIR)/$(MAN1_SUBDIR)/ja/% |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
267 |
$(call LogInfo, Converting $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 268 |
$(install-file) |
269 |
||
270 |
$(JDK_IMAGE_DIR)/man/ja/man1/%: $(MAN_SRC_DIR)/$(MAN1_SUBDIR)/ja/% |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
271 |
$(call LogInfo, Converting $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 272 |
$(install-file) |
273 |
endif |
|
274 |
||
275 |
ifneq ($(findstring $(OPENJDK_TARGET_OS), linux macosx), ) |
|
276 |
$(JRE_IMAGE_DIR)/man/ja: |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
277 |
$(call LogInfo, Creating $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 278 |
$(CD) $(@D) && $(RM) ja && $(LN) -s ja_JP.UTF-8 ja |
279 |
||
280 |
$(JDK_IMAGE_DIR)/man/ja: |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
281 |
$(call LogInfo, Creating $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 282 |
$(CD) $(@D) && $(RM) ja && $(LN) -s ja_JP.UTF-8 ja |
283 |
endif |
|
284 |
||
285 |
ifeq ($(OPENJDK_TARGET_OS), solaris) |
|
286 |
JRE_MAN_PAGE_LIST = $(addprefix $(JRE_IMAGE_DIR)/man/man1/, $(JRE_MAN_PAGES)) \ |
|
287 |
$(addprefix $(JRE_IMAGE_DIR)/man/ja/man1/, $(JRE_MAN_PAGES)) \ |
|
288 |
$(addprefix $(JRE_IMAGE_DIR)/man/ja_JP.UTF-8/man1/, $(JRE_MAN_PAGES)) \ |
|
289 |
$(addprefix $(JRE_IMAGE_DIR)/man/ja_JP.PCK/man1/, $(JRE_MAN_PAGES)) |
|
290 |
||
291 |
JDK_MAN_PAGE_LIST = $(addprefix $(JDK_IMAGE_DIR)/man/man1/, $(JDK_MAN_PAGES)) \ |
|
292 |
$(addprefix $(JDK_IMAGE_DIR)/man/ja/man1/, $(JDK_MAN_PAGES)) \ |
|
293 |
$(addprefix $(JDK_IMAGE_DIR)/man/ja_JP.UTF-8/man1/, $(JDK_MAN_PAGES)) \ |
|
294 |
$(addprefix $(JDK_IMAGE_DIR)/man/ja_JP.PCK/man1/, $(JDK_MAN_PAGES)) |
|
295 |
endif |
|
296 |
||
297 |
ifneq ($(findstring $(OPENJDK_TARGET_OS), linux macosx), ) |
|
298 |
JRE_MAN_PAGE_LIST = $(addprefix $(JRE_IMAGE_DIR)/man/man1/, $(JRE_MAN_PAGES)) \ |
|
299 |
$(addprefix $(JRE_IMAGE_DIR)/man/ja_JP.UTF-8/man1/, $(JRE_MAN_PAGES)) \ |
|
300 |
$(JRE_IMAGE_DIR)/man/ja |
|
301 |
||
302 |
JDK_MAN_PAGE_LIST = $(addprefix $(JDK_IMAGE_DIR)/man/man1/, $(JDK_MAN_PAGES)) \ |
|
303 |
$(addprefix $(JDK_IMAGE_DIR)/man/ja_JP.UTF-8/man1/, $(JDK_MAN_PAGES)) \ |
|
304 |
$(JDK_IMAGE_DIR)/man/ja |
|
305 |
endif |
|
306 |
||
307 |
JRE_TARGETS += $(JRE_MAN_PAGE_LIST) |
|
308 |
JDK_TARGETS += $(JDK_MAN_PAGE_LIST) |
|
309 |
endif # Windows |
|
310 |
||
311 |
################################################################################ |
|
312 |
# src.zip |
|
313 |
||
42523 | 314 |
$(JDK_IMAGE_DIR)/lib/src.zip: $(SUPPORT_OUTPUTDIR)/src.zip |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
315 |
$(call LogInfo, Copying $(patsubst $(OUTPUTDIR)/%,%,$@)) |
27560 | 316 |
$(install-file) |
317 |
||
42523 | 318 |
JDK_TARGETS += $(JDK_IMAGE_DIR)/lib/src.zip |
27560 | 319 |
|
320 |
################################################################################ |
|
321 |
# /demo dir |
|
41260 | 322 |
# Avoid doing the expensive find unless called with "jdk" as target. |
323 |
ifneq ($(filter jdk, $(MAKECMDGOALS)), ) |
|
324 |
||
325 |
DEMO_FILES := \ |
|
326 |
$(if $(wildcard $(SUPPORT_OUTPUTDIR)/demos/image), \ |
|
41875 | 327 |
$(call DoubleDollar, \ |
41260 | 328 |
$(shell $(FIND) $(SUPPORT_OUTPUTDIR)/demos/image \ |
41875 | 329 |
-type f -a ! \( -name "_the*" -o -name "javac_state" \) )) \ |
41260 | 330 |
) |
331 |
||
332 |
ifeq ($(ZIP_EXTERNAL_DEBUG_SYMBOLS), true) |
|
333 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
|
334 |
DEMO_FILES := $(call not-containing, .dSYM, $(DEMO_FILES)) |
|
335 |
else |
|
336 |
DEMO_FILES := $(filter-out %.debuginfo %.pdb %.map, $(DEMO_FILES)) |
|
337 |
endif |
|
338 |
endif |
|
339 |
||
35008 | 340 |
$(eval $(call SetupCopyFiles, JDK_COPY_DEMOS, \ |
341 |
SRC := $(SUPPORT_OUTPUTDIR)/demos/image, \ |
|
342 |
DEST := $(JDK_IMAGE_DIR)/demo, \ |
|
41260 | 343 |
FILES := $(DEMO_FILES), \ |
35008 | 344 |
)) |
27560 | 345 |
|
35008 | 346 |
JDK_TARGETS += $(JDK_COPY_DEMOS) |
27560 | 347 |
endif |
348 |
||
349 |
################################################################################ |
|
29305
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
350 |
# Code coverage data files |
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
351 |
|
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
352 |
ifeq ($(GCOV_ENABLED), true) |
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
353 |
|
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
354 |
GCOV_FIND_EXPR := -type f -name "*.gcno" |
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
355 |
|
29444
b6186ae3a799
8075236: Change layout of gcov .gcno files in symbols image
erikj
parents:
29305
diff
changeset
|
356 |
$(eval $(call SetupCopyFiles,COPY_HOTSPOT_GCOV_GCNO, \ |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
357 |
SRC := $(OUTPUTDIR), \ |
29444
b6186ae3a799
8075236: Change layout of gcov .gcno files in symbols image
erikj
parents:
29305
diff
changeset
|
358 |
DEST := $(SYMBOLS_IMAGE_DIR)/gcov, \ |
b6186ae3a799
8075236: Change layout of gcov .gcno files in symbols image
erikj
parents:
29305
diff
changeset
|
359 |
FILES := $(shell $(FIND) $(HOTSPOT_OUTPUTDIR) $(GCOV_FIND_EXPR)))) |
29305
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
360 |
|
29444
b6186ae3a799
8075236: Change layout of gcov .gcno files in symbols image
erikj
parents:
29305
diff
changeset
|
361 |
SYMBOLS_TARGETS += $(COPY_HOTSPOT_GCOV_GCNO) |
29305
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
362 |
|
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
363 |
$(eval $(call SetupCopyFiles,COPY_JDK_GCOV_GCNO, \ |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47224
diff
changeset
|
364 |
SRC := $(OUTPUTDIR), \ |
29444
b6186ae3a799
8075236: Change layout of gcov .gcno files in symbols image
erikj
parents:
29305
diff
changeset
|
365 |
DEST := $(SYMBOLS_IMAGE_DIR)/gcov, \ |
29305
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
366 |
FILES := $(shell $(FIND) $(SUPPORT_OUTPUTDIR)/native $(GCOV_FIND_EXPR)))) |
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
367 |
|
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
368 |
SYMBOLS_TARGETS += $(COPY_JDK_GCOV_GCNO) |
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
369 |
|
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
370 |
endif |
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
371 |
|
4ddc6faf7842
8073021: add native code coverage target into makefiles
erikj
parents:
29303
diff
changeset
|
372 |
################################################################################ |
37653 | 373 |
# Debug symbols |
374 |
# Since debug symbols are not included in the jmod files, they need to be copied |
|
375 |
# in manually after generating the images. |
|
376 |
||
377 |
ALL_JDK_MODULES := $(JDK_MODULES) |
|
378 |
ALL_JRE_MODULES := $(sort $(JRE_MODULES), $(foreach m, $(JRE_MODULES), \ |
|
379 |
$(call FindTransitiveDepsForModule, $m))) |
|
380 |
||
381 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
|
382 |
LIBS_TARGET_SUBDIR := bin |
|
383 |
else |
|
384 |
LIBS_TARGET_SUBDIR := lib |
|
385 |
endif |
|
386 |
||
387 |
# Param 1 - dir to find debuginfo files in |
|
388 |
FindDebuginfoFiles = \ |
|
389 |
$(wildcard $(addprefix $1/*, $(DEBUGINFO_SUFFIXES)) \ |
|
390 |
$(addprefix $1/*/*, $(DEBUGINFO_SUFFIXES)) \ |
|
391 |
$(addprefix $1/*/*/*, $(DEBUGINFO_SUFFIXES))) |
|
392 |
||
41260 | 393 |
# Pick the correct debug info files to copy, either zipped or not. |
394 |
ifeq ($(ZIP_EXTERNAL_DEBUG_SYMBOLS), true) |
|
395 |
DEBUGINFO_SUFFIXES += .diz |
|
396 |
else |
|
397 |
DEBUGINFO_SUFFIXES := .debuginfo .pdb .map |
|
398 |
# On Macosx, if debug symbols have not been zipped, find all files inside *.dSYM |
|
399 |
# dirs. |
|
400 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
|
401 |
$(eval $(call FillCacheFind, \ |
|
402 |
$(SUPPORT_OUTPUTDIR)/modules_cmds $(SUPPORT_OUTPUTDIR)/modules_libs)) |
|
403 |
FindDebuginfoFiles = \ |
|
404 |
$(if $(wildcard $1), $(call containing, .dSYM/, $(call CacheFind, $1))) |
|
405 |
endif |
|
37653 | 406 |
endif |
407 |
||
408 |
# Param 1 - either JDK or JRE |
|
409 |
SetupCopyDebuginfo = \ |
|
410 |
$(foreach m, $(ALL_$1_MODULES), \ |
|
411 |
$(eval $(call SetupCopyFiles, COPY_$1_LIBS_DEBUGINFO_$m, \ |
|
412 |
SRC := $(SUPPORT_OUTPUTDIR)/modules_libs/$m, \ |
|
413 |
DEST := $($1_IMAGE_DIR)/$(LIBS_TARGET_SUBDIR), \ |
|
414 |
FILES := $(call FindDebuginfoFiles, \ |
|
415 |
$(SUPPORT_OUTPUTDIR)/modules_libs/$m), \ |
|
416 |
)) \ |
|
417 |
$(eval $1_TARGETS += $$(COPY_$1_LIBS_DEBUGINFO_$m)) \ |
|
418 |
) |
|
419 |
||
420 |
# No space before argument to avoid having to put $(strip ) everywhere in |
|
421 |
# implementation above. |
|
422 |
$(call SetupCopyDebuginfo,JDK) |
|
423 |
$(call SetupCopyDebuginfo,JRE) |
|
424 |
||
425 |
################################################################################ |
|
27560 | 426 |
|
427 |
# Include custom post hook here to make it possible to augment the target lists |
|
428 |
# before actual target prerequisites are declared. |
|
429 |
$(eval $(call IncludeCustomExtension, , Images-post.gmk)) |
|
430 |
||
431 |
################################################################################ |
|
432 |
||
433 |
$(JRE_TARGETS): $(TOOL_JRE_TARGETS) |
|
434 |
$(JDK_TARGETS): $(TOOL_JDK_TARGETS) |
|
435 |
||
41260 | 436 |
jdk: $(JDK_TARGETS) |
437 |
jre: $(JRE_TARGETS) |
|
438 |
symbols: $(SYMBOLS_TARGETS) |
|
439 |
||
440 |
all: jdk jre symbols |
|
27560 | 441 |
|
442 |
$(JRE_COMPACT1_TARGETS): $(TOOL_JRE_COMPACT1_TARGETS) |
|
443 |
$(JRE_COMPACT2_TARGETS): $(TOOL_JRE_COMPACT2_TARGETS) |
|
444 |
$(JRE_COMPACT3_TARGETS): $(TOOL_JRE_COMPACT3_TARGETS) |
|
445 |
||
446 |
profiles: $(TOOL_JRE_COMPACT1_TARGETS) \ |
|
447 |
$(TOOL_JRE_COMPACT2_TARGETS) \ |
|
448 |
$(TOOL_JRE_COMPACT3_TARGETS) \ |
|
449 |
$(JRE_COMPACT1_TARGETS) \ |
|
450 |
$(JRE_COMPACT2_TARGETS) \ |
|
451 |
$(JRE_COMPACT3_TARGETS) |
|
452 |
||
41260 | 453 |
.PHONY: default all jdk jre symbols profiles |