< prev index next >

make/launcher/LauncherCommon.gmk

Print this page




  88   endif
  89 
  90   ifeq ($$($1_MAIN_MODULE), )
  91     $1_MAIN_MODULE := $(MODULE)
  92   endif
  93 
  94   $1_JAVA_ARGS += -ms8m
  95   ifneq ($$($1_MAIN_CLASS), )
  96     $1_LAUNCHER_CLASS := -m $$($1_MAIN_MODULE)/$$($1_MAIN_CLASS)
  97   endif
  98 
  99   ifneq ($$($1_EXTRA_JAVA_ARGS), )
 100     $1_EXTRA_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \
 101       $$(addprefix -J, $$($1_EXTRA_JAVA_ARGS)), "$$a"$(COMMA) )) }'
 102     $1_CFLAGS += -DEXTRA_JAVA_ARGS=$$($1_EXTRA_JAVA_ARGS_STR)
 103   endif
 104   $1_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \
 105       $$(addprefix -J, $$($1_JAVA_ARGS)) $$($1_LAUNCHER_CLASS), "$$a"$(COMMA) )) }'
 106   $1_CFLAGS += -DJAVA_ARGS=$$($1_JAVA_ARGS_STR)
 107 
 108   ifeq ($(OPENJDK_TARGET_OS), macosx)
 109     ifeq ($$($1_MACOSX_SIGNED), true)
 110       $1_PLIST_FILE := Info-privileged.plist
 111         $1_CODESIGN := true
 112     else
 113       $1_PLIST_FILE := Info-cmdline.plist
 114     endif
 115 
 116     $1_LDFLAGS += -sectcreate __TEXT __info_plist $(MACOSX_PLIST_DIR)/$$($1_PLIST_FILE)
 117 
 118     ifeq ($(STATIC_BUILD), true)
 119       $1_LDFLAGS += -exported_symbols_list \
 120               $(SUPPORT_OUTPUTDIR)/build-static/exported.symbols
 121       $1_LIBS += \
 122           $$(shell $(FIND) $(SUPPORT_OUTPUTDIR)/modules_libs/java.base -name "*.a") \
 123           $(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libdt_socket.a \
 124           $(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libjdwp.a \
 125           $(SUPPORT_OUTPUTDIR)/native/java.base/$(LIBRARY_PREFIX)fdlibm$(STATIC_LIBRARY_SUFFIX) \
 126           -framework CoreFoundation \
 127           -framework Foundation \
 128           -framework SystemConfiguration \


 162       LDFLAGS_aix := -L$(SUPPORT_OUTPUTDIR)/native/java.base, \
 163       LIBS := $(JDKEXE_LIBS) $$($1_LIBS), \
 164       LIBS_linux := -ljli -lpthread $(LIBDL), \
 165       LIBS_macosx := -ljli -framework Cocoa -framework Security \
 166           -framework ApplicationServices, \
 167       LIBS_solaris := -ljli -lthread $(LIBDL), \
 168       LIBS_aix := -ljli_static, \
 169       LIBS_windows := $$($1_WINDOWS_JLI_LIB) \
 170           $(SUPPORT_OUTPUTDIR)/native/java.base/libjava/java.lib, \
 171       OUTPUT_DIR := $$($1_OUTPUT_DIR), \
 172       VERSIONINFO_RESOURCE := $$($1_VERSION_INFO_RESOURCE), \
 173       EXTRA_RC_FLAGS := $$($1_EXTRA_RC_FLAGS), \
 174       MANIFEST := $(JAVA_MANIFEST), \
 175       MANIFEST_VERSION := $(VERSION_NUMBER_FOUR_POSITIONS), \
 176       CODESIGN := $$($1_CODESIGN), \
 177   ))
 178 
 179   $1 += $$(BUILD_LAUNCHER_$1)
 180   TARGETS += $$($1)
 181 
 182   ifeq ($(OPENJDK_TARGET_OS), aix)
 183     $$(BUILD_LAUNCHER_$1): $(call FindStaticLib, java.base, jli_static)
 184   endif
 185 
 186   ifeq ($(OPENJDK_TARGET_OS), windows)
 187     $$(BUILD_LAUNCHER_$1): $(call FindStaticLib, java.base, java, /libjava) \
 188         $$($1_WINDOWS_JLI_LIB)
 189   endif
 190 endef
 191 
 192 ################################################################################
 193 # Create man pages for jmod to pick up. There should be a one-to-one
 194 # relationship between executables and man pages (even if this is not always
 195 # the case), so piggyback man page generation on the launcher compilation.
 196 
 197 ifeq ($(OPENJDK_TARGET_OS_TYPE), unix)
 198   # Only build manpages on unix systems.
 199   # We assume all our man pages should reside in section 1.
 200 
 201   MAN_FILES_MD := $(wildcard $(addsuffix /*.md, $(call FindModuleManDirs, $(MODULE))))
 202   MAN_FILES_TROFF := $(wildcard $(addsuffix /*.1, $(call FindModuleManDirs, $(MODULE))))
 203 
 204   ifneq ($(MAN_FILES_MD), )
 205     # If we got markdown files, ignore the troff files
 206     ifeq ($(ENABLE_PANDOC), false)
 207       $(info Warning: pandoc not found. Not generating man pages)
 208     else
 209       # Create dynamic man pages from markdown using pandoc. We need
 210       # PANDOC_TROFF_MANPAGE_FILTER, a wrapper around
 211       # PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT. This is created by buildtools-jdk.
 212 
 213       # We should also depend on the source javascript filter
 214       PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT := \
 215           $(TOPDIR)/make/scripts/pandoc-troff-manpage-filter.js
 216 
 217       # The norm in man pages is to display code literals as bold, but pandoc




  88   endif
  89 
  90   ifeq ($$($1_MAIN_MODULE), )
  91     $1_MAIN_MODULE := $(MODULE)
  92   endif
  93 
  94   $1_JAVA_ARGS += -ms8m
  95   ifneq ($$($1_MAIN_CLASS), )
  96     $1_LAUNCHER_CLASS := -m $$($1_MAIN_MODULE)/$$($1_MAIN_CLASS)
  97   endif
  98 
  99   ifneq ($$($1_EXTRA_JAVA_ARGS), )
 100     $1_EXTRA_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \
 101       $$(addprefix -J, $$($1_EXTRA_JAVA_ARGS)), "$$a"$(COMMA) )) }'
 102     $1_CFLAGS += -DEXTRA_JAVA_ARGS=$$($1_EXTRA_JAVA_ARGS_STR)
 103   endif
 104   $1_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \
 105       $$(addprefix -J, $$($1_JAVA_ARGS)) $$($1_LAUNCHER_CLASS), "$$a"$(COMMA) )) }'
 106   $1_CFLAGS += -DJAVA_ARGS=$$($1_JAVA_ARGS_STR)
 107 
 108   ifeq ($(call isTargetOs, macosx), true)
 109     ifeq ($$($1_MACOSX_SIGNED), true)
 110       $1_PLIST_FILE := Info-privileged.plist
 111         $1_CODESIGN := true
 112     else
 113       $1_PLIST_FILE := Info-cmdline.plist
 114     endif
 115 
 116     $1_LDFLAGS += -sectcreate __TEXT __info_plist $(MACOSX_PLIST_DIR)/$$($1_PLIST_FILE)
 117 
 118     ifeq ($(STATIC_BUILD), true)
 119       $1_LDFLAGS += -exported_symbols_list \
 120               $(SUPPORT_OUTPUTDIR)/build-static/exported.symbols
 121       $1_LIBS += \
 122           $$(shell $(FIND) $(SUPPORT_OUTPUTDIR)/modules_libs/java.base -name "*.a") \
 123           $(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libdt_socket.a \
 124           $(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libjdwp.a \
 125           $(SUPPORT_OUTPUTDIR)/native/java.base/$(LIBRARY_PREFIX)fdlibm$(STATIC_LIBRARY_SUFFIX) \
 126           -framework CoreFoundation \
 127           -framework Foundation \
 128           -framework SystemConfiguration \


 162       LDFLAGS_aix := -L$(SUPPORT_OUTPUTDIR)/native/java.base, \
 163       LIBS := $(JDKEXE_LIBS) $$($1_LIBS), \
 164       LIBS_linux := -ljli -lpthread $(LIBDL), \
 165       LIBS_macosx := -ljli -framework Cocoa -framework Security \
 166           -framework ApplicationServices, \
 167       LIBS_solaris := -ljli -lthread $(LIBDL), \
 168       LIBS_aix := -ljli_static, \
 169       LIBS_windows := $$($1_WINDOWS_JLI_LIB) \
 170           $(SUPPORT_OUTPUTDIR)/native/java.base/libjava/java.lib, \
 171       OUTPUT_DIR := $$($1_OUTPUT_DIR), \
 172       VERSIONINFO_RESOURCE := $$($1_VERSION_INFO_RESOURCE), \
 173       EXTRA_RC_FLAGS := $$($1_EXTRA_RC_FLAGS), \
 174       MANIFEST := $(JAVA_MANIFEST), \
 175       MANIFEST_VERSION := $(VERSION_NUMBER_FOUR_POSITIONS), \
 176       CODESIGN := $$($1_CODESIGN), \
 177   ))
 178 
 179   $1 += $$(BUILD_LAUNCHER_$1)
 180   TARGETS += $$($1)
 181 
 182   ifeq ($(call isTargetOs, aix), true)
 183     $$(BUILD_LAUNCHER_$1): $(call FindStaticLib, java.base, jli_static)
 184   endif
 185 
 186   ifeq ($(call isTargetOs, windows), true)
 187     $$(BUILD_LAUNCHER_$1): $(call FindStaticLib, java.base, java, /libjava) \
 188         $$($1_WINDOWS_JLI_LIB)
 189   endif
 190 endef
 191 
 192 ################################################################################
 193 # Create man pages for jmod to pick up. There should be a one-to-one
 194 # relationship between executables and man pages (even if this is not always
 195 # the case), so piggyback man page generation on the launcher compilation.
 196 
 197 ifeq ($(call isTargetOsType, unix), true)
 198   # Only build manpages on unix systems.
 199   # We assume all our man pages should reside in section 1.
 200 
 201   MAN_FILES_MD := $(wildcard $(addsuffix /*.md, $(call FindModuleManDirs, $(MODULE))))
 202   MAN_FILES_TROFF := $(wildcard $(addsuffix /*.1, $(call FindModuleManDirs, $(MODULE))))
 203 
 204   ifneq ($(MAN_FILES_MD), )
 205     # If we got markdown files, ignore the troff files
 206     ifeq ($(ENABLE_PANDOC), false)
 207       $(info Warning: pandoc not found. Not generating man pages)
 208     else
 209       # Create dynamic man pages from markdown using pandoc. We need
 210       # PANDOC_TROFF_MANPAGE_FILTER, a wrapper around
 211       # PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT. This is created by buildtools-jdk.
 212 
 213       # We should also depend on the source javascript filter
 214       PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT := \
 215           $(TOPDIR)/make/scripts/pandoc-troff-manpage-filter.js
 216 
 217       # The norm in man pages is to display code literals as bold, but pandoc


< prev index next >