author | weijun |
Wed, 12 Nov 2014 10:47:08 +0800 | |
changeset 27499 | 10c5f7509a99 |
parent 26671 | b214ab286ce9 |
child 27591 | f8f4973d2329 |
child 27560 | adc258b13e2c |
permissions | -rw-r--r-- |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
1 |
# |
20636
142c294d346e
6604021: RMIC is defaulting to BOOT jdk version, needs to be rmic.jar
erikj
parents:
20273
diff
changeset
|
2 |
# Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
4 |
# |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
5 |
# This code is free software; you can redistribute it and/or modify it |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
7 |
# published by the Free Software Foundation. Oracle designates this |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
8 |
# particular file as subject to the "Classpath" exception as provided |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
9 |
# by Oracle in the LICENSE file that accompanied this code. |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
10 |
# |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
11 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
12 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
13 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
14 |
# version 2 for more details (a copy is included in the LICENSE file that |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
15 |
# accompanied this code). |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
16 |
# |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
17 |
# You should have received a copy of the GNU General Public License version |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
18 |
# 2 along with this work; if not, write to the Free Software Foundation, |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
19 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
20 |
# |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
21 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
22 |
# or visit www.oracle.com if you need additional information or have any |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
23 |
# questions. |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
24 |
# |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
25 |
|
13697 | 26 |
# This makefile is much simpler now that it can use the smart javac wrapper |
27 |
# for dependency tracking between java packages and incremental compiles. |
|
28 |
# It could be even more simple if we added support for incremental jar updates |
|
29 |
# directly from the smart javac wrapper. |
|
30 |
||
31 |
# Cleaning/copying properties here is not a good solution. The properties |
|
32 |
# should be cleaned/copied by a annotation processor in sjavac. |
|
33 |
||
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
34 |
# When you read this source. Remember that $(sort ...) has the side effect |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
35 |
# of removing duplicates. It is actually this side effect that is |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
36 |
# desired whenever sort is used below! |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
37 |
|
25854 | 38 |
ifndef _JAVA_COMPILATION_GMK |
39 |
_JAVA_COMPILATION_GMK := 1 |
|
40 |
||
20363 | 41 |
ifeq (,$(_MAKEBASE_GMK)) |
42 |
$(error You must include MakeBase.gmk prior to including JavaCompilation.gmk) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
43 |
endif |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
44 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
45 |
FALSE_FIND_PATTERN:=-name FILE_NAME_THAT_DOESNT_EXIST |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
46 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
47 |
define SetupJavaCompiler |
20363 | 48 |
# param 1 is for example GENERATE_OLD_BYTECODE or GENERATE_NEW_JDKBYTECODE |
49 |
# This is the name of the compiler setup. |
|
50 |
# param 2-9 are named args. |
|
51 |
# JVM:=The jvm used to run the javac/javah command |
|
52 |
# JAVAC:=The javac jar and bootstrap classpath changes, or just bin/javac if JVM is left out |
|
53 |
# FLAGS:=Flags to be supplied to javac |
|
54 |
# SERVER_DIR:=Use a javac server (-XDserver) and store the server related files here |
|
55 |
# SERVER_JVM:=Use this JVM for the server. Defaults to the JVM above. |
|
56 |
$(foreach i,2 3 4 5 6 7 8 9 10 11 12 13 14 15, $(if $($i),$1_$(strip $($i)))$(NEWLINE)) |
|
57 |
$(call LogSetupMacroEntry,SetupJavaCompiler($1),$2,$3,$4,$5,$6,$7,$8,$9,$(10),$(11),$(12),$(13),$(14),$(15)) |
|
58 |
$(if $(16),$(error Internal makefile error: Too many arguments to SetupJavaCompiler, please update JavaCompilation.gmk)) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
59 |
|
20363 | 60 |
# The port file contains the tcp/ip on which the server listens |
61 |
# and the cookie necessary to talk to the server. |
|
62 |
$1_SJAVAC_PORTFILE:=$$($1_SERVER_DIR)/server.port |
|
63 |
# You can use a different JVM to run the background javac server. |
|
64 |
ifeq ($$($1_SERVER_JVM),) |
|
65 |
# It defaults to the same JVM that is used to start the javac command. |
|
66 |
$1_SERVER_JVM:=$$($1_JVM) |
|
67 |
endif |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
68 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
69 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
70 |
define SetupArchive |
20363 | 71 |
# param 1 is for example ARCHIVE_MYPACKAGE |
72 |
# param 2 are the dependecies |
|
73 |
# param 3,4,5,6,7,8,9 are named args. |
|
74 |
# SRCS:=List of directories in where to find files to add to archive |
|
75 |
# SUFFIXES:=File suffixes to include in jar |
|
76 |
# INCLUDES:=List of directories/packages in SRCS that should be included |
|
77 |
# EXCLUDES:=List of directories/packages in SRCS that should be excluded |
|
78 |
# EXCLUDE_FILES:=List of files in SRCS that should be excluded |
|
79 |
# EXTRA_FILES:=List of files in SRCS that should be included regardless of suffix match. |
|
80 |
# JAR:=Jar file to create |
|
81 |
# MANIFEST:=Optional manifest file template. |
|
82 |
# JARMAIN:=Optional main class to add to manifest |
|
83 |
# JARINDEX:=true means generate the index in the jar file. |
|
84 |
# SKIP_METAINF:=Set to prevent contents of an META-INF directory to be automatically |
|
85 |
# added to the archive. |
|
86 |
# EXTRA_MANIFEST_ATTR:=Extra attribute to add to manifest. |
|
87 |
# CHECK_COMPRESS_JAR Check the COMPRESS_JAR variable |
|
88 |
||
89 |
# NOTE: $2 is dependencies, not a named argument! |
|
90 |
$(foreach i,3 4 5 6 7 8 9 10 11 12 13 14 15, $(if $($i),$1_$(strip $($i)))$(NEWLINE)) |
|
91 |
$(call LogSetupMacroEntry,SetupArchive($1),<dependencies>,$3,$4,$5,$6,$7,$8,$9,$(10),$(11),$(12),$(13),$(14),$(15)) |
|
20364 | 92 |
$(if $(findstring $(LOG_LEVEL),trace), $(info *[2] <dependencies> = $(strip $2))) |
20363 | 93 |
$(if $(16),$(error Internal makefile error: Too many arguments to SetupArchive, please update JavaCompilation.gmk)) |
14111 | 94 |
|
20363 | 95 |
$1_JARMAIN:=$(strip $$($1_JARMAIN)) |
96 |
$1_JARNAME:=$$(notdir $$($1_JAR)) |
|
97 |
$1_MANIFEST_FILE:=$$(dir $$($1_JAR))_the.$$($1_JARNAME)_manifest |
|
98 |
$1_DELETESS_FILE:=$$(dir $$($1_JAR))_the.$$($1_JARNAME)_deletess |
|
99 |
$1_DELETES_FILE:=$$(dir $$($1_JAR))_the.$$($1_JARNAME)_deletes |
|
100 |
$1_BIN:=$$(dir $$($1_JAR)) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
101 |
|
20363 | 102 |
ifeq (,$$($1_SUFFIXES)) |
103 |
# No suffix was set, default to classes. |
|
104 |
$1_SUFFIXES:=.class |
|
105 |
endif |
|
106 |
# Convert suffixes to a find expression |
|
107 |
$1_FIND_PATTERNS:=$(FALSE_FIND_PATTERN) $$(patsubst %,$(SPACE)-o$(SPACE)-name$(SPACE)$(DQUOTE)*%$(DQUOTE),$$($1_SUFFIXES)) |
|
108 |
# On windows, a lot of includes/excludes risk making the command line too long, so |
|
109 |
# writing the grep patterns to files. |
|
110 |
ifneq (,$$($1_INCLUDES)) |
|
25854 | 111 |
$1_GREP_INCLUDE_PATTERNS:=$$(call EscapeDollar, \ |
112 |
$$(foreach src,$$($1_SRCS), $$(addprefix $$(src)/,$$($1_INCLUDES)))) |
|
20363 | 113 |
# If there are a lot of include patterns, output to file to shorten command lines |
114 |
ifeq ($$(word 20,$$($1_GREP_INCLUDE_PATTERNS)),) |
|
115 |
$1_GREP_INCLUDES:=| $(GREP) $$(patsubst %,$(SPACE)-e$(SPACE)$(DQUOTE)%$(DQUOTE),$$($1_GREP_INCLUDE_PATTERNS)) |
|
116 |
else |
|
20364 | 117 |
$1_GREP_INCLUDE_OUTPUT:=$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_include $$(NEWLINE) \ |
118 |
$$(call ListPathsSafely,$1_GREP_INCLUDE_PATTERNS,\n, \ |
|
119 |
>> $$($1_BIN)/_the.$$($1_JARNAME)_include) |
|
20363 | 120 |
$1_GREP_INCLUDES:=| $(GREP) -f $$($1_BIN)/_the.$$($1_JARNAME)_include |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
121 |
endif |
20363 | 122 |
endif |
123 |
ifneq (,$$($1_EXCLUDES)$$($1_EXCLUDE_FILES)) |
|
25854 | 124 |
$1_GREP_EXCLUDE_PATTERNS:=$$(call EscapeDollar, \ |
125 |
$$(foreach src,$$($1_SRCS),$$(addprefix $$(src)/, \ |
|
126 |
$$($1_EXCLUDES) $$($1_EXCLUDE_FILES)))) |
|
20363 | 127 |
# If there are a lot of include patterns, output to file to shorten command lines |
128 |
ifeq ($$(word 20,$$($1_GREP_EXCLUDE_PATTERNS)),) |
|
129 |
$1_GREP_EXCLUDES:=| $(GREP) -v $$(patsubst %,$(SPACE)-e$(SPACE)$(DQUOTE)%$(DQUOTE),$$($1_GREP_EXCLUDE_PATTERNS)) |
|
12801 | 130 |
else |
20364 | 131 |
$1_GREP_EXCLUDE_OUTPUT=$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_exclude $$(NEWLINE) \ |
132 |
$$(call ListPathsSafely,$1_GREP_EXCLUDE_PATTERNS,\n, \ |
|
133 |
>> $$($1_BIN)/_the.$$($1_JARNAME)_exclude) |
|
20363 | 134 |
$1_GREP_EXCLUDES:=| $(GREP) -v -f $$($1_BIN)/_the.$$($1_JARNAME)_exclude |
12801 | 135 |
endif |
20363 | 136 |
endif |
137 |
||
138 |
# Check if this jar needs to have its index generated. |
|
139 |
ifneq (,$$($1_JARINDEX)) |
|
140 |
$1_JARINDEX = (cd $$(dir $$@) && $(JAR) -i $$(notdir $$@)) |
|
141 |
else |
|
142 |
$1_JARINDEX = true |
|
143 |
endif |
|
144 |
# When this macro is run in the same makefile as the java compilation, dependencies are |
|
145 |
# transfered in make variables. When the macro is run in a different makefile than the |
|
146 |
# java compilation, the dependencies need to be found in the filesystem. |
|
147 |
ifneq (,$2) |
|
148 |
$1_DEPS:=$2 |
|
149 |
else |
|
23170
51e606ecede5
8037281: Improve CacheFind and enable on all platforms
erikj
parents:
23169
diff
changeset
|
150 |
# Add all source roots to the find cache since we are likely going to run find |
51e606ecede5
8037281: Improve CacheFind and enable on all platforms
erikj
parents:
23169
diff
changeset
|
151 |
# on these more than once. The cache will only be updated if necessary. |
51e606ecede5
8037281: Improve CacheFind and enable on all platforms
erikj
parents:
23169
diff
changeset
|
152 |
$$(eval $$(call FillCacheFind, $$($1_FIND_LIST))) |
20363 | 153 |
$1_DEPS:=$$(filter $$(addprefix %,$$($1_SUFFIXES)), \ |
154 |
$$(call CacheFind,$$($1_SRCS))) |
|
155 |
ifneq (,$$($1_GREP_INCLUDE_PATTERNS)) |
|
156 |
$1_DEPS:=$$(filter $$(addsuffix %,$$($1_GREP_INCLUDE_PATTERNS)),$$($1_DEPS)) |
|
12801 | 157 |
endif |
20363 | 158 |
ifneq (,$$($1_GREP_EXCLUDE_PATTERNS)) |
159 |
$1_DEPS:=$$(filter-out $$(addsuffix %,$$($1_GREP_EXCLUDE_PATTERNS)),$$($1_DEPS)) |
|
160 |
endif |
|
25854 | 161 |
# Look for EXTRA_FILES in all SRCS dirs and as absolute paths. |
162 |
$1_DEPS+=$$(wildcard $$(foreach src, $$($1_SRCS), \ |
|
163 |
$$(addprefix $$(src)/, $$($1_EXTRA_FILES))) $$($1_EXTRA_FILES)) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
164 |
ifeq (,$$($1_SKIP_METAINF)) |
20363 | 165 |
$1_DEPS+=$$(call CacheFind,$$(wildcard $$(addsuffix /META-INF,$$($1_SRCS)))) |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
166 |
endif |
20363 | 167 |
endif |
23169
fdc2570ccbf4
8037238: JDK 9 images don't rebuild when access bridge jars rebuild
erikj
parents:
23167
diff
changeset
|
168 |
# The dependency list should never be empty |
fdc2570ccbf4
8037238: JDK 9 images don't rebuild when access bridge jars rebuild
erikj
parents:
23167
diff
changeset
|
169 |
ifeq ($$(strip $$($1_DEPS)), ) |
fdc2570ccbf4
8037238: JDK 9 images don't rebuild when access bridge jars rebuild
erikj
parents:
23167
diff
changeset
|
170 |
$$(warning No dependencies found for $1) |
fdc2570ccbf4
8037238: JDK 9 images don't rebuild when access bridge jars rebuild
erikj
parents:
23167
diff
changeset
|
171 |
endif |
20363 | 172 |
|
173 |
# Utility macros, to make the shell script receipt somewhat easier to decipher. |
|
12801 | 174 |
|
25854 | 175 |
# Capture extra files is the same for both CAPTURE_CONTENTS and SCAPTURE_CONTENTS so |
176 |
# only define it once to avoid duplication. |
|
177 |
# The list of extra files might be long, so need to use ListPathsSafely to print |
|
178 |
# them out to a separte file. Then process the contents of that file to rewrite |
|
179 |
# into -C <dir> <file> lines. |
|
180 |
# The EXTRA_FILES_RESOLVED varible must be set in the macro so that it's evaluated |
|
181 |
# in the recipe when the files are guaranteed to exist. |
|
182 |
$1_CAPTURE_EXTRA_FILES=\ |
|
183 |
$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_contents.extra $$(NEWLINE) \ |
|
184 |
$$(eval $1_EXTRA_FILES_RESOLVED:=$$(call DoubleDollar, $$(call DoubleDollar, \ |
|
185 |
$$(wildcard $$(foreach src, $$($1_SRCS), \ |
|
186 |
$$(addprefix $$(src)/, $$($1_EXTRA_FILES))) $$($1_EXTRA_FILES))))) \ |
|
187 |
$$(if $$($1_EXTRA_FILES_RESOLVED), \ |
|
188 |
$$(call ListPathsSafely,$1_EXTRA_FILES_RESOLVED,\n, \ |
|
189 |
>> $$($1_BIN)/_the.$$($1_JARNAME)_contents.extra) $$(NEWLINE) \ |
|
190 |
$(SED) $$(foreach src,$$($1_SRCS), -e 's|$$(src)/|-C $$(src) |g') \ |
|
191 |
$$($1_BIN)/_the.$$($1_JARNAME)_contents.extra \ |
|
192 |
>> $$($1_BIN)/_the.$$($1_JARNAME)_contents $$(NEWLINE)) |
|
193 |
||
20363 | 194 |
# The capture contents macro finds all files (matching the patterns, typically |
195 |
# .class and .prp) that are newer than the jar-file, ie the new content to be put into the jar. |
|
22467 | 196 |
# NOTICE: please leave the parentheses space separated otherwise the AIX build will break! |
25854 | 197 |
$1_CAPTURE_CONTENTS=\ |
198 |
$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_contents $$(NEWLINE) \ |
|
199 |
$$(foreach src,$$($1_SRCS), \ |
|
200 |
$(FIND) $$(src) -type f -a \( $$($1_FIND_PATTERNS) \) -a -newer $$@ $$($1_GREP_INCLUDES) \ |
|
201 |
$$($1_GREP_EXCLUDES) | $(SED) 's|$$(src)/|-C $$(src) |g' \ |
|
202 |
>> $$($1_BIN)/_the.$$($1_JARNAME)_contents $$(NEWLINE)) \ |
|
203 |
$$($1_CAPTURE_EXTRA_FILES) |
|
204 |
||
20363 | 205 |
# The capture metainf macro finds all files below the META-INF directory that are newer than the jar-file. |
206 |
ifeq (,$$($1_SKIP_METAINF)) |
|
25854 | 207 |
$1_CAPTURE_METAINF =$$(foreach src,$$($1_SRCS), \ |
208 |
( $(FIND) $$(src)/META-INF -type f -a -newer $$@ 2> /dev/null | $(SED) 's|$$(src)/|-C $$(src) |g' >> \ |
|
209 |
$$($1_BIN)/_the.$$($1_JARNAME)_contents ) $$(NEWLINE) ) |
|
20363 | 210 |
endif |
211 |
# The capture deletes macro finds all deleted files and concatenates them. The resulting file |
|
212 |
# tells us what to remove from the jar-file. |
|
25854 | 213 |
$1_CAPTURE_DELETES=$$(foreach src,$$($1_SRCS),($(FIND) $$(src) -name _the.package.deleted -newer $$@ \ |
214 |
-exec $(SED) 's|$$(src)||g' \{\} >> $$($1_DELETES_FILE) \;) $$(NEWLINE)) |
|
20363 | 215 |
# The update contents macro updates the jar file with the previously capture contents. |
22467 | 216 |
# Use 'wc -w' to see if the contents file is empty. |
25854 | 217 |
$1_UPDATE_CONTENTS=\ |
218 |
if [ "`$(WC) -l $$($1_BIN)/_the.$$($1_JARNAME)_contents | $(AWK) '{ print $$$$1 }'`" -gt "0" ]; then \ |
|
219 |
$(ECHO) " updating" `$(WC) -l $$($1_BIN)/_the.$$($1_JARNAME)_contents | $(AWK) '{ print $$$$1 }'` files && \ |
|
220 |
$(JAR) $$($1_JAR_UPDATE_OPTIONS) $$@ @$$($1_BIN)/_the.$$($1_JARNAME)_contents; \ |
|
221 |
fi $$(NEWLINE) |
|
20363 | 222 |
# The s-variants of the above macros are used when the jar is created from scratch. |
22467 | 223 |
# NOTICE: please leave the parentheses space separated otherwise the AIX build will break! |
25854 | 224 |
$1_SCAPTURE_CONTENTS=\ |
225 |
$(RM) $$($1_BIN)/_the.$$($1_JARNAME)_contents $$(NEWLINE) \ |
|
226 |
$$(foreach src,$$($1_SRCS), \ |
|
227 |
$(FIND) $$(src) -type f -a \( $$($1_FIND_PATTERNS) \) $$($1_GREP_INCLUDES) \ |
|
228 |
$$($1_GREP_EXCLUDES) | $(SED) 's|$$(src)/|-C $$(src) |g' \ |
|
229 |
>> $$($1_BIN)/_the.$$($1_JARNAME)_contents $$(NEWLINE)) \ |
|
230 |
$$($1_CAPTURE_EXTRA_FILES) |
|
13132 | 231 |
|
20363 | 232 |
ifeq (,$$($1_SKIP_METAINF)) |
233 |
$1_SCAPTURE_METAINF=$$(foreach src,$$($1_SRCS), \ |
|
25854 | 234 |
( $(FIND) $$(src)/META-INF -type f 2> /dev/null | $(SED) 's|$$(src)/|-C $$(src) |g' >> \ |
235 |
$$($1_BIN)/_the.$$($1_JARNAME)_contents) $$(NEWLINE) ) |
|
20363 | 236 |
endif |
25854 | 237 |
$1_SUPDATE_CONTENTS=$(JAR) $$($1_JAR_UPDATE_OPTIONS) $$@ @$$($1_BIN)/_the.$$($1_JARNAME)_contents $$(NEWLINE) |
20363 | 238 |
|
239 |
# Use a slightly shorter name for logging, but with enough path to identify this jar. |
|
240 |
$1_NAME:=$$(subst $$(OUTPUT_ROOT)/,,$$($1_JAR)) |
|
241 |
||
242 |
ifneq (,$$($1_CHECK_COMPRESS_JAR)) |
|
243 |
$1_JAR_CREATE_OPTIONS := c0fm |
|
244 |
$1_JAR_UPDATE_OPTIONS := u0f |
|
245 |
ifeq ($(COMPRESS_JARS), true) |
|
246 |
$1_JAR_CREATE_OPTIONS := cfm |
|
247 |
$1_JAR_UPDATE_OPTIONS := uf |
|
13132 | 248 |
endif |
20363 | 249 |
else |
250 |
$1_JAR_CREATE_OPTIONS := cfm |
|
251 |
$1_JAR_UPDATE_OPTIONS := uf |
|
252 |
endif |
|
13132 | 253 |
|
20363 | 254 |
# Here is the rule that creates/updates the jar file. |
255 |
$$($1_JAR) : $$($1_DEPS) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
256 |
$(MKDIR) -p $$($1_BIN) |
15051
d32ad37472e6
8005540: build-infra: Improve incremental build speed on windows by caching find results
erikj
parents:
14613
diff
changeset
|
257 |
$$($1_GREP_INCLUDE_OUTPUT) |
d32ad37472e6
8005540: build-infra: Improve incremental build speed on windows by caching find results
erikj
parents:
14613
diff
changeset
|
258 |
$$($1_GREP_EXCLUDE_OUTPUT) |
20363 | 259 |
$$(if $$($1_MANIFEST), \ |
260 |
$(SED) -e "s#@@RELEASE@@#$(RELEASE)#" \ |
|
261 |
-e "s#@@COMPANY_NAME@@#$(COMPANY_NAME)#" $$($1_MANIFEST) > $$($1_MANIFEST_FILE) \ |
|
262 |
, \ |
|
263 |
$(RM) $$($1_MANIFEST_FILE) && $(TOUCH) $$($1_MANIFEST_FILE)) |
|
14111 | 264 |
$$(if $$($1_JARMAIN),$(ECHO) "Main-Class: $$(strip $$($1_JARMAIN))" >> $$($1_MANIFEST_FILE)) |
265 |
$$(if $$($1_EXTRA_MANIFEST_ATTR),$(PRINTF) "$$($1_EXTRA_MANIFEST_ATTR)\n" >> $$($1_MANIFEST_FILE)) |
|
20363 | 266 |
$$(if $$(wildcard $$@), \ |
267 |
$(ECHO) Modifying $$($1_NAME) $$(NEWLINE) \ |
|
268 |
$$($1_CAPTURE_CONTENTS) \ |
|
269 |
$$($1_CAPTURE_METAINF) \ |
|
270 |
$(RM) $$($1_DELETES_FILE) $$(NEWLINE) \ |
|
271 |
$$($1_CAPTURE_DELETES) \ |
|
272 |
$(CAT) $$($1_DELETES_FILE) > $$($1_DELETESS_FILE) $$(NEWLINE) \ |
|
273 |
if [ -s $$($1_DELETESS_FILE) ]; then \ |
|
274 |
$(ECHO) " deleting" `$(WC) -l $$($1_DELETESS_FILE) | $(AWK) '{ print $$$$1 }'` files && \ |
|
275 |
$(ZIP) -q -d $$@ `$(CAT) $$($1_DELETESS_FILE)` ; \ |
|
276 |
fi $$(NEWLINE) \ |
|
277 |
$$($1_UPDATE_CONTENTS) true $$(NEWLINE) \ |
|
278 |
$$($1_JARINDEX) && true \ |
|
279 |
, \ |
|
280 |
$(ECHO) Creating $$($1_NAME) && $(JAR) $$($1_JAR_CREATE_OPTIONS) $$@ $$($1_MANIFEST_FILE) $$(NEWLINE) \ |
|
281 |
$$($1_SCAPTURE_CONTENTS) \ |
|
282 |
$$($1_SCAPTURE_METAINF) \ |
|
283 |
$$($1_SUPDATE_CONTENTS) \ |
|
284 |
$$($1_JARINDEX) && true ) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
285 |
|
22480
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
286 |
# Add jar to target list |
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
287 |
$1 += $$($1_JAR) |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
288 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
289 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
290 |
define SetupZipArchive |
20363 | 291 |
# param 1 is for example ZIP_MYSOURCE |
292 |
# param 2,3,4,5,6,7,8,9 are named args. |
|
293 |
# SRC,ZIP,INCLUDES,INCLUDE_FILES,EXCLUDES,EXCLUDE_FILES,SUFFIXES,EXTRA_DEPS |
|
294 |
$(foreach i,2 3 4 5 6 7 8 9 10 11 12 13 14 15, $(if $($i),$1_$(strip $($i)))$(NEWLINE)) |
|
295 |
$(call LogSetupMacroEntry,SetupZipArchive($1),$2,$3,$4,$5,$6,$7,$8,$9,$(10),$(11),$(12),$(13),$(14),$(15)) |
|
296 |
$(if $(16),$(error Internal makefile error: Too many arguments to SetupZipArchive, please update JavaCompilation.gmk)) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
297 |
|
20363 | 298 |
# To avoid running find over too large sets of files, which causes make to crash |
299 |
# on some configurations (cygwin), use INCLUDES and INCLUDE_FILES to build a set |
|
300 |
# of directories to run find in, if available. |
|
301 |
ifneq ($$($1_INCLUDES)$$($1_INCLUDE_FILES),) |
|
302 |
$1_FIND_LIST := $$(wildcard $$(foreach i,$$($1_SRC), \ |
|
303 |
$$(addprefix $$i/,$$($1_INCLUDES) $$($1_INCLUDE_FILES)))) |
|
304 |
else |
|
305 |
$1_FIND_LIST := $$($1_SRC) |
|
306 |
endif |
|
18422 | 307 |
|
20363 | 308 |
# Find all files in the source tree. |
20645
6170a286f879
8025869: make docs doesn't regenerate docs correctly after changing API doc comments in jaxp sources
erikj
parents:
20364
diff
changeset
|
309 |
$1_ALL_SRCS := $$(call not-containing,_the.,$$(call CacheFind,$$($1_FIND_LIST))) |
6170a286f879
8025869: make docs doesn't regenerate docs correctly after changing API doc comments in jaxp sources
erikj
parents:
20364
diff
changeset
|
310 |
|
6170a286f879
8025869: make docs doesn't regenerate docs correctly after changing API doc comments in jaxp sources
erikj
parents:
20364
diff
changeset
|
311 |
# Filter on suffixes if set |
6170a286f879
8025869: make docs doesn't regenerate docs correctly after changing API doc comments in jaxp sources
erikj
parents:
20364
diff
changeset
|
312 |
ifneq ($$($1_SUFFIXES),) |
6170a286f879
8025869: make docs doesn't regenerate docs correctly after changing API doc comments in jaxp sources
erikj
parents:
20364
diff
changeset
|
313 |
$1_ALL_SRCS := $$(filter $$(addprefix %, $$($1_SUFFIXES)), $$($1_ALL_SRCS)) |
6170a286f879
8025869: make docs doesn't regenerate docs correctly after changing API doc comments in jaxp sources
erikj
parents:
20364
diff
changeset
|
314 |
endif |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
315 |
|
20363 | 316 |
ifneq ($$($1_INCLUDES),) |
317 |
ifneq ($$($1_SUFFIXES),) |
|
318 |
$1_ZIP_INCLUDES := $$(foreach s,$$($1_SUFFIXES), \ |
|
319 |
$$(addprefix -i$(SPACE)$(DQUOTE),$$(addsuffix /*$$s$(DQUOTE),$$($1_INCLUDES)))) |
|
320 |
else |
|
321 |
$1_ZIP_INCLUDES := $$(addprefix -i$(SPACE)$(DQUOTE),$$(addsuffix /*$(DQUOTE),$$($1_INCLUDES))) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
322 |
endif |
20363 | 323 |
endif |
324 |
ifneq ($$($1_INCLUDE_FILES),) |
|
325 |
$1_ZIP_INCLUDES += $$(addprefix -i$(SPACE),$$($1_INCLUDE_FILES)) |
|
326 |
endif |
|
327 |
ifneq ($$($1_EXCLUDES),) |
|
328 |
$1_SRC_EXCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_EXCLUDES)))) |
|
329 |
$1_ZIP_EXCLUDES := $$(addprefix -x$(SPACE)$(DQUOTE),$$(addsuffix /*$(DQUOTE),$$($1_EXCLUDES))) |
|
330 |
$1_ALL_SRCS := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_ALL_SRCS)) |
|
331 |
endif |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
332 |
|
20363 | 333 |
# Use a slightly shorter name for logging, but with enough path to identify this zip. |
334 |
$1_NAME:=$$(subst $$(OUTPUT_ROOT)/,,$$($1_ZIP)) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
335 |
|
20363 | 336 |
# Now $1_ALL_SRCS should contain all sources that are going to be put into the zip. |
337 |
# I.e. the zip -i and -x options should match the filtering done in the makefile. |
|
338 |
# Explicitly excluded files can be given with absolute path. The patsubst solution |
|
339 |
# isn't perfect but the likelyhood of an absolute path to match something in a src |
|
340 |
# dir is very small. |
|
341 |
# If zip has nothing to do, it returns 12 and would fail the build. Check for 12 |
|
342 |
# and only fail if it's not. |
|
343 |
$$($1_ZIP) : $$($1_ALL_SRCS) $$($1_EXTRA_DEPS) |
|
344 |
$(MKDIR) -p $$(@D) |
|
345 |
$(ECHO) Updating $$($1_NAME) |
|
346 |
$$(foreach i,$$($1_SRC),(cd $$i && $(ZIP) -qru $$@ . $$($1_ZIP_INCLUDES) $$($1_ZIP_EXCLUDES) -x \*_the.\* $$(addprefix -x$(SPACE),$$(patsubst $$i/%,%,$$($1_EXCLUDE_FILES))) || test "$$$$?" = "12" )$$(NEWLINE)) true |
|
347 |
$(TOUCH) $$@ |
|
22480
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
348 |
|
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
349 |
# Add zip to target list |
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
350 |
$1 += $$($1_ZIP) |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
351 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
352 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
353 |
define add_file_to_copy |
20363 | 354 |
# param 1 = BUILD_MYPACKAGE |
355 |
# parma 2 = The source file to copy. |
|
356 |
$2_TARGET:=$2 |
|
357 |
# Remove the source prefix. |
|
358 |
$$(foreach i,$$($1_SRC),$$(eval $$(call remove_string,$$i,$2_TARGET))) |
|
25854 | 359 |
# To allow for automatic overrides, do not create a rule for a target file that |
360 |
# already has one |
|
361 |
ifeq ($$(findstring $$($2_TARGET), $$($1_COPY_LIST)), ) |
|
362 |
$1_COPY_LIST += $$($2_TARGET) |
|
363 |
# Now we can setup the depency that will trigger the copying. |
|
364 |
$$($1_BIN)$$($2_TARGET) : $2 |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
365 |
$(MKDIR) -p $$(@D) |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
366 |
$(CP) $$< $$@ |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
367 |
$(CHMOD) -f ug+w $$@ |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
368 |
|
25854 | 369 |
# And do not forget this target |
370 |
$1_ALL_COPY_TARGETS += $$($1_BIN)$$($2_TARGET) |
|
371 |
endif |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
372 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
373 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
374 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
375 |
# This macro is used only for properties files that are to be |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
376 |
# copied over to the classes directory in cleaned form: |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
377 |
# Previously this was inconsistently done in different repositories. |
13697 | 378 |
# This is the new clean standard. Though it is to be superseded by |
379 |
# a standard annotation processor from with sjavac. |
|
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
380 |
# |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
381 |
# The sed expression does this: |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
382 |
# 1. Add a backslash before any :, = or ! that do not have a backslash already. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
383 |
# 2. Apply the file unicode2x.sed which does a whole bunch of \u00XX to \xXX |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
384 |
# conversions. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
385 |
# 3. Delete all lines starting with #. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
386 |
# 4. Delete empty lines. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
387 |
# 5. Append lines ending with \ with the next line. |
24080
8bfff14321a9
8041265: jdk/bin/rmic -iiop failed on macosx-x86_64 with "Class sun.rmi.rmic.iiop.BatchEnvironmen not found"
erikj
parents:
23983
diff
changeset
|
388 |
# 6. Remove leading and trailing white space. Note that tabs must be explicit |
8bfff14321a9
8041265: jdk/bin/rmic -iiop failed on macosx-x86_64 with "Class sun.rmi.rmic.iiop.BatchEnvironmen not found"
erikj
parents:
23983
diff
changeset
|
389 |
# as sed on macosx does not understand '\t'. |
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
390 |
# 7. Replace the first \= with just =. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
391 |
# 8. Finally it's all sorted to create a stable output. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
392 |
# |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
393 |
# It is assumed that = is the character used for separating names and values. |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
394 |
define add_file_to_clean |
20363 | 395 |
# param 1 = BUILD_MYPACKAGE |
396 |
# parma 2 = The source file to copy and clean. |
|
397 |
$2_TARGET:=$2 |
|
398 |
# Remove the source prefix. |
|
399 |
$$(foreach i,$$($1_SRC),$$(eval $$(call remove_string,$$i,$2_TARGET))) |
|
400 |
# Now we can setup the depency that will trigger the copying. |
|
401 |
$$($1_BIN)$$($2_TARGET) : $2 |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
402 |
$(MKDIR) -p $$(@D) |
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
403 |
$(CAT) $$< | $(SED) -e 's/\([^\\]\):/\1\\:/g' -e 's/\([^\\]\)=/\1\\=/g' \ |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
404 |
-e 's/\([^\\]\)!/\1\\!/g' -e 's/#.*/#/g' \ |
21759 | 405 |
| $(SED) -f "$(SRC_ROOT)/make/common/support/unicode2x.sed" \ |
20363 | 406 |
| $(SED) -e '/^#/d' -e '/^$$$$/d' \ |
407 |
-e :a -e '/\\$$$$/N; s/\\\n//; ta' \ |
|
24080
8bfff14321a9
8041265: jdk/bin/rmic -iiop failed on macosx-x86_64 with "Class sun.rmi.rmic.iiop.BatchEnvironmen not found"
erikj
parents:
23983
diff
changeset
|
408 |
-e 's/^[ ]*//;s/[ ]*$$$$//' \ |
23167
9996c6e2c03a
8036965: 9-dev solaris builds failed: sort: can't read STDIN: Illegal byte sequence
erikj
parents:
23162
diff
changeset
|
409 |
-e 's/\\=/=/' | LC_ALL=C $(SORT) > $$@ |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
410 |
$(CHMOD) -f ug+w $$@ |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
411 |
|
20363 | 412 |
# And do not forget this target |
413 |
$1_ALL_COPY_CLEAN_TARGETS += $$($1_BIN)$$($2_TARGET) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
414 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
415 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
416 |
define remove_string |
20363 | 417 |
$2 := $$(subst $1,,$$($2)) |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
418 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
419 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
420 |
define replace_space_with_pathsep |
20363 | 421 |
$1:=$(subst $(SPACE),$(PATH_SEP),$(strip $(patsubst %,%,$2))) |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
422 |
endef |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
423 |
|
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
424 |
define SetupJavaCompilation |
20363 | 425 |
# param 1 is for example BUILD_MYPACKAGE |
426 |
# param 2,3,4,5,6,7,8 are named args. |
|
427 |
# SETUP:=must point to a previously setup java compiler, for example: SETUP:=BOOTJAVAC |
|
428 |
# JVM:=path to ..bin/java |
|
429 |
# ADD_JAVAC_FLAGS:=javac flags to append to the default ones. |
|
430 |
# SRC:=one or more directories to search for sources |
|
431 |
# BIN:=store classes here |
|
432 |
# INCLUDES:=myapp.foo means will only compile java files in myapp.foo or any of its sub-packages. |
|
433 |
# EXCLUDES:=myapp.foo means will do not compile java files in myapp.foo or any of its sub-packages. |
|
434 |
# COPY:=.prp means copy all prp files to the corresponding package in BIN. |
|
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
435 |
# COPY_FILES:=myapp/foo/setting.txt means copy this file over to the package myapp/foo |
20363 | 436 |
# CLEAN:=.properties means copy and clean all properties file to the corresponding package in BIN. |
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
437 |
# CLEAN_FILES:=myapp/foo/setting.txt means clean this file over to the package myapp/foo |
20363 | 438 |
# SRCZIP:=Create a src.zip based on the found sources and copied files. |
439 |
# INCLUDE_FILES:="com/sun/SolarisFoobar.java" means only compile this file! |
|
440 |
# EXCLUDE_FILES:="com/sun/SolarisFoobar.java" means do not compile this particular file! |
|
441 |
# "SolarisFoobar.java" means do not compile SolarisFoobar, wherever it is found. |
|
20636
142c294d346e
6604021: RMIC is defaulting to BOOT jdk version, needs to be rmic.jar
erikj
parents:
20273
diff
changeset
|
442 |
# JAVAC_SOURCE_PATH_OVERRIDE:=This forces an explicit -sourcepath to javac instead of the complete |
142c294d346e
6604021: RMIC is defaulting to BOOT jdk version, needs to be rmic.jar
erikj
parents:
20273
diff
changeset
|
443 |
# source roots from SRC. This is sometimes needed when compiling specific subsets of the source. |
20363 | 444 |
# HEADERS:=path to directory where all generated c-headers are written. |
445 |
# DEPENDS:=Extra dependecy |
|
26671
b214ab286ce9
8058797: Building with sjavac broken after JDK-8058118
erikj
parents:
26129
diff
changeset
|
446 |
# DISABLE_SJAVAC:=Explicitly disable the use of sjavac for this compilation unit. |
20363 | 447 |
$(foreach i,2 3 4 5 6 7 8 9 10 11 12 13 14 15, $(if $($i),$1_$(strip $($i)))$(NEWLINE)) |
448 |
$(call LogSetupMacroEntry,SetupJavaCompilation($1),$2,$3,$4,$5,$6,$7,$8,$9,$(10),$(11),$(12),$(13),$(14),$(15)) |
|
449 |
$(if $(16),$(error Internal makefile error: Too many arguments to SetupJavaCompilation, please update JavaCompilation.gmk)) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
450 |
|
20363 | 451 |
# Extract the info from the java compiler setup. |
452 |
$1_JVM := $$($$($1_SETUP)_JVM) |
|
453 |
$1_JAVAC := $$($$($1_SETUP)_JAVAC) |
|
454 |
$1_FLAGS := $$($$($1_SETUP)_FLAGS) $(JAVAC_FLAGS) $$($1_ADD_JAVAC_FLAGS) |
|
455 |
ifeq ($$($1_JAVAC),) |
|
456 |
$$(error The Java compilation $1 refers to a non-existant java compiler setup $$($1_SETUP)) |
|
457 |
endif |
|
458 |
$1_SJAVAC_PORTFILE := $$($$($1_SETUP)_SJAVAC_PORTFILE) |
|
459 |
$1_SERVER_JVM := $$($$($1_SETUP)_SERVER_JVM) |
|
460 |
||
461 |
# Handle addons and overrides. |
|
462 |
$1_SRC:=$$(call ADD_SRCS,$$($1_SRC)) |
|
463 |
# Make sure the dirs exist. |
|
464 |
$$(foreach d,$$($1_SRC), $$(if $$(wildcard $$d),,$$(error SRC specified to SetupJavaCompilation $1 contains missing directory $$d))) |
|
465 |
$$(eval $$(call MakeDir,$$($1_BIN))) |
|
23170
51e606ecede5
8037281: Improve CacheFind and enable on all platforms
erikj
parents:
23169
diff
changeset
|
466 |
# Add all source roots to the find cache since we are likely going to run find |
51e606ecede5
8037281: Improve CacheFind and enable on all platforms
erikj
parents:
23169
diff
changeset
|
467 |
# on these more than once. The cache will only be updated if necessary. |
51e606ecede5
8037281: Improve CacheFind and enable on all platforms
erikj
parents:
23169
diff
changeset
|
468 |
$$(eval $$(call FillCacheFind,$$($1_SRC))) |
25854 | 469 |
# Find all files in the source trees. Preserve order of source roots for overrides to |
470 |
# work correctly. CacheFind does not preserve order so need to call it for each root. |
|
471 |
$1_ALL_SRCS += $$(filter-out $(OVR_SRCS),$$(foreach s,$$($1_SRC),$$(call CacheFind,$$(s)))) |
|
20363 | 472 |
# Extract the java files. |
473 |
ifneq ($$($1_EXCLUDE_FILES),) |
|
474 |
$1_EXCLUDE_FILES_PATTERN:=$$(addprefix %,$$($1_EXCLUDE_FILES)) |
|
475 |
endif |
|
476 |
$1_SRCS := $$(filter-out $$($1_EXCLUDE_FILES_PATTERN),$$(filter %.java,$$($1_ALL_SRCS))) |
|
477 |
ifneq ($$($1_INCLUDE_FILES),) |
|
478 |
$1_INCLUDE_FILES:=$$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_INCLUDE_FILES))) |
|
479 |
$1_SRCS := $$(filter $$($1_INCLUDE_FILES), $$($1_SRCS)) |
|
480 |
endif |
|
481 |
||
482 |
# Now we have a list of all java files to compile: $$($1_SRCS) |
|
483 |
||
484 |
# Create the corresponding smart javac wrapper command line. |
|
23983
fa89aaeb38c2
8037085: The sjavac exclude option should accept valid directory identifiers
alundblad
parents:
23170
diff
changeset
|
485 |
$1_SJAVAC_ARGS:=$$(addprefix -x ,$$(addsuffix /*,$$($1_EXCLUDES))) \ |
fa89aaeb38c2
8037085: The sjavac exclude option should accept valid directory identifiers
alundblad
parents:
23170
diff
changeset
|
486 |
$$(addprefix -i ,$$(addsuffix /*,$$($1_INCLUDES))) \ |
20363 | 487 |
$$(addprefix -xf *,$$(strip $$($1_EXCLUDE_FILES))) \ |
488 |
$$(addprefix -if *,$$(strip $$($1_INCLUDE_FILES))) \ |
|
489 |
-src "$$(subst $$(SPACE),$$(PATH_SEP),$$(strip $$($1_SRC)))" |
|
13697 | 490 |
|
20363 | 491 |
# Prepend the source/bin path to the filter expressions. |
492 |
ifneq ($$($1_INCLUDES),) |
|
493 |
$1_SRC_INCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_INCLUDES)))) |
|
494 |
$1_SRCS := $$(filter $$($1_SRC_INCLUDES),$$($1_SRCS)) |
|
495 |
endif |
|
496 |
ifneq ($$($1_EXCLUDES),) |
|
497 |
$1_SRC_EXCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_EXCLUDES)))) |
|
498 |
$1_SRCS := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_SRCS)) |
|
499 |
endif |
|
500 |
||
25854 | 501 |
# All files below META-INF are always copied. |
502 |
$1_ALL_COPIES := $$(filter $$(addsuffix /META-INF%,$$($1_SRC)),$$($1_ALL_SRCS)) |
|
20363 | 503 |
# Find all files to be copied from source to bin. |
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
504 |
ifneq (,$$($1_COPY)$$($1_COPY_FILES)) |
20363 | 505 |
# Search for all files to be copied. |
25854 | 506 |
$1_ALL_COPIES += $$(filter $$(addprefix %,$$($1_COPY)),$$($1_ALL_SRCS)) |
20363 | 507 |
# Copy these explicitly |
508 |
$1_ALL_COPIES += $$($1_COPY_FILES) |
|
509 |
# Copy must also respect filters. |
|
510 |
ifneq (,$$($1_INCLUDES)) |
|
511 |
$1_ALL_COPIES := $$(filter $$($1_SRC_INCLUDES),$$($1_ALL_COPIES)) |
|
13697 | 512 |
endif |
20363 | 513 |
ifneq (,$$($1_EXCLUDES)) |
514 |
$1_ALL_COPIES := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_ALL_COPIES)) |
|
515 |
endif |
|
516 |
ifneq (,$$($1_EXCLUDE_FILES)) |
|
517 |
$1_ALL_COPIES := $$(filter-out $$($1_EXCLUDE_FILES_PATTERN),$$($1_ALL_COPIES)) |
|
13697 | 518 |
endif |
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
519 |
endif |
25854 | 520 |
ifneq (,$$($1_ALL_COPIES)) |
521 |
# Yep, there are files to be copied! |
|
522 |
$1_ALL_COPY_TARGETS:= |
|
523 |
$$(foreach i,$$($1_ALL_COPIES),$$(eval $$(call add_file_to_copy,$1,$$i))) |
|
524 |
# Now we can depend on $$($1_ALL_COPY_TARGETS) to copy all files! |
|
525 |
endif |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
526 |
|
20363 | 527 |
# Find all property files to be copied and cleaned from source to bin. |
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
528 |
ifneq (,$$($1_CLEAN)$$($1_CLEAN_FILES)) |
20363 | 529 |
# Search for all files to be copied. |
530 |
$1_ALL_CLEANS := $$(filter $$(addprefix %,$$($1_CLEAN)),$$($1_ALL_SRCS)) |
|
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
531 |
# Clean these explicitly |
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
532 |
$1_ALL_CLEANS += $$($1_CLEAN_FILES) |
20363 | 533 |
# Copy and clean must also respect filters. |
534 |
ifneq (,$$($1_INCLUDES)) |
|
535 |
$1_ALL_CLEANS := $$(filter $$($1_SRC_INCLUDES),$$($1_ALL_CLEANS)) |
|
536 |
endif |
|
537 |
ifneq (,$$($1_EXCLUDES)) |
|
538 |
$1_ALL_CLEANS := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_ALL_CLEANS)) |
|
539 |
endif |
|
540 |
ifneq (,$$($1_EXCLUDE_FILES)) |
|
541 |
$1_ALL_CLEANS := $$(filter-out $$($1_EXCLUDE_FILES_PATTERN),$$($1_ALL_CLEANS)) |
|
542 |
endif |
|
543 |
ifneq (,$$($1_ALL_CLEANS)) |
|
544 |
# Yep, there are files to be copied and cleaned! |
|
545 |
$1_ALL_COPY_CLEAN_TARGETS:= |
|
23162
cb2710310e93
8036611: Cleanup of handling of properties and other java resources in the build
erikj
parents:
22481
diff
changeset
|
546 |
$$(foreach i,$$($1_ALL_CLEANS),$$(eval $$(call add_file_to_clean,$1,$$i))) |
20363 | 547 |
# Now we can depend on $$($1_ALL_COPY_CLEAN_TARGETS) to copy all files! |
548 |
endif |
|
549 |
endif |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
550 |
|
20363 | 551 |
# Prep the source paths. |
20638 | 552 |
ifneq ($$($1_JAVAC_SOURCE_PATH_OVERRIDE),) |
553 |
$$(eval $$(call replace_space_with_pathsep,$1_SRCROOTSC,$$($1_JAVAC_SOURCE_PATH_OVERRIDE))) |
|
20363 | 554 |
else |
555 |
$$(eval $$(call replace_space_with_pathsep,$1_SRCROOTSC,$$($1_SRC))) |
|
556 |
endif |
|
557 |
||
558 |
# Create a sed expression to remove the source roots and to replace / with . |
|
559 |
# and remove .java at the end. |
|
560 |
$1_REWRITE_INTO_CLASSES:=$$(foreach i,$$($1_SRC),-e 's|$$i/||g') -e 's|/|.|g' -e 's|.java$$$$||g' |
|
561 |
||
562 |
ifeq ($$($1_DISABLE_SJAVAC)x$$(ENABLE_SJAVAC),xyes) |
|
563 |
ifneq (,$$($1_HEADERS)) |
|
564 |
$1_HEADERS_ARG := -h $$($1_HEADERS) |
|
13697 | 565 |
endif |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
566 |
|
20363 | 567 |
# Using sjavac to compile. |
26129
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
568 |
$1_COMPILE_TARGETS := $$($1_BIN)/_the.$1_batch |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
569 |
|
20363 | 570 |
# Create SJAVAC variable form JAVAC variable. Expects $1_JAVAC to be |
571 |
# "bootclasspathprepend -cp .../javac.jar com.sun.tools.javac.Main" |
|
572 |
# and javac is simply replaced with sjavac. |
|
573 |
$1_SJAVAC:=$$(subst com.sun.tools.javac.Main,com.sun.tools.sjavac.Main,$$($1_JAVAC)) |
|
574 |
||
575 |
# Set the $1_REMOTE to spawn a background javac server. |
|
576 |
$1_REMOTE:=--server:portfile=$$($1_SJAVAC_PORTFILE),id=$1,sjavac=$$(subst $$(SPACE),%20,$$(subst $$(COMMA),%2C,$$(strip $$($1_SERVER_JVM) $$($1_SJAVAC)))) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
577 |
|
26129
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
578 |
$$($1_BIN)/_the.$1_batch: $$($1_SRCS) $$($1_DEPENDS) |
20363 | 579 |
$(MKDIR) -p $$(@D) |
26129
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
580 |
# As a workaround for sjavac not tracking api changed from the classpath, force full |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
581 |
# recompile if an external dependency, which is something other than a source |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
582 |
# change, triggered this compilation. |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
583 |
$$(if $$(filter-out $$($1_SRCS), $$?), $(FIND) $$(@D) -name "*.class" $(FIND_DELETE)) |
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
584 |
$$(call ListPathsSafely,$1_SRCS,\n, >> $$($1_BIN)/_the.$1_batch.tmp) |
20363 | 585 |
$(ECHO) Compiling $1 |
586 |
($$($1_JVM) $$($1_SJAVAC) \ |
|
587 |
$$($1_REMOTE) \ |
|
25854 | 588 |
-j 1 \ |
20363 | 589 |
--permit-unidentified-artifacts \ |
590 |
--permit-sources-without-package \ |
|
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
591 |
--compare-found-sources $$($1_BIN)/_the.$1_batch.tmp \ |
20363 | 592 |
--log=$(LOG_LEVEL) \ |
593 |
$$($1_SJAVAC_ARGS) \ |
|
594 |
$$($1_FLAGS) \ |
|
595 |
$$($1_HEADERS_ARG) \ |
|
596 |
-d $$($1_BIN) && \ |
|
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
597 |
$(MV) $$($1_BIN)/_the.$1_batch.tmp $$($1_BIN)/_the.$1_batch) |
26129
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
598 |
# Create a pubapi file that only changes when the pubapi changes. Dependent |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
599 |
# compilations can use this file to only get recompiled when pubapi has changed. |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
600 |
# Grep returns 1 if no matching lines are found. Do not fail for this. |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
601 |
$(GREP) -e "^I" $$($1_BIN)/javac_state > $$($1_BIN)/_the.$1_pubapi.tmp \ |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
602 |
|| test "$$$$?" = "1" |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
603 |
if [ ! -f $$($1_BIN)/_the.$1_pubapi ] \ |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
604 |
|| [ "`$(DIFF) $$($1_BIN)/_the.$1_pubapi $$($1_BIN)/_the.$1_pubapi.tmp`" != "" ]; then \ |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
605 |
$(MV) $$($1_BIN)/_the.$1_pubapi.tmp $$($1_BIN)/_the.$1_pubapi; \ |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
606 |
fi |
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
607 |
|
20363 | 608 |
else |
609 |
# Using plain javac to batch compile everything. |
|
25854 | 610 |
$1_COMPILE_TARGETS := $$($1_BIN)/_the.$1_batch |
14111 | 611 |
|
20363 | 612 |
# When building in batch, put headers in a temp dir to filter out those that actually |
613 |
# changed before copying them to the real header dir. |
|
614 |
ifneq (,$$($1_HEADERS)) |
|
22481
e0f8e9039971
8033210: Intermittent build failure: jdk8 fails on win_i586 in jdk/make (p11_convert.c(67) : Cannot open 'sun_security_pkcs11_wrapper_PKCS11.h)
erikj
parents:
22480
diff
changeset
|
615 |
$1_HEADERS_ARG := -h $$($1_HEADERS).$1.tmp |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
616 |
|
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
617 |
$$($1_HEADERS)/_the.$1_headers: $$($1_BIN)/_the.$1_batch |
14111 | 618 |
$(MKDIR) -p $$(@D) |
25854 | 619 |
if [ -d "$$($1_HEADERS).$1.tmp" ]; then \ |
620 |
for f in `ls $$($1_HEADERS).$1.tmp`; do \ |
|
621 |
if [ ! -f "$$($1_HEADERS)/$$$$f" ] \ |
|
622 |
|| [ "`$(DIFF) $$($1_HEADERS)/$$$$f $$($1_HEADERS).$1.tmp/$$$$f`" != "" ]; then \ |
|
22481
e0f8e9039971
8033210: Intermittent build failure: jdk8 fails on win_i586 in jdk/make (p11_convert.c(67) : Cannot open 'sun_security_pkcs11_wrapper_PKCS11.h)
erikj
parents:
22480
diff
changeset
|
623 |
$(CP) -f $$($1_HEADERS).$1.tmp/$$$$f $$($1_HEADERS)/$$$$f; \ |
14111 | 624 |
fi; \ |
25854 | 625 |
done; \ |
626 |
fi |
|
22481
e0f8e9039971
8033210: Intermittent build failure: jdk8 fails on win_i586 in jdk/make (p11_convert.c(67) : Cannot open 'sun_security_pkcs11_wrapper_PKCS11.h)
erikj
parents:
22480
diff
changeset
|
627 |
$(RM) -r $$($1_HEADERS).$1.tmp |
14111 | 628 |
$(TOUCH) $$@ |
629 |
||
25854 | 630 |
$1_HEADER_TARGETS := $$($1_HEADERS)/_the.$1_headers |
20363 | 631 |
endif |
14111 | 632 |
|
20363 | 633 |
# When not using sjavac, pass along all sources to javac using an @file. |
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
634 |
$$($1_BIN)/_the.$1_batch: $$($1_SRCS) $$($1_DEPENDS) |
20363 | 635 |
$(MKDIR) -p $$(@D) |
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
636 |
$(RM) $$($1_BIN)/_the.$1_batch $$($1_BIN)/_the.$1_batch.tmp |
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
637 |
$$(call ListPathsSafely,$1_SRCS,\n, >> $$($1_BIN)/_the.$1_batch.tmp) |
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
638 |
$(ECHO) Compiling `$(WC) $$($1_BIN)/_the.$1_batch.tmp | $(TR) -s ' ' | $(CUT) -f 2 -d ' '` files for $1 |
20363 | 639 |
($$($1_JVM) $$($1_JAVAC) $$($1_FLAGS) \ |
640 |
-implicit:none -sourcepath "$$($1_SRCROOTSC)" \ |
|
21054
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
641 |
-d $$($1_BIN) $$($1_HEADERS_ARG) @$$($1_BIN)/_the.$1_batch.tmp && \ |
dac7de31b5b5
8009280: JCE jurisdiction policy files not copied into jdk/lib/security
erikj
parents:
20650
diff
changeset
|
642 |
$(MV) $$($1_BIN)/_the.$1_batch.tmp $$($1_BIN)/_the.$1_batch) |
14111 | 643 |
|
20363 | 644 |
endif |
645 |
||
25854 | 646 |
# Add all targets to main variable |
647 |
$1 := $$($1_ALL_COPY_TARGETS) $$($1_ALL_COPY_CLEAN_TARGETS) $$($1_COMPILE_TARGETS) \ |
|
648 |
$$($1_HEADER_TARGETS) |
|
649 |
||
20363 | 650 |
# Check if a jar file was specified, then setup the rules for the jar. |
651 |
ifneq (,$$($1_JAR)) |
|
652 |
# If no suffixes was explicitly set for this jar file. |
|
653 |
# Use class and the cleaned/copied properties file suffixes as the default |
|
654 |
# for the types of files to be put into the jar. |
|
655 |
ifeq (,$$($1_SUFFIXES)) |
|
656 |
$1_SUFFIXES:=.class $$($1_CLEAN) $$($1_COPY) |
|
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
657 |
endif |
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
658 |
|
20363 | 659 |
$$(eval $$(call SetupArchive,ARCHIVE_$1,$$($1), \ |
660 |
SRCS:=$$($1_BIN), \ |
|
661 |
SUFFIXES:=$$($1_SUFFIXES), \ |
|
662 |
EXCLUDE:=$$($1_EXCLUDES), \ |
|
663 |
INCLUDES:=$$($1_INCLUDES), \ |
|
664 |
EXTRA_FILES:=$$($1_ALL_COPY_TARGETS) $$($1_ALL_COPY_CLEAN_TARGETS), \ |
|
665 |
JAR:=$$($1_JAR), \ |
|
666 |
JARMAIN:=$$($1_JARMAIN), \ |
|
667 |
MANIFEST:=$$($1_MANIFEST), \ |
|
668 |
EXTRA_MANIFEST_ATTR:=$$($1_EXTRA_MANIFEST_ATTR), \ |
|
669 |
JARINDEX:=$$($1_JARINDEX), \ |
|
670 |
HEADERS:=$$($1_HEADERS), \ |
|
671 |
SETUP:=$$($1_SETUP))) |
|
22480
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
672 |
|
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
673 |
# Add jar to target list |
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
674 |
$1 += $$($1_JAR) |
20363 | 675 |
endif |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
676 |
|
20363 | 677 |
# Check if a srczip was specified, then setup the rules for the srczip. |
678 |
ifneq (,$$($1_SRCZIP)) |
|
679 |
$$(eval $$(call SetupZipArchive,ARCHIVE_$1, \ |
|
680 |
SRC:=$$($1_SRC), \ |
|
681 |
ZIP:=$$($1_SRCZIP), \ |
|
682 |
INCLUDES:=$$($1_INCLUDES), \ |
|
683 |
EXCLUDES:=$$($1_EXCLUDES), \ |
|
684 |
EXCLUDE_FILES:=$$($1_EXCLUDE_FILES))) |
|
22480
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
685 |
|
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
686 |
# Add zip to target list |
d1be923b168a
8026773: Failing compilation in Corba does not fail the build
erikj
parents:
22469
diff
changeset
|
687 |
$1 += $$($1_SRCZIP) |
20363 | 688 |
endif |
12258
6ec26f6cc53e
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
689 |
endef |
25854 | 690 |
|
691 |
# Use this macro to find the correct target to depend on when the original |
|
692 |
# SetupJavaCompilation is declared in a different makefile, to avoid having |
|
693 |
# to declare and evaluate it again. |
|
694 |
# param 1 is for example BUILD_MYPACKAGE |
|
695 |
# param 2 is the output directory (BIN) |
|
696 |
define SetupJavaCompilationCompileTarget |
|
26129
5ca768410aba
8055922: Work around sjavac limitation with public api tracking cross modules
erikj
parents:
25854
diff
changeset
|
697 |
$(if $(findstring yes, $(ENABLE_SJAVAC)), $(strip $2)/_the.$(strip $1)_pubapi, \ |
25854 | 698 |
$(strip $2)/_the.$(strip $1)_batch) |
699 |
endef |
|
700 |
endif |