source: clfs-embedded/BOOK/stylesheets/lfs-xsl/docbook-xsl-snapshot/xhtml/profile-docbook.xsl@ eb56776

Last change on this file since eb56776 was 9882b55, checked in by Manuel Canales Esparcia <manuel@…>, 17 years ago

Added the new lfs-xsl stylesheets.

  • Property mode set to 100644
File size: 17.0 KB
Line 
1<?xml version="1.0" encoding="ASCII"?>
2<!--This file was created automatically by html2xhtml-->
3<!--from the HTML stylesheets.-->
4<!--This file was created automatically by xsl2profile-->
5<!--from the DocBook XSL stylesheets.-->
6<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ng="http://docbook.org/docbook-ng" xmlns:db="http://docbook.org/ns/docbook" xmlns:exsl="http://exslt.org/common" xmlns:exslt="http://exslt.org/common" xmlns="http://www.w3.org/1999/xhtml" exslt:dummy="dummy" ng:dummy="dummy" db:dummy="dummy" extension-element-prefixes="exslt" exclude-result-prefixes="db ng exsl exslt" version="1.0">
7
8<xsl:output method="xml" encoding="UTF-8" indent="no" doctype-public="-//W3C//DTD XHTML 1.0 Transitional//EN" doctype-system="http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"/>
9
10<!-- ********************************************************************
11 $Id$
12 ********************************************************************
13
14 This file is part of the XSL DocBook Stylesheet distribution.
15 See ../README or http://docbook.sf.net/release/xsl/current/ for
16 copyright and other information.
17
18 ******************************************************************** -->
19
20<!-- ==================================================================== -->
21
22<xsl:include href="../VERSION"/>
23<xsl:include href="param.xsl"/>
24<xsl:include href="../lib/lib.xsl"/>
25<xsl:include href="../common/l10n.xsl"/>
26<xsl:include href="../common/common.xsl"/>
27<xsl:include href="../common/utility.xsl"/>
28<xsl:include href="../common/labels.xsl"/>
29<xsl:include href="../common/titles.xsl"/>
30<xsl:include href="../common/subtitles.xsl"/>
31<xsl:include href="../common/gentext.xsl"/>
32<xsl:include href="../common/targets.xsl"/>
33<xsl:include href="../common/olink.xsl"/>
34<xsl:include href="../common/pi.xsl"/>
35<xsl:include href="autotoc.xsl"/>
36<xsl:include href="autoidx.xsl"/>
37<xsl:include href="lists.xsl"/>
38<xsl:include href="callout.xsl"/>
39<xsl:include href="verbatim.xsl"/>
40<xsl:include href="graphics.xsl"/>
41<xsl:include href="xref.xsl"/>
42<xsl:include href="formal.xsl"/>
43<xsl:include href="table.xsl"/>
44<xsl:include href="htmltbl.xsl"/>
45<xsl:include href="sections.xsl"/>
46<xsl:include href="inline.xsl"/>
47<xsl:include href="footnote.xsl"/>
48<xsl:include href="html.xsl"/>
49<xsl:include href="info.xsl"/>
50<xsl:include href="keywords.xsl"/>
51<xsl:include href="division.xsl"/>
52<xsl:include href="toc.xsl"/>
53<xsl:include href="index.xsl"/>
54<xsl:include href="refentry.xsl"/>
55<xsl:include href="math.xsl"/>
56<xsl:include href="admon.xsl"/>
57<xsl:include href="component.xsl"/>
58<xsl:include href="biblio.xsl"/>
59<xsl:include href="biblio-iso690.xsl"/>
60<xsl:include href="glossary.xsl"/>
61<xsl:include href="block.xsl"/>
62<xsl:include href="task.xsl"/>
63<xsl:include href="qandaset.xsl"/>
64<xsl:include href="synop.xsl"/>
65<xsl:include href="titlepage.xsl"/>
66<xsl:include href="titlepage.templates.xsl"/>
67<xsl:include href="pi.xsl"/>
68<xsl:include href="ebnf.xsl"/>
69<xsl:include href="chunker.xsl"/>
70<xsl:include href="html-rtf.xsl"/>
71<xsl:include href="annotations.xsl"/>
72<xsl:include href="../common/stripns.xsl"/>
73
74<xsl:param name="stylesheet.result.type" select="'xhtml'"/>
75<xsl:param name="htmlhelp.output" select="0"/>
76
77<!-- ==================================================================== -->
78
79<xsl:key name="id" match="*" use="@id|@xml:id"/>
80<xsl:key name="gid" match="*" use="generate-id()"/>
81
82<!-- ==================================================================== -->
83
84<xsl:template match="*">
85 <xsl:message>
86 <xsl:text>Element </xsl:text>
87 <xsl:value-of select="local-name(.)"/>
88 <xsl:text> in namespace '</xsl:text>
89 <xsl:value-of select="namespace-uri(.)"/>
90 <xsl:text>' encountered</xsl:text>
91 <xsl:if test="parent::*">
92 <xsl:text> in </xsl:text>
93 <xsl:value-of select="name(parent::*)"/>
94 </xsl:if>
95 <xsl:text>, but no template matches.</xsl:text>
96 </xsl:message>
97
98 <span xmlns:saxon="http://icl.com/saxon" class="ERROR">
99 <xsl:text>&lt;</xsl:text>
100 <xsl:value-of select="name(.)"/>
101 <xsl:text>&gt;</xsl:text>
102 <xsl:apply-templates/>
103 <xsl:text>&lt;/</xsl:text>
104 <xsl:value-of select="name(.)"/>
105 <xsl:text>&gt;</xsl:text>
106 </span>
107</xsl:template>
108
109<xsl:template match="text()">
110 <xsl:value-of select="."/>
111</xsl:template>
112
113<xsl:template name="body.attributes">
114<!-- no apply-templates; make it empty -->
115</xsl:template>
116
117<xsl:template name="head.content">
118 <xsl:param name="node" select="."/>
119 <xsl:param name="title">
120 <xsl:apply-templates select="$node" mode="object.title.markup.textonly"/>
121 </xsl:param>
122
123 <title>
124 <xsl:copy-of select="$title"/>
125 </title>
126
127 <xsl:if test="$html.stylesheet != ''">
128 <xsl:call-template name="output.html.stylesheets">
129 <xsl:with-param name="stylesheets" select="normalize-space($html.stylesheet)"/>
130 </xsl:call-template>
131 </xsl:if>
132
133 <xsl:if test="$link.mailto.url != ''">
134 <link rev="made" href="{$link.mailto.url}"/>
135 </xsl:if>
136
137 <xsl:if test="$html.base != ''">
138 <base href="{$html.base}"/>
139 </xsl:if>
140
141 <meta name="generator" content="DocBook {$DistroTitle} V{$VERSION}"/>
142
143 <xsl:if test="$generate.meta.abstract != 0">
144 <xsl:variable name="info" select="(articleinfo |bookinfo |prefaceinfo |chapterinfo |appendixinfo |sectioninfo |sect1info |sect2info |sect3info |sect4info |sect5info |referenceinfo |refentryinfo |partinfo |info |docinfo)[1]"/>
145 <xsl:if test="$info and $info/abstract">
146 <meta name="description">
147 <xsl:attribute name="content">
148 <xsl:for-each select="$info/abstract[1]/*">
149 <xsl:value-of select="normalize-space(.)"/>
150 <xsl:if test="position() &lt; last()">
151 <xsl:text> </xsl:text>
152 </xsl:if>
153 </xsl:for-each>
154 </xsl:attribute>
155 </meta>
156 </xsl:if>
157 </xsl:if>
158
159 <xsl:if test="($draft.mode = 'yes' or ($draft.mode = 'maybe' and ancestor-or-self::*[@status][1]/@status = 'draft')) and $draft.watermark.image != ''">
160 <style type="text/css"><xsl:text>
161body { background-image: url('</xsl:text>
162<xsl:value-of select="$draft.watermark.image"/><xsl:text>');
163 background-repeat: no-repeat;
164 background-position: top left;
165 /* The following properties make the watermark "fixed" on the page. */
166 /* I think that's just a bit too distracting for the reader... */
167 /* background-attachment: fixed; */
168 /* background-position: center center; */
169 }</xsl:text>
170 </style>
171 </xsl:if>
172 <xsl:apply-templates select="." mode="head.keywords.content"/>
173</xsl:template>
174
175<xsl:template name="output.html.stylesheets">
176 <xsl:param name="stylesheets" select="''"/>
177
178 <xsl:choose>
179 <xsl:when test="contains($stylesheets, ' ')">
180 <link rel="stylesheet" href="{substring-before($stylesheets, ' ')}">
181 <xsl:if test="$html.stylesheet.type != ''">
182 <xsl:attribute name="type">
183 <xsl:value-of select="$html.stylesheet.type"/>
184 </xsl:attribute>
185 </xsl:if>
186 </link>
187 <xsl:call-template name="output.html.stylesheets">
188 <xsl:with-param name="stylesheets" select="substring-after($stylesheets, ' ')"/>
189 </xsl:call-template>
190 </xsl:when>
191 <xsl:when test="$stylesheets != ''">
192 <link rel="stylesheet" href="{$stylesheets}">
193 <xsl:if test="$html.stylesheet.type != ''">
194 <xsl:attribute name="type">
195 <xsl:value-of select="$html.stylesheet.type"/>
196 </xsl:attribute>
197 </xsl:if>
198 </link>
199 </xsl:when>
200 </xsl:choose>
201</xsl:template>
202
203<!-- ============================================================ -->
204
205<xsl:template match="*" mode="head.keywords.content">
206 <xsl:apply-templates select="chapterinfo/keywordset" mode="html.header"/>
207 <xsl:apply-templates select="appendixinfo/keywordset" mode="html.header"/>
208 <xsl:apply-templates select="prefaceinfo/keywordset" mode="html.header"/>
209 <xsl:apply-templates select="bookinfo/keywordset" mode="html.header"/>
210 <xsl:apply-templates select="setinfo/keywordset" mode="html.header"/>
211 <xsl:apply-templates select="articleinfo/keywordset" mode="html.header"/>
212 <xsl:apply-templates select="artheader/keywordset" mode="html.header"/>
213 <xsl:apply-templates select="sect1info/keywordset" mode="html.header"/>
214 <xsl:apply-templates select="sect2info/keywordset" mode="html.header"/>
215 <xsl:apply-templates select="sect3info/keywordset" mode="html.header"/>
216 <xsl:apply-templates select="sect4info/keywordset" mode="html.header"/>
217 <xsl:apply-templates select="sect5info/keywordset" mode="html.header"/>
218 <xsl:apply-templates select="sectioninfo/keywordset" mode="html.header"/>
219 <xsl:apply-templates select="refsect1info/keywordset" mode="html.header"/>
220 <xsl:apply-templates select="refsect2info/keywordset" mode="html.header"/>
221 <xsl:apply-templates select="refsect3info/keywordset" mode="html.header"/>
222 <xsl:apply-templates select="bibliographyinfo/keywordset" mode="html.header"/>
223 <xsl:apply-templates select="glossaryinfo/keywordset" mode="html.header"/>
224 <xsl:apply-templates select="indexinfo/keywordset" mode="html.header"/>
225 <xsl:apply-templates select="refentryinfo/keywordset" mode="html.header"/>
226 <xsl:apply-templates select="partinfo/keywordset" mode="html.header"/>
227 <xsl:apply-templates select="referenceinfo/keywordset" mode="html.header"/>
228 <xsl:apply-templates select="docinfo/keywordset" mode="html.header"/>
229 <xsl:apply-templates select="info/keywordset" mode="html.header"/>
230
231 <xsl:if test="$inherit.keywords != 0 and parent::*">
232 <xsl:apply-templates select="parent::*" mode="head.keywords.content"/>
233 </xsl:if>
234</xsl:template>
235
236<!-- ============================================================ -->
237
238<xsl:template name="system.head.content">
239 <xsl:param name="node" select="."/>
240
241 <!-- FIXME: When chunking, only the annotations actually used
242 in this chunk should be referenced. I don't think it
243 does any harm to reference them all, but it adds
244 unnecessary bloat to each chunk. -->
245 <xsl:if test="$annotation.support != 0 and //annotation">
246 <xsl:call-template name="add.annotation.links"/>
247 <script type="text/javascript">
248 <xsl:text>
249// Create PopupWindow objects</xsl:text>
250 <xsl:for-each select="//annotation">
251 <xsl:text>
252var popup_</xsl:text>
253 <xsl:value-of select="generate-id(.)"/>
254 <xsl:text> = new PopupWindow("popup-</xsl:text>
255 <xsl:value-of select="generate-id(.)"/>
256 <xsl:text>");
257</xsl:text>
258 <xsl:text>popup_</xsl:text>
259 <xsl:value-of select="generate-id(.)"/>
260 <xsl:text>.offsetY = 15;
261</xsl:text>
262 <xsl:text>popup_</xsl:text>
263 <xsl:value-of select="generate-id(.)"/>
264 <xsl:text>.autoHide();
265</xsl:text>
266 </xsl:for-each>
267 </script>
268
269 <style type="text/css">
270 <xsl:value-of select="$annotation.css"/>
271 </style>
272 </xsl:if>
273
274 <!-- system.head.content is like user.head.content, except that
275 it is called before head.content. This is important because it
276 means, for example, that <style> elements output by system.head.content
277 have a lower CSS precedence than the users stylesheet. -->
278</xsl:template>
279
280<!-- ============================================================ -->
281
282<xsl:template name="user.preroot">
283 <!-- Pre-root output, can be used to output comments and PIs. -->
284 <!-- This must not output any element content! -->
285</xsl:template>
286
287<xsl:template name="user.head.content">
288 <xsl:param name="node" select="."/>
289</xsl:template>
290
291<xsl:template name="user.header.navigation">
292 <xsl:param name="node" select="."/>
293</xsl:template>
294
295<xsl:template name="user.header.content">
296 <xsl:param name="node" select="."/>
297</xsl:template>
298
299<xsl:template name="user.footer.content">
300 <xsl:param name="node" select="."/>
301</xsl:template>
302
303<xsl:template name="user.footer.navigation">
304 <xsl:param name="node" select="."/>
305</xsl:template>
306
307<xslo:include xmlns:xslo="http://www.w3.org/1999/XSL/Transform" href="../profiling/profile-mode.xsl"/><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-content"><xslo:choose><xslo:when test="*/self::ng:* or */self::db:*"><xslo:message>Note: namesp. cut : stripped namespace before processing</xslo:message><xslo:variable name="stripped-content"><xslo:apply-templates select="/" mode="stripNS"/></xslo:variable><xslo:message>Note: namesp. cut : processing stripped document</xslo:message><xslo:apply-templates select="exslt:node-set($stripped-content)" mode="profile"/></xslo:when><xslo:otherwise><xslo:apply-templates select="/" mode="profile"/></xslo:otherwise></xslo:choose></xslo:variable><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-nodes" select="exslt:node-set($profiled-content)"/><xsl:template match="/">
308 <!-- * Get a title for current doc so that we let the user -->
309 <!-- * know what document we are processing at this point. -->
310 <xsl:variable name="doc.title">
311 <xsl:call-template name="get.doc.title"/>
312 </xsl:variable>
313 <xsl:choose>
314 <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
315 toss the namespace and continue. Use the docbook5 namespaced
316 stylesheets for DocBook5 if you don't want to use this feature.-->
317 <!-- include extra test for Xalan quirk -->
318 <xsl:when test="false()"/>
319 <!-- Can't process unless namespace removed -->
320 <xsl:when test="false()"/>
321 <xsl:otherwise>
322 <xsl:choose>
323 <xsl:when test="$rootid != ''">
324 <xsl:choose>
325 <xsl:when test="count($profiled-nodes//*[@id=$rootid]) = 0">
326 <xsl:message terminate="yes">
327 <xsl:text>ID '</xsl:text>
328 <xsl:value-of select="$rootid"/>
329 <xsl:text>' not found in document.</xsl:text>
330 </xsl:message>
331 </xsl:when>
332 <xsl:otherwise>
333 <xsl:if test="$collect.xref.targets = 'yes' or $collect.xref.targets = 'only'">
334 <xsl:apply-templates select="key('id', $rootid)" mode="collect.targets"/>
335 </xsl:if>
336 <xsl:if test="$collect.xref.targets != 'only'">
337 <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid]" mode="process.root"/>
338 <xsl:if test="$tex.math.in.alt != ''">
339 <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid]" mode="collect.tex.math"/>
340 </xsl:if>
341 </xsl:if>
342 </xsl:otherwise>
343 </xsl:choose>
344 </xsl:when>
345 <xsl:otherwise>
346 <xsl:if test="$collect.xref.targets = 'yes' or $collect.xref.targets = 'only'">
347 <xsl:apply-templates select="$profiled-nodes" mode="collect.targets"/>
348 </xsl:if>
349 <xsl:if test="$collect.xref.targets != 'only'">
350 <xsl:apply-templates select="$profiled-nodes" mode="process.root"/>
351 <xsl:if test="$tex.math.in.alt != ''">
352 <xsl:apply-templates select="$profiled-nodes" mode="collect.tex.math"/>
353 </xsl:if>
354 </xsl:if>
355 </xsl:otherwise>
356 </xsl:choose>
357 </xsl:otherwise>
358 </xsl:choose>
359</xsl:template>
360
361<xsl:template match="*" mode="process.root">
362 <xsl:variable name="doc" select="self::*"/>
363
364 <xsl:call-template name="user.preroot"/>
365 <xsl:call-template name="root.messages"/>
366
367 <html>
368 <head>
369 <xsl:call-template name="system.head.content">
370 <xsl:with-param name="node" select="$doc"/>
371 </xsl:call-template>
372 <xsl:call-template name="head.content">
373 <xsl:with-param name="node" select="$doc"/>
374 </xsl:call-template>
375 <xsl:call-template name="user.head.content">
376 <xsl:with-param name="node" select="$doc"/>
377 </xsl:call-template>
378 </head>
379 <body>
380 <xsl:call-template name="body.attributes"/>
381 <xsl:call-template name="user.header.content">
382 <xsl:with-param name="node" select="$doc"/>
383 </xsl:call-template>
384 <xsl:apply-templates select="."/>
385 <xsl:call-template name="user.footer.content">
386 <xsl:with-param name="node" select="$doc"/>
387 </xsl:call-template>
388 </body>
389 </html>
390 <xsl:value-of select="$html.append"/>
391</xsl:template>
392
393<xsl:template name="root.messages">
394 <!-- redefine this any way you'd like to output messages -->
395 <!-- DO NOT OUTPUT ANYTHING FROM THIS TEMPLATE -->
396</xsl:template>
397
398<!-- ==================================================================== -->
399
400<xsl:template name="chunk">
401 <xsl:param name="node" select="."/>
402
403 <!-- The default is that we are not chunking... -->
404 <xsl:text>0</xsl:text>
405</xsl:template>
406
407<!-- ==================================================================== -->
408
409</xsl:stylesheet>
Note: See TracBrowser for help on using the repository browser.