mirror of
https://github.com/Zeckmathederg/glfs.git
synced 2025-01-25 07:42:13 +08:00
308 lines
11 KiB
XML
308 lines
11 KiB
XML
<?xml version='1.0' encoding='ISO-8859-1'?>
|
|
|
|
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
version="1.0">
|
|
|
|
<!-- This stylesheet contains misc templates for output formating.
|
|
This file is for that templates that don't fit in other files
|
|
and that not afect the chunk algorithm. -->
|
|
|
|
<!-- Individual elements templates -->
|
|
|
|
<!-- para:
|
|
Added a choose to skip empty "Home page" in packages.xml.
|
|
Added an if for HLFS features. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/block.xsl -->
|
|
<xsl:template match="para">
|
|
<xsl:choose>
|
|
<xsl:when test="child::ulink[@url=' ']"/>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="paragraph">
|
|
<xsl:with-param name="class">
|
|
<xsl:if test="@role">
|
|
<xsl:if test="$book-type = 'hlfs'">
|
|
<xsl:if test="contains($hlfs-features,concat(',',@role,','))">
|
|
<xsl:text>feature-</xsl:text>
|
|
</xsl:if>
|
|
</xsl:if>
|
|
<xsl:value-of select="@role"/>
|
|
</xsl:if>
|
|
</xsl:with-param>
|
|
<xsl:with-param name="content">
|
|
<xsl:if test="position() = 1 and parent::listitem">
|
|
<xsl:call-template name="anchor">
|
|
<xsl:with-param name="node" select="parent::listitem"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
<xsl:call-template name="anchor"/>
|
|
<xsl:apply-templates/>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<!-- screen:
|
|
Changed class attribute asignament to fit our look needs.
|
|
Removed unused line numbering support. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/verbatim.xsl
|
|
It match also programlisting and synopsis. The code for that tags
|
|
is unchanged. -->
|
|
<xsl:template match="screen">
|
|
<pre>
|
|
<xsl:attribute name="class">
|
|
<xsl:choose>
|
|
<xsl:when test="@role and not(@role = 'nodump')">
|
|
<xsl:if test="$book-type = 'hlfs'">
|
|
<xsl:if test="contains($hlfs-features,concat(',',@role,','))">
|
|
<xsl:text>feature-</xsl:text>
|
|
</xsl:if>
|
|
</xsl:if>
|
|
<xsl:value-of select="@role"/>
|
|
</xsl:when>
|
|
<xsl:when test="child::* = userinput">userinput</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="name(.)"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:attribute>
|
|
<xsl:apply-templates/>
|
|
</pre>
|
|
</xsl:template>
|
|
|
|
<!-- userinput:
|
|
Using a customized output when inside screen.
|
|
In other cases, use the original template. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/inline.xsl -->
|
|
<xsl:template match="userinput">
|
|
<xsl:choose>
|
|
<xsl:when test="ancestor::screen">
|
|
<kbd class="command">
|
|
<xsl:apply-templates/>
|
|
</kbd>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-imports/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<!-- itemizadlist:
|
|
@compact is not allowed in XHTML 1.0 Strict DTD. Changing it
|
|
to @class. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/lists.xsl -->
|
|
<xsl:template match="itemizedlist">
|
|
<div>
|
|
<xsl:apply-templates select="." mode="class.attribute"/>
|
|
<xsl:call-template name="anchor"/>
|
|
<xsl:if test="title">
|
|
<xsl:call-template name="formal.object.heading"/>
|
|
</xsl:if>
|
|
<xsl:apply-templates select="*[not(self::listitem or self::title
|
|
or self::titleabbrev)]
|
|
|comment()[not(preceding-sibling::listitem)]
|
|
|processing-instruction()[not(preceding-sibling::listitem)]"/>
|
|
<ul>
|
|
<xsl:if test="@spacing='compact'">
|
|
<xsl:attribute name="class">
|
|
<xsl:value-of select="@spacing"/>
|
|
</xsl:attribute>
|
|
</xsl:if>
|
|
<xsl:apply-templates select="listitem |comment()[preceding-sibling::listitem]
|
|
|processing-instruction()[preceding-sibling::listitem]"/>
|
|
</ul>
|
|
</div>
|
|
</xsl:template>
|
|
|
|
<!-- orderedlist:
|
|
@start, @type, and @compact sre not allowed in XHTML 1.0 Strict DTD.
|
|
@start and @type can be replaced by CSS code.
|
|
Changing @compact to @class. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/lists.xsl -->
|
|
<xsl:template match="orderedlist">
|
|
<div>
|
|
<xsl:apply-templates select="." mode="class.attribute"/>
|
|
<xsl:call-template name="anchor"/>
|
|
<xsl:if test="title">
|
|
<xsl:call-template name="formal.object.heading"/>
|
|
</xsl:if>
|
|
<xsl:apply-templates select="*[not(self::listitem or self::title
|
|
or self::titleabbrev)]
|
|
|comment()[not(preceding-sibling::listitem)]
|
|
|processing-instruction()[not(preceding-sibling::listitem)]"/>
|
|
<ol>
|
|
<xsl:if test="@spacing='compact'">
|
|
<xsl:attribute name="class">
|
|
<xsl:value-of select="@spacing"/>
|
|
</xsl:attribute>
|
|
</xsl:if>
|
|
<xsl:apply-templates select="listitem |comment()[preceding-sibling::listitem]
|
|
|processing-instruction()[preceding-sibling::listitem]"/>
|
|
</ol>
|
|
</div>
|
|
</xsl:template>
|
|
|
|
<!-- seg in segementedlist:
|
|
Added a span around seg text to can match it with CSS code. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/lists.xsl -->
|
|
<xsl:template match="seg">
|
|
<xsl:variable name="segnum" select="count(preceding-sibling::seg)+1"/>
|
|
<xsl:variable name="seglist" select="ancestor::segmentedlist"/>
|
|
<xsl:variable name="segtitles" select="$seglist/segtitle"/>
|
|
<!-- Note: segtitle is only going to be the right thing in a well formed
|
|
SegmentedList. If there are too many Segs or too few SegTitles,
|
|
you'll get something odd...maybe an error -->
|
|
<div class="seg">
|
|
<strong class="segtitle">
|
|
<xsl:apply-templates select="$segtitles[$segnum=position()]"
|
|
mode="segtitle-in-seg"/>
|
|
<xsl:text>: </xsl:text>
|
|
</strong>
|
|
<span class="segbody">
|
|
<xsl:if test="@id">
|
|
<a id="{@id}" name="{@id}"/>
|
|
</xsl:if>
|
|
<xsl:apply-templates/>
|
|
</span>
|
|
</div>
|
|
</xsl:template>
|
|
|
|
<!-- variablelist:
|
|
If it have a role attribute, wrap the default output into a div with
|
|
a class attribute matching that role attribute.
|
|
Apply the original template in all cases. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/lists.xsl -->
|
|
<xsl:template match="variablelist">
|
|
<xsl:choose>
|
|
<xsl:when test="@role">
|
|
<div class="{@role}">
|
|
<xsl:apply-imports/>
|
|
</div>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-imports/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<!-- para/simplelist:
|
|
Self-made template. Add a line break and process the childs.
|
|
If @type is specified, the original templates should be used,
|
|
but not tested. -->
|
|
<xsl:template match="para/simplelist">
|
|
<br/>
|
|
<xsl:apply-templates mode="condensed"/>
|
|
</xsl:template>
|
|
|
|
<!-- member:
|
|
Self-made template to process it and add a line break. -->
|
|
<xsl:template match="member" mode="condensed">
|
|
<xsl:call-template name="anchor"/>
|
|
<xsl:call-template name="simple.xlink">
|
|
<xsl:with-param name="content">
|
|
<xsl:apply-templates/>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
<br/>
|
|
</xsl:template>
|
|
|
|
|
|
<!-- Named formating templates -->
|
|
|
|
<!-- Body attributes:
|
|
Add to the body XHTML output tag a class attribute with the book type
|
|
and a id attribute with the book type and version. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/docbook.xsl -->
|
|
<xsl:template name="body.attributes">
|
|
<xsl:attribute name="class">
|
|
<xsl:value-of select="$book-type"/>
|
|
</xsl:attribute>
|
|
<xsl:attribute name="id">
|
|
<xsl:value-of select="$book-type"/>
|
|
<xsl:text>-</xsl:text>
|
|
<xsl:value-of select="substring-after(/book/bookinfo/subtitle, ' ')"/>
|
|
</xsl:attribute>
|
|
</xsl:template>
|
|
|
|
<!-- Revision History -->
|
|
|
|
<!-- revhistory mode titlepage.mode:
|
|
Removed hardcoded style attributes.
|
|
Removed support for separate revhistory file. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.xsl -->
|
|
<xsl:template match="revhistory" mode="titlepage.mode">
|
|
<xsl:variable name="numcols">
|
|
<xsl:choose>
|
|
<xsl:when test="//authorinitials">4</xsl:when>
|
|
<xsl:otherwise>3</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:variable>
|
|
<xsl:variable name="title">
|
|
<xsl:call-template name="gentext">
|
|
<xsl:with-param name="key">RevHistory</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:variable>
|
|
<xsl:variable name="contents">
|
|
<table summary="{$title}" class="{name(.)}">
|
|
<tr>
|
|
<th colspan="{$numcols}">
|
|
<b>
|
|
<xsl:value-of select="$title"/>
|
|
</b>
|
|
</th>
|
|
</tr>
|
|
<xsl:apply-templates mode="titlepage.mode">
|
|
<xsl:with-param name="numcols" select="$numcols"/>
|
|
</xsl:apply-templates>
|
|
</table>
|
|
</xsl:variable>
|
|
<xsl:copy-of select="$contents"/>
|
|
</xsl:template>
|
|
|
|
<!-- revhistory/revision mode titlepage.mode:
|
|
Removed hardcoded style attributes. -->
|
|
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.xsl -->
|
|
<xsl:template match="revhistory/revision" mode="titlepage.mode">
|
|
<xsl:param name="numcols" select="'3'"/>
|
|
<xsl:variable name="revnumber" select="revnumber"/>
|
|
<xsl:variable name="revdate" select="date"/>
|
|
<xsl:variable name="revauthor" select="authorinitials|author"/>
|
|
<xsl:variable name="revremark" select="revremark|revdescription"/>
|
|
<tr>
|
|
<td>
|
|
<xsl:if test="$revnumber">
|
|
<xsl:call-template name="gentext">
|
|
<xsl:with-param name="key" select="'Revision'"/>
|
|
</xsl:call-template>
|
|
<xsl:call-template name="gentext.space"/>
|
|
<xsl:apply-templates select="$revnumber[1]" mode="titlepage.mode"/>
|
|
</xsl:if>
|
|
</td>
|
|
<td>
|
|
<xsl:apply-templates select="$revdate[1]" mode="titlepage.mode"/>
|
|
</td>
|
|
<xsl:choose>
|
|
<xsl:when test="$revauthor">
|
|
<td>
|
|
<xsl:for-each select="$revauthor">
|
|
<xsl:apply-templates select="." mode="titlepage.mode"/>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text>, </xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each>
|
|
</td>
|
|
</xsl:when>
|
|
<xsl:when test="$numcols > 3">
|
|
<td> </td>
|
|
</xsl:when>
|
|
<xsl:otherwise/>
|
|
</xsl:choose>
|
|
<td>
|
|
<xsl:apply-templates select="$revremark[1]" mode="titlepage.mode"/>
|
|
</td>
|
|
</tr>
|
|
</xsl:template>
|
|
|
|
</xsl:stylesheet>
|