author | apetcher |
Tue, 22 May 2018 14:01:11 -0400 | |
branch | JDK-8171279-XDH-TLS-branch |
changeset 56590 | 8c3ea606198d |
parent 47314 | 743814386712 |
child 50590 | 5fa19bad622d |
permissions | -rw-r--r-- |
27560 | 1 |
# |
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
2 |
# Copyright (c) 2014, 2016, 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 |
|
30 |
include JavaCompilation.gmk |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
31 |
include Modules.gmk |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
32 |
|
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
33 |
SRC_ZIP_WORK_DIR := $(SUPPORT_OUTPUTDIR)/src |
27560 | 34 |
|
35 |
# Hook to include the corresponding custom file, if present. |
|
47314 | 36 |
$(eval $(call IncludeCustomExtension, ZipSource.gmk)) |
27560 | 37 |
|
38 |
################################################################################ |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
39 |
# Create the directory structure for src.zip using symlinks. |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
40 |
# <module>/<package>/<file>.java |
27560 | 41 |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
42 |
# Find extra source dirs for a module that are not part of normal compilation |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
43 |
# but should be included in src.zip. |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
44 |
# $1: Module to find dirs for |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
45 |
ExtraSrcDirs = \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
46 |
$(wildcard $(SUPPORT_OUTPUTDIR)/rmic/$(strip $1)) |
27560 | 47 |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
48 |
ALL_MODULES := $(FindAllModules) |
27560 | 49 |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
50 |
# Generate the src dirs in the first make invocation and then call this makefile |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
51 |
# again to create src.zip. |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
52 |
$(foreach m, $(ALL_MODULES), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
53 |
$(foreach d, $(call FindModuleSrcDirs, $m) $(call ExtraSrcDirs, $m), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
54 |
$(eval $d_TARGET := $(SRC_ZIP_WORK_DIR)/$(patsubst $(TOPDIR)/%,%,$d)/$m) \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
55 |
$(if $(SRC_GENERATED), , \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
56 |
$(eval $$($d_TARGET): $d ; \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
57 |
$$(if $(filter $(TOPDIR)/%, $d), $$(link-file-relative), $$(link-file-absolute)) \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
58 |
) \ |
27560 | 59 |
) \ |
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
60 |
$(eval SRC_ZIP_SRCS += $$($d_TARGET)) \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
61 |
$(eval SRC_ZIP_SRCS_$m += $$($d_TARGET)) \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
62 |
) \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
63 |
) |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
64 |
|
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
65 |
TARGETS += $(SRC_ZIP_SRCS) |
27560 | 66 |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
67 |
################################################################################ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
68 |
# Only evaluate the creation of src.zip in a sub make call when the symlinked |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
69 |
# src directory structure has been generated. |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
70 |
ifeq ($(SRC_GENERATED), true) |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
71 |
$(eval $(call SetupZipArchive, BUILD_SRC_ZIP, \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
72 |
SRC := $(dir $(SRC_ZIP_SRCS)), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
73 |
INCLUDES := $(SRC_ZIP_INCLUDES), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
74 |
INCLUDE_FILES := $(SRC_ZIP_INCLUDE_FILES), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
75 |
EXCLUDES := $(SRC_ZIP_EXCLUDES), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
76 |
EXCLUDE_FILES := $(SRC_ZIP_EXCLUDE_FILES), \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
77 |
SUFFIXES := .java, \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
78 |
ZIP := $(SUPPORT_OUTPUTDIR)/src.zip, \ |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
79 |
)) |
27560 | 80 |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
81 |
do-zip: $(BUILD_SRC_ZIP) |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
82 |
|
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
83 |
.PHONY: do-zip |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
84 |
endif |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
85 |
|
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
86 |
zip: $(SRC_ZIP_SRCS) |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
87 |
+$(MAKE) $(MAKE_ARGS) -f ZipSource.gmk do-zip SRC_GENERATED=true |
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
88 |
|
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
89 |
TARGETS += zip |
27560 | 90 |
|
91 |
################################################################################ |
|
92 |
||
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
93 |
all: $(TARGETS) |
27560 | 94 |
|
41658
14de1ab85d25
8062810: Examine src.zip in JDK image and decide if source classes should be organized by module
erikj
parents:
28600
diff
changeset
|
95 |
.PHONY: default all zip |