mirror of
https://github.com/Zeckmathederg/glfs.git
synced 2025-01-24 15:12:11 +08:00
0d7e9a2687
The template for sect3.titlepage generates: <h3 class="sect3"> <a id="{id of sect3}" name="{id of sect3}"></a> <h4 class="title"> <a id="{id of sect3}" name="{id of sect3}">i{title of sect3}</a> </h4> </h3> resulting in double definition of the same id, which is a validity error in XML documents. Replace with the same template as for sect2, using h3 instead of h2.
197 lines
6.7 KiB
XML
197 lines
6.7 KiB
XML
<?xml version='1.0' encoding='UTF-8'?>
|
|
|
|
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
version="1.0">
|
|
|
|
<!-- This stylesheet controls the h* xhtml tags used for several titles -->
|
|
|
|
<!-- preface.titlepage:
|
|
Uses h1 and removed a lot of unneeded code.
|
|
No label in preface. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="preface.titlepage">
|
|
<h1 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h1>
|
|
</xsl:template>
|
|
|
|
<!-- part.titlepage:
|
|
Uses h1 and removed a lot of unneeded code.
|
|
When sections are not labeled, we want the part label in TOC
|
|
but not in titlepage. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="part.titlepage">
|
|
<h1 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:if test="$section.autolabel != 0">
|
|
<xsl:apply-templates select="." mode="label.markup"/>
|
|
<xsl:text>. </xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h1>
|
|
</xsl:template>
|
|
|
|
<!-- partintro.titlepage:
|
|
Uses h2 and removed a lot of unneeded code. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="partintro.titlepage">
|
|
<xsl:if test="title">
|
|
<h2 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h2>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<!-- appendix.titlepage:
|
|
Uses h1 and removed a lot of unneeded code.
|
|
When sections are not labeled, we want the appendix label in TOC
|
|
but not in titlepage. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="appendix.titlepage">
|
|
<h1 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:if test="$section.autolabel != 0">
|
|
<xsl:apply-templates select="." mode="label.markup"/>
|
|
<xsl:text>. </xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h1>
|
|
</xsl:template>
|
|
|
|
<!-- chapter.titlepage:
|
|
Uses h1 and removed a lot of unneeded code.
|
|
When sections are not labeled, we want the chapter label in TOC
|
|
but not in titlepage. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="chapter.titlepage">
|
|
<h1 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:if test="$section.autolabel != 0">
|
|
<xsl:apply-templates select="." mode="label.markup"/>
|
|
<xsl:text>. </xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h1>
|
|
</xsl:template>
|
|
|
|
<!-- sect1.titlepage:
|
|
Uses h1 and removed a lot of unneeded code. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="sect1.titlepage">
|
|
<h1 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:if test="$section.autolabel != 0">
|
|
<xsl:apply-templates select="." mode="label.markup"/>
|
|
<xsl:text>. </xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h1>
|
|
</xsl:template>
|
|
|
|
<!-- sect2.titlepage:
|
|
Uses h2 and removed a lot of unneeded code.
|
|
Skip empty titles.
|
|
No label in preface. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="sect2.titlepage">
|
|
<xsl:choose>
|
|
<xsl:when test="string-length(title) = 0"/>
|
|
<xsl:otherwise>
|
|
<h2 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:if test="not(ancestor::preface) and $section.autolabel != 0">
|
|
<xsl:apply-templates select="." mode="label.markup"/>
|
|
<xsl:text>. </xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h2>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<!-- sect3.titlepage:
|
|
Same as sect2 except it uses h3 -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="sect3.titlepage">
|
|
<xsl:choose>
|
|
<xsl:when test="string-length(title) = 0"/>
|
|
<xsl:otherwise>
|
|
<h3 class="{name(.)}">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:if test="not(ancestor::preface) and $section.autolabel != 0">
|
|
<xsl:apply-templates select="." mode="label.markup"/>
|
|
<xsl:text>. </xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="title"/>
|
|
</h3>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
<!-- dedication.titlepage:
|
|
Uses h2 and removed a lot of unneeded code. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="dedication.titlepage">
|
|
<h2>
|
|
<xsl:value-of select="title"/>
|
|
</h2>
|
|
</xsl:template>
|
|
|
|
<!-- bridgehead:
|
|
We use always renderas attributes and want the output h* level
|
|
matching the defined sect* level.
|
|
Create the anchor only if there is an @id. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/sections.xsl -->
|
|
<xsl:template match="bridgehead">
|
|
<xsl:variable name="hlevel">
|
|
<xsl:choose>
|
|
<xsl:when test="@renderas = 'sect1'">1</xsl:when>
|
|
<xsl:when test="@renderas = 'sect2'">2</xsl:when>
|
|
<xsl:when test="@renderas = 'sect3'">3</xsl:when>
|
|
<xsl:when test="@renderas = 'sect4'">4</xsl:when>
|
|
<xsl:when test="@renderas = 'sect5'">5</xsl:when>
|
|
</xsl:choose>
|
|
</xsl:variable>
|
|
<xsl:element name="h{$hlevel}" namespace="http://www.w3.org/1999/xhtml">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:apply-templates/>
|
|
</xsl:element>
|
|
</xsl:template>
|
|
|
|
<!-- book.titlepage.verso:
|
|
Process bookinfo/bibliosource from here. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
|
|
<xsl:template name="book.titlepage.verso">
|
|
<xsl:apply-templates select="bookinfo/bibliosource"/>
|
|
</xsl:template>
|
|
|
|
<!-- bookinfo/bibliosource:
|
|
Self-made template to handle bibliosource when inside bookinfo. -->
|
|
<xsl:template match="bookinfo/bibliosource">
|
|
<p class="copyright">
|
|
<xsl:apply-templates/>
|
|
</p>
|
|
</xsl:template>
|
|
|
|
</xsl:stylesheet>
|