mirror of
https://github.com/boostorg/boostbook.git
synced 2025-05-09 15:03:57 +00:00
200 lines
6.8 KiB
XML
200 lines
6.8 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision"
|
|
version="1.0">
|
|
|
|
<!-- Import the HTML chunking stylesheet -->
|
|
<xsl:import
|
|
href="http://docbook.sourceforge.net/release/xsl/current/html/chunk.xsl"/>
|
|
|
|
<xsl:import href="docbook-layout.xsl"/>
|
|
<xsl:import href="navbar.xsl"/>
|
|
|
|
<xsl:param name="html.stylesheet" select="'boostbook.css'"/>
|
|
<xsl:param name="navig.graphics" select="1"/>
|
|
<xsl:param name="navig.graphics.extension" select="'.png'"/>
|
|
<xsl:param name="chapter.autolabel" select="1"/>
|
|
<xsl:param name="use.id.as.filename" select="1"/>
|
|
<xsl:param name="refentry.generate.name" select="0"/>
|
|
<xsl:param name="refentry.generate.title" select="1"/>
|
|
<xsl:param name="make.year.ranges" select="1"/>
|
|
<xsl:param name="generate.manifest" select="1"/>
|
|
<xsl:param name="generate.section.toc.level" select="3"/>
|
|
<xsl:param name="doc.standalone">false</xsl:param>
|
|
<xsl:param name="chunker.output.indent">yes</xsl:param>
|
|
<xsl:param name="toc.max.depth">2</xsl:param>
|
|
|
|
<xsl:param name="generate.toc">
|
|
appendix toc,title
|
|
article/appendix nop
|
|
article toc,title
|
|
book toc,title
|
|
chapter toc,title
|
|
part toc,title
|
|
preface toc,title
|
|
qandadiv toc
|
|
qandaset toc
|
|
reference toc,title
|
|
sect1 toc
|
|
sect2 toc
|
|
sect3 toc
|
|
sect4 toc
|
|
sect5 toc
|
|
section toc
|
|
set toc,title
|
|
</xsl:param>
|
|
|
|
|
|
<xsl:template name="format.cvs.revision">
|
|
<xsl:param name="text"/>
|
|
|
|
<!-- Remove the "$Date: " -->
|
|
<xsl:variable name="text.noprefix"
|
|
select="substring-after($text, '$Date: ')"/>
|
|
|
|
<!-- Grab the year -->
|
|
<xsl:variable name="year" select="substring-before($text.noprefix, '/')"/>
|
|
<xsl:variable name="text.noyear"
|
|
select="substring-after($text.noprefix, '/')"/>
|
|
|
|
<!-- Grab the month -->
|
|
<xsl:variable name="month" select="substring-before($text.noyear, '/')"/>
|
|
<xsl:variable name="text.nomonth"
|
|
select="substring-after($text.noyear, '/')"/>
|
|
|
|
<!-- Grab the year -->
|
|
<xsl:variable name="day" select="substring-before($text.nomonth, ' ')"/>
|
|
<xsl:variable name="text.noday"
|
|
select="substring-after($text.nomonth, ' ')"/>
|
|
|
|
<!-- Get the time -->
|
|
<xsl:variable name="time" select="substring-before($text.noday, ' ')"/>
|
|
|
|
<xsl:variable name="month.name">
|
|
<xsl:choose>
|
|
<xsl:when test="$month=1">January</xsl:when>
|
|
<xsl:when test="$month=2">February</xsl:when>
|
|
<xsl:when test="$month=3">March</xsl:when>
|
|
<xsl:when test="$month=4">April</xsl:when>
|
|
<xsl:when test="$month=5">May</xsl:when>
|
|
<xsl:when test="$month=6">June</xsl:when>
|
|
<xsl:when test="$month=7">July</xsl:when>
|
|
<xsl:when test="$month=8">August</xsl:when>
|
|
<xsl:when test="$month=9">September</xsl:when>
|
|
<xsl:when test="$month=10">October</xsl:when>
|
|
<xsl:when test="$month=11">November</xsl:when>
|
|
<xsl:when test="$month=12">December</xsl:when>
|
|
</xsl:choose>
|
|
</xsl:variable>
|
|
|
|
<xsl:value-of select="concat($month.name, ' ', $day, ', ', $year, ' at ',
|
|
$time, ' GMT')"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="copyright" mode="boost.footer">
|
|
<xsl:if test="position() > 1">
|
|
<br/>
|
|
</xsl:if>
|
|
<xsl:call-template name="gentext">
|
|
<xsl:with-param name="key" select="'Copyright'"/>
|
|
</xsl:call-template>
|
|
<xsl:call-template name="gentext.space"/>
|
|
<xsl:call-template name="dingbat">
|
|
<xsl:with-param name="dingbat">copyright</xsl:with-param>
|
|
</xsl:call-template>
|
|
<xsl:call-template name="gentext.space"/>
|
|
<xsl:call-template name="copyright.years">
|
|
<xsl:with-param name="years" select="year"/>
|
|
<xsl:with-param name="print.ranges" select="$make.year.ranges"/>
|
|
<xsl:with-param name="single.year.ranges"
|
|
select="$make.single.year.ranges"/>
|
|
</xsl:call-template>
|
|
<xsl:call-template name="gentext.space"/>
|
|
<xsl:apply-templates select="holder" mode="titlepage.mode"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template name="user.footer.content">
|
|
<table width="100%">
|
|
<tr>
|
|
<td align="left">
|
|
<xsl:variable name="revision-nodes"
|
|
select="ancestor-or-self::*
|
|
[not (attribute::rev:last-revision='')]"/>
|
|
<xsl:if test="count($revision-nodes) > 0">
|
|
<xsl:variable name="revision-node"
|
|
select="$revision-nodes[last()]"/>
|
|
<xsl:variable name="revision-text">
|
|
<xsl:value-of
|
|
select="normalize-space($revision-node/attribute::rev:last-revision)"/>
|
|
</xsl:variable>
|
|
<xsl:if test="string-length($revision-text) > 0">
|
|
<small>
|
|
<p>
|
|
<xsl:text>Last revised: </xsl:text>
|
|
<xsl:call-template name="format.cvs.revision">
|
|
<xsl:with-param name="text" select="$revision-text"/>
|
|
</xsl:call-template>
|
|
</p>
|
|
</small>
|
|
</xsl:if>
|
|
</xsl:if>
|
|
</td>
|
|
<td align="right">
|
|
<small>
|
|
<xsl:apply-templates select="ancestor::*/*/copyright"
|
|
mode="boost.footer"/>
|
|
</small>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="variablelist">
|
|
<xsl:choose>
|
|
<xsl:when test="@spacing='boost'">
|
|
<p><xsl:apply-templates mode="boost.variablelist"/></p>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-imports />
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="varlistentry" mode="boost.variablelist">
|
|
<xsl:if test="position() > 1">
|
|
<br/>
|
|
</xsl:if>
|
|
<b><xsl:apply-templates select="term"/></b>:
|
|
|
|
<xsl:choose>
|
|
<xsl:when test="local-name(listitem/*[1])='simpara' or
|
|
local-name(listitem/*[1])='para'">
|
|
<xsl:apply-templates
|
|
select="listitem/*[1]/*|listitem/*[1]/text()"/>
|
|
<xsl:apply-templates select="(listitem/*|listitem/text())[position() > 1]"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-templates select="listitem/*|listitem/text()"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<!-- We don't want refentry's to show up in the TOC because they
|
|
will merely be redundant with the synopsis. -->
|
|
<xsl:template match="refentry" mode="toc"/>
|
|
|
|
<!-- override the behaviour of some DocBook elements for better
|
|
rendering facilities -->
|
|
|
|
<xsl:template match = "programlisting[ancestor::informaltable]">
|
|
<pre class = "table-{name(.)}"><xsl:apply-templates/></pre>
|
|
</xsl:template>
|
|
|
|
<xsl:template match = "refsynopsisdiv">
|
|
<h2 class = "{name(.)}-title">Synopsis</h2>
|
|
<div class = "{name(.)}">
|
|
<xsl:apply-templates/>
|
|
</div>
|
|
</xsl:template>
|
|
</xsl:stylesheet>
|