author | ihse |
Mon, 04 Nov 2019 11:15:45 +0100 | |
changeset 58909 | 66f7d2494d4e |
parent 55675 | a33465cf8774 |
permissions | -rw-r--r-- |
25859 | 1 |
# |
54091
efb8569c95d5
8220504: Move definition of JAVA_VERSION_INFO_RESOURCE to Launcher-java.base.gmk
clanger
parents:
53683
diff
changeset
|
2 |
# Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. |
25859 | 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 |
||
49244
995a5556edfa
8199639: Introduce SetupJdkLibrary and SetupJdkExecutable
ihse
parents:
49241
diff
changeset
|
26 |
include JdkNativeCompilation.gmk |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
27 |
include Modules.gmk |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
28 |
include ProcessMarkdown.gmk |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
29 |
include ToolsJdk.gmk |
25859 | 30 |
|
49534 | 31 |
# Tell the compiler not to export any functions unless declared so in |
32 |
# the source code. On Windows, this is the default and cannot be changed. |
|
33 |
# On Mac, we have always exported all symbols, probably due to oversight |
|
34 |
# and/or misunderstanding. To emulate this, don't hide any symbols |
|
35 |
# by default. |
|
52812
fc54d27e58d8
8214063: OpenJDK will not build on AIX while using the xlc 13.1 compiler
afarley
parents:
52714
diff
changeset
|
36 |
# On AIX/xlc we need at least xlc 13.1 for the symbol hiding (see JDK-8214063) |
49534 | 37 |
# Also provide an override for non-conformant libraries. |
38 |
ifeq ($(TOOLCHAIN_TYPE), gcc) |
|
39 |
LAUNCHER_CFLAGS += -fvisibility=hidden |
|
40 |
LDFLAGS_JDKEXE += -Wl,--exclude-libs,ALL |
|
41 |
else ifeq ($(TOOLCHAIN_TYPE), clang) |
|
51855 | 42 |
LAUNCHER_CFLAGS += -fvisibility=hidden |
49534 | 43 |
else ifeq ($(TOOLCHAIN_TYPE), solstudio) |
44 |
LAUNCHER_CFLAGS += -xldscope=hidden |
|
45 |
endif |
|
46 |
||
47217 | 47 |
LAUNCHER_SRC := $(TOPDIR)/src/java.base/share/native/launcher |
49534 | 48 |
LAUNCHER_CFLAGS += -I$(TOPDIR)/src/java.base/share/native/launcher \ |
47217 | 49 |
-I$(TOPDIR)/src/java.base/share/native/libjli \ |
50 |
-I$(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS_TYPE)/native/libjli \ |
|
51 |
-I$(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS)/native/libjli \ |
|
25859 | 52 |
# |
47217 | 53 |
GLOBAL_VERSION_INFO_RESOURCE := $(TOPDIR)/src/java.base/windows/native/common/version.rc |
54 |
MACOSX_PLIST_DIR := $(TOPDIR)/src/java.base/macosx/native/launcher |
|
55 |
JAVA_MANIFEST := $(TOPDIR)/src/java.base/windows/native/launcher/java.manifest |
|
25859 | 56 |
|
33523 | 57 |
################################################################################ |
58 |
# Build standard launcher. |
|
25859 | 59 |
|
33523 | 60 |
# Setup make rules for building a standard launcher. |
61 |
# |
|
62 |
# Parameter 1 is the name of the rule. This name is used as variable prefix, |
|
63 |
# and the targets generated are listed in a variable by that name. It is also |
|
64 |
# used as the name of the executable. |
|
65 |
# |
|
66 |
# Remaining parameters are named arguments. These include: |
|
36511 | 67 |
# MAIN_MODULE The module of the main class to launch if different from the |
68 |
# current module |
|
33523 | 69 |
# MAIN_CLASS The Java main class to launch |
45463
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
70 |
# JAVA_ARGS Processed into a -DJAVA_ARGS and added to CFLAGS |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
71 |
# EXTRA_JAVA_ARGS Processed into a -DEXTRA_JAVA_ARGS and is prepended |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
72 |
# before JAVA_ARGS to CFLAGS, primarily to allow long string literal |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
73 |
# compile time defines exceeding Visual Studio 2013 limitations. |
33523 | 74 |
# CFLAGS Additional CFLAGS |
75 |
# CFLAGS_windows Additional CFLAGS_windows |
|
54548 | 76 |
# EXTRA_RC_FLAGS Additional EXTRA_RC_FLAGS |
33523 | 77 |
# MACOSX_SIGNED On macosx, sign this binary |
78 |
# OPTIMIZATION Override default optimization level (LOW) |
|
79 |
# OUTPUT_DIR Override default output directory |
|
80 |
# VERSION_INFO_RESOURCE Override default Windows resource file |
|
81 |
SetupBuildLauncher = $(NamedParamsMacroTemplate) |
|
82 |
define SetupBuildLauncherBody |
|
83 |
# Setup default values (unless overridden) |
|
84 |
ifeq ($$($1_OPTIMIZATION), ) |
|
85 |
$1_OPTIMIZATION := LOW |
|
86 |
endif |
|
87 |
||
36511 | 88 |
ifeq ($$($1_MAIN_MODULE), ) |
89 |
$1_MAIN_MODULE := $(MODULE) |
|
90 |
endif |
|
91 |
||
51808 | 92 |
$1_JAVA_ARGS += -ms8m |
93 |
ifneq ($$($1_MAIN_CLASS), ) |
|
94 |
$1_LAUNCHER_CLASS := -m $$($1_MAIN_MODULE)/$$($1_MAIN_CLASS) |
|
33523 | 95 |
endif |
96 |
||
51808 | 97 |
ifneq ($$($1_EXTRA_JAVA_ARGS), ) |
98 |
$1_EXTRA_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \ |
|
99 |
$$(addprefix -J, $$($1_EXTRA_JAVA_ARGS)), "$$a"$(COMMA) )) }' |
|
100 |
$1_CFLAGS += -DEXTRA_JAVA_ARGS=$$($1_EXTRA_JAVA_ARGS_STR) |
|
101 |
endif |
|
102 |
$1_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \ |
|
103 |
$$(addprefix -J, $$($1_JAVA_ARGS)) $$($1_LAUNCHER_CLASS), "$$a"$(COMMA) )) }' |
|
104 |
$1_CFLAGS += -DJAVA_ARGS=$$($1_JAVA_ARGS_STR) |
|
105 |
||
53683 | 106 |
ifeq ($(call isTargetOs, macosx), true) |
33523 | 107 |
ifeq ($$($1_MACOSX_SIGNED), true) |
108 |
$1_PLIST_FILE := Info-privileged.plist |
|
25859 | 109 |
$1_CODESIGN := true |
33523 | 110 |
else |
111 |
$1_PLIST_FILE := Info-cmdline.plist |
|
25859 | 112 |
endif |
113 |
||
51825
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
114 |
$1_LDFLAGS += -sectcreate __TEXT __info_plist $(MACOSX_PLIST_DIR)/$$($1_PLIST_FILE) |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
115 |
|
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
116 |
ifeq ($(STATIC_BUILD), true) |
33666 | 117 |
$1_LDFLAGS += -exported_symbols_list \ |
118 |
$(SUPPORT_OUTPUTDIR)/build-static/exported.symbols |
|
119 |
$1_LIBS += \ |
|
35241 | 120 |
$$(shell $(FIND) $(SUPPORT_OUTPUTDIR)/modules_libs/java.base -name "*.a") \ |
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
121 |
$(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libdt_socket.a \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
122 |
$(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libjdwp.a \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
123 |
$(SUPPORT_OUTPUTDIR)/native/java.base/$(LIBRARY_PREFIX)fdlibm$(STATIC_LIBRARY_SUFFIX) \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
124 |
-framework CoreFoundation \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
125 |
-framework Foundation \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
126 |
-framework SystemConfiguration \ |
33666 | 127 |
-lstdc++ -liconv |
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
128 |
endif |
25859 | 129 |
endif |
130 |
||
131 |
ifeq ($(USE_EXTERNAL_LIBZ), true) |
|
33406 | 132 |
$1_LIBS += -lz |
25859 | 133 |
endif |
134 |
||
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51855
diff
changeset
|
135 |
$1_WINDOWS_JLI_LIB := $(call FindStaticLib, java.base, jli, /libjli) |
25859 | 136 |
|
49244
995a5556edfa
8199639: Introduce SetupJdkLibrary and SetupJdkExecutable
ihse
parents:
49241
diff
changeset
|
137 |
$$(eval $$(call SetupJdkExecutable, BUILD_LAUNCHER_$1, \ |
49070
d7859531621b
8198751: Refactor SetupNativeCompilation to take NAME and TYPE
ihse
parents:
47217
diff
changeset
|
138 |
NAME := $1, \ |
35241 | 139 |
EXTRA_FILES := $(LAUNCHER_SRC)/main.c, \ |
33523 | 140 |
OPTIMIZATION := $$($1_OPTIMIZATION), \ |
54548 | 141 |
CFLAGS := $$(CFLAGS_JDKEXE) \ |
25859 | 142 |
$(LAUNCHER_CFLAGS) \ |
33984
2333676816eb
8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents:
29931
diff
changeset
|
143 |
$(VERSION_CFLAGS) \ |
25859 | 144 |
-DLAUNCHER_NAME='"$(LAUNCHER_NAME)"' \ |
33523 | 145 |
-DPROGNAME='"$1"' \ |
146 |
$$($1_CFLAGS), \ |
|
25859 | 147 |
CFLAGS_linux := -fPIC, \ |
148 |
CFLAGS_solaris := -KPIC -DHAVE_GETHRTIME, \ |
|
33523 | 149 |
CFLAGS_windows := $$($1_CFLAGS_windows), \ |
51853
ec62d6cab037
8211029: Have a common set of enabled warnings for all native libraries
ihse
parents:
51825
diff
changeset
|
150 |
DISABLED_WARNINGS_gcc := unused-function, \ |
34695
7a6cc9982d22
8142907: Integration of minor fixes from the build-infra project
ihse
parents:
34389
diff
changeset
|
151 |
LDFLAGS := $$(LDFLAGS_JDKEXE) \ |
51825
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
152 |
$$(call SET_EXECUTABLE_ORIGIN) \ |
25859 | 153 |
$$($1_LDFLAGS), \ |
51825
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
154 |
LDFLAGS_linux := $$(call SET_EXECUTABLE_ORIGIN,/../lib) \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
155 |
-L$(call FindLibDirForModule, java.base), \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
156 |
LDFLAGS_macosx := $$(call SET_EXECUTABLE_ORIGIN,/../lib) \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
157 |
-L$(call FindLibDirForModule, java.base), \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
158 |
LDFLAGS_solaris := $$(call SET_EXECUTABLE_ORIGIN,/../lib) \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
159 |
-L$(call FindLibDirForModule, java.base), \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
160 |
LDFLAGS_aix := -L$(SUPPORT_OUTPUTDIR)/native/java.base, \ |
33406 | 161 |
LIBS := $(JDKEXE_LIBS) $$($1_LIBS), \ |
51825
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
162 |
LIBS_linux := -ljli -lpthread $(LIBDL), \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
163 |
LIBS_macosx := -ljli -framework Cocoa -framework Security \ |
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
164 |
-framework ApplicationServices, \ |
49241 | 165 |
LIBS_solaris := -ljli -lthread $(LIBDL), \ |
51825
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
166 |
LIBS_aix := -ljli_static, \ |
33406 | 167 |
LIBS_windows := $$($1_WINDOWS_JLI_LIB) \ |
51825
e3632b4706c4
8210931: JLI and launchers normalization and cleanup
ihse
parents:
51811
diff
changeset
|
168 |
$(SUPPORT_OUTPUTDIR)/native/java.base/libjava/java.lib, \ |
33523 | 169 |
OUTPUT_DIR := $$($1_OUTPUT_DIR), \ |
25859 | 170 |
VERSIONINFO_RESOURCE := $$($1_VERSION_INFO_RESOURCE), \ |
49244
995a5556edfa
8199639: Introduce SetupJdkLibrary and SetupJdkExecutable
ihse
parents:
49241
diff
changeset
|
171 |
EXTRA_RC_FLAGS := $$($1_EXTRA_RC_FLAGS), \ |
25859 | 172 |
MANIFEST := $(JAVA_MANIFEST), \ |
33984
2333676816eb
8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents:
29931
diff
changeset
|
173 |
MANIFEST_VERSION := $(VERSION_NUMBER_FOUR_POSITIONS), \ |
29925
6d47adfc6b47
8077847: Better handling of Windows executable manifest version
ihse
parents:
27953
diff
changeset
|
174 |
CODESIGN := $$($1_CODESIGN), \ |
33523 | 175 |
)) |
25859 | 176 |
|
33523 | 177 |
$1 += $$(BUILD_LAUNCHER_$1) |
178 |
TARGETS += $$($1) |
|
25859 | 179 |
|
53683 | 180 |
ifeq ($(call isTargetOs, aix), true) |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51855
diff
changeset
|
181 |
$$(BUILD_LAUNCHER_$1): $(call FindStaticLib, java.base, jli_static) |
25859 | 182 |
endif |
183 |
||
53683 | 184 |
ifeq ($(call isTargetOs, windows), true) |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51855
diff
changeset
|
185 |
$$(BUILD_LAUNCHER_$1): $(call FindStaticLib, java.base, java, /libjava) \ |
25859 | 186 |
$$($1_WINDOWS_JLI_LIB) |
187 |
endif |
|
188 |
endef |
|
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
189 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
190 |
################################################################################ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
191 |
# Create man pages for jmod to pick up. There should be a one-to-one |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
192 |
# relationship between executables and man pages (even if this is not always |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
193 |
# the case), so piggyback man page generation on the launcher compilation. |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
194 |
|
53683 | 195 |
ifeq ($(call isTargetOsType, unix), true) |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
196 |
# Only build manpages on unix systems. |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
197 |
# We assume all our man pages should reside in section 1. |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
198 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
199 |
MAN_FILES_MD := $(wildcard $(addsuffix /*.md, $(call FindModuleManDirs, $(MODULE)))) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
200 |
MAN_FILES_TROFF := $(wildcard $(addsuffix /*.1, $(call FindModuleManDirs, $(MODULE)))) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
201 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
202 |
ifneq ($(MAN_FILES_MD), ) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
203 |
# If we got markdown files, ignore the troff files |
53087
f48737b2f428
8215635: Pandoc check in Docs.gmk does not work on Windows
erikj
parents:
52940
diff
changeset
|
204 |
ifeq ($(ENABLE_PANDOC), false) |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
205 |
$(info Warning: pandoc not found. Not generating man pages) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
206 |
else |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
207 |
# Create dynamic man pages from markdown using pandoc. We need |
52940
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
208 |
# PANDOC_TROFF_MANPAGE_FILTER, a wrapper around |
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
209 |
# PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT. This is created by buildtools-jdk. |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
210 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
211 |
# We should also depend on the source javascript filter |
52940
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
212 |
PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT := \ |
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
213 |
$(TOPDIR)/make/scripts/pandoc-troff-manpage-filter.js |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
214 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
215 |
# The norm in man pages is to display code literals as bold, but pandoc |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
216 |
# "correctly" converts these constructs (encoded in markdown using `...` |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
217 |
# or ```...```) to \f[C]. Ideally, we should use the filter to encapsulate |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
218 |
# the Code/CodeBlock in Strong. While this works for Code, pandoc cannot |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
219 |
# correctly render man page output for CodeBlock wrapped in Strong. So we |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
220 |
# take the easy way out, and post-process the troff output, replacing |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
221 |
# \f[C] with \f[CB]. This has the added benefit of working correctly on |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
222 |
# pandoc prior to version 2.0, which cannot properly produced nested |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
223 |
# formatting in man pages (see https://github.com/jgm/pandoc/issues/3568). |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
224 |
# |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
225 |
# As of pandoc 2.3, the termination of formatting is still broken |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
226 |
# (see https://github.com/jgm/pandoc/issues/4973). We need to replace |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
227 |
# \f[] with \f[R]. |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
228 |
MAN_POST_PROCESS := $(SED) -e 's/\\f\[C\]/\\f\[CB\]/g' \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
229 |
-e 's/\\f\[\]/\\f\[R\]/g' |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
230 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
231 |
# Now generate the man pages from markdown using pandoc |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
232 |
$(eval $(call SetupProcessMarkdown, BUILD_MAN_PAGES, \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
233 |
DEST := $(SUPPORT_OUTPUTDIR)/modules_man/$(MODULE)/man1, \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
234 |
FILES := $(MAN_FILES_MD), \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
235 |
FORMAT := man, \ |
52940
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
236 |
FILTER := $(PANDOC_TROFF_MANPAGE_FILTER), \ |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
237 |
POST_PROCESS := $(MAN_POST_PROCESS), \ |
55675
a33465cf8774
8227644: make more build-time variables available to Markdown files
jjg
parents:
54548
diff
changeset
|
238 |
REPLACEMENTS := \ |
a33465cf8774
8227644: make more build-time variables available to Markdown files
jjg
parents:
54548
diff
changeset
|
239 |
@@COPYRIGHT_YEAR@@ => $(COPYRIGHT_YEAR) ; \ |
a33465cf8774
8227644: make more build-time variables available to Markdown files
jjg
parents:
54548
diff
changeset
|
240 |
@@VERSION_SHORT@@ => $(VERSION_SHORT) ; \ |
a33465cf8774
8227644: make more build-time variables available to Markdown files
jjg
parents:
54548
diff
changeset
|
241 |
@@VERSION_SPECIFICATION@@ => $(VERSION_SPECIFICATION), \ |
52940
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
242 |
EXTRA_DEPS := $(PANDOC_TROFF_MANPAGE_FILTER) \ |
26e2cfebcfba
8214720: Add pandoc filter to improve html man page output
ihse
parents:
52812
diff
changeset
|
243 |
$(PANDOC_TROFF_MANPAGE_FILTER_JAVASCRIPT), \ |
52714
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
244 |
)) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
245 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
246 |
TARGETS += $(BUILD_MAN_PAGES) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
247 |
endif |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
248 |
else |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
249 |
# No markdown man pages present |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
250 |
ifeq ($(BUILD_MANPAGES), true) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
251 |
# BUILD_MANPAGES is a mis-nomer. It really means "copy the pre-generated man pages". |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
252 |
$(eval $(call SetupCopyFiles, COPY_MAN_PAGES, \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
253 |
DEST := $(SUPPORT_OUTPUTDIR)/modules_man/$(MODULE)/man1, \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
254 |
FILES := $(MAN_FILES_TROFF), \ |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
255 |
)) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
256 |
|
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
257 |
TARGETS += $(COPY_MAN_PAGES) |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
258 |
endif |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
259 |
endif |
2e52aa822c57
8178317: Create man pages using pandoc from markdown sources
ihse
parents:
52022
diff
changeset
|
260 |
endif |