11#
2- # Copyright (c) 2014, 2025 , Oracle and/or its affiliates. All rights reserved.
2+ # Copyright (c) 2014, 2026 , Oracle and/or its affiliates. All rights reserved.
33# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44#
55# This code is free software; you can redistribute it and/or modify it
@@ -140,25 +140,20 @@ VALUECLASSES_STR := valueclasses
140140ifneq ($(COMPILER), bootjdk)
141141 MODULE_VALUECLASS_SRC_DIRS := $(call FindModuleValueClassSrcDirs, $(MODULE))
142142 MODULE_VALUECLASS_SOURCEPATH := $(call GetModuleValueClassSrcPath)
143-
144- # Temporarily compile valueclasses into a separate directory with the form:
145- # <tempdir>/<module>/<classpath>
146- # and then copy the class files into:
147- # <outdir>/<module>/META-INF/preview/<classpath>
148- # We cannot compile directly into the desired directory because it's the
149- # compiler which creates the original '<module>/<classpath>/...' hierarchy.
150- VALUECLASS_OUTPUTDIR := $(SUPPORT_OUTPUTDIR)/$(VALUECLASSES_STR)
151- PREVIEW_OUTPUTDIR := $(COMPILATION_OUTPUTDIR)/$(MODULE)/META-INF/preview
152-
153143 ifneq ($(MODULE_VALUECLASS_SRC_DIRS),)
144+ # Temporarily compile valueclasses into a separate directory, and then copy
145+ # into the correct "META-INF/preview" path location.
146+ # We cannot compile directly into the desired directory because it's the
147+ # compiler which creates the original '<module>/<classpath>/...' hierarchy.
148+ TEMP_OUTPUTDIR := $(SUPPORT_OUTPUTDIR)/$(VALUECLASSES_STR)
149+
154150 $(eval $(call SetupJavaCompilation, $(MODULE)-$(VALUECLASSES_STR), \
155151 SMALL_JAVA := false, \
156152 MODULE := $(MODULE), \
157153 SRC := $(wildcard $(MODULE_VALUECLASS_SRC_DIRS)), \
158154 INCLUDES := $(JDK_USER_DEFINED_FILTER), \
159155 FAIL_NO_SRC := $(FAIL_NO_SRC), \
160- BIN := $(VALUECLASS_OUTPUTDIR)/, \
161- JAR := $(JDK_OUTPUTDIR)/lib/$(VALUECLASSES_STR)/$(MODULE)-$(VALUECLASSES_STR).jar, \
156+ BIN := $(TEMP_OUTPUTDIR)/, \
162157 HEADERS := $(SUPPORT_OUTPUTDIR)/headers, \
163158 DISABLED_WARNINGS := $(DISABLED_WARNINGS_java) preview, \
164159 EXCLUDES := $(EXCLUDES), \
@@ -173,27 +168,24 @@ ifneq ($(COMPILER), bootjdk)
173168 --enable-preview -source $(JDK_SOURCE_TARGET_VERSION), \
174169 ))
175170
176- TARGETS += $($(MODULE)-$(VALUECLASSES_STR))
177-
178- # Restructure the value class hierarchy from "<module>/<classpath>/..."
179- # to "<module>/META-INF/preview/<classpath>/..."
180- # When module patching is removed, this could probably be a move rather than a copy.
181-
182- # FIXME: The marker file should probably go in modules root dir.
183- # FIXME: Copying value classes should not also copy marker files.
184- $(PREVIEW_OUTPUTDIR)/_the.copy_valueclasses.marker: $($(MODULE)-$(VALUECLASSES_STR))
185- $(call MakeTargetDir)
186- $(CP) -R $(VALUECLASS_OUTPUTDIR)/$(MODULE)/. $(@D)/
171+ # Don't add '$($(MODULE)-$(VALUECLASSES_STR))' to TARGETS (it's transient).
172+ # The 'valueclasses' target below depends on it, and that's the non-transient
173+ # result we care about.
174+
175+ # Copy compiled output from "$TEMP_OUTPUTDIR/$MODULE/<classpath>/..."
176+ # to "$COMPILATION_OUTPUTDIR/$MODULE/META-INF/preview/<classpath>/...".
177+ MOD_SRC := $(TEMP_OUTPUTDIR)/$(MODULE)
178+ MOD_DST := $(COMPILATION_OUTPUTDIR)/$(MODULE)
179+
180+ # NOTE: We cannot use '$(CP) -R $(MOD_SRC)/*/ ...' to select sub-directories (it
181+ # does not work on MacOS/BSD). Use 'filter-out' to explicitly exclude marker files.
182+ $(MOD_DST)/_the.$(MODULE).valueclasses: $($(MODULE)-$(VALUECLASSES_STR))
183+ $(RM) -r $(@D)/META-INF/preview
184+ $(MKDIR) -p $(@D)/META-INF/preview
185+ $(CP) -R $(filter-out $(MOD_SRC)/_%, $(wildcard $(MOD_SRC)/*)) $(@D)/META-INF/preview
187186 $(TOUCH) $@
188187
189- TARGETS += $(PREVIEW_OUTPUTDIR)/_the.copy_valueclasses.marker
190-
191- $(eval $(call SetupCopyFiles, $(MODULE)-copy-valueclass-jar, \
192- FILES := $(JDK_OUTPUTDIR)/lib/$(VALUECLASSES_STR)/$(MODULE)-$(VALUECLASSES_STR).jar, \
193- DEST := $(SUPPORT_OUTPUTDIR)/modules_libs/$(MODULE)/$(VALUECLASSES_STR), \
194- ))
195-
196- TARGETS += $($(MODULE)-copy-valueclass-jar)
188+ TARGETS += $(MOD_DST)/_the.$(MODULE).valueclasses
197189 endif
198190endif
199191
0 commit comments