1 | <?xml version='1.0'?>
|
---|
2 | <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
---|
3 | xmlns:exsl="http://exslt.org/common"
|
---|
4 | exclude-result-prefixes="exsl"
|
---|
5 | version='1.0'>
|
---|
6 |
|
---|
7 | <!-- ********************************************************************
|
---|
8 | $Id: other.xsl,v 1.11 2005/07/09 07:41:58 xmldoc Exp $
|
---|
9 | ********************************************************************
|
---|
10 |
|
---|
11 | This file is part of the XSL DocBook Stylesheet distribution.
|
---|
12 | See ../README or http://docbook.sf.net/release/xsl/current/ for
|
---|
13 | copyright and other information.
|
---|
14 |
|
---|
15 | ******************************************************************** -->
|
---|
16 |
|
---|
17 | <!-- * This file contains named templates that are related to things -->
|
---|
18 | <!-- * other than just assembling the actual text of the main text flow -->
|
---|
19 | <!-- * of each man page. This "other" stuff currently amounts to: -->
|
---|
20 | <!-- * -->
|
---|
21 | <!-- * - adding a comment to top part of roff source of each page -->
|
---|
22 | <!-- * - making a .TH title line (for controlling page header/footer) -->
|
---|
23 | <!-- * - setting hyphenation, alignment, & line-breaking defaults -->
|
---|
24 | <!-- * - "preparing" the complete man page contents for final output -->
|
---|
25 | <!-- * - writing the actual man file to the filesystem -->
|
---|
26 | <!-- * - writing any "stub" pages to the filesystem -->
|
---|
27 | <!-- * -->
|
---|
28 | <!-- * The templates in this file are actually called only once per -->
|
---|
29 | <!-- * each Refentry; they are just in a separate file for the purpose -->
|
---|
30 | <!-- * of keeping things modular. -->
|
---|
31 |
|
---|
32 | <!-- ==================================================================== -->
|
---|
33 | <!-- * Get character map contents -->
|
---|
34 | <!-- ==================================================================== -->
|
---|
35 |
|
---|
36 | <xsl:variable name="man.charmap.contents">
|
---|
37 | <xsl:if test="$man.charmap.enabled != 0">
|
---|
38 | <xsl:call-template name="read-character-map">
|
---|
39 | <xsl:with-param name="use.subset" select="$man.charmap.use.subset"/>
|
---|
40 | <xsl:with-param name="subset.profile" select="$man.charmap.subset.profile"/>
|
---|
41 | <xsl:with-param name="uri">
|
---|
42 | <xsl:choose>
|
---|
43 | <xsl:when test="$man.charmap.uri != ''">
|
---|
44 | <xsl:value-of select="$man.charmap.uri"/>
|
---|
45 | </xsl:when>
|
---|
46 | <xsl:otherwise>
|
---|
47 | <xsl:value-of select="'../manpages/charmap.groff.xsl'"/>
|
---|
48 | </xsl:otherwise>
|
---|
49 | </xsl:choose>
|
---|
50 | </xsl:with-param>
|
---|
51 | </xsl:call-template>
|
---|
52 | </xsl:if>
|
---|
53 | </xsl:variable>
|
---|
54 |
|
---|
55 | <!-- ==================================================================== -->
|
---|
56 |
|
---|
57 | <xsl:template name="top.comment">
|
---|
58 | <xsl:text>.\" ** You probably do not want to</xsl:text>
|
---|
59 | <xsl:text> edit this file directly ** </xsl:text>
|
---|
60 | <xsl:text>.\" It was generated using the DocBook</xsl:text>
|
---|
61 | <xsl:text> XSL Stylesheets (version </xsl:text>
|
---|
62 | <xsl:value-of select="$VERSION"/>
|
---|
63 | <xsl:text>). </xsl:text>
|
---|
64 | <xsl:text>.\" Instead of manually editing it, you</xsl:text>
|
---|
65 | <xsl:text> probably should edit the DocBook XML </xsl:text>
|
---|
66 | <xsl:text>.\" source for it and then use the DocBook</xsl:text>
|
---|
67 | <xsl:text> XSL Stylesheets to regenerate it. </xsl:text>
|
---|
68 | </xsl:template>
|
---|
69 |
|
---|
70 | <!-- ==================================================================== -->
|
---|
71 |
|
---|
72 | <xsl:template name="TH.title.line">
|
---|
73 |
|
---|
74 | <!-- * The exact way that .TH contents are displayed is system- -->
|
---|
75 | <!-- * dependent; it varies somewhat between OSes and roff -->
|
---|
76 | <!-- * versions. Below is a description of how Linux systems with -->
|
---|
77 | <!-- * a modern groff seem to render .TH contents. -->
|
---|
78 | <!-- * -->
|
---|
79 | <!-- * title(section) extra3 title(section) <- page header -->
|
---|
80 | <!-- * extra2 extra1 title(section) <- page footer-->
|
---|
81 | <!-- * -->
|
---|
82 | <!-- * Or, using the names with which the man(7) man page refers -->
|
---|
83 | <!-- * to the various fields: -->
|
---|
84 | <!-- * -->
|
---|
85 | <!-- * title(section) manual title(section) <- page header -->
|
---|
86 | <!-- * source date title(section) <- page footer-->
|
---|
87 | <!-- * -->
|
---|
88 | <!-- * Note that while extra1, extra2, and extra3 are all (nominally) -->
|
---|
89 | <!-- * optional, in practice almost all pages include an "extra1" -->
|
---|
90 | <!-- * field, which is, universally, a date (in some form), and it is -->
|
---|
91 | <!-- * always rendered in the same place (the middle footer position) -->
|
---|
92 | <!-- * -->
|
---|
93 | <!-- * Here are a couple of examples of real-world man pages that -->
|
---|
94 | <!-- * have somewhat useful page headers/footers: -->
|
---|
95 | <!-- * -->
|
---|
96 | <!-- * gtk-options(7) GTK+ User's Manual gtk-options(7) -->
|
---|
97 | <!-- * GTK+ 1.2 2003-10-20 gtk-options(7) -->
|
---|
98 | <!-- * -->
|
---|
99 | <!-- * svgalib(7) Svgalib User Manual svgalib(7) -->
|
---|
100 | <!-- * Svgalib 1.4.1 16 December 1999 svgalib(7) -->
|
---|
101 | <!-- * -->
|
---|
102 | <xsl:param name="title"/>
|
---|
103 | <xsl:param name="section"/>
|
---|
104 | <xsl:param name="extra1"/>
|
---|
105 | <xsl:param name="extra2"/>
|
---|
106 | <xsl:param name="extra3"/>
|
---|
107 |
|
---|
108 | <xsl:call-template name="mark.subheading"/>
|
---|
109 | <!-- * Note that we generate quotes around _every_ field in the -->
|
---|
110 | <!-- * .TH title line, including the "title" and "section" -->
|
---|
111 | <!-- * fields. That is because we use the contents of those "as -->
|
---|
112 | <!-- * is", unchanged from the DocBook source; and DTD-based -->
|
---|
113 | <!-- * validation does not provide a way to constrain them to be -->
|
---|
114 | <!-- * "space free" -->
|
---|
115 | <xsl:text>.TH "</xsl:text>
|
---|
116 | <xsl:call-template name="string.upper">
|
---|
117 | <xsl:with-param name="string">
|
---|
118 | <xsl:choose>
|
---|
119 | <xsl:when test="$man.th.title.max.length != ''">
|
---|
120 | <xsl:value-of
|
---|
121 | select="normalize-space(substring($title, 1, $man.th.title.max.length))"/>
|
---|
122 | </xsl:when>
|
---|
123 | <xsl:otherwise>
|
---|
124 | <xsl:value-of select="normalize-space($title)"/>
|
---|
125 | </xsl:otherwise>
|
---|
126 | </xsl:choose>
|
---|
127 | </xsl:with-param>
|
---|
128 | </xsl:call-template>
|
---|
129 | <xsl:text>" "</xsl:text>
|
---|
130 | <xsl:value-of select="normalize-space($section)"/>
|
---|
131 | <xsl:text>" "</xsl:text>
|
---|
132 | <xsl:if test="$man.th.extra1.suppress = 0">
|
---|
133 | <!-- * there is no max.length for the extra1 field; the reason -->
|
---|
134 | <!-- * is, it is almost always a date, and it is not possible -->
|
---|
135 | <!-- * to truncate dates without changing their meaning -->
|
---|
136 | <xsl:value-of select="normalize-space($extra1)"/>
|
---|
137 | </xsl:if>
|
---|
138 | <xsl:text>" "</xsl:text>
|
---|
139 | <xsl:if test="$man.th.extra2.suppress = 0">
|
---|
140 | <xsl:choose>
|
---|
141 | <!-- * if max.length is non-empty, use value to truncate field -->
|
---|
142 | <xsl:when test="$man.th.extra2.max.length != ''">
|
---|
143 | <xsl:value-of
|
---|
144 | select="normalize-space(substring($extra2, 1, $man.th.extra2.max.length))"/>
|
---|
145 | </xsl:when>
|
---|
146 | <xsl:otherwise>
|
---|
147 | <xsl:value-of select="normalize-space($extra2)"/>
|
---|
148 | </xsl:otherwise>
|
---|
149 | </xsl:choose>
|
---|
150 | </xsl:if>
|
---|
151 | <xsl:text>" "</xsl:text>
|
---|
152 | <xsl:if test="$man.th.extra3.suppress = 0">
|
---|
153 | <xsl:choose>
|
---|
154 | <!-- * if max.length is non-empty, use value to truncate field -->
|
---|
155 | <xsl:when test="$man.th.extra3.max.length != ''">
|
---|
156 | <xsl:value-of
|
---|
157 | select="normalize-space(substring($extra3, 1, $man.th.extra3.max.length))"/>
|
---|
158 | </xsl:when>
|
---|
159 | <xsl:otherwise>
|
---|
160 | <xsl:value-of select="normalize-space($extra3)"/>
|
---|
161 | </xsl:otherwise>
|
---|
162 | </xsl:choose>
|
---|
163 | </xsl:if>
|
---|
164 | <xsl:text>" </xsl:text>
|
---|
165 | <xsl:call-template name="mark.subheading"/>
|
---|
166 | </xsl:template>
|
---|
167 |
|
---|
168 | <!-- ============================================================== -->
|
---|
169 |
|
---|
170 | <xsl:template name="set.default.formatting">
|
---|
171 | <!-- * Set default hyphenation, justification, and line-breaking -->
|
---|
172 | <!-- * -->
|
---|
173 | <!-- * If the value of man.hypenate is zero (the default), then -->
|
---|
174 | <!-- * disable hyphenation (".nh" = "no hyphenation") -->
|
---|
175 | <xsl:if test="$man.hyphenate = 0">
|
---|
176 | <xsl:text>.\" disable hyphenation </xsl:text>
|
---|
177 | <xsl:text>.nh </xsl:text>
|
---|
178 | </xsl:if>
|
---|
179 | <!-- * If the value of man.justify is zero (the default), then -->
|
---|
180 | <!-- * disable justification (".ad l" means "adjust to left only") -->
|
---|
181 | <xsl:if test="$man.justify = 0">
|
---|
182 | <xsl:text>.\" disable justification</xsl:text>
|
---|
183 | <xsl:text> (adjust text to left margin only) </xsl:text>
|
---|
184 | <xsl:text>.ad l </xsl:text>
|
---|
185 | </xsl:if>
|
---|
186 | <!-- * Unless the value of man.break.after.slash is zero (the -->
|
---|
187 | <!-- * default), tell groff that it is OK to break a line -->
|
---|
188 | <!-- * after a slash when needed. -->
|
---|
189 | <xsl:if test="$man.break.after.slash != 0">
|
---|
190 | <xsl:text>.\" enable line breaks after slashes </xsl:text>
|
---|
191 | <xsl:text>.cflags 4 / </xsl:text>
|
---|
192 | </xsl:if>
|
---|
193 | </xsl:template>
|
---|
194 |
|
---|
195 | <!-- ================================================================== -->
|
---|
196 |
|
---|
197 | <!-- * The prepare.manpage.contents template is called after -->
|
---|
198 | <!-- * everything else has been done, just before writing the actual -->
|
---|
199 | <!-- * man-page files to the filesystem. It works on the entire roff -->
|
---|
200 | <!-- * source for each man page (not just the visible contents). -->
|
---|
201 | <xsl:template name="prepare.manpage.contents">
|
---|
202 | <xsl:param name="content" select="''"/>
|
---|
203 |
|
---|
204 | <!-- * First do "essential" string/character substitutions; for -->
|
---|
205 | <!-- * example, the backslash character _must_ be substituted with -->
|
---|
206 | <!-- * a double backslash, to prevent it from being interpreted as -->
|
---|
207 | <!-- * a roff escape -->
|
---|
208 | <xsl:variable name="adjusted.content">
|
---|
209 | <xsl:call-template name="apply-string-subst-map">
|
---|
210 | <xsl:with-param name="content" select="$content"/>
|
---|
211 | <xsl:with-param name="map.contents"
|
---|
212 | select="exsl:node-set($man.string.subst.map)/*"/>
|
---|
213 | </xsl:call-template>
|
---|
214 | </xsl:variable>
|
---|
215 |
|
---|
216 | <!-- * Optionally, apply a character map to replace Unicode -->
|
---|
217 | <!-- * symbols and special characters. -->
|
---|
218 | <xsl:choose>
|
---|
219 | <xsl:when test="$man.charmap.enabled != 0">
|
---|
220 | <xsl:call-template name="apply-character-map">
|
---|
221 | <xsl:with-param name="content" select="$adjusted.content"/>
|
---|
222 | <xsl:with-param name="map.contents"
|
---|
223 | select="exsl:node-set($man.charmap.contents)/*"/>
|
---|
224 | </xsl:call-template>
|
---|
225 | </xsl:when>
|
---|
226 | <xsl:otherwise>
|
---|
227 | <!-- * if we reach here, value of $man.charmap.enabled is zero, -->
|
---|
228 | <!-- * so we just pass the adjusted contents through "as is" -->
|
---|
229 | <xsl:value-of select="$adjusted.content"/>
|
---|
230 | </xsl:otherwise>
|
---|
231 | </xsl:choose>
|
---|
232 | </xsl:template>
|
---|
233 |
|
---|
234 | <!-- ================================================================== -->
|
---|
235 |
|
---|
236 | <xsl:template name="write.man.file">
|
---|
237 | <xsl:param name="name"/>
|
---|
238 | <xsl:param name="section"/>
|
---|
239 | <xsl:param name="content"/>
|
---|
240 | <xsl:param name="filename">
|
---|
241 | <xsl:call-template name="string.subst">
|
---|
242 | <!-- replace spaces in source filename with underscores in output filename -->
|
---|
243 | <xsl:with-param name="string"
|
---|
244 | select="concat(normalize-space($name), '.', normalize-space($section))"/>
|
---|
245 | <xsl:with-param name="target" select="' '"/>
|
---|
246 | <xsl:with-param name="replacement" select="'_'"/>
|
---|
247 | </xsl:call-template>
|
---|
248 | </xsl:param>
|
---|
249 | <xsl:call-template name="write.text.chunk">
|
---|
250 | <xsl:with-param name="filename" select="$filename"/>
|
---|
251 | <xsl:with-param name="quiet" select="$man.output.quietly"/>
|
---|
252 | <xsl:with-param name="encoding" select="$man.output.encoding"/>
|
---|
253 | <xsl:with-param name="content" select="$content"/>
|
---|
254 | </xsl:call-template>
|
---|
255 | </xsl:template>
|
---|
256 |
|
---|
257 | <!-- ============================================================== -->
|
---|
258 |
|
---|
259 | <!-- * A "stub" is sort of alias for another file, intended to be read -->
|
---|
260 | <!-- * and expanded by soelim(1); it's simply a file whose complete -->
|
---|
261 | <!-- * contents are just a single line of the following form: -->
|
---|
262 | <!-- * -->
|
---|
263 | <!-- * .so manX/realname.X -->
|
---|
264 | <!-- * -->
|
---|
265 | <!-- * "realname" is a name of another man-page file. That .so line is -->
|
---|
266 | <!-- * basically a roff "include" statement. When the man command finds -->
|
---|
267 | <!-- * it, it calls soelim(1) and includes and displays the contents of -->
|
---|
268 | <!-- * the manX/realqname.X file. -->
|
---|
269 | <!-- * -->
|
---|
270 | <!-- * If a refentry has multiple refnames, we generate a "stub" page for -->
|
---|
271 | <!-- * each refname found, except for the first one. -->
|
---|
272 | <xsl:template name="write.stubs">
|
---|
273 | <xsl:param name="first.refname"/>
|
---|
274 | <xsl:param name="section"/>
|
---|
275 | <xsl:for-each select="refnamediv/refname">
|
---|
276 | <xsl:if test=". != $first.refname">
|
---|
277 | <xsl:call-template name="write.text.chunk">
|
---|
278 | <xsl:with-param name="filename"
|
---|
279 | select="concat(normalize-space(.), '.',
|
---|
280 | $section)"/>
|
---|
281 | <xsl:with-param name="quiet" select="$man.output.quietly"/>
|
---|
282 | <xsl:with-param
|
---|
283 | name="content"
|
---|
284 | select="concat('.so man', $section, '/',
|
---|
285 | $first.refname, '.', $section, ' ')"/>
|
---|
286 | </xsl:call-template>
|
---|
287 | </xsl:if>
|
---|
288 | </xsl:for-each>
|
---|
289 | </xsl:template>
|
---|
290 |
|
---|
291 | </xsl:stylesheet>
|
---|