1 <?xml version='
1.0'
encoding=
"UTF-8"?>
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
19 <xsl:stylesheet version=
"1.0" xmlns:
style=
"http://openoffice.org/2000/style" xmlns:
text=
"http://openoffice.org/2000/text" xmlns:
office=
"http://openoffice.org/2000/office" xmlns:
table=
"http://openoffice.org/2000/table" xmlns:
draw=
"http://openoffice.org/2000/drawing" xmlns:
fo=
"http://www.w3.org/1999/XSL/Format" xmlns:
xlink=
"http://www.w3.org/1999/xlink" xmlns:
dc=
"http://purl.org/dc/elements/1.1/" xmlns:
meta=
"http://openoffice.org/2000/meta" xmlns:
number=
"http://openoffice.org/2000/datastyle" xmlns:
svg=
"http://www.w3.org/2000/svg" xmlns:
chart=
"http://openoffice.org/2000/chart" xmlns:
dr3d=
"http://openoffice.org/2000/dr3d" xmlns:
math=
"http://www.w3.org/1998/Math/MathML" xmlns:
form=
"http://openoffice.org/2000/form" xmlns:
script=
"http://openoffice.org/2000/script" xmlns:
config=
"http://openoffice.org/2001/config" office:
class=
"text" xmlns:
xsl=
"http://www.w3.org/1999/XSL/Transform" exclude-result-prefixes=
"office meta table number dc fo xlink chart math script xsl draw svg dr3d form config text style">
20 <xsl:output method=
"xml" indent=
"yes" omit-xml-declaration=
"no" version=
"1.0" encoding=
"UTF-8" doctype-public=
"-//OASIS//DTD DocBook XML V4.1.2//EN" doctype-system=
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"/>
23 <!-- Heading will be mapped to sections.
24 In OpenDocument headings are not nested, they do not embrace their related content, the XML hierarchy has to be restructured.
26 Example of OpenDocument content:
29 <text:h text:style-name="Heading 1" text:level="1">Heading 1</text:h>
30 <text:p text:style-name="Text body">Heading 1 Content</text:p>
31 <text:h text:style-name="Heading 2" text:level="2">Heading 2</text:h>
32 <text:p text:style-name="Text body">Heading 2 Content</text:p>
35 Example of DocBook content:
37 <article lang="en-US">
39 <title>Heading 1</title>
40 <para>Heading 1 Content</para>
42 <title>Heading 2</title>
43 <para>Heading 2 Content</para>
49 <!-- The key function "nestedContent" returns all ODF elements that are children of the current heading (i.e. text:h) or their parent office:body in case there is no text:h.
50 It works by matching all ODF elements, that text:h refer to (it's sibling or office:body childring)
51 Various keyed element sets of these matched elements are being generated. A set is identified by having the same last (closest) preceding text:h or if none existent the parent document.
52 All those elements, that have the current heading as last preceding heading (text:h) are returned as a nodeset.
54 <xsl:key name=
"nestedContent"
55 match=
"text:p | table:table | text:span | text:ordered-list | office:annotation | text:unordered-list | text:footnote | text:a | text:list-item | draw:plugin | draw:text-box | text:footnote-body | text:section"
56 use=
"generate-id((.. | preceding::text:h)[last()])"/>
58 <!-- The key function "nestedHeadings" returns a nodeset of all heading (text:h) elements, which belong to this heading (follow and have a higher outline number than the current text:h, which ID is given to the function) -->
59 <xsl:key name=
"nestedHeadings"
61 use=
"generate-id(preceding::text:h[@text:level < current()/@text:level][1])"/>
63 <!-- The key function "getHeadingsByOutline" returns all headings of a certain outline level -->
64 <xsl:key name=
"getHeadingsByOutline"
68 <!-- A further problem during mapping of Heading to sections is the quantity of levels. In OpenDocument there can exist more than 4 hierarchies (outline levels).
69 Furthermore an OpenDocument have not to start with heading outline level 1 nor does an outline level 2 have to follow.
70 Therefore all possible existing heading outline levels from 1 to 10 have to be mapped to the section1 to section4 in DocBook.
71 The lowest outline number is mapped section1, second is section2... until fourth and higher are all mapped to section4 -->
73 <!-- Each global variable hold the outline level which has been mapped to one of the four sections in DocBook -->
74 <xsl:variable name=
"section1_OutlineLevel">
75 <xsl:call-template name=
"findOutlineLevel">
76 <xsl:with-param name=
"candidateOutlineLevel" select=
"1"/>
79 <xsl:variable name=
"section2_OutlineLevel">
80 <xsl:call-template name=
"findOutlineLevel">
81 <xsl:with-param name=
"candidateOutlineLevel" select=
"$section1_OutlineLevel + 1"/>
84 <xsl:variable name=
"section3_OutlineLevel">
85 <xsl:call-template name=
"findOutlineLevel">
86 <xsl:with-param name=
"candidateOutlineLevel" select=
"$section2_OutlineLevel + 1"/>
89 <xsl:variable name=
"section4_OutlineLevel">
90 <xsl:call-template name=
"findOutlineLevel">
91 <xsl:with-param name=
"candidateOutlineLevel" select=
"$section3_OutlineLevel + 1"/>
95 <!-- get the minimum available heading outline level (usually '1') -->
96 <xsl:template name=
"findOutlineLevel">
97 <xsl:param name=
"candidateOutlineLevel"/>
99 <xsl:when test=
"key('getHeadingsByOutline', $candidateOutlineLevel)[1]/@text:level != ''">
100 <xsl:value-of select=
"$candidateOutlineLevel"/>
103 <xsl:if test=
"$candidateOutlineLevel < 11">
104 <xsl:call-template name=
"findOutlineLevel">
105 <xsl:with-param name=
"candidateOutlineLevel" select=
"$candidateOutlineLevel + 1"/>
114 <xsl:template match=
"/*">
115 <xsl:element name=
"article">
116 <xsl:attribute name=
"lang">
117 <xsl:value-of select=
"/*/office:meta/dc:language"/>
119 <!-- page style header -->
120 <xsl:call-template name=
"page-style">
121 <xsl:with-param name=
"area" select=
"'header'"/>
123 <xsl:apply-templates select=
"office:body"/>
124 <!-- page style footer -->
125 <xsl:call-template name=
"page-style"/>
130 <xsl:key match=
"style:master-page" name=
"styleMasterPage" use=
"@style:name" />
131 <!-- using a simple heuristic for "standard" page-style heading/footer from page styles -->
132 <xsl:template name=
"page-style">
133 <xsl:param name=
"area"/>
135 <xsl:variable name=
"defaultPageStyle" select=
"key('styleMasterPage', 'Standard')"/>
137 <xsl:when test=
"$area = 'header'">
138 <xsl:apply-templates select=
"$defaultPageStyle/style:header/*"/>
141 <xsl:apply-templates select=
"$defaultPageStyle/style:footer/*"/>
147 <xsl:template match=
"office:body">
148 <!-- here all children of office:body before the first heading are matched -->
149 <xsl:apply-templates select=
"key('nestedContent', generate-id())"/>
150 <!-- have to be descendant as text:h can be in a list:item in some list -->
151 <xsl:variable name=
"firstHeading" select=
"descendant::text:h[1]"/>
152 <!-- changing the context node from office:body to text:h as required for used key functions -->
153 <xsl:for-each select=
"descendant::text:h[@text:level=$section1_OutlineLevel][1]">
154 <!-- if the first heading is not of the section1 level -->
155 <xsl:if test=
"generate-id(.) != generate-id($firstHeading)">
156 <!-- create an anonymous section1 and embrace all headings preceding the first real existent section1 -->
157 <xsl:element name=
"sect1">
159 <!-- create sections for all the first section1 preluding headings -->
160 <xsl:for-each select=
"key('getHeadingsByOutline', $section1_OutlineLevel)[1]/preceding::text:h">
161 <xsl:call-template name=
"make-section">
162 <xsl:with-param name=
"previousSectionLevel" select=
"$section1_OutlineLevel"/>
163 <xsl:with-param name=
"currentSectionLevel">
164 <xsl:call-template name=
"getSectionLevel">
165 <xsl:with-param name=
"outlineLevel" select=
"@text:level"/>
173 <!-- match all headings, which are mapped to section1 to create a nested section structure used in docbook (see first comment after copyright) -->
174 <xsl:apply-templates mode=
"recreateStructure" select=
"descendant::text:h[@text:level = $section1_OutlineLevel]"/>
177 <xsl:template match=
"text:h" mode=
"recreateStructure">
178 <!-- relate the current ODF outline level of the heading to one of the four docbook section levels-->
179 <xsl:variable name=
"currentSectionLevel">
180 <xsl:call-template name=
"getSectionLevel">
181 <xsl:with-param name=
"outlineLevel" select=
"@text:level"/>
185 <!-- heading with outline level 1 might be an Abstract -->
186 <xsl:when test=
"$currentSectionLevel = 1">
188 <!-- when the content of a level 1 heading is 'Abstract' the <abstract> docbook element is used instead of <section1> -->
189 <xsl:when test=
".='Abstract'">
191 <xsl:apply-templates select=
"key('nestedContent', generate-id())"/>
192 <xsl:apply-templates select=
"key('nestedHeadings', generate-id())" mode=
"recreateStructure"/>
196 <xsl:call-template name=
"make-section">
197 <xsl:with-param name=
"currentSectionLevel" select=
"$currentSectionLevel"/>
198 <xsl:with-param name=
"previousSectionLevel" select=
"$currentSectionLevel"/>
204 <xsl:variable name=
"previousHeading" select=
"preceding::text:h[@text:level < current()/@text:level][1]"/>
206 <xsl:when test=
"$previousHeading/@text:level != ''">
207 <xsl:call-template name=
"make-section">
208 <xsl:with-param name=
"currentSectionLevel" select=
"$currentSectionLevel"/>
209 <xsl:with-param name=
"previousSectionLevel">
210 <xsl:call-template name=
"getSectionLevel">
211 <xsl:with-param name=
"outlineLevel" select=
"$previousHeading/@text:level"/>
217 <xsl:call-template name=
"make-section">
218 <xsl:with-param name=
"currentSectionLevel" select=
"$currentSectionLevel"/>
219 <xsl:with-param name=
"previousSectionLevel" select=
"$currentSectionLevel"/>
227 <xsl:template match=
"text:bookmark | text:bookmark-start">
228 <xsl:element name=
"anchor">
229 <xsl:attribute name=
"id">
230 <!-- ID have to be an NCName which have to start with a letter or '_'
231 in case of the frequent starting number a '_' will be added as prefix -->
233 <xsl:when test=
"(starts-with(@text:name, '0') or
234 starts-with(@text:name, '1') or
235 starts-with(@text:name, '2') or
236 starts-with(@text:name, '3') or
237 starts-with(@text:name, '4') or
238 starts-with(@text:name, '5') or
239 starts-with(@text:name, '6') or
240 starts-with(@text:name, '7') or
241 starts-with(@text:name, '8') or
242 starts-with(@text:name, '9'))">
243 <xsl:value-of select=
"concat('_', @text:name)"/>
246 <xsl:value-of select=
"@text:name"/>
253 <xsl:template name=
"getSectionLevel">
254 <xsl:param name=
"outlineLevel"/>
256 <xsl:when test=
"$outlineLevel = $section1_OutlineLevel">1</xsl:when>
257 <xsl:when test=
"$outlineLevel = $section2_OutlineLevel">2</xsl:when>
258 <xsl:when test=
"$outlineLevel = $section3_OutlineLevel">3</xsl:when>
259 <xsl:otherwise>4</xsl:otherwise>
263 <!-- make-section creates the nested section hierarchy and
264 in case the difference between the parent section and the new section is higher than one
265 a section is inserted to keep the output format valid -->
266 <xsl:template name=
"make-section">
267 <xsl:param name=
"currentSectionLevel"/>
268 <xsl:param name=
"previousSectionLevel"/>
270 <!-- empty title as it is an empty section between two headings with an outline level difference higher than 1 -->
271 <xsl:when test=
"$currentSectionLevel > $previousSectionLevel+1">
272 <xsl:element name=
"{concat('sect', $previousSectionLevel + 1)}">
274 <xsl:call-template name=
"make-section">
275 <xsl:with-param name=
"currentSectionLevel" select=
"$currentSectionLevel"/>
276 <xsl:with-param name=
"previousSectionLevel" select=
"$previousSectionLevel +1"/>
281 <xsl:element name=
"{concat('sect', $currentSectionLevel)}">
283 <xsl:apply-templates/>
285 <xsl:apply-templates select=
"key('nestedContent', generate-id())"/>
286 <xsl:apply-templates select=
"key('nestedHeadings', generate-id())" mode=
"recreateStructure"/>
293 <xsl:template match=
"office:meta">
294 <!--<xsl:apply-templates/>--></xsl:template>
296 <xsl:template match=
"meta:editing-cycles"></xsl:template>
298 <xsl:template match=
"meta:user-defined"></xsl:template>
300 <xsl:template match=
"meta:editing-duration"></xsl:template>
302 <xsl:template match=
"dc:language"></xsl:template>
304 <xsl:template match=
"dc:date">
306 <xsl:value-of select="substring-before(.,'T')"/>
307 </pubdate>--></xsl:template>
309 <xsl:template match=
"meta:creation-date"></xsl:template>
311 <xsl:template match=
"office:styles">
312 <xsl:apply-templates/>
315 <xsl:template match=
"office:script"></xsl:template>
318 <xsl:template match=
"office:settings"></xsl:template>
320 <xsl:template match=
"office:font-decls"></xsl:template>
322 <xsl:template match=
"text:section">
324 <xsl:when test=
"@text:name='ArticleInfo'">
327 <xsl:value-of select=
"text:p[@text:style-name='Document Title']"/>
330 <xsl:value-of select=
"text:p[@text:style-name='Document SubTitle']"/>
333 <xsl:value-of select=
"text:p/text:variable-set[@text:name='articleinfo.edition']"/>
335 <xsl:for-each select=
"text:p/text:variable-set[substring-after(@text:name,'articleinfo.releaseinfo')]">
337 <xsl:value-of select=
"."/>
340 <xsl:call-template name=
"ArticleInfo">
341 <xsl:with-param name=
"level" select=
"0"/>
345 <xsl:when test=
"@text:name='Abstract'">
347 <xsl:apply-templates/>
350 <xsl:when test=
"@text:name='Appendix'">
352 <xsl:apply-templates/>
356 <xsl:element name=
"{concat('sect', count(ancestor::text:section) + 1)}">
357 <xsl:attribute name=
"id">
358 <xsl:value-of select=
"@text:name"/>
360 <xsl:apply-templates/>
366 <xsl:template name=
"ArticleInfo">
367 <xsl:param name=
"level"/>
368 <xsl:variable name=
"author">
369 <xsl:value-of select=
"concat('articleinfo.author_','', $level)"/>
371 <xsl:if test=
"text:p/text:variable-set[contains(@text:name, $author )]">
372 <xsl:call-template name=
"Author">
373 <xsl:with-param name=
"AuthorLevel" select=
"0"/>
375 <xsl:call-template name=
"Copyright">
376 <xsl:with-param name=
"CopyrightLevel" select=
"0"/>
381 <xsl:template name=
"Copyright">
382 <xsl:param name=
"CopyrightLevel"/>
384 <xsl:variable name=
"Copyright">
385 <xsl:value-of select=
"concat('articleinfo.copyright_','', $CopyrightLevel)"/>
388 <xsl:if test=
"text:p/text:variable-set[contains(@text:name,$Copyright)]">
390 <xsl:call-template name=
"Year">
391 <xsl:with-param name=
"CopyrightLevel" select=
"$CopyrightLevel"/>
392 <xsl:with-param name=
"YearlLevel" select=
"0"/>
394 <xsl:call-template name=
"Holder">
395 <xsl:with-param name=
"CopyrightLevel" select=
"$CopyrightLevel"/>
396 <xsl:with-param name=
"HolderlLevel" select=
"0"/>
404 <xsl:template name=
"Year">
405 <xsl:param name=
"CopyrightLevel"/>
406 <xsl:param name=
"YearLevel"/>
407 <xsl:variable name=
"Copyright">
408 <xsl:value-of select=
"concat('articleinfo.copyright_','', $CopyrightLevel)"/>
410 <xsl:variable name=
"Year">
411 <xsl:value-of select=
"concat($Copyright,'',concat('.year_','',$YearLevel))"/>
414 <xsl:if test=
"text:p/text:variable-set[@text:name=$Year]">
416 <xsl:value-of select=
"text:p/text:variable-set[@text:name=$Year]"/>
422 <xsl:template name=
"Holder">
423 <xsl:param name=
"CopyrightLevel"/>
424 <xsl:param name=
"HolderLevel"/>
425 <xsl:variable name=
"Copyright">
426 <xsl:value-of select=
"concat('articleinfo.copyright_','', $CopyrightLevel)"/>
428 <xsl:variable name=
"Holder">
429 <xsl:value-of select=
"concat($Copyright,'',concat('.holder_','',$HolderLevel))"/>
432 <xsl:if test=
"text:p/text:variable-set[@text:name=$Holder]">
434 <xsl:value-of select=
"text:p/text:variable-set[@text:name=$Holder]"/>
441 <xsl:template name=
"Author">
442 <xsl:param name=
"AuthorLevel"/>
443 <xsl:variable name=
"Author">
444 <xsl:value-of select=
"concat('articleinfo.author_','', $AuthorLevel)"/>
446 <xsl:if test=
"text:p/text:variable-set[contains(@text:name, $Author )]">
448 <xsl:call-template name=
"Surname">
449 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
450 <xsl:with-param name=
"SurnameLevel" select=
"0"/>
452 <xsl:call-template name=
"Firstname">
453 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
454 <xsl:with-param name=
"FirstnameLevel" select=
"0"/>
456 <xsl:call-template name=
"Affiliation">
457 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
458 <xsl:with-param name=
"AffilLevel" select=
"0"/>
461 <xsl:call-template name=
"Author">
462 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel+1"/>
468 <xsl:template name=
"Surname">
469 <xsl:param name=
"AuthorLevel"/>
470 <xsl:param name=
"SurnameLevel"/>
471 <xsl:variable name=
"Author">
472 <xsl:value-of select=
"concat('articleinfo.author_','', $AuthorLevel)"/>
474 <xsl:variable name=
"Surname">
475 <xsl:value-of select=
"concat($Author,'',concat('.surname_','',$SurnameLevel))"/>
477 <xsl:if test=
"text:p/text:variable-set[@text:name=$Surname]">
479 <xsl:value-of select=
"text:p/text:variable-set[@text:name=$Surname]"/>
481 <xsl:call-template name=
"Surname">
482 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
483 <xsl:with-param name=
"SurnameLevel" select=
"SurnameLevel+1"/>
492 <xsl:template name=
"Firstname">
493 <xsl:param name=
"AuthorLevel"/>
494 <xsl:param name=
"FirstnameLevel"/>
495 <xsl:variable name=
"Author">
496 <xsl:value-of select=
"concat('articleinfo.author_','', $AuthorLevel)"/>
498 <xsl:variable name=
"Firstname">
499 <xsl:value-of select=
"concat($Author,'',concat('.firstname_','',$FirstnameLevel))"/>
501 <xsl:if test=
"text:p/text:variable-set[@text:name=$Firstname]">
503 <xsl:value-of select=
"text:p/text:variable-set[@text:name=$Firstname]"/>
505 <xsl:call-template name=
"Surname">
506 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
507 <xsl:with-param name=
"FirstnameLevel" select=
"FirstnameLevel+1"/>
514 <xsl:template name=
"Affiliation">
515 <xsl:param name=
"AuthorLevel"/>
516 <xsl:param name=
"AffilLevel"/>
517 <xsl:variable name=
"Author">
518 <xsl:value-of select=
"concat('articleinfo.author_','', $AuthorLevel)"/>
520 <xsl:variable name=
"Affil">
521 <xsl:value-of select=
"concat($Author,'',concat('.affiliation_','',$AffilLevel))"/>
523 <xsl:if test=
"text:p/text:variable-set[contains(@text:name,$Affil)]">
525 <xsl:call-template name=
"Orgname">
526 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
527 <xsl:with-param name=
"AffilLevel" select=
"$AffilLevel"/>
528 <xsl:with-param name=
"OrgLevel" select=
"0"/>
530 <xsl:call-template name=
"Address">
531 <xsl:with-param name=
"AuthorLevel" select=
"$AuthorLevel"/>
532 <xsl:with-param name=
"AffilLevel" select=
"$AffilLevel"/>
533 <xsl:with-param name=
"AddressLevel" select=
"0"/>
540 <xsl:template name=
"Orgname">
541 <xsl:param name=
"AuthorLevel"/>
542 <xsl:param name=
"AffilLevel"/>
543 <xsl:param name=
"OrgLevel"/>
545 <xsl:variable name=
"Author">
546 <xsl:value-of select=
"concat('articleinfo.author_','', $AuthorLevel)"/>
548 <xsl:variable name=
"Affil">
549 <xsl:value-of select=
"concat($Author,'',concat('.affiliation_','',$AffilLevel))"/>
551 <xsl:variable name=
"Org">
552 <xsl:value-of select=
"concat($Affil,'',concat('.orgname_','',$OrgLevel))"/>
555 <xsl:if test=
"text:p/text:variable-set[@text:name=$Org]">
557 <xsl:value-of select=
"text:p/text:variable-set[@text:name=$Org]"/>
562 <xsl:template name=
"Address">
563 <xsl:param name=
"AuthorLevel"/>
564 <xsl:param name=
"AffilLevel"/>
565 <xsl:param name=
"AddressLevel"/>
567 <xsl:variable name=
"Author">
568 <xsl:value-of select=
"concat('articleinfo.author_','', $AuthorLevel)"/>
570 <xsl:variable name=
"Affil">
571 <xsl:value-of select=
"concat($Author,'',concat('.affiliation_','',$AffilLevel))"/>
573 <xsl:variable name=
"Address">
574 <xsl:value-of select=
"concat($Affil,'',concat('.address_','',$AddressLevel))"/>
577 <xsl:if test=
"text:p/text:variable-set[@text:name=$Address]">
579 <xsl:value-of select=
"text:p/text:variable-set[@text:name=$Address]"/>
587 <xsl:template match=
"text:p[@text:style-name='Document Title']"></xsl:template>
589 <xsl:template match=
"text:p[@text:style-name='Document SubTitle']"></xsl:template>
592 <xsl:template match=
"text:p[@text:style-name='Section Title']">
593 <xsl:element name=
"title">
594 <xsl:apply-templates/>
598 <xsl:template match=
"text:p[@text:style-name='Appendix Title']">
599 <xsl:element name=
"title">
600 <xsl:apply-templates/>
605 <!--<xsl:template match="text:p[@text:style-name='VarList Item']">
606 <xsl:if test="not(preceding-sibling::text:p[@text:style-name='VarList Item'])">
607 <xsl:text disable-output-escaping="yes"><listitem></xsl:text>
610 <xsl:apply-templates/>
612 <xsl:if test="not(following-sibling::text:p[@text:style-name='VarList Item'])">
613 <xsl:text disable-output-escaping="yes"></listitem></xsl:text>
618 <xsl:template match=
"text:p[@text:style-name='Section1 Title']">
619 <xsl:element name=
"title">
620 <xsl:apply-templates/>
625 <xsl:template match=
"text:p[@text:style-name='Section2 Title']">
626 <xsl:element name=
"title">
627 <xsl:apply-templates/>
632 <xsl:template match=
"text:p[@text:style-name='Section3 Title']">
633 <xsl:element name=
"title">
634 <xsl:apply-templates/>
638 <xsl:template match=
"text:footnote-citation"></xsl:template>
640 <xsl:template match=
"text:p[@text:style-name='Mediaobject']">
642 <xsl:apply-templates/>
646 <xsl:template match=
"office:annotation/text:p">
649 <xsl:apply-templates/>
654 <!--<xsl:template match="meta:initial-creator">
656 <xsl:apply-templates />
660 <xsl:template match=
"table:table">
662 <xsl:when test=
"following-sibling::text:p[@text:style-name='Table']">
664 <xsl:attribute name=
"id">
665 <xsl:value-of select=
"@table:name"/>
668 <xsl:value-of select=
"following-sibling::text:p[@text:style-name='Table']"/>
670 <xsl:call-template name=
"generictable"/>
674 <informaltable frame=
"all">
675 <xsl:call-template name=
"generictable"/>
682 <xsl:template name=
"generictable">
683 <xsl:variable name=
"cells" select=
"count(descendant::table:table-cell)"></xsl:variable>
684 <xsl:variable name=
"rows">
685 <xsl:value-of select=
"count(descendant::table:table-row)"/>
687 <xsl:variable name=
"cols">
688 <xsl:value-of select=
"$cells div $rows"/>
690 <xsl:variable name=
"numcols">
692 <xsl:when test=
"child::table:table-column/@table:number-columns-repeated">
693 <xsl:value-of select=
"number(table:table-column/@table:number-columns-repeated+1)"/>
696 <xsl:value-of select=
"$cols"/>
700 <xsl:element name=
"tgroup">
701 <xsl:attribute name=
"cols">
702 <xsl:value-of select=
"$numcols"/>
704 <xsl:call-template name=
"colspec">
705 <xsl:with-param name=
"left" select=
"1"/>
707 <xsl:apply-templates/>
711 <xsl:template name=
"colspec">
712 <xsl:param name=
"left"/>
713 <xsl:if test=
"number($left < ( table:table-column/@table:number-columns-repeated +2) )">
714 <xsl:element name=
"colspec">
715 <xsl:attribute name=
"colnum">
716 <xsl:value-of select=
"$left"/>
718 <xsl:attribute name=
"colname">c
<xsl:value-of select=
"$left"/>
721 <xsl:call-template name=
"colspec">
722 <xsl:with-param name=
"left" select=
"$left+1"/>
727 <xsl:template match=
"table:table-column">
728 <xsl:apply-templates/>
731 <xsl:template match=
"table:table-header-rows">
733 <xsl:apply-templates/>
737 <xsl:template match=
"table:table-header-rows/table:table-row">
739 <xsl:apply-templates/>
743 <xsl:template match=
"table:table/table:table-row">
744 <xsl:if test=
"not(preceding-sibling::table:table-row)">
745 <xsl:text disable-output-escaping=
"yes"><tbody
></xsl:text>
748 <xsl:apply-templates/>
750 <xsl:if test=
"not(following-sibling::table:table-row)">
751 <xsl:text disable-output-escaping=
"yes"></tbody
></xsl:text>
755 <xsl:template match=
"table:table-cell">
756 <xsl:element name=
"entry">
757 <xsl:if test=
"@table:number-columns-spanned >'1'">
758 <xsl:attribute name=
"namest">
759 <xsl:value-of select=
"concat('c',count(preceding-sibling::table:table-cell[not(@table:number-columns-spanned)]) +sum(preceding-sibling::table:table-cell/@table:number-columns-spanned)+1)"/>
761 <xsl:attribute name=
"nameend">
762 <xsl:value-of select=
"concat('c',count(preceding-sibling::table:table-cell[not(@table:number-columns-spanned)]) +sum(preceding-sibling::table:table-cell/@table:number-columns-spanned)+ @table:number-columns-spanned)"/>
765 <xsl:apply-templates/>
769 <xsl:template match=
"text:p">
771 <xsl:when test=
"@text:style-name='Table'"></xsl:when>
774 <xsl:apply-templates/>
780 <xsl:key match=
"text:list-style" name=
"getListStyle" use=
"@style:name"/>
782 <xsl:template match=
"text:ordered-list">
783 <xsl:param name=
"outlineLevel" select=
"1"/>
785 <xsl:variable name=
"listStyle" select=
"key('getListStyle', @text:style-name)/*[@text:level = $outlineLevel]"/>
787 <!-- if the list is not recognizable as a list (e.g. no indent, number/bullet, etc.) the list will be ignored -->
788 <xsl:if test=
"$listStyle/style:properties/@*">
790 <xsl:apply-templates>
791 <xsl:with-param name=
"itemType" select=
"'listitem'"/>
792 <xsl:with-param name=
"outlineLevel" select=
"$outlineLevel + 1"/>
793 </xsl:apply-templates>
798 <xsl:template match=
"text:unordered-list">
799 <xsl:param name=
"outlineLevel" select=
"1"/>
801 <xsl:variable name=
"listStyle" select=
"key('getListStyle', @text:style-name)/*[@text:level = $outlineLevel]"/>
802 <!-- if the list is not recognizable as a list (e.g. no indent, number/bullet, etc.) the list will be ignored -->
803 <xsl:if test=
"$listStyle/style:properties/@*">
805 <xsl:when test=
"@text:style-name='Var List'">
807 <xsl:apply-templates>
808 <xsl:with-param name=
"itemType" select=
"'varlist'"/>
809 <xsl:with-param name=
"outlineLevel" select=
"$outlineLevel + 1"/>
810 </xsl:apply-templates>
815 <xsl:apply-templates>
816 <xsl:with-param name=
"itemType" select=
"'listitem'"/>
817 <xsl:with-param name=
"outlineLevel" select=
"$outlineLevel + 1"/>
818 </xsl:apply-templates>
825 <xsl:template match=
"text:list-item | text:list-header">
826 <xsl:param name=
"listType"/>
827 <xsl:param name=
"outlineLevel"/>
830 <xsl:when test=
"$listType='Var List'">
831 <xsl:element name=
"varlistentry">
832 <xsl:apply-templates>
833 <xsl:with-param name=
"outlineLevel" select=
"$outlineLevel"/>
834 </xsl:apply-templates>
838 <xsl:element name=
"listitem">
839 <xsl:apply-templates>
840 <xsl:with-param name=
"outlineLevel" select=
"$outlineLevel"/>
841 </xsl:apply-templates>
847 <xsl:template match=
"text:p[@text:style-name='VarList Term']">
848 <xsl:element name=
"term">
849 <xsl:apply-templates/>
853 <xsl:template match=
"text:p[@text:style-name='VarList Item']">
854 <xsl:element name=
"para">
855 <xsl:apply-templates/>
859 <!-- text headings should only be matched once, when creating a nested docbook section structure, but might be as well become as part of a list a title -->
860 <xsl:template match=
"text:h">
862 <xsl:apply-templates/>
866 <xsl:template match=
"dc:title"></xsl:template>
868 <xsl:template match=
"dc:description">
871 <xsl:apply-templates/>
876 <xsl:template match=
"dc:subject"></xsl:template>
879 <xsl:template match=
"meta:generator"></xsl:template>
881 <xsl:template match=
"draw:plugin">
882 <xsl:element name=
"audioobject">
883 <xsl:attribute name=
"fileref">
884 <xsl:value-of select=
"@xlink:href"/>
886 <xsl:attribute name=
"width"></xsl:attribute>
890 <xsl:template match=
"text:footnote">
892 <xsl:apply-templates/>
896 <xsl:template match=
"text:footnote-body">
897 <xsl:apply-templates/>
901 <xsl:template match=
"draw:text-box"></xsl:template>
905 <xsl:template match=
"draw:image">
907 <xsl:when test=
"parent::text:p[@text:style-name='Mediaobject']">
908 <xsl:element name=
"imageobject">
909 <xsl:element name=
"imagedata">
910 <xsl:attribute name=
"fileref">
911 <xsl:value-of select=
"@xlink:href"/>
914 <xsl:element name=
"caption">
915 <xsl:value-of select=
"."/>
920 <xsl:element name=
"inlinegraphic">
921 <xsl:attribute name=
"fileref">
923 <xsl:when test=
"@xlink:href != ''">
924 <xsl:value-of select=
"@xlink:href"/>
927 <xsl:text>embedded:
</xsl:text>
928 <xsl:value-of select=
"@draw:name"/>
932 <xsl:attribute name=
"width">
933 <xsl:value-of select=
"@svg:width"/>
935 <xsl:attribute name=
"depth">
936 <xsl:value-of select=
"@svg:height"/>
944 <xsl:template match=
"text:span">
946 <xsl:when test=
"./@text:style-name='GuiMenu'">
947 <xsl:element name=
"guimenu">
948 <xsl:value-of select=
"."/>
951 <xsl:when test=
"./@text:style-name='GuiSubMenu'">
952 <xsl:element name=
"guisubmenu">
953 <xsl:value-of select=
"."/>
956 <xsl:when test=
"@text:style-name='GuiMenuItem'">
957 <xsl:element name=
"guimenuitem">
958 <xsl:value-of select=
"."/>
961 <xsl:when test=
"@text:style-name='GuiButton'">
962 <xsl:element name=
"guibutton">
963 <xsl:value-of select=
"."/>
966 <xsl:when test=
"@text:style-name='GuiButton'">
967 <xsl:element name=
"guibutton">
968 <xsl:value-of select=
"."/>
971 <xsl:when test=
"@text:style-name='GuiLabel'">
972 <xsl:element name=
"guilabel">
973 <xsl:value-of select=
"."/>
976 <xsl:when test=
"@text:style-name='Emphasis'">
977 <xsl:element name=
"emphasis">
978 <xsl:value-of select=
"."/>
981 <xsl:when test=
"@text:style-name='FileName'">
982 <xsl:element name=
"filename">
983 <xsl:value-of select=
"."/>
986 <xsl:when test=
"@text:style-name='Application'">
987 <xsl:element name=
"application">
988 <xsl:value-of select=
"."/>
991 <xsl:when test=
"@text:style-name='Command'">
993 <xsl:apply-templates/>
996 <xsl:when test=
"@text:style-name='SubScript'">
998 <xsl:apply-templates/>
1001 <xsl:when test=
"@text:style-name='SuperScript'">
1003 <xsl:apply-templates/>
1006 <xsl:when test=
"@text:style-name='SystemItem'">
1008 <xsl:apply-templates/>
1011 <xsl:when test=
"@text:style-name='ComputerOutput'">
1013 <xsl:apply-templates/>
1016 <xsl:when test=
"@text:style-name='Highlight'">
1018 <xsl:apply-templates/>
1021 <xsl:when test=
"@text:style-name='KeyCap'">
1023 <xsl:apply-templates/>
1026 <xsl:when test=
"@text:style-name='KeySym'">
1027 <xsl:element name=
"keysym">
1028 <xsl:apply-templates/>
1031 <xsl:when test=
"@text:style-name='KeyCombo'">
1033 <xsl:apply-templates/>
1037 <xsl:apply-templates/>
1044 <xsl:template match=
"text:a">
1046 <xsl:when test=
"contains(@xlink:href,'://')">
1047 <xsl:element name=
"ulink">
1048 <xsl:attribute name=
"url">
1049 <xsl:value-of select=
"@xlink:href"/>
1051 <xsl:apply-templates/>
1054 <xsl:when test=
"contains(@xlink:href,'mailto:')">
1055 <xsl:element name=
"ulink">
1056 <xsl:attribute name=
"url">
1057 <xsl:value-of select=
"@xlink:href"/>
1059 <xsl:apply-templates/>
1062 <xsl:when test=
"not(contains(@xlink:href,'#'))">
1063 <xsl:element name=
"olink">
1064 <xsl:attribute name=
"targetdocent">
1065 <xsl:value-of select=
"@xlink:href"/>
1067 <xsl:apply-templates/>
1071 <xsl:variable name=
"linkvar" select=
"substring-after(@xlink:href,'#')"/>
1072 <xsl:element name=
"link">
1073 <xsl:attribute name=
"linkend">
1074 <xsl:value-of select=
"substring-before($linkvar,'%')"/>
1076 <xsl:apply-templates/>
1083 Change Made By Kevin Fowlks (fowlks@msu.edu) July 2nd, 2003
1084 This allows users to create example code in DocBook.
1086 Note: This type of grouping could also be implemented for
1087 <notes>,<literallayout>, <blockquote> or any other tag that requires text to be treated as blocked.
1089 <xsl:template match=
"text:p[@text:style-name='Example']">
1090 <xsl:if test=
"not(preceding-sibling::*[1][self::text:p[@text:style-name='Example']])">
1091 <xsl:element name=
"example">
1092 <xsl:element name=
"title"></xsl:element>
1093 <xsl:element name=
"programlisting">
1094 <xsl:value-of select=
"."/>
1095 <xsl:text disable-output-escaping=
"no">
</xsl:text>
1096 <xsl:apply-templates mode=
"in-list" select=
"following-sibling::*[1][self::text:p[@text:style-name='Example']]"/>
1102 <xsl:template match=
"text:p[@text:style-name='Example']" mode=
"in-list">
1103 <xsl:value-of select=
"."/>
1104 <xsl:text disable-output-escaping=
"no">
</xsl:text>
1105 <xsl:apply-templates mode=
"in-list" select=
"following-sibling::*[1][self::text:p[@text:style-name='Example']]"/>
1108 <!-- ****************** -->
1109 <!-- *** Whitespace *** -->
1110 <!-- ****************** -->
1112 <xsl:template match=
"text:s">
1113 <xsl:call-template name=
"write-breakable-whitespace">
1114 <xsl:with-param name=
"whitespaces" select=
"@text:c"/>
1115 </xsl:call-template>
1119 <!--write the number of 'whitespaces' -->
1120 <xsl:template name=
"write-breakable-whitespace">
1121 <xsl:param name=
"whitespaces"/>
1123 <!--write two space chars as the normal white space character will be stripped
1124 and the other is able to break -->
1125 <xsl:text> </xsl:text>
1126 <xsl:if test=
"$whitespaces >= 2">
1127 <xsl:call-template name=
"write-breakable-whitespace-2">
1128 <xsl:with-param name=
"whitespaces" select=
"$whitespaces - 1"/>
1129 </xsl:call-template>
1134 <!--write the number of 'whitespaces' -->
1135 <xsl:template name=
"write-breakable-whitespace-2">
1136 <xsl:param name=
"whitespaces"/>
1137 <!--write two space chars as the normal white space character will be stripped
1138 and the other is able to break -->
1139 <xsl:text> </xsl:text>
1140 <xsl:if test=
"$whitespaces >= 2">
1141 <xsl:call-template name=
"write-breakable-whitespace">
1142 <xsl:with-param name=
"whitespaces" select=
"$whitespaces - 1"/>
1143 </xsl:call-template>
1147 <xsl:template match=
"text:tab-stop">
1148 <xsl:call-template name=
"write-breakable-whitespace">
1149 <xsl:with-param name=
"whitespaces" select=
"8"/>
1150 </xsl:call-template>