8329102: Clean up jdk.jpackage native compilation

Reviewed-by: erikj
This commit is contained in:
Magnus Ihse Bursie 2024-03-27 10:30:58 +00:00
parent 788d2bc40c
commit 37a5a08378
2 changed files with 80 additions and 89 deletions

View File

@ -291,6 +291,10 @@ define SetupJdkExecutableBody
-I$(TOPDIR)/src/java.base/windows/native/common \
$$($1_EXTRA_RCFLAGS)
ifneq ($$($1_HEADERS_FROM_SRC), false)
$1_SRC_HEADER_FLAGS := $$(addprefix -I, $$(wildcard $$($1_SRC)))
endif
$1_JDK_LIBS += $$($1_JDK_LIBS_$$(OPENJDK_TARGET_OS))
$1_JDK_LIBS += $$($1_JDK_LIBS_$$(OPENJDK_TARGET_OS_TYPE))
# Prepend JDK libs before external libs

View File

@ -26,169 +26,156 @@
include LibCommon.gmk
include LauncherCommon.gmk
JPACKAGE_OUTPUT_DIR := \
$(JDK_OUTPUTDIR)/modules/$(MODULE)/jdk/jpackage/internal/resources
JPACKAGE_CFLAGS_windows := -DUNICODE -D_UNICODE
JPACKAGE_CXXFLAGS_windows := -EHsc $(JPACKAGE_CFLAGS_windows)
################################################################################
## Build jpackageapplauncher
################################################################################
ifeq ($(call isTargetOs, linux), true)
JPACKAGE_APPLAUNCHER_SRC := \
$(call FindSrcDirsForComponent, jdk.jpackage, applauncher)
JPACKAGE_APPLAUNCHER_LINK_TYPE := C
JPACKAGE_APPLAUNCHER_INCLUDE_FILES := %.c
JPACKAGEAPPLAUNCHER_LINK_TYPE := C
JPACKAGEAPPLAUNCHER_INCLUDE_FILES := %.c
else
JPACKAGE_APPLAUNCHER_SRC := \
$(call FindSrcDirsForComponent, jdk.jpackage, applauncher) \
$(call FindSrcDirsForComponent, jdk.jpackage, common)
JPACKAGE_APPLAUNCHER_LINK_TYPE := C++
JPACKAGEAPPLAUNCHER_LINK_TYPE := C++
endif
JPACKAGE_OUTPUT_DIR := $(JDK_OUTPUTDIR)/modules/$(MODULE)/jdk/jpackage/internal/resources
JPACKAGE_CXXFLAGS_windows := -EHsc -DUNICODE -D_UNICODE
JPACKAGE_CFLAGS_windows := -DUNICODE -D_UNICODE
JPACKAGE_APPLAUNCHER_INCLUDES := $(addprefix -I, $(JPACKAGE_APPLAUNCHER_SRC))
# Output app launcher executable in resources dir, and symbols in the object dir
$(eval $(call SetupJdkExecutable, BUILD_JPACKAGE_APPLAUNCHEREXE, \
$(eval $(call SetupJdkExecutable, BUILD_JPACKAGEAPPLAUNCHER, \
NAME := jpackageapplauncher, \
LINK_TYPE := $(JPACKAGE_APPLAUNCHER_LINK_TYPE), \
LINK_TYPE := $(JPACKAGEAPPLAUNCHER_LINK_TYPE), \
OUTPUT_DIR := $(JPACKAGE_OUTPUT_DIR), \
SYMBOLS_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/jpackageapplauncher, \
SRC := $(JPACKAGE_APPLAUNCHER_SRC), \
INCLUDE_FILES := $(JPACKAGE_APPLAUNCHER_INCLUDE_FILES), \
SRC := applauncher, \
EXTRA_SRC := common, \
INCLUDE_FILES := $(JPACKAGEAPPLAUNCHER_INCLUDE_FILES), \
OPTIMIZATION := LOW, \
DISABLED_WARNINGS_clang_LinuxPackage.c := format-nonliteral, \
DISABLED_WARNINGS_clang_JvmLauncherLib.c := format-nonliteral, \
CFLAGS_FILTER_OUT := -MD, \
CXXFLAGS_FILTER_OUT := -MD, \
CXXFLAGS := $(JPACKAGE_APPLAUNCHER_INCLUDES), \
CFLAGS := $(JPACKAGE_APPLAUNCHER_INCLUDES), \
CFLAGS_macosx := -Wno-format-nonliteral, \
CXXFLAGS_windows := -MT $(JPACKAGE_CXXFLAGS_windows), \
CFLAGS_windows := -MT $(JPACKAGE_CFLAGS_windows), \
CXXFLAGS_windows := -MT $(JPACKAGE_CXXFLAGS_windows), \
LD_SET_ORIGIN := false, \
LIBS_macosx := -framework Cocoa -rpath @executable_path/../Frameworks/ -rpath @executable_path/../PlugIns/, \
LIBS_windows := user32.lib ole32.lib msi.lib shlwapi.lib \
Shell32.lib, \
LIBS_linux := -ldl, \
LDFLAGS_macosx := -rpath @executable_path/../Frameworks/ \
-rpath @executable_path/../PlugIns/, \
LIBS_macosx := -framework Cocoa, \
LIBS_windows := msi.lib ole32.lib shell32.lib shlwapi.lib user32.lib, \
LIBS_linux := $(LIBDL), \
MANIFEST := $(JAVA_MANIFEST), \
MANIFEST_VERSION := $(VERSION_NUMBER_FOUR_POSITIONS) \
))
JPACKAGE_TARGETS += $(BUILD_JPACKAGE_APPLAUNCHEREXE)
################################################################################
TARGETS += $(BUILD_JPACKAGEAPPLAUNCHER)
ifeq ($(call isTargetOs, linux), true)
##############################################################################
## Build libjpackageapplauncheraux
##############################################################################
JPACKAGE_LIBAPPLAUNCHER_SRC := \
$(call FindSrcDirsForComponent, jdk.jpackage, applauncher) \
$(call FindSrcDirsForComponent, jdk.jpackage, libapplauncher) \
$(call FindSrcDirsForComponent, jdk.jpackage, common)
JPACKAGE_LIBAPPLAUNCHER_INCLUDES := $(addprefix -I, $(JPACKAGE_LIBAPPLAUNCHER_SRC))
$(eval $(call SetupJdkLibrary, BUILD_JPACKAGE_LIBAPPLAUNCHER, \
$(eval $(call SetupJdkLibrary, BUILD_LIBJPACKAGEAPPLAUNCHERAUX, \
NAME := jpackageapplauncheraux, \
OUTPUT_DIR := $(JPACKAGE_OUTPUT_DIR), \
SYMBOLS_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjpackageapplauncheraux, \
SRC := $(JPACKAGE_LIBAPPLAUNCHER_SRC), \
SYMBOLS_DIR := \
$(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjpackageapplauncheraux, \
SRC := libapplauncher, \
EXTRA_SRC := \
applauncher \
common, \
EXCLUDE_FILES := LinuxLauncher.c LinuxPackage.c, \
LINK_TYPE := C++, \
OPTIMIZATION := LOW, \
DISABLED_WARNINGS_clang_JvmLauncherLib.c := format-nonliteral, \
DISABLED_WARNINGS_clang_tstrings.cpp := format-nonliteral, \
CXXFLAGS := $(JPACKAGE_LIBAPPLAUNCHER_INCLUDES), \
CFLAGS := $(JPACKAGE_LIBAPPLAUNCHER_INCLUDES), \
LD_SET_ORIGIN := false, \
LIBS := -ldl, \
LIBS_linux := $(LIBDL), \
))
JPACKAGE_TARGETS += $(BUILD_JPACKAGE_LIBAPPLAUNCHER)
TARGETS += $(BUILD_LIBJPACKAGEAPPLAUNCHERAUX)
endif
################################################################################
ifeq ($(call isTargetOs, windows), true)
##############################################################################
## Build libjpackage
##############################################################################
$(eval $(call SetupJdkLibrary, BUILD_LIB_JPACKAGE, \
$(eval $(call SetupJdkLibrary, BUILD_LIBJPACKAGE, \
NAME := jpackage, \
OPTIMIZATION := LOW, \
EXTRA_SRC := jdk.jpackage:common, \
EXTRA_SRC := common, \
CXXFLAGS_windows := $(JPACKAGE_CXXFLAGS_windows), \
LDFLAGS := $(LDFLAGS_CXX_JDK), \
LIBS := advapi32.lib ole32.lib msi.lib user32.lib \
shlwapi.lib Shell32.lib, \
LIBS_windows := advapi32.lib msi.lib ole32.lib shell32.lib shlwapi.lib \
user32.lib, \
))
JPACKAGE_TARGETS += $(BUILD_LIB_JPACKAGE)
TARGETS += $(BUILD_LIBJPACKAGE)
JPACKAGE_WIXHELPER_SRC := \
$(call FindSrcDirsForComponent, jdk.jpackage, libwixhelper) \
$(call FindSrcDirsForComponent, jdk.jpackage, common)
##############################################################################
## Build libwixhelper
##############################################################################
# Build Wix custom action helper
# Output library in resources dir, and symbols in the object dir
$(eval $(call SetupJdkLibrary, BUILD_LIB_WIXHELPER, \
$(eval $(call SetupJdkLibrary, BUILD_LIBWIXHELPER, \
NAME := wixhelper, \
OUTPUT_DIR := $(JPACKAGE_OUTPUT_DIR), \
SYMBOLS_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libwixhelper, \
OPTIMIZATION := LOW, \
SRC := $(JPACKAGE_WIXHELPER_SRC), \
EXTRA_SRC := common, \
CXXFLAGS_FILTER_OUT := -MD, \
CXXFLAGS := $(addprefix -I, $(JPACKAGE_WIXHELPER_SRC)), \
CXXFLAGS_windows := -MT $(JPACKAGE_CXXFLAGS_windows), \
LDFLAGS := $(LDFLAGS_CXX_JDK), \
LIBS := ole32.lib msi.lib User32.lib shlwapi.lib \
Shell32.lib, \
LIBS_windows := msi.lib ole32.lib shell32.lib shlwapi.lib user32.lib, \
))
JPACKAGE_TARGETS += $(BUILD_LIB_WIXHELPER)
TARGETS += $(BUILD_LIBWIXHELPER)
JPACKAGE_MSIWRAPPER_SRC := \
$(call FindSrcDirsForComponent, jdk.jpackage, msiwrapper) \
$(call FindSrcDirsForComponent, jdk.jpackage, common)
##############################################################################
## Build msiwrapper
##############################################################################
# Build exe installer wrapper for msi installer
$(eval $(call SetupJdkExecutable, BUILD_JPACKAGE_MSIWRAPPER, \
$(eval $(call SetupJdkExecutable, BUILD_MSIWRAPPER, \
NAME := msiwrapper, \
OUTPUT_DIR := $(JPACKAGE_OUTPUT_DIR), \
SYMBOLS_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/msiwrapper, \
SRC := $(JPACKAGE_MSIWRAPPER_SRC), \
EXTRA_SRC := common, \
CXXFLAGS_FILTER_OUT := -MD, \
CXXFLAGS := $(addprefix -I, $(JPACKAGE_MSIWRAPPER_SRC)), \
CXXFLAGS_windows := -MT $(JPACKAGE_CXXFLAGS_windows), \
LIBS := ole32.lib msi.lib user32.lib shlwapi.lib Shell32.lib, \
LIBS_windows := msi.lib ole32.lib shell32.lib shlwapi.lib user32.lib, \
))
JPACKAGE_TARGETS += $(BUILD_JPACKAGE_MSIWRAPPER)
TARGETS += $(BUILD_MSIWRAPPER)
##############################################################################
## Build jpackageapplauncherw
##############################################################################
# Build non-console version of launcher
$(eval $(call SetupJdkExecutable, BUILD_JPACKAGE_APPLAUNCHERWEXE, \
$(eval $(call SetupJdkExecutable, BUILD_JPACKAGEAPPLAUNCHERW, \
NAME := jpackageapplauncherw, \
LINK_TYPE := $(BUILD_JPACKAGE_APPLAUNCHEREXE_LINK_TYPE), \
OUTPUT_DIR := $(JPACKAGE_OUTPUT_DIR), \
SYMBOLS_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/jpackageapplauncherw, \
SRC := $(BUILD_JPACKAGE_APPLAUNCHEREXE_SRC), \
OPTIMIZATION := $(BUILD_JPACKAGE_APPLAUNCHEREXE_OPTIMIZATION), \
CXXFLAGS := $(BUILD_JPACKAGE_APPLAUNCHEREXE_CXXFLAGS), \
CXXFLAGS_windows := $(BUILD_JPACKAGE_APPLAUNCHEREXE_CXXFLAGS_windows) -DJP_LAUNCHERW, \
CFLAGS := $(BUILD_JPACKAGE_APPLAUNCHEREXE_CFLAGS), \
CFLAGS_windows := $(BUILD_JPACKAGE_APPLAUNCHEREXE_CFLAGS_windows) -DJP_LAUNCHERW, \
LD_SET_ORIGIN := $(BUILD_JPACKAGE_APPLAUNCHEREXE_LD_SET_ORIGIN), \
LDFLAGS := $(BUILD_JPACKAGE_APPLAUNCHEREXE_LDFLAGS), \
LIBS := $(BUILD_JPACKAGE_APPLAUNCHEREXE_LIBS), \
LIBS_windows := $(BUILD_JPACKAGE_APPLAUNCHEREXE_LIBS_windows), \
SYMBOLS_DIR := \
$(SUPPORT_OUTPUTDIR)/native/$(MODULE)/jpackageapplauncherw, \
SRC := applauncher, \
EXTRA_SRC := common, \
OPTIMIZATION := LOW, \
CFLAGS_FILTER_OUT := -MD, \
CXXFLAGS_FILTER_OUT := -MD, \
CFLAGS := -DJP_LAUNCHERW, \
CXXFLAGS := -DJP_LAUNCHERW, \
CFLAGS_windows := -MT $(JPACKAGE_CFLAGS_windows), \
CXXFLAGS_windows := -MT $(JPACKAGE_CXXFLAGS_windows), \
LD_SET_ORIGIN := false, \
LIBS_windows := msi.lib ole32.lib shell32.lib shlwapi.lib user32.lib, \
MANIFEST := $(JAVA_MANIFEST), \
MANIFEST_VERSION := $(VERSION_NUMBER_FOUR_POSITIONS) \
))
JPACKAGE_TARGETS += $(BUILD_JPACKAGE_APPLAUNCHERWEXE)
TARGETS += $(BUILD_JPACKAGEAPPLAUNCHERW)
endif
TARGETS += $(JPACKAGE_TARGETS)
$(JPACKAGE_TARGETS): $(call FindLib, java.base, java)