1 | <?xml version='1.0'?>
|
---|
2 | <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
---|
3 | xmlns:date="http://exslt.org/dates-and-times"
|
---|
4 | xmlns:exsl="http://exslt.org/common"
|
---|
5 | exclude-result-prefixes="date exsl"
|
---|
6 | version='1.0'>
|
---|
7 |
|
---|
8 | <!-- ********************************************************************
|
---|
9 | $Id: info.xsl 7883 2008-03-08 17:59:39Z xmldoc $
|
---|
10 | ********************************************************************
|
---|
11 |
|
---|
12 | This file is part of the XSL DocBook Stylesheet distribution.
|
---|
13 | See ../README or http://docbook.sf.net/release/xsl/current/ for
|
---|
14 | copyright and other information.
|
---|
15 |
|
---|
16 | ******************************************************************** -->
|
---|
17 |
|
---|
18 | <xsl:variable name="blurb-indent">
|
---|
19 | <xsl:choose>
|
---|
20 | <xsl:when test="not($man.indent.blurbs = 0)">
|
---|
21 | <xsl:value-of select="$man.indent.width"/>
|
---|
22 | </xsl:when>
|
---|
23 | <xsl:when test="not($man.indent.refsect = 0)">
|
---|
24 | <!-- * "zq" is the name of a register we set for -->
|
---|
25 | <!-- * preserving the original default indent value -->
|
---|
26 | <!-- * when $man.indent.refsect is non-zero; -->
|
---|
27 | <!-- * "u" is a roff unit specifier -->
|
---|
28 | <xsl:text>\n(zqu</xsl:text>
|
---|
29 | </xsl:when>
|
---|
30 | <xsl:otherwise/> <!-- * otherwise, just leave it empty -->
|
---|
31 | </xsl:choose>
|
---|
32 | </xsl:variable>
|
---|
33 |
|
---|
34 | <!-- ================================================================== -->
|
---|
35 | <!-- * About the $info param used in this stylesheet -->
|
---|
36 | <!-- * -->
|
---|
37 | <!-- * The $info param is a "master info" node set that contains -->
|
---|
38 | <!-- * the entire contents of the *info child of the current -->
|
---|
39 | <!-- * Refentry, plus the entire contents of the *info children of -->
|
---|
40 | <!-- * all ancestors of the current Refentry, in document order. -->
|
---|
41 | <!-- * -->
|
---|
42 | <!-- * We try to find a "best match" for selecting content from -->
|
---|
43 | <!-- * $infor; we look through it in reverse document order until we -->
|
---|
44 | <!-- * can find something usable. -->
|
---|
45 | <!-- * -->
|
---|
46 | <!-- * Specifically what the basic metadata-gathering XPath expression -->
|
---|
47 | <!-- * in this stylesheet does is: -->
|
---|
48 | <!-- * -->
|
---|
49 | <!-- * 1. Look through the entire "master info" node set.-->
|
---|
50 | <!-- * 2. Get the last node in the set that contains, for -->
|
---|
51 | <!-- * example, an Author element. That amounts to being the -->
|
---|
52 | <!-- * closest *info node to the Refentry - either its *info -->
|
---|
53 | <!-- * child, or the *info node of its closest ancestor that -->
|
---|
54 | <!-- * contains an Author. -->
|
---|
55 |
|
---|
56 | <!-- ================================================================== -->
|
---|
57 | <!-- * Get user "refentry metadata" preferences -->
|
---|
58 | <!-- ================================================================== -->
|
---|
59 | <!-- * The DocBook XSL stylesheets include several user-configurable -->
|
---|
60 | <!-- * global stylesheet parameters for controlling refentry metadata -->
|
---|
61 | <!-- * gathering. Those parameters are not read directly by the other -->
|
---|
62 | <!-- * refentry metadata-gathering templates. Instead, they are read -->
|
---|
63 | <!-- * only by the get.refentry.metadata.prefs template, which -->
|
---|
64 | <!-- * assembles them into a structure that is then passed to the -->
|
---|
65 | <!-- * other refentry metadata-gathering template. -->
|
---|
66 |
|
---|
67 | <xsl:variable name="get.refentry.metadata.prefs">
|
---|
68 | <!-- * get.refentry.metadata.prefs is in common/refentry.xsl -->
|
---|
69 | <xsl:call-template name="get.refentry.metadata.prefs"/>
|
---|
70 | </xsl:variable>
|
---|
71 |
|
---|
72 | <xsl:variable name="refentry.metadata.prefs"
|
---|
73 | select="exsl:node-set($get.refentry.metadata.prefs)"/>
|
---|
74 |
|
---|
75 | <!-- * ============================================================== -->
|
---|
76 | <!-- * Get content for Author metadata field. -->
|
---|
77 | <!-- * ============================================================== -->
|
---|
78 |
|
---|
79 | <!-- * The make.roff.metatada.author template and metadata.author -->
|
---|
80 | <!-- * mode are used only for populating the Author field in the -->
|
---|
81 | <!-- * metadata "top comment" we embed in roff source of each page. -->
|
---|
82 | <xsl:template name="make.roff.metadata.author">
|
---|
83 | <xsl:param name="info"/>
|
---|
84 | <xsl:param name="refname"/>
|
---|
85 | <xsl:choose>
|
---|
86 | <xsl:when test="$info//author">
|
---|
87 | <xsl:apply-templates
|
---|
88 | select="(($info[//author])[last()]//author)[1]"
|
---|
89 | mode="metadata.author"/>
|
---|
90 | </xsl:when>
|
---|
91 | <xsl:when test="$info//corpauthor">
|
---|
92 | <xsl:apply-templates
|
---|
93 | select="(($info[//corpauthor])[last()]//corpauthor)[1]"
|
---|
94 | mode="metadata.author"/>
|
---|
95 | </xsl:when>
|
---|
96 | <xsl:when test="$info//editor">
|
---|
97 | <xsl:apply-templates
|
---|
98 | select="(($info[//editor])[last()]//editor)[1]"
|
---|
99 | mode="metadata.author"/>
|
---|
100 | </xsl:when>
|
---|
101 | <xsl:when test="$info//corpcredit">
|
---|
102 | <xsl:apply-templates
|
---|
103 | select="(($info[//corpcredit])[last()]//corpcredit)[1]"
|
---|
104 | mode="metadata.author"/>
|
---|
105 | </xsl:when>
|
---|
106 | <xsl:when test="$info//othercredit">
|
---|
107 | <xsl:apply-templates
|
---|
108 | select="(($info[//othercredit])[last()]//othercredit)[1]"
|
---|
109 | mode="metadata.author"/>
|
---|
110 | </xsl:when>
|
---|
111 | <xsl:when test="$info//collab">
|
---|
112 | <xsl:apply-templates
|
---|
113 | select="(($info[//collab])[last()]//collab)[1]"
|
---|
114 | mode="metadata.author"/>
|
---|
115 | </xsl:when>
|
---|
116 | <xsl:when test="$info//orgname">
|
---|
117 | <xsl:apply-templates
|
---|
118 | select="(($info[//orgname])[last()]//orgname)[1]"
|
---|
119 | mode="metadata.author"/>
|
---|
120 | </xsl:when>
|
---|
121 | <xsl:when test="$info//publishername">
|
---|
122 | <xsl:apply-templates
|
---|
123 | select="(($info[//publishername])[last()]//publishername)[1]"
|
---|
124 | mode="metadata.author"/>
|
---|
125 | </xsl:when>
|
---|
126 | <xsl:otherwise>
|
---|
127 | <!-- * otherwise, we need to check to see if we have an "Author" -->
|
---|
128 | <!-- * or "Authors" section in the refentry -->
|
---|
129 | <xsl:variable name="gentext.author">
|
---|
130 | <xsl:text>"</xsl:text>
|
---|
131 | <xsl:call-template name="gentext">
|
---|
132 | <xsl:with-param name="key" select="'Author'"/>
|
---|
133 | </xsl:call-template>
|
---|
134 | <xsl:text>"</xsl:text>
|
---|
135 | </xsl:variable>
|
---|
136 | <xsl:variable name="gentext.AUTHOR">
|
---|
137 | <xsl:if test="not($gentext.author = '')">
|
---|
138 | <xsl:call-template name="string.upper">
|
---|
139 | <xsl:with-param name="string" select="$gentext.author"/>
|
---|
140 | </xsl:call-template>
|
---|
141 | </xsl:if>
|
---|
142 | </xsl:variable>
|
---|
143 | <xsl:variable name="gentext.authors">
|
---|
144 | <xsl:text>"</xsl:text>
|
---|
145 | <xsl:call-template name="gentext">
|
---|
146 | <xsl:with-param name="key" select="'Authors'"/>
|
---|
147 | </xsl:call-template>
|
---|
148 | <xsl:text>"</xsl:text>
|
---|
149 | </xsl:variable>
|
---|
150 | <xsl:variable name="gentext.AUTHORS">
|
---|
151 | <xsl:if test="not($gentext.authors = '')">
|
---|
152 | <xsl:call-template name="string.upper">
|
---|
153 | <xsl:with-param name="string" select="$gentext.authors"/>
|
---|
154 | </xsl:call-template>
|
---|
155 | </xsl:if>
|
---|
156 | </xsl:variable>
|
---|
157 | <!-- * get all refentry/refsect1/title & refentry/refsection/title -->
|
---|
158 | <!-- * instances, delimit each with double quotes, and put them -->
|
---|
159 | <!-- * into a single refsect1.titles string -->
|
---|
160 | <xsl:variable name="refsect1.titles">
|
---|
161 | <xsl:for-each select="refsect1/title">
|
---|
162 | <xsl:text>"</xsl:text>
|
---|
163 | <xsl:value-of select="normalize-space(.)"/>
|
---|
164 | <xsl:text>"</xsl:text>
|
---|
165 | <xsl:text> </xsl:text>
|
---|
166 | </xsl:for-each>
|
---|
167 | <xsl:for-each select="refsection/title">
|
---|
168 | <xsl:text>"</xsl:text>
|
---|
169 | <xsl:value-of select="normalize-space(.)"/>
|
---|
170 | <xsl:text>"</xsl:text>
|
---|
171 | <xsl:text> </xsl:text>
|
---|
172 | </xsl:for-each>
|
---|
173 | </xsl:variable>
|
---|
174 | <xsl:variable name="author.section.title">
|
---|
175 | <xsl:choose>
|
---|
176 | <xsl:when test="not($gentext.authors = '') and
|
---|
177 | contains($refsect1.titles,$gentext.authors)">
|
---|
178 | <xsl:value-of select="$gentext.authors"/>
|
---|
179 | </xsl:when>
|
---|
180 | <xsl:when test="not($gentext.AUTHORS = '') and
|
---|
181 | contains($refsect1.titles,$gentext.AUTHORS)">
|
---|
182 | <xsl:value-of select="$gentext.AUTHORS"/>
|
---|
183 | </xsl:when>
|
---|
184 | <xsl:when test="not($gentext.author = '') and
|
---|
185 | contains($refsect1.titles,$gentext.author)">
|
---|
186 | <xsl:value-of select="$gentext.author"/>
|
---|
187 | </xsl:when>
|
---|
188 | <xsl:when test="not($gentext.AUTHOR = '') and
|
---|
189 | contains($refsect1.titles,$gentext.AUTHOR)">
|
---|
190 | <xsl:value-of select="$gentext.AUTHOR"/>
|
---|
191 | </xsl:when>
|
---|
192 | <!-- * git docs (for one) use "DOCUMENTATION" for their authors section -->
|
---|
193 | <xsl:when test="contains($refsect1.titles,'Documentation')">
|
---|
194 | <xsl:text>Documentation</xsl:text>
|
---|
195 | </xsl:when>
|
---|
196 | <xsl:when test="contains($refsect1.titles,'DOCUMENTATION')">
|
---|
197 | <xsl:text>DOCUMENTATION</xsl:text>
|
---|
198 | </xsl:when>
|
---|
199 | <xsl:otherwise/> <!-- * otherwise, leave empty -->
|
---|
200 | </xsl:choose>
|
---|
201 | </xsl:variable>
|
---|
202 | <xsl:choose>
|
---|
203 | <xsl:when test="not($author.section.title = '')">
|
---|
204 | <!-- * if we have a non-empty $author.section.title value, -->
|
---|
205 | <!-- * then reference that title (instead of putting a -->
|
---|
206 | <!-- * specific author name) -->
|
---|
207 | <xsl:text>[see the </xsl:text>
|
---|
208 | <xsl:value-of select="$author.section.title"/>
|
---|
209 | <xsl:text> section]</xsl:text>
|
---|
210 | </xsl:when>
|
---|
211 | <xsl:otherwise>
|
---|
212 | <!-- * otherwise we have no info/author content and no Author -->
|
---|
213 | <!-- * or Authors section, so we insert a fixme and report -->
|
---|
214 | <!-- * the problem to the user -->
|
---|
215 | <xsl:text>[FIXME: author] [see http://docbook.sf.net/el/author]</xsl:text>
|
---|
216 | <xsl:if test="$refentry.meta.get.quietly = 0">
|
---|
217 | <xsl:call-template name="log.message">
|
---|
218 | <xsl:with-param name="level">Warn</xsl:with-param>
|
---|
219 | <xsl:with-param name="source" select="$refname"/>
|
---|
220 | <xsl:with-param name="context-desc">meta author</xsl:with-param>
|
---|
221 | <xsl:with-param name="message">
|
---|
222 | <xsl:text>no refentry/info/author</xsl:text>
|
---|
223 | </xsl:with-param>
|
---|
224 | </xsl:call-template>
|
---|
225 | <xsl:call-template name="log.message">
|
---|
226 | <xsl:with-param name="level">Note</xsl:with-param>
|
---|
227 | <xsl:with-param name="source" select="$refname"/>
|
---|
228 | <xsl:with-param name="context-desc">meta author</xsl:with-param>
|
---|
229 | <xsl:with-param name="message">
|
---|
230 | <xsl:text>see http://docbook.sf.net/el/author</xsl:text>
|
---|
231 | </xsl:with-param>
|
---|
232 | </xsl:call-template>
|
---|
233 | <xsl:call-template name="log.message">
|
---|
234 | <xsl:with-param name="level">Warn</xsl:with-param>
|
---|
235 | <xsl:with-param name="source" select="$refname"/>
|
---|
236 | <xsl:with-param name="context-desc">meta author</xsl:with-param>
|
---|
237 | <xsl:with-param name="message">
|
---|
238 | <xsl:text>no author data, so inserted a fixme</xsl:text>
|
---|
239 | </xsl:with-param>
|
---|
240 | </xsl:call-template>
|
---|
241 | </xsl:if>
|
---|
242 | </xsl:otherwise>
|
---|
243 | </xsl:choose>
|
---|
244 | </xsl:otherwise>
|
---|
245 | </xsl:choose>
|
---|
246 | </xsl:template>
|
---|
247 |
|
---|
248 | <xsl:template match="author|editor|othercredit|collab" mode="metadata.author">
|
---|
249 | <xsl:choose>
|
---|
250 | <xsl:when test="collabname">
|
---|
251 | <!-- * If this node is a Collab, then it should have a -->
|
---|
252 | <!-- * Collabname child, so get that. -->
|
---|
253 | <xsl:variable name="contents">
|
---|
254 | <xsl:apply-templates select="collabname"/>
|
---|
255 | </xsl:variable>
|
---|
256 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
257 | </xsl:when>
|
---|
258 | <xsl:otherwise>
|
---|
259 | <!-- * Otherwise, this node is not a Collab, but instead -->
|
---|
260 | <!-- * an author|editor|othercredit, which must have a name -->
|
---|
261 | <!-- * of some kind; so get that name -->
|
---|
262 | <xsl:call-template name="person.name.normalized"/>
|
---|
263 | </xsl:otherwise>
|
---|
264 | </xsl:choose>
|
---|
265 | <xsl:if test=".//email|address/otheraddr/ulink">
|
---|
266 | <xsl:text> </xsl:text>
|
---|
267 | <!-- * For each attribution found, use only the first e-mail -->
|
---|
268 | <!-- * address or ulink value found -->
|
---|
269 | <xsl:apply-templates select="(.//email|address/otheraddr/ulink)[1]"
|
---|
270 | mode="metadata.author"/>
|
---|
271 | </xsl:if>
|
---|
272 | </xsl:template>
|
---|
273 |
|
---|
274 | <xsl:template match="email|address/otheraddr/ulink" mode="metadata.author">
|
---|
275 | <xsl:text><</xsl:text>
|
---|
276 | <xsl:choose>
|
---|
277 | <xsl:when test="self::email">
|
---|
278 | <xsl:variable name="contents">
|
---|
279 | <xsl:apply-templates/>
|
---|
280 | </xsl:variable>
|
---|
281 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
282 | </xsl:when>
|
---|
283 | <xsl:when test="self::ulink">
|
---|
284 | <xsl:variable name="contents">
|
---|
285 | <xsl:apply-templates select="."/>
|
---|
286 | </xsl:variable>
|
---|
287 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
288 | </xsl:when>
|
---|
289 | </xsl:choose>
|
---|
290 | <xsl:text>></xsl:text>
|
---|
291 | </xsl:template>
|
---|
292 |
|
---|
293 | <xsl:template match="corpauthor|corpcredit|orgname|publishername" mode="metadata.author">
|
---|
294 | <xsl:variable name="contents">
|
---|
295 | <xsl:apply-templates/>
|
---|
296 | </xsl:variable>
|
---|
297 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
298 | </xsl:template>
|
---|
299 |
|
---|
300 | <!-- * ============================================================== -->
|
---|
301 | <!-- * Assemble the AUTHOR/AUTHORS section -->
|
---|
302 | <!-- * ============================================================== -->
|
---|
303 |
|
---|
304 | <xsl:template name="author.section">
|
---|
305 | <xsl:param name="info"/>
|
---|
306 | <!-- * The $info param is a "master info" node set that contains -->
|
---|
307 | <!-- * the entires contents of the *info child of the current -->
|
---|
308 | <!-- * Refentry, plus the entire contents of the *info children of -->
|
---|
309 | <!-- * all ancestors of the current Refentry, in document order. -->
|
---|
310 | <xsl:choose>
|
---|
311 | <xsl:when test="$info//author|$info//editor|$info//collab|
|
---|
312 | $info//corpauthor|$info//corpcredit|
|
---|
313 | $info//othercredit|$info/orgname|
|
---|
314 | $info/publishername|$info/publisher">
|
---|
315 | <xsl:variable name="authorcount">
|
---|
316 | <xsl:value-of
|
---|
317 | select="count(
|
---|
318 | $info//author|$info//editor|$info//collab|
|
---|
319 | $info//corpauthor|$info//corpcredit|
|
---|
320 | $info//othercredit)">
|
---|
321 | </xsl:value-of>
|
---|
322 | </xsl:variable>
|
---|
323 | <xsl:call-template name="make.subheading">
|
---|
324 | <xsl:with-param name="title">
|
---|
325 | <xsl:call-template name="make.authorsecttitle">
|
---|
326 | <xsl:with-param name="authorcount" select="$authorcount"/>
|
---|
327 | </xsl:call-template>
|
---|
328 | </xsl:with-param>
|
---|
329 | </xsl:call-template>
|
---|
330 | <!-- * Now output all the actual author, editor, etc. content -->
|
---|
331 | <xsl:for-each
|
---|
332 | select="$info//author|$info//editor|$info//collab|
|
---|
333 | $info//corpauthor|$info//corpcredit|
|
---|
334 | $info//othercredit|$info/orgname|
|
---|
335 | $info/publishername|$info/publisher">
|
---|
336 | <xsl:apply-templates select="." mode="authorsect"/>
|
---|
337 | </xsl:for-each>
|
---|
338 | </xsl:when>
|
---|
339 | <xsl:otherwise/> <!-- * do nothing, no author info found -->
|
---|
340 | </xsl:choose>
|
---|
341 | </xsl:template>
|
---|
342 |
|
---|
343 | <xsl:template name="make.authorsecttitle">
|
---|
344 | <!-- * If we have exactly one attributable person/entity, then output -->
|
---|
345 | <!-- * localized gentext for 'Author'; otherwise, output 'Authors'. -->
|
---|
346 | <xsl:param name="authorcount"/>
|
---|
347 | <xsl:param name="authorsecttitle">
|
---|
348 | <xsl:choose>
|
---|
349 | <xsl:when test="$authorcount = 1">
|
---|
350 | <xsl:text>Author</xsl:text>
|
---|
351 | </xsl:when>
|
---|
352 | <xsl:otherwise>
|
---|
353 | <xsl:text>Authors</xsl:text>
|
---|
354 | </xsl:otherwise>
|
---|
355 | </xsl:choose>
|
---|
356 | </xsl:param>
|
---|
357 | <xsl:call-template name="gentext">
|
---|
358 | <xsl:with-param name="key" select="$authorsecttitle"/>
|
---|
359 | </xsl:call-template>
|
---|
360 | </xsl:template>
|
---|
361 |
|
---|
362 | <xsl:template match="author|editor|othercredit" mode="authorsect">
|
---|
363 | <xsl:variable name="person-name">
|
---|
364 | <xsl:call-template name="person.name.normalized"/>
|
---|
365 | </xsl:variable>
|
---|
366 | <!-- * If we have a person-name or email or ulink content, then -->
|
---|
367 | <!-- * output name and email or ulink content on the same line -->
|
---|
368 | <xsl:choose>
|
---|
369 | <xsl:when test="not($person-name = '') or .//email or address/otheraddr/ulink">
|
---|
370 | <xsl:text>.PP </xsl:text>
|
---|
371 | <!-- * Display person name in bold -->
|
---|
372 | <xsl:call-template name="bold">
|
---|
373 | <xsl:with-param name="node" select="exsl:node-set($person-name)"/>
|
---|
374 | <xsl:with-param name="context" select="."/>
|
---|
375 | </xsl:call-template>
|
---|
376 | <!-- * Display e-mail address(es) and ulink(s) on same line as name -->
|
---|
377 | <xsl:apply-templates select=".//email|address/otheraddr/ulink" mode="authorsect"/>
|
---|
378 | <xsl:text> </xsl:text>
|
---|
379 | </xsl:when>
|
---|
380 | <xsl:otherwise>
|
---|
381 | <xsl:text>.br </xsl:text>
|
---|
382 | </xsl:otherwise>
|
---|
383 | </xsl:choose>
|
---|
384 | <!-- * Display affiliation(s) on separate lines -->
|
---|
385 | <xsl:apply-templates select="affiliation" mode="authorsect"/>
|
---|
386 | <!-- * Display direct-child addresses on separate lines -->
|
---|
387 | <xsl:apply-templates select="address" mode="authorsect"/>
|
---|
388 | <!-- * Call template for handling various attribution possibilities -->
|
---|
389 | <xsl:call-template name="attribution">
|
---|
390 | <xsl:with-param name="person-name" select="$person-name"/>
|
---|
391 | </xsl:call-template>
|
---|
392 | </xsl:template>
|
---|
393 |
|
---|
394 | <xsl:template match="collab" mode="authorsect">
|
---|
395 | <xsl:text>.PP </xsl:text>
|
---|
396 | <xsl:call-template name="bold">
|
---|
397 | <xsl:with-param name="node" select="collabname"/>
|
---|
398 | <xsl:with-param name="context" select="."/>
|
---|
399 | </xsl:call-template>
|
---|
400 | <!-- * Display e-mail address(es) and ulink(s) on same line as name -->
|
---|
401 | <xsl:apply-templates select=".//email|address/otheraddr/ulink" mode="authorsect"/>
|
---|
402 | <xsl:text> </xsl:text>
|
---|
403 | <!-- * Display affilition(s) on separate lines -->
|
---|
404 | <xsl:apply-templates select="affiliation" mode="authorsect"/>
|
---|
405 | </xsl:template>
|
---|
406 |
|
---|
407 | <xsl:template match="corpauthor|corpcredit|orgname|publishername" mode="authorsect">
|
---|
408 | <xsl:text>.PP </xsl:text>
|
---|
409 | <xsl:call-template name="bold">
|
---|
410 | <xsl:with-param name="node" select="."/>
|
---|
411 | <xsl:with-param name="context" select="."/>
|
---|
412 | </xsl:call-template>
|
---|
413 | <xsl:text> </xsl:text>
|
---|
414 | <xsl:if test="self::publishername">
|
---|
415 | <!-- * Display localized "Publisher" gentext -->
|
---|
416 | <xsl:call-template name="publisher.attribution"/>
|
---|
417 | </xsl:if>
|
---|
418 | </xsl:template>
|
---|
419 |
|
---|
420 | <xsl:template match="publisher" mode="authorsect">
|
---|
421 | <xsl:text>.PP </xsl:text>
|
---|
422 | <xsl:call-template name="bold">
|
---|
423 | <xsl:with-param name="node" select="publishername"/>
|
---|
424 | <xsl:with-param name="context" select="."/>
|
---|
425 | </xsl:call-template>
|
---|
426 | <!-- * Display e-mail address(es) and ulink(s) on same line as name -->
|
---|
427 | <xsl:apply-templates select=".//email|address/otheraddr/ulink" mode="authorsect"/>
|
---|
428 | <!-- * Display addresses on separate lines -->
|
---|
429 | <xsl:apply-templates select="address" mode="authorsect"/>
|
---|
430 | <!-- * Display localized "Publisher" literal -->
|
---|
431 | <xsl:call-template name="publisher.attribution"/>
|
---|
432 | </xsl:template>
|
---|
433 |
|
---|
434 | <xsl:template name="publisher.attribution">
|
---|
435 | <xsl:text> </xsl:text>
|
---|
436 | <xsl:text>.RS</xsl:text>
|
---|
437 | <xsl:if test="not($blurb-indent = '')">
|
---|
438 | <xsl:text> </xsl:text>
|
---|
439 | <xsl:value-of select="$blurb-indent"/>
|
---|
440 | </xsl:if>
|
---|
441 | <xsl:text> </xsl:text>
|
---|
442 | <xsl:call-template name="gentext">
|
---|
443 | <xsl:with-param name="key" select="'Publisher'"/>
|
---|
444 | </xsl:call-template>
|
---|
445 | <xsl:text>. </xsl:text>
|
---|
446 | <xsl:text>.RE </xsl:text>
|
---|
447 | </xsl:template>
|
---|
448 |
|
---|
449 | <xsl:template match="email|address/otheraddr/ulink" mode="authorsect">
|
---|
450 | <xsl:choose>
|
---|
451 | <xsl:when test="preceding-sibling::*[descendant-or-self::email]
|
---|
452 | or preceding-sibling::address/otheraddr/ulink
|
---|
453 | or ancestor::address[preceding-sibling::*[descendant-or-self::email]]
|
---|
454 | or ancestor::address[preceding-sibling::address/otheraddr/ulink]">
|
---|
455 | <!-- * This is not the first instance, so do nothing. -->
|
---|
456 | </xsl:when>
|
---|
457 | <xsl:otherwise>
|
---|
458 | <!-- * This is first instances of an e-mail address or ulink, -->
|
---|
459 | <!-- * so put a space before it. -->
|
---|
460 | <xsl:text> </xsl:text>
|
---|
461 | </xsl:otherwise>
|
---|
462 | </xsl:choose>
|
---|
463 | <!-- * Note that the reason for the \& character after the opening -->
|
---|
464 | <!-- * angle bracket and before the closing angle bracket is to -->
|
---|
465 | <!-- * prevent groff from inserting a linebreak at those points and -->
|
---|
466 | <!-- * outputting a hyphen character where the break occurs -->
|
---|
467 | <xsl:text><\&</xsl:text>
|
---|
468 | <xsl:choose>
|
---|
469 | <xsl:when test="self::email">
|
---|
470 | <xsl:variable name="contents">
|
---|
471 | <xsl:apply-templates/>
|
---|
472 | </xsl:variable>
|
---|
473 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
474 | </xsl:when>
|
---|
475 | <xsl:when test="self::ulink">
|
---|
476 | <xsl:variable name="contents">
|
---|
477 | <xsl:apply-templates select="."/>
|
---|
478 | </xsl:variable>
|
---|
479 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
480 | </xsl:when>
|
---|
481 | </xsl:choose>
|
---|
482 | <xsl:text>\&></xsl:text>
|
---|
483 | <xsl:choose>
|
---|
484 | <xsl:when test="not(following-sibling::*[descendant-or-self::email]
|
---|
485 | or following-sibling::address/otheraddr/ulink
|
---|
486 | or ancestor::address[following-sibling::*[descendant-or-self::email]]
|
---|
487 | or ancestor::address[following-sibling::address/otheraddr/ulink])">
|
---|
488 | <!-- * This is the final instance, so do nothing. -->
|
---|
489 | </xsl:when>
|
---|
490 | <xsl:otherwise>
|
---|
491 | <!-- * Separate multiple e-mail addresses or ulinks with a comma -->
|
---|
492 | <xsl:text>, </xsl:text>
|
---|
493 | </xsl:otherwise>
|
---|
494 | </xsl:choose>
|
---|
495 | </xsl:template>
|
---|
496 |
|
---|
497 | <xsl:template match="affiliation" mode="authorsect">
|
---|
498 | <!-- * Get the string value of the contents of this Affiliation. If the -->
|
---|
499 | <!-- * affiliation only contains an Address child whose only content is -->
|
---|
500 | <!-- * an email address or ulink, then these contents will end up empty. -->
|
---|
501 | <xsl:variable name="contents">
|
---|
502 | <xsl:apply-templates mode="authorsect"/>
|
---|
503 | </xsl:variable>
|
---|
504 | <!-- * If contents are actually empty except for an email address -->
|
---|
505 | <!-- * or ulink, then output nothing. -->
|
---|
506 | <xsl:if test="$contents != ''">
|
---|
507 | <xsl:text>.br </xsl:text>
|
---|
508 | <xsl:for-each select="shortaffil|jobtitle|orgname|orgdiv|address">
|
---|
509 | <!-- * only display output of nodes other than email or ulink -->
|
---|
510 | <xsl:apply-templates select="node()[not(self::email) and not(self::otheraddr/ulink)]"/>
|
---|
511 | <xsl:choose>
|
---|
512 | <xsl:when test="position() = last()"/> <!-- do nothing -->
|
---|
513 | <xsl:otherwise>
|
---|
514 | <!-- * only add comma if the node has a child node other than -->
|
---|
515 | <!-- * an email address or ulink -->
|
---|
516 | <xsl:if test="child::node()[not(self::email) and not(self::otheraddr/ulink)]">
|
---|
517 | <xsl:text>, </xsl:text>
|
---|
518 | </xsl:if>
|
---|
519 | </xsl:otherwise>
|
---|
520 | </xsl:choose>
|
---|
521 | </xsl:for-each>
|
---|
522 | <xsl:text> </xsl:text>
|
---|
523 | <xsl:choose>
|
---|
524 | <xsl:when test="position() = last()"/> <!-- do nothing -->
|
---|
525 | <xsl:otherwise>
|
---|
526 | <!-- * put a line break after every Affiliation instance except -->
|
---|
527 | <!-- * the last one in the set -->
|
---|
528 | <xsl:text>.br </xsl:text>
|
---|
529 | </xsl:otherwise>
|
---|
530 | </xsl:choose>
|
---|
531 | </xsl:if>
|
---|
532 | </xsl:template>
|
---|
533 |
|
---|
534 | <xsl:template match="address" mode="authorsect">
|
---|
535 | <xsl:variable name="contents"
|
---|
536 | select="normalize-space(node()[not(self::email)
|
---|
537 | and not(self::otheraddr/ulink)])"/>
|
---|
538 | <!-- * If this contents of this Address do not contain anything except -->
|
---|
539 | <!-- * an email address or ulink, then output nothing. -->
|
---|
540 | <xsl:if test="$contents != ''">
|
---|
541 | <xsl:text> </xsl:text>
|
---|
542 | <xsl:text>.br </xsl:text>
|
---|
543 | <!--* Skip email and ulink descendants of Address (rendered elsewhere) -->
|
---|
544 | <xsl:apply-templates select="node()[not(self::email) and not(self::otheraddr/ulink)]"/>
|
---|
545 | </xsl:if>
|
---|
546 | </xsl:template>
|
---|
547 |
|
---|
548 | <xsl:template name="attribution">
|
---|
549 | <xsl:param name="person-name"/>
|
---|
550 | <xsl:param name="refname" select="ancestor::refentry/refnamediv[1]/refname[1]"/>
|
---|
551 | <!-- * Determine appropriate attribution for a particular person's role. -->
|
---|
552 | <xsl:choose>
|
---|
553 | <!-- * if we have a *blurb or contrib, just use that -->
|
---|
554 | <xsl:when test="contrib|personblurb|authorblurb">
|
---|
555 | <xsl:apply-templates select="contrib|personblurb|authorblurb" mode="authorsect"/>
|
---|
556 | <xsl:text> </xsl:text>
|
---|
557 | </xsl:when>
|
---|
558 | <xsl:otherwise>
|
---|
559 | <!-- * otherwise we have no attribution information to use... -->
|
---|
560 | <xsl:if test="not($person-name = '')">
|
---|
561 | <!-- * if we have a person name or organization name -->
|
---|
562 | <!-- * ($person-name can actually be an orgname, not just a -->
|
---|
563 | <!-- * person name), then report to the user that we are -->
|
---|
564 | <!-- * lacking attribution information for that person -->
|
---|
565 | <xsl:if test="$refentry.meta.get.quietly = 0">
|
---|
566 | <xsl:call-template name="log.message">
|
---|
567 | <xsl:with-param name="level">Warn</xsl:with-param>
|
---|
568 | <xsl:with-param name="source" select="$refname"/>
|
---|
569 | <xsl:with-param name="context-desc">AUTHOR sect.</xsl:with-param>
|
---|
570 | <xsl:with-param name="message">
|
---|
571 | <xsl:text>no personblurb|contrib for </xsl:text>
|
---|
572 | <xsl:value-of select="$person-name"/>
|
---|
573 | </xsl:with-param>
|
---|
574 | </xsl:call-template>
|
---|
575 | <xsl:call-template name="log.message">
|
---|
576 | <xsl:with-param name="level">Note</xsl:with-param>
|
---|
577 | <xsl:with-param name="source" select="$refname"/>
|
---|
578 | <xsl:with-param name="context-desc">AUTHOR sect.</xsl:with-param>
|
---|
579 | <xsl:with-param name="message">
|
---|
580 | <xsl:text>see see http://docbook.sf.net/el/contrib</xsl:text>
|
---|
581 | </xsl:with-param>
|
---|
582 | </xsl:call-template>
|
---|
583 | <xsl:call-template name="log.message">
|
---|
584 | <xsl:with-param name="level">Note</xsl:with-param>
|
---|
585 | <xsl:with-param name="source" select="$refname"/>
|
---|
586 | <xsl:with-param name="context-desc">AUTHOR sect.</xsl:with-param>
|
---|
587 | <xsl:with-param name="message">
|
---|
588 | <xsl:text>see see http://docbook.sf.net/el/personblurb</xsl:text>
|
---|
589 | </xsl:with-param>
|
---|
590 | </xsl:call-template>
|
---|
591 | </xsl:if>
|
---|
592 | </xsl:if>
|
---|
593 | <xsl:choose>
|
---|
594 | <!-- * If we have no *blurb or contrib, but this is an Author or -->
|
---|
595 | <!-- * Editor, then render the corresponding localized gentext -->
|
---|
596 | <xsl:when test="self::author">
|
---|
597 | <xsl:text> </xsl:text>
|
---|
598 | <xsl:text>.RS</xsl:text>
|
---|
599 | <xsl:if test="not($blurb-indent = '')">
|
---|
600 | <xsl:text> </xsl:text>
|
---|
601 | <xsl:value-of select="$blurb-indent"/>
|
---|
602 | </xsl:if>
|
---|
603 | <xsl:text> </xsl:text>
|
---|
604 | <xsl:call-template name="gentext">
|
---|
605 | <xsl:with-param name="key" select="'Author'"/>
|
---|
606 | </xsl:call-template>
|
---|
607 | <xsl:text>. </xsl:text>
|
---|
608 | <xsl:text>.RE </xsl:text>
|
---|
609 | </xsl:when>
|
---|
610 | <xsl:when test="self::editor">
|
---|
611 | <xsl:text> </xsl:text>
|
---|
612 | <xsl:text>.RS</xsl:text>
|
---|
613 | <xsl:if test="not($blurb-indent = '')">
|
---|
614 | <xsl:text> </xsl:text>
|
---|
615 | <xsl:value-of select="$blurb-indent"/>
|
---|
616 | </xsl:if>
|
---|
617 | <xsl:text> </xsl:text>
|
---|
618 | <xsl:call-template name="gentext">
|
---|
619 | <xsl:with-param name="key" select="'Editor'"/>
|
---|
620 | </xsl:call-template>
|
---|
621 | <xsl:text>. </xsl:text>
|
---|
622 | <xsl:text>.RE </xsl:text>
|
---|
623 | </xsl:when>
|
---|
624 | <!-- * If we have no *blurb or contrib, but this is an Othercredit, -->
|
---|
625 | <!-- * check value of Class attribute and use corresponding gentext. -->
|
---|
626 | <xsl:when test="self::othercredit">
|
---|
627 | <xsl:choose>
|
---|
628 | <xsl:when test="@class and @class != 'other'">
|
---|
629 | <xsl:text> </xsl:text>
|
---|
630 | <xsl:text>.RS</xsl:text>
|
---|
631 | <xsl:if test="not($blurb-indent = '')">
|
---|
632 | <xsl:text> </xsl:text>
|
---|
633 | <xsl:value-of select="$blurb-indent"/>
|
---|
634 | </xsl:if>
|
---|
635 | <xsl:text> </xsl:text>
|
---|
636 | <xsl:call-template name="gentext">
|
---|
637 | <xsl:with-param name="key" select="@class"/>
|
---|
638 | </xsl:call-template>
|
---|
639 | <xsl:text>. </xsl:text>
|
---|
640 | <xsl:text>.RE </xsl:text>
|
---|
641 | </xsl:when>
|
---|
642 | <xsl:otherwise>
|
---|
643 | <!-- * We have an Othercredit, but no usable value for the Class -->
|
---|
644 | <!-- * attribute, so nothing to show, do nothing -->
|
---|
645 | </xsl:otherwise>
|
---|
646 | </xsl:choose>
|
---|
647 | </xsl:when>
|
---|
648 | <xsl:otherwise>
|
---|
649 | <!-- * We have no *blurb or contrib or anything else we can use to -->
|
---|
650 | <!-- * display appropriate attribution for this person, so do nothing -->
|
---|
651 | </xsl:otherwise>
|
---|
652 | </xsl:choose>
|
---|
653 | </xsl:otherwise>
|
---|
654 | </xsl:choose>
|
---|
655 | </xsl:template>
|
---|
656 |
|
---|
657 | <xsl:template match="personblurb|authorblurb" mode="authorsect">
|
---|
658 | <xsl:call-template name="mark.up.blurb.or.contrib"/>
|
---|
659 | <!-- * yeah, it's possible for a *blurb to have a "title" -->
|
---|
660 | <xsl:apply-templates select="title"/>
|
---|
661 | <xsl:apply-templates select="*[not(self::title)]"/>
|
---|
662 | <!-- * If this *blurb has a sibling "name" element of some kind, then -->
|
---|
663 | <!-- * the mark.up.blurb.or.contrib template will generated an "RS" -->
|
---|
664 | <!-- * call that will cause it to be indented; so we need to call -->
|
---|
665 | <!-- * "RE" to restore the previous indent level -->
|
---|
666 | <xsl:if test="../personname|../surname|../firstname
|
---|
667 | |../othername|../lineage|../honorific
|
---|
668 | |../affiliation|../email|../address">
|
---|
669 | <xsl:text>.RE </xsl:text>
|
---|
670 | </xsl:if>
|
---|
671 | </xsl:template>
|
---|
672 |
|
---|
673 | <xsl:template match="personblurb/title|authorblurb/title">
|
---|
674 | <!-- * always render period after title -->
|
---|
675 | <xsl:variable name="contents">
|
---|
676 | <xsl:apply-templates/>
|
---|
677 | </xsl:variable>
|
---|
678 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
679 | <xsl:text>.</xsl:text>
|
---|
680 | <!-- * render space after Title+period if the title is followed -->
|
---|
681 | <!-- * by something element content -->
|
---|
682 | <xsl:if test="following-sibling::*[name() != '']">
|
---|
683 | <xsl:text> </xsl:text>
|
---|
684 | </xsl:if>
|
---|
685 | </xsl:template>
|
---|
686 |
|
---|
687 | <xsl:template match="contrib" mode="authorsect">
|
---|
688 | <xsl:call-template name="mark.up.blurb.or.contrib"/>
|
---|
689 | <xsl:variable name="contents">
|
---|
690 | <xsl:apply-templates/>
|
---|
691 | </xsl:variable>
|
---|
692 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
693 | <xsl:text> </xsl:text>
|
---|
694 | <xsl:if test="../personname|../surname|../firstname
|
---|
695 | |../othername|../lineage|../honorific
|
---|
696 | |../affiliation|../email|../address">
|
---|
697 | <xsl:text>.RE </xsl:text>
|
---|
698 | </xsl:if>
|
---|
699 | </xsl:template>
|
---|
700 |
|
---|
701 | <xsl:template name="mark.up.blurb.or.contrib">
|
---|
702 | <xsl:choose>
|
---|
703 | <!-- * If this *blurb has a sibling "name" element of some kind, then -->
|
---|
704 | <!-- * we are already outputting the name content, and we need to -->
|
---|
705 | <!-- * indent the *blurb content after that. -->
|
---|
706 | <xsl:when
|
---|
707 | test="../personname|../surname|../firstname
|
---|
708 | |../othername|../lineage|../honorific
|
---|
709 | |../affiliation|../email|../address">
|
---|
710 | <xsl:text> </xsl:text>
|
---|
711 | <xsl:text>.RS</xsl:text>
|
---|
712 | <xsl:if test="not($blurb-indent = '')">
|
---|
713 | <xsl:text> </xsl:text>
|
---|
714 | <xsl:value-of select="$blurb-indent"/>
|
---|
715 | </xsl:if>
|
---|
716 | </xsl:when>
|
---|
717 | <xsl:otherwise>
|
---|
718 | <!-- * otherwise, we have no "name" content, so don't indent; -->
|
---|
719 | <!-- * instead, decide if we need a .PP or just a .br -->
|
---|
720 | <xsl:choose>
|
---|
721 | <xsl:when test="not(preceding-sibling::*)">
|
---|
722 | <!-- * if this *blurb or contrib has no preceding -->
|
---|
723 | <!-- * siblings, then we need to start a new paragraph -->
|
---|
724 | <xsl:text>.PP</xsl:text>
|
---|
725 | </xsl:when>
|
---|
726 | <xsl:otherwise>
|
---|
727 | <!-- * otherwise, this has no preceding siblings, so -->
|
---|
728 | <!-- * just put a linebreak -->
|
---|
729 | <xsl:text>.br</xsl:text>
|
---|
730 | </xsl:otherwise>
|
---|
731 | </xsl:choose>
|
---|
732 | </xsl:otherwise>
|
---|
733 | </xsl:choose>
|
---|
734 | <xsl:text> </xsl:text>
|
---|
735 | </xsl:template>
|
---|
736 |
|
---|
737 | <!-- * ============================================================== -->
|
---|
738 | <!-- * Assemble the COPYRIGHT section -->
|
---|
739 | <!-- * ============================================================== -->
|
---|
740 | <!-- * The COPYRIGHT section is output only if a copyright or -->
|
---|
741 | <!-- * legalnotice is found. It contains the copyright contents -->
|
---|
742 | <!-- * followed by the legalnotice contents. -->
|
---|
743 | <xsl:template name="copyright.section">
|
---|
744 | <xsl:param name="info"/>
|
---|
745 | <xsl:choose>
|
---|
746 | <xsl:when test="$info//copyright|$info//legalnotice">
|
---|
747 | <xsl:call-template name="make.subheading">
|
---|
748 | <xsl:with-param name="title">
|
---|
749 | <xsl:call-template name="gentext">
|
---|
750 | <xsl:with-param name="key">Copyright</xsl:with-param>
|
---|
751 | </xsl:call-template>
|
---|
752 | </xsl:with-param>
|
---|
753 | </xsl:call-template>
|
---|
754 | <xsl:text>.br </xsl:text>
|
---|
755 | <!-- * the copyright mode="titlepage.mode" template is -->
|
---|
756 | <!-- * imported from the HTML stylesheets -->
|
---|
757 | <xsl:for-each select="
|
---|
758 | (($info[//copyright])[last()]//copyright)
|
---|
759 | | (($info[//legalnotice])[last()]//legalnotice)">
|
---|
760 | <xsl:choose>
|
---|
761 | <xsl:when test="local-name(.) = 'copyright'">
|
---|
762 | <xsl:variable name="contents">
|
---|
763 | <xsl:apply-templates select="." mode="titlepage.mode"/>
|
---|
764 | </xsl:variable>
|
---|
765 | <xsl:value-of select="normalize-space($contents)"/>
|
---|
766 | <xsl:text> </xsl:text>
|
---|
767 | <xsl:text>.br </xsl:text>
|
---|
768 | </xsl:when>
|
---|
769 | <xsl:otherwise>
|
---|
770 | <xsl:apply-templates select="." mode="titlepage.mode"/>
|
---|
771 | <xsl:text> </xsl:text>
|
---|
772 | <xsl:text>.sp </xsl:text>
|
---|
773 | </xsl:otherwise>
|
---|
774 | </xsl:choose>
|
---|
775 | </xsl:for-each>
|
---|
776 | </xsl:when>
|
---|
777 | <xsl:otherwise/> <!-- * do nothing, no copyright or legalnotice found -->
|
---|
778 | </xsl:choose>
|
---|
779 | </xsl:template>
|
---|
780 |
|
---|
781 | <xsl:template match="legalnotice">
|
---|
782 | <xsl:apply-templates/>
|
---|
783 | </xsl:template>
|
---|
784 |
|
---|
785 | <!-- * ============================================================== -->
|
---|
786 |
|
---|
787 | <!-- * suppress refmeta and all *info (we grab what we need from them -->
|
---|
788 | <!-- * elsewhere) -->
|
---|
789 |
|
---|
790 | <xsl:template match="refmeta"/>
|
---|
791 |
|
---|
792 | <xsl:template match="info|refentryinfo|referenceinfo|refsynopsisdivinfo
|
---|
793 | |refsectioninfo|refsect1info|refsect2info|refsect3info
|
---|
794 | |setinfo|bookinfo|articleinfo|chapterinfo|sectioninfo
|
---|
795 | |sect1info|sect2info|sect3info|sect4info|sect5info
|
---|
796 | |partinfo|prefaceinfo|appendixinfo|docinfo"/>
|
---|
797 |
|
---|
798 | <!-- ============================================================== -->
|
---|
799 |
|
---|
800 | </xsl:stylesheet>
|
---|