8328146: Set LIBCXX automatically

Reviewed-by: erikj
This commit is contained in:
Magnus Ihse Bursie 2024-03-15 13:23:37 +00:00
parent 90ab52e598
commit 42aec8c5e7
9 changed files with 21 additions and 17 deletions

View File

@ -140,6 +140,10 @@ define SetupJdkLibraryBody
endif endif
endif endif
ifeq ($$($1_LINK_TYPE), C++)
$1_LIBS += $(LIBCXX)
endif
ifeq ($$($1_SRC), ) ifeq ($$($1_SRC), )
ifneq ($$(MODULE), ) ifneq ($$(MODULE), )
$1_SRC := $$(call FindSrcDirsForLib, $$(MODULE), $$($1_NAME)) $1_SRC := $$(call FindSrcDirsForLib, $$(MODULE), $$($1_NAME))
@ -233,6 +237,10 @@ define SetupJdkExecutableBody
endif endif
endif endif
ifeq ($$($1_LINK_TYPE), C++)
$1_LIBS += $(LIBCXX)
endif
ifeq ($$($1_VERSIONINFO_RESOURCE), ) ifeq ($$($1_VERSIONINFO_RESOURCE), )
$1_VERSIONINFO_RESOURCE := $$(GLOBAL_VERSION_INFO_RESOURCE) $1_VERSIONINFO_RESOURCE := $$(GLOBAL_VERSION_INFO_RESOURCE)
endif endif

View File

@ -141,7 +141,6 @@ $(eval $(call SetupJdkExecutable, BUILD_GTEST_LAUNCHER, \
-I$(GTEST_FRAMEWORK_SRC)/googlemock/include, \ -I$(GTEST_FRAMEWORK_SRC)/googlemock/include, \
LDFLAGS := $(LDFLAGS_JDKEXE), \ LDFLAGS := $(LDFLAGS_JDKEXE), \
LDFLAGS_unix := -L$(JVM_OUTPUTDIR)/gtest $(call SET_SHARED_LIBRARY_ORIGIN), \ LDFLAGS_unix := -L$(JVM_OUTPUTDIR)/gtest $(call SET_SHARED_LIBRARY_ORIGIN), \
LIBS_linux := $(LIBCXX), \
LIBS_unix := -ljvm, \ LIBS_unix := -ljvm, \
LIBS_windows := $(JVM_OUTPUTDIR)/gtest/objs/jvm.lib, \ LIBS_windows := $(JVM_OUTPUTDIR)/gtest/objs/jvm.lib, \
COPY_DEBUG_SYMBOLS := $(GTEST_COPY_DEBUG_SYMBOLS), \ COPY_DEBUG_SYMBOLS := $(GTEST_COPY_DEBUG_SYMBOLS), \

View File

@ -213,9 +213,8 @@ $(eval $(call SetupJdkLibrary, BUILD_SYSLOOKUPLIB, \
LDFLAGS := $(LDFLAGS_JDKLIB), \ LDFLAGS := $(LDFLAGS_JDKLIB), \
LDFLAGS_linux := -Wl$(COMMA)--no-as-needed, \ LDFLAGS_linux := -Wl$(COMMA)--no-as-needed, \
LDFLAGS_aix := -brtl -bexpfull, \ LDFLAGS_aix := -brtl -bexpfull, \
LIBS := $(LIBCXX), \ LIBS_linux := -lm -ldl, \
LIBS_linux := -lc -lm -ldl, \ LIBS_aix := -lm -ldecNumber, \
LIBS_aix := -lc -lm -ldecNumber, \
)) ))
TARGETS += $(BUILD_SYSLOOKUPLIB) TARGETS += $(BUILD_SYSLOOKUPLIB)
@ -247,8 +246,7 @@ ifeq ($(call isTargetOs, linux)+$(call isTargetCpu, x86_64)+$(INCLUDE_COMPILER2)
CXXFLAGS := $(CXXFLAGS_JDKLIB) -std=c++17, \ CXXFLAGS := $(CXXFLAGS_JDKLIB) -std=c++17, \
LDFLAGS := $(LDFLAGS_JDKLIB) \ LDFLAGS := $(LDFLAGS_JDKLIB) \
$(call SET_SHARED_LIBRARY_ORIGIN), \ $(call SET_SHARED_LIBRARY_ORIGIN), \
LIBS := $(LIBCXX), \ LIBS_linux := -lm -ldl, \
LIBS_linux := -lc -lm -ldl, \
)) ))
TARGETS += $(BUILD_LIB_SIMD_SORT) TARGETS += $(BUILD_LIB_SIMD_SORT)

View File

@ -122,7 +122,7 @@ $(eval $(call SetupJdkLibrary, BUILD_LIBJIMAGE, \
CFLAGS_unix := -UDEBUG, \ CFLAGS_unix := -UDEBUG, \
LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK) \ LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK) \
$(call SET_SHARED_LIBRARY_ORIGIN), \ $(call SET_SHARED_LIBRARY_ORIGIN), \
LIBS_unix := -ljvm -ldl $(LIBCXX), \ LIBS_unix := -ljvm -ldl, \
LIBS_windows := jvm.lib, \ LIBS_windows := jvm.lib, \
)) ))

View File

@ -71,7 +71,7 @@ ifeq ($(call isTargetOs, aix), false)
LIBS_linux := $(ALSA_LIBS), \ LIBS_linux := $(ALSA_LIBS), \
LIBS_macosx := -framework CoreAudio -framework CoreFoundation \ LIBS_macosx := -framework CoreAudio -framework CoreFoundation \
-framework CoreServices -framework AudioUnit \ -framework CoreServices -framework AudioUnit \
-framework CoreMIDI -framework AudioToolbox $(LIBCXX), \ -framework CoreMIDI -framework AudioToolbox, \
LIBS_windows := $(WIN_JAVA_LIB) advapi32.lib dsound.lib winmm.lib user32.lib ole32.lib, \ LIBS_windows := $(WIN_JAVA_LIB) advapi32.lib dsound.lib winmm.lib user32.lib ole32.lib, \
)) ))

View File

@ -572,7 +572,7 @@ $(eval $(call SetupJdkLibrary, BUILD_LIBFONTMANAGER, \
LDFLAGS_unix := -L$(INSTALL_LIBRARIES_HERE), \ LDFLAGS_unix := -L$(INSTALL_LIBRARIES_HERE), \
LDFLAGS_aix := -Wl$(COMMA)-berok, \ LDFLAGS_aix := -Wl$(COMMA)-berok, \
LIBS := $(BUILD_LIBFONTMANAGER_FONTLIB), \ LIBS := $(BUILD_LIBFONTMANAGER_FONTLIB), \
LIBS_unix := -lawt -ljava -ljvm $(LIBM) $(LIBCXX), \ LIBS_unix := -lawt -ljava -ljvm $(LIBM), \
LIBS_macosx := -lawt_lwawt -framework CoreText -framework CoreFoundation -framework CoreGraphics, \ LIBS_macosx := -lawt_lwawt -framework CoreText -framework CoreFoundation -framework CoreGraphics, \
LIBS_windows := $(WIN_JAVA_LIB) advapi32.lib user32.lib gdi32.lib \ LIBS_windows := $(WIN_JAVA_LIB) advapi32.lib user32.lib gdi32.lib \
$(WIN_AWT_LIB), \ $(WIN_AWT_LIB), \

View File

@ -66,7 +66,6 @@ $(eval $(call SetupJdkLibrary, BUILD_LIBSA, \
CXXFLAGS := $(CXXFLAGS_JDKLIB) $(SA_CFLAGS) $(SA_CXXFLAGS), \ CXXFLAGS := $(CXXFLAGS_JDKLIB) $(SA_CFLAGS) $(SA_CXXFLAGS), \
EXTRA_SRC := $(LIBSA_EXTRA_SRC), \ EXTRA_SRC := $(LIBSA_EXTRA_SRC), \
LDFLAGS := $(LDFLAGS_JDKLIB) $(call SET_SHARED_LIBRARY_ORIGIN), \ LDFLAGS := $(LDFLAGS_JDKLIB) $(call SET_SHARED_LIBRARY_ORIGIN), \
LIBS := $(LIBCXX), \
LIBS_unix := -ljava, \ LIBS_unix := -ljava, \
LIBS_linux := $(LIBDL), \ LIBS_linux := $(LIBDL), \
LIBS_macosx := -framework Foundation \ LIBS_macosx := -framework Foundation \

View File

@ -35,7 +35,7 @@ ifeq ($(call isTargetOs, linux macosx windows), true)
OPTIMIZATION := LOW, \ OPTIMIZATION := LOW, \
CFLAGS := $(CXXFLAGS_JDKLIB), \ CFLAGS := $(CXXFLAGS_JDKLIB), \
LDFLAGS := $(LDFLAGS_JDKLIB), \ LDFLAGS := $(LDFLAGS_JDKLIB), \
LIBS_unix := $(JDKLIB_LIBS) $(LIBCXX), \ LIBS_unix := $(JDKLIB_LIBS), \
LIBS_windows := $(JDKLIB_LIBS) user32.lib, \ LIBS_windows := $(JDKLIB_LIBS) user32.lib, \
)) ))

View File

@ -75,8 +75,8 @@ $(eval $(call SetupJdkExecutable, BUILD_JPACKAGE_APPLAUNCHEREXE, \
CXXFLAGS_windows := $(JPACKAGE_CXXFLAGS_windows), \ CXXFLAGS_windows := $(JPACKAGE_CXXFLAGS_windows), \
CFLAGS_windows := $(JPACKAGE_CFLAGS_windows), \ CFLAGS_windows := $(JPACKAGE_CFLAGS_windows), \
LDFLAGS := $(LDFLAGS_JDKEXE), \ LDFLAGS := $(LDFLAGS_JDKEXE), \
LIBS_macosx := $(LIBCXX) -framework Cocoa -rpath @executable_path/../Frameworks/ -rpath @executable_path/../PlugIns/, \ LIBS_macosx := -framework Cocoa -rpath @executable_path/../Frameworks/ -rpath @executable_path/../PlugIns/, \
LIBS_windows := $(LIBCXX) user32.lib ole32.lib msi.lib shlwapi.lib \ LIBS_windows := user32.lib ole32.lib msi.lib shlwapi.lib \
Shell32.lib, \ Shell32.lib, \
LIBS_linux := -ldl, \ LIBS_linux := -ldl, \
MANIFEST := $(JAVA_MANIFEST), \ MANIFEST := $(JAVA_MANIFEST), \
@ -110,7 +110,7 @@ ifeq ($(call isTargetOs, linux), true)
CXXFLAGS := $(CXXFLAGS_JDKLIB) $(JPACKAGE_LIBAPPLAUNCHER_INCLUDES), \ CXXFLAGS := $(CXXFLAGS_JDKLIB) $(JPACKAGE_LIBAPPLAUNCHER_INCLUDES), \
CFLAGS := $(CFLAGS_JDKLIB) $(JPACKAGE_LIBAPPLAUNCHER_INCLUDES), \ CFLAGS := $(CFLAGS_JDKLIB) $(JPACKAGE_LIBAPPLAUNCHER_INCLUDES), \
LDFLAGS := $(LDFLAGS_JDKLIB), \ LDFLAGS := $(LDFLAGS_JDKLIB), \
LIBS := $(LIBCXX) -ldl, \ LIBS := -ldl, \
)) ))
JPACKAGE_TARGETS += $(BUILD_JPACKAGE_LIBAPPLAUNCHER) JPACKAGE_TARGETS += $(BUILD_JPACKAGE_LIBAPPLAUNCHER)
@ -129,7 +129,7 @@ ifeq ($(call isTargetOs, windows), true)
CXXFLAGS := $(CXXFLAGS_JDKLIB) $(JPACKAGE_CXXFLAGS_windows), \ CXXFLAGS := $(CXXFLAGS_JDKLIB) $(JPACKAGE_CXXFLAGS_windows), \
LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK) \ LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK) \
$(call SET_SHARED_LIBRARY_ORIGIN), \ $(call SET_SHARED_LIBRARY_ORIGIN), \
LIBS := $(LIBCXX) advapi32.lib ole32.lib msi.lib user32.lib \ LIBS := advapi32.lib ole32.lib msi.lib user32.lib \
shlwapi.lib Shell32.lib, \ shlwapi.lib Shell32.lib, \
)) ))
@ -150,7 +150,7 @@ ifeq ($(call isTargetOs, windows), true)
CXXFLAGS := $(call JpackageWithStaticCrt, $(CXXFLAGS_JDKLIB)) \ CXXFLAGS := $(call JpackageWithStaticCrt, $(CXXFLAGS_JDKLIB)) \
$(addprefix -I, $(JPACKAGE_WIXHELPER_SRC)) $(JPACKAGE_CXXFLAGS_windows), \ $(addprefix -I, $(JPACKAGE_WIXHELPER_SRC)) $(JPACKAGE_CXXFLAGS_windows), \
LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK), \ LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK), \
LIBS := $(LIBCXX) ole32.lib msi.lib User32.lib shlwapi.lib \ LIBS := ole32.lib msi.lib User32.lib shlwapi.lib \
Shell32.lib, \ Shell32.lib, \
)) ))
@ -169,7 +169,7 @@ ifeq ($(call isTargetOs, windows), true)
CXXFLAGS := $(call JpackageWithStaticCrt, $(CXXFLAGS_JDKEXE)) \ CXXFLAGS := $(call JpackageWithStaticCrt, $(CXXFLAGS_JDKEXE)) \
$(addprefix -I, $(JPACKAGE_MSIWRAPPER_SRC)) $(JPACKAGE_CXXFLAGS_windows), \ $(addprefix -I, $(JPACKAGE_MSIWRAPPER_SRC)) $(JPACKAGE_CXXFLAGS_windows), \
LDFLAGS := $(LDFLAGS_JDKEXE), \ LDFLAGS := $(LDFLAGS_JDKEXE), \
LIBS := $(LIBCXX) ole32.lib msi.lib user32.lib shlwapi.lib Shell32.lib, \ LIBS := ole32.lib msi.lib user32.lib shlwapi.lib Shell32.lib, \
)) ))
JPACKAGE_TARGETS += $(BUILD_JPACKAGE_MSIWRAPPER) JPACKAGE_TARGETS += $(BUILD_JPACKAGE_MSIWRAPPER)