mirror of
https://github.com/samba-team/samba.git
synced 2025-12-21 20:23:50 +03:00
1209 lines
42 KiB
XML
1209 lines
42 KiB
XML
<?xml version='1.0'?>
|
|
<!DOCTYPE xsl:stylesheet [ <!ENTITY % xsldoc.ent SYSTEM "./xsldoc.ent"> %xsldoc.ent; ]>
|
|
<!--#############################################################################
|
|
| $Id: xref.mod.xsl,v 1.41 2004/01/28 02:07:08 j-devenish Exp $
|
|
|- #############################################################################
|
|
| $Author: j-devenish $
|
|
+ ############################################################################## -->
|
|
|
|
<xsl:stylesheet
|
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
xmlns:doc="http://nwalsh.com/xsl/documentation/1.0"
|
|
exclude-result-prefixes="doc" version='1.0'>
|
|
|
|
<doc:reference id="xref" xmlns="">
|
|
<referenceinfo>
|
|
<releaseinfo role="meta">
|
|
$Id: xref.mod.xsl,v 1.41 2004/01/28 02:07:08 j-devenish Exp $
|
|
</releaseinfo>
|
|
<authorgroup>
|
|
&ramon;
|
|
&james;
|
|
</authorgroup>
|
|
<copyright>
|
|
<year>2000</year><year>2001</year><year>2002</year><year>2003</year><year>2004</year>
|
|
<holder>Ramon Casellas</holder>
|
|
</copyright>
|
|
<revhistory>
|
|
<doc:revision rcasver="1.12">&rev_2003_05;</doc:revision>
|
|
</revhistory>
|
|
</referenceinfo>
|
|
<title>Cross References <filename>xref.mod.xsl</filename></title>
|
|
<partintro>
|
|
<para>
|
|
|
|
Portions (c) Norman Walsh, official DocBook XSL stylesheets. See docbook.sf.net
|
|
|
|
</para>
|
|
</partintro>
|
|
</doc:reference>
|
|
|
|
<doc:template xmlns="">
|
|
<refpurpose>Process <doc:db>anchor</doc:db> elements</refpurpose>
|
|
<doc:description>
|
|
<para>
|
|
Identify a place in the document for cross references.
|
|
</para>
|
|
</doc:description>
|
|
<doc:variables>
|
|
&no_var;
|
|
</doc:variables>
|
|
<doc:notes>
|
|
<para>
|
|
Inserts a &LaTeX; <function condition="latex">hypertarget</function>
|
|
with the current node's id value and no content.
|
|
<doc:todo>Check to see whether this causes typesetting problems
|
|
with <command>latex</command> (as opposed to
|
|
<command>pdflatex</command>) due to insertion of errant
|
|
<literal>pdfmark</literal>s.</doc:todo>
|
|
</para>
|
|
</doc:notes>
|
|
</doc:template>
|
|
<xsl:template match="anchor">
|
|
<xsl:param name="id" select="@id"/>
|
|
<xsl:text>\hypertarget{</xsl:text>
|
|
<xsl:value-of select="$id"/>
|
|
<xsl:text>}{}</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:key name="cross-refs" match="xref|link" use="@linkend"/>
|
|
<doc:template name="id.is.xrefed" xmlns="">
|
|
<refpurpose>Auxiliary named template</refpurpose>
|
|
<doc:description>
|
|
<para>This template returns 1 if there exists somewhere an xref
|
|
or link whose linkend is the target's id.</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template name="id.is.xrefed">
|
|
<xsl:param name="target" select="."/>
|
|
<xsl:variable name="id">
|
|
<xsl:call-template name="generate.label.id">
|
|
<xsl:with-param name="object" select="$target"/>
|
|
</xsl:call-template>
|
|
</xsl:variable>
|
|
<xsl:choose>
|
|
<xsl:when test="count(key('cross-refs', $id))>0">
|
|
<xsl:text>1</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>0</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<doc:template name="xref.xreflabel" xmlns="">
|
|
<refpurpose>Auxiliary named template</refpurpose>
|
|
<doc:description>
|
|
<para> Called to process an xreflabel...you might use this to make
|
|
xreflabels come out in the right font for different targets,
|
|
for example.</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template name="xref.xreflabel">
|
|
<xsl:param name="target" select="."/>
|
|
<xsl:value-of select="$target/@xreflabel"/>
|
|
</xsl:template>
|
|
|
|
<doc:template match="xref|link" xmlns="">
|
|
<refpurpose>Xref and Link XSL Template</refpurpose>
|
|
<doc:description>
|
|
<para>
|
|
<doc:todo>Undocumented.</doc:todo>
|
|
</para>
|
|
</doc:description>
|
|
<doc:variables>
|
|
<itemizedlist>
|
|
<listitem><simpara><xref linkend="param.insert.xref.page.number"/></simpara></listitem>
|
|
<listitem><simpara><xref linkend="param.latex.use.varioref"/></simpara></listitem>
|
|
</itemizedlist>
|
|
</doc:variables>
|
|
</doc:template>
|
|
<xsl:template match="xref|link">
|
|
<xsl:variable name="targets" select="key('id',@linkend)"/>
|
|
<xsl:variable name="target" select="$targets[1]"/>
|
|
<xsl:variable name="refelem" select="local-name($target)"/>
|
|
<xsl:call-template name="check.id.unique"><xsl:with-param name="linkend" select="@linkend"/></xsl:call-template>
|
|
<xsl:choose>
|
|
<xsl:when test="$refelem=''">
|
|
<xsl:message><xsl:text>XRef to nonexistent id: </xsl:text><xsl:value-of select="@linkend"/></xsl:message>
|
|
<xsl:text>XrefId[?</xsl:text>
|
|
<xsl:if test="local-name(.)='link'"><xsl:apply-templates/></xsl:if>
|
|
<xsl:text>?]</xsl:text>
|
|
</xsl:when>
|
|
|
|
<!-- This is a link with content ... -->
|
|
<xsl:when test="local-name(.)='link' and .!=''">
|
|
<xsl:call-template name="generate.hyperlink">
|
|
<xsl:with-param name="target" select="$target"/>
|
|
<xsl:with-param name="text"><xsl:apply-templates/></xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
|
|
<xsl:otherwise>
|
|
<xsl:choose>
|
|
<xsl:when test="@endterm">
|
|
<xsl:variable name="etargets" select="key('id',@endterm)"/>
|
|
<xsl:variable name="etarget" select="$etargets[1]"/>
|
|
<xsl:choose>
|
|
<xsl:when test="count($etarget) = 0">
|
|
<xsl:message>
|
|
<xsl:value-of select="count($etargets)"/>
|
|
<xsl:text>Endterm points to nonexistent ID: </xsl:text>
|
|
<xsl:value-of select="@endterm"/>
|
|
</xsl:message>
|
|
<xsl:text>[NONEXISTENT ID]</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="generate.hyperlink">
|
|
<xsl:with-param name="target" select="$target"/>
|
|
<xsl:with-param name="text">
|
|
<xsl:call-template name="generate.xref.text">
|
|
<xsl:with-param name="target" select="$etarget"/>
|
|
</xsl:call-template>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:when>
|
|
<!-- If an xreflabel has been specified for the target ... -->
|
|
<xsl:when test="local-name(.)='xref' and $target/@xreflabel">
|
|
<xsl:call-template name="generate.hyperlink">
|
|
<xsl:with-param name="target" select="$target"/>
|
|
<xsl:with-param name="text">
|
|
<xsl:text>{[</xsl:text>
|
|
<xsl:call-template name="xref.xreflabel">
|
|
<xsl:with-param name="target" select="$target"/>
|
|
</xsl:call-template>
|
|
<xsl:text>]}</xsl:text>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="generate.hyperlink">
|
|
<xsl:with-param name="target" select="$target"/>
|
|
<xsl:with-param name="text">
|
|
<xsl:call-template name="generate.xref.text">
|
|
<xsl:with-param name="target" select="$target"/>
|
|
</xsl:call-template>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:if test="$insert.xref.page.number=1 and not($latex.use.varioref='1') and $refelem!='' and local-name(.)='xref'">
|
|
<xsl:variable name="xref.text">
|
|
<xsl:call-template name="gentext.template">
|
|
<xsl:with-param name="context" select="'xref'"/>
|
|
<xsl:with-param name="name" select="'page.citation'"/>
|
|
</xsl:call-template>
|
|
</xsl:variable>
|
|
<xsl:for-each select="$target">
|
|
<xsl:call-template name="substitute-markup">
|
|
<xsl:with-param name="template" select="$xref.text"/>
|
|
</xsl:call-template>
|
|
</xsl:for-each>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<doc:template>
|
|
<refpurpose> Generate xref text </refpurpose>
|
|
<doc:variables>
|
|
<itemizedlist>
|
|
<listitem><simpara><xref linkend="param.use.role.as.xrefstyle"/></simpara></listitem>
|
|
</itemizedlist>
|
|
</doc:variables>
|
|
</doc:template>
|
|
<xsl:template name="generate.xref.text">
|
|
<xsl:param name="target"/>
|
|
<xsl:apply-templates select="$target" mode="xref-to">
|
|
<xsl:with-param name="referrer" select="."/>
|
|
<xsl:with-param name="xrefstyle">
|
|
<xsl:choose>
|
|
<xsl:when test="@role and not(@xrefstyle) and $use.role.as.xrefstyle != 0">
|
|
<xsl:value-of select="@role"/>
|
|
</xsl:when>
|
|
<xsl:when test="@xrefstyle">
|
|
<xsl:value-of select="@xrefstyle"/>
|
|
</xsl:when>
|
|
<xsl:when test="local-name($target)='title' or local-name($target)='subtitle'">
|
|
<xsl:value-of select="concat(local-name($target), '-unnumbered')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>xref-number</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:with-param>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<doc:template name="generate.hyperlink" xmlns="">
|
|
<refpurpose> Choose hyperlink syntax </refpurpose>
|
|
<doc:description>
|
|
<para>Will use hyperref, if it is available. Otherwise, just outputs
|
|
unlinked text. If the destination is a citation, a backreference is
|
|
emitted (even though it is technically a hyperlink, not a citation).
|
|
If the 'text' arises from an @endterm, then the 'optional argument'
|
|
syntax of <literal>\cite</literal> is used.</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template name="generate.hyperlink">
|
|
<xsl:param name="target"/>
|
|
<xsl:param name="text"/>
|
|
<xsl:variable name="element" select="local-name($target)"/>
|
|
<xsl:variable name="citation" select="$element='biblioentry' or $element='bibliomixed'"/>
|
|
<xsl:choose>
|
|
<xsl:when test="$citation and @endterm!=''">
|
|
<xsl:text>\docbooktolatexcite</xsl:text>
|
|
<xsl:text>{</xsl:text>
|
|
<xsl:value-of select="$target/@id"/>
|
|
<xsl:text>}{</xsl:text>
|
|
<xsl:call-template name="scape-optionalarg">
|
|
<xsl:with-param name="string" select="$text"/>
|
|
</xsl:call-template>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:if test="$latex.use.hyperref=1 and not(ancestor::title)">
|
|
<xsl:text>\hyperlink{</xsl:text>
|
|
<xsl:value-of select="$target/@id"/>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>{</xsl:text>
|
|
<xsl:if test="$citation">
|
|
<xsl:text>\docbooktolatexbackcite{</xsl:text>
|
|
<xsl:value-of select="$target/@id"/>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="$text"/>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<doc:template basename="insert.label.markup" xmlns="">
|
|
<refpurpose>Numbering template</refpurpose>
|
|
<doc:description>
|
|
<para>
|
|
Let &LaTeX; manage the numbering. Otherwise sty files that
|
|
do specify another numberic (e.g I,II) get messed.
|
|
</para>
|
|
</doc:description>
|
|
<doc:variables>
|
|
<itemizedlist>
|
|
<listitem><simpara><xref linkend="param.insert.xref.page.number"/></simpara></listitem>
|
|
<listitem><simpara><xref linkend="param.latex.use.varioref"/></simpara></listitem>
|
|
</itemizedlist>
|
|
</doc:variables>
|
|
</doc:template>
|
|
<xsl:template match="*" mode="insert.label.markup" name="insert.label.markup">
|
|
<xsl:param name="id" select="@id"/>
|
|
<xsl:choose>
|
|
<xsl:when test="$insert.xref.page.number=1 and $latex.use.varioref='1'">
|
|
<xsl:text>{\vref{</xsl:text><xsl:value-of select="$id"/><xsl:text>}}</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>{\ref{</xsl:text><xsl:value-of select="$id"/><xsl:text>}}</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<doc:template basename="insert.label.markup" xmlns="">
|
|
<refpurpose>Numbering template -- uses parent's @id</refpurpose>
|
|
<doc:description>
|
|
<para>
|
|
Calls <xref linkend="template.insert.label.markup"/> using parent's @id.
|
|
</para>
|
|
</doc:description>
|
|
<doc:variables>
|
|
<itemizedlist>
|
|
<listitem><simpara><xref linkend="param.insert.xref.page.number"/></simpara></listitem>
|
|
<listitem><simpara><xref linkend="param.latex.use.varioref"/></simpara></listitem>
|
|
</itemizedlist>
|
|
</doc:variables>
|
|
</doc:template>
|
|
<xsl:template match="title" mode="insert.label.markup">
|
|
<xsl:call-template name="insert.label.markup">
|
|
<xsl:with-param name="id">
|
|
<xsl:choose>
|
|
<xsl:when test="contains(local-name(..), 'info')">
|
|
<xsl:call-template name="generate.label.id">
|
|
<xsl:with-param name="object" select="../.."/>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="generate.label.id">
|
|
<xsl:with-param name="object" select=".."/>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:template>
|
|
|
|
<doc:template xmlns="">
|
|
<refpurpose> Format titles in xref text </refpurpose>
|
|
<doc:params>
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term>title</term>
|
|
<listitem><simpara>The text. This is expected to
|
|
be received from gentext.xsl, in which case it will
|
|
contain no deliberate &LaTeX; commands and must be
|
|
escaped.</simpara></listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term>is.component</term>
|
|
<listitem><simpara>Whether the node is considered
|
|
to be a <quote>component</quote> in the sense of &DocBook;.
|
|
If so, the formatting of the title may be different. By default,
|
|
the determination of component elements is performed by the
|
|
<literal>is.component</literal> template in
|
|
<filename>common.xsl</filename>.</simpara></listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</doc:params>
|
|
<doc:description>
|
|
<para>
|
|
Calls <xref linkend="template.normalize-scape"/>. If the node
|
|
is a component type (e.g. appendix, article, chapter, preface,
|
|
bibliography, glossary or index) then gentext.startquote and
|
|
gentext.endquote are placed around the title.
|
|
</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template match="*" mode="insert.title.markup" name="generate.title.markup">
|
|
<xsl:param name="title"/>
|
|
<xsl:param name="is.component">
|
|
<xsl:call-template name="is.component"/>
|
|
</xsl:param>
|
|
<xsl:choose>
|
|
<xsl:when test="$is.component=1">
|
|
<xsl:call-template name="gentext.startquote"/>
|
|
<xsl:call-template name="normalize-scape">
|
|
<xsl:with-param name="string" select="$title"/>
|
|
</xsl:call-template>
|
|
<xsl:call-template name="gentext.endquote"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="normalize-scape">
|
|
<xsl:with-param name="string" select="$title"/>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<doc:template xmlns="">
|
|
<refpurpose> Format titles in xref text </refpurpose>
|
|
<doc:params>
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term>title</term>
|
|
<listitem><simpara>The text.</simpara></listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term>is.component</term>
|
|
<listitem><simpara>Whether the node's parent is considered
|
|
to be a <quote>component</quote> in the sense of &DocBook;.
|
|
</simpara></listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</doc:params>
|
|
<doc:description>
|
|
<para>
|
|
Calls <xref linkend="template.generate.title.markup"/>.
|
|
</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template match="title" mode="insert.title.markup">
|
|
<xsl:param name="title"/>
|
|
<xsl:param name="is.component">
|
|
<xsl:choose>
|
|
<xsl:when test="contains(local-name(..), 'info')">
|
|
<xsl:call-template name="is.component">
|
|
<xsl:with-param name="node" select="../.."/>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="is.component">
|
|
<xsl:with-param name="node" select=".."/>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:param>
|
|
<xsl:call-template name="generate.title.markup">
|
|
<xsl:with-param name="title" select="$title"/>
|
|
<xsl:with-param name="is.component" select="$is.component"/>
|
|
</xsl:call-template>
|
|
</xsl:template>
|
|
|
|
<doc:template xmlns="">
|
|
<refpurpose> Format titles in xref text </refpurpose>
|
|
<doc:description>
|
|
<para>
|
|
Does not add quotation marks around the title
|
|
but does italicise it.
|
|
</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template match="book" mode="insert.title.markup">
|
|
<xsl:param name="title"/>
|
|
<xsl:text>{\textit{</xsl:text>
|
|
<xsl:call-template name="normalize-scape">
|
|
<xsl:with-param name="string" select="$title"/>
|
|
</xsl:call-template>
|
|
<xsl:text>}}</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="*" mode="insert.subtitle.markup">
|
|
<xsl:message>Warning: unexpected insert.subtitle.markup in DB2LaTeX</xsl:message>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="*" mode="insert.pagenumber.markup">
|
|
<xsl:param name="target" select="."/>
|
|
<xsl:choose>
|
|
<xsl:when test="$latex.use.varioref='1'">
|
|
<xsl:variable name="options"><xsl:call-template name="latex.vpageref.options"/></xsl:variable>
|
|
<xsl:text>\vpageref</xsl:text>
|
|
<xsl:if test="$options!=''">
|
|
<xsl:choose>
|
|
<xsl:when test="contains($options,'[')">
|
|
<xsl:value-of select="$options"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>[</xsl:text>
|
|
<xsl:value-of select="$options"/>
|
|
<xsl:text>]</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:if>
|
|
<xsl:text>{</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>\pageref{</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:value-of select="$target/@id"/>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="*" mode="insert.direction.markup">
|
|
<xsl:message>Warning: unexpected insert.direction.markup in DB2LaTeX</xsl:message>
|
|
</xsl:template>
|
|
|
|
<doc:template match="ulink" xmlns="">
|
|
<refpurpose>A link that addresses its target by means of a URL (Uniform Resource Locator)</refpurpose>
|
|
<doc:variables>
|
|
<itemizedlist>
|
|
<listitem><simpara><xref linkend="param.ulink.show"/></simpara></listitem>
|
|
<listitem><simpara><xref linkend="param.ulink.footnotes"/></simpara></listitem>
|
|
<listitem><simpara><xref linkend="param.latex.ulink.protocols.relaxed"/></simpara></listitem>
|
|
<listitem><simpara><xref linkend="param.latex.hyphenation.tttricks"/></simpara></listitem>
|
|
</itemizedlist>
|
|
</doc:variables>
|
|
</doc:template>
|
|
<xsl:template match="ulink" name="ulink">
|
|
<xsl:param name="hyphenation">\docbookhyphenateurl</xsl:param>
|
|
<xsl:param name="url" select="@url"/>
|
|
<xsl:param name="content">
|
|
<xsl:call-template name="trim-outer">
|
|
<xsl:with-param name="string" select="."/>
|
|
</xsl:call-template>
|
|
</xsl:param>
|
|
<xsl:choose>
|
|
<xsl:when test="$content = '' or $content = $url">
|
|
<xsl:call-template name="generate.typeset.url">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="url" select="$url"/>
|
|
<xsl:with-param name="prepend" select="''"/>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:when test="$latex.ulink.protocols.relaxed='1' and (substring-after($url,':')=$content or substring-after($url,'://')=$content)">
|
|
<xsl:call-template name="generate.typeset.url">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="url" select="$content"/>
|
|
<xsl:with-param name="prepend" select="''"/>
|
|
</xsl:call-template>
|
|
<xsl:if test="$ulink.footnotes='1' and count(ancestor::footnote)=0">
|
|
<xsl:call-template name="generate.ulink.in.footnote">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="url" select="$url"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:when>
|
|
<xsl:when test="$latex.use.tabularx=1 and count(ancestor::table)>0">
|
|
<xsl:apply-templates/>
|
|
<xsl:call-template name="generate.typeset.url">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="url" select="$url"/>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:when test="$ulink.footnotes='1' or $ulink.show='1'">
|
|
<xsl:apply-templates/>
|
|
<xsl:if test="$ulink.footnotes='1' and count(ancestor::footnote)=0">
|
|
<xsl:call-template name="generate.ulink.in.footnote">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="url" select="$url"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
<xsl:if test="$ulink.show='1' or ($ulink.footnotes='1' and ancestor::footnote)">
|
|
<xsl:call-template name="generate.typeset.url">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="url" select="$url"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>\href{</xsl:text>
|
|
<xsl:call-template name="scape-href">
|
|
<xsl:with-param name="string" select="$url"/>
|
|
</xsl:call-template>
|
|
<xsl:text>}</xsl:text>
|
|
<xsl:text>{</xsl:text>
|
|
<xsl:apply-templates/>
|
|
<xsl:text>}</xsl:text><!-- End Of second argument of \href -->
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<doc:template match="olink" xmlns="">
|
|
<refpurpose>OLink XSL template</refpurpose>
|
|
<doc:description>
|
|
<para></para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template match="olink">
|
|
<xsl:apply-templates/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="*" name="title.xref">
|
|
<xsl:param name="target" select="."/>
|
|
<xsl:choose>
|
|
<xsl:when test="name($target) = 'figure'
|
|
or name($target) = 'example'
|
|
or name($target) = 'equation'
|
|
or name($target) = 'table'
|
|
or name($target) = 'dedication'
|
|
or name($target) = 'preface'
|
|
or name($target) = 'bibliography'
|
|
or name($target) = 'glossary'
|
|
or name($target) = 'index'
|
|
or name($target) = 'setindex'
|
|
or name($target) = 'colophon'">
|
|
<xsl:call-template name="gentext.startquote"/>
|
|
<xsl:apply-templates select="$target" mode="title.content"/>
|
|
<xsl:call-template name="gentext.endquote"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>{\em </xsl:text><xsl:apply-templates select="$target" mode="title.content"/><xsl:text>}</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="title" mode="xref">
|
|
<xsl:apply-templates/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="command" mode="xref">
|
|
<xsl:call-template name="inline.boldseq"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="function" mode="xref">
|
|
<xsl:call-template name="inline.monoseq"/>
|
|
</xsl:template>
|
|
|
|
<doc:template xmlns="">
|
|
<refpurpose> Typeset a URL using the <function condition="latex">url</function> or <function condition="latex">href</function> commands </refpurpose>
|
|
<doc:variables>
|
|
<itemizedlist>
|
|
<listitem><simpara><xref linkend="param.latex.url.quotation"/></simpara></listitem>
|
|
</itemizedlist>
|
|
</doc:variables>
|
|
<doc:description>
|
|
<para>If <xref linkend="param.latex.url.quotation"/> is set,
|
|
the <quote>urlstartquote</quote> and <quote>urlendquote</quote>
|
|
gentext dingbats will be emitted.</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template name="generate.typeset.url">
|
|
<xsl:param name="hyphenation"/>
|
|
<xsl:param name="url" select="@url"/>
|
|
<xsl:param name="prepend" select="' '"/>
|
|
<xsl:value-of select="$prepend"/>
|
|
<xsl:if test="$latex.url.quotation=1">
|
|
<xsl:call-template name="gentext.dingbat">
|
|
<xsl:with-param name="dingbat">urlstartquote</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
<xsl:choose>
|
|
<xsl:when test="$latex.use.url='1'">
|
|
<xsl:text>\url{</xsl:text>
|
|
<xsl:call-template name="scape-url">
|
|
<xsl:with-param name="string" select="$url"/>
|
|
</xsl:call-template>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:text>\href{</xsl:text>
|
|
<xsl:call-template name="scape-href">
|
|
<xsl:with-param name="string" select="$url"/>
|
|
</xsl:call-template>
|
|
<xsl:text>}{\texttt{</xsl:text>
|
|
<xsl:call-template name="generate.string.url">
|
|
<xsl:with-param name="hyphenation" select="$hyphenation"/>
|
|
<xsl:with-param name="string" select="$url"/>
|
|
</xsl:call-template>
|
|
<xsl:text>}}</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:if test="$latex.url.quotation=1">
|
|
<xsl:call-template name="gentext.dingbat">
|
|
<xsl:with-param name="dingbat">urlendquote</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<doc:template name="generate.string.url" xmlns="">
|
|
<refpurpose>Escape and hyphenate a string as a teletype URL.</refpurpose>
|
|
<doc:description>
|
|
<para>
|
|
This template typsets teletype text using slash.hyphen if
|
|
$latex.hyphenation.tttricks is disabled.
|
|
Has two parameters: 'hyphenation' and 'string'.
|
|
</para>
|
|
</doc:description>
|
|
</doc:template>
|
|
<xsl:template name="generate.string.url">
|
|
<xsl:param name="hyphenation" />
|
|
<xsl:param name="string" />
|
|
<xsl:param name="url" select="$string"/>
|
|
<xsl:choose>
|
|
<xsl:when test="$latex.hyphenation.tttricks=1">
|
|
<xsl:value-of select="$hyphenation" />
|
|
<xsl:text>{</xsl:text>
|
|
<xsl:call-template name="normalize-scape"><xsl:with-param name="string" select="$string"/></xsl:call-template>
|
|
<xsl:text>}</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<!-- LaTeX chars are scaped. Each / except the :// is mapped to a /\- -->
|
|
<xsl:call-template name="scape.slash.hyphen"><xsl:with-param name="string" select="$url"/></xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<xsl:template name="xpath.location">
|
|
<!-- abbreviated -->
|
|
<xsl:param name="node" select="."/>
|
|
<xsl:value-of select="local-name($node)"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="*" mode="object.xref.template">
|
|
<xsl:param name="purpose"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
<xsl:param name="referrer"/>
|
|
|
|
<xsl:variable name="user-template">
|
|
<xsl:if test="$xrefstyle != '' and not(contains($xrefstyle, ':'))">
|
|
<xsl:call-template name="gentext.template.exists">
|
|
<xsl:with-param name="context" select="$xrefstyle"/>
|
|
<xsl:with-param name="name">
|
|
<xsl:call-template name="xpath.location"/>
|
|
</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:variable>
|
|
|
|
<xsl:variable name="context">
|
|
<xsl:choose>
|
|
<xsl:when test="$user-template = 1">
|
|
<xsl:value-of select="$xrefstyle"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="'xref'"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:variable>
|
|
|
|
<xsl:call-template name="gentext.template">
|
|
<xsl:with-param name="context" select="$context"/>
|
|
<xsl:with-param name="name">
|
|
<xsl:call-template name="xpath.location"/>
|
|
</xsl:with-param>
|
|
<xsl:with-param name="purpose" select="$purpose"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:call-template>
|
|
|
|
</xsl:template>
|
|
|
|
<xsl:template match="*" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:message>
|
|
<xsl:text>Don't know what gentext to create for xref to: "</xsl:text>
|
|
<xsl:value-of select="name(.)"/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:message>
|
|
<xsl:text>?</xsl:text>
|
|
<xsl:value-of select="$referrer/@linkend"/>
|
|
<xsl:text>?</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="title" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="purpose"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
<xsl:param name="name">
|
|
<xsl:choose>
|
|
<xsl:when test="contains(local-name(parent::*), 'info')">
|
|
<xsl:call-template name="xpath.location">
|
|
<xsl:with-param name="node" select="../.."/>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:call-template name="xpath.location">
|
|
<xsl:with-param name="node" select=".."/>
|
|
</xsl:call-template>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:param>
|
|
|
|
<xsl:variable name="template">
|
|
<xsl:variable name="user-template">
|
|
<xsl:if test="$xrefstyle != '' and not(contains($xrefstyle, ':'))">
|
|
<xsl:call-template name="gentext.template.exists">
|
|
<xsl:with-param name="context" select="$xrefstyle"/>
|
|
<xsl:with-param name="name" select="$name"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:variable>
|
|
<xsl:variable name="context">
|
|
<xsl:choose>
|
|
<xsl:when test="$user-template = 1">
|
|
<xsl:value-of select="$xrefstyle"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="'title'"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:variable>
|
|
<xsl:call-template name="gentext.template">
|
|
<xsl:with-param name="context" select="$context"/>
|
|
<xsl:with-param name="name" select="$name"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="purpose" select="$purpose"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:call-template>
|
|
</xsl:variable>
|
|
|
|
<xsl:call-template name="substitute-markup">
|
|
<xsl:with-param name="purpose" select="$purpose"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
<xsl:with-param name="template" select="$template"/>
|
|
</xsl:call-template>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="abstract|article|authorblurb|bibliodiv|bibliomset
|
|
|biblioset|blockquote|calloutlist|caution|colophon
|
|
|constraintdef|formalpara|glossdiv|important|indexdiv
|
|
|itemizedlist|legalnotice|lot|msg|msgexplan|msgmain
|
|
|msgrel|msgset|msgsub|note|orderedlist|partintro
|
|
|productionset|qandadiv|refsynopsisdiv|segmentedlist
|
|
|set|setindex|sidebar|tip|toc|variablelist|warning"
|
|
mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<!-- catch-all for things with (possibly optional) titles -->
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="author|editor|othercredit|personname" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:call-template name="person.name"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="authorgroup" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:call-template name="person.name.list"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="figure|example|table|equation" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="procedure" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="cmdsynopsis" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="(.//command)[1]" mode="xref"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="funcsynopsis" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="(.//function)[1]" mode="xref"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="dedication|preface|chapter|appendix" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="bibliography" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<!--
|
|
<xsl:template match="biblioentry|bibliomixed" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:text>[</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="string(.) = ''">
|
|
<xsl:variable name="bib" select="document($bibliography.collection)"/>
|
|
<xsl:variable name="id" select="@id"/>
|
|
<xsl:variable name="entry" select="$bib/bibliography/*[@id=$id][1]"/>
|
|
<xsl:choose>
|
|
<xsl:when test="$entry">
|
|
<xsl:choose>
|
|
<xsl:when test="$bibliography.numbered != 0">
|
|
<xsl:number from="bibliography" count="biblioentry|bibliomixed"
|
|
level="any" format="1"/>
|
|
</xsl:when>
|
|
<xsl:when test="local-name($entry/*[1]) = 'abbrev'">
|
|
<xsl:apply-templates select="$entry/*[1]"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@id"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:message>
|
|
<xsl:text>No bibliography entry: </xsl:text>
|
|
<xsl:value-of select="$id"/>
|
|
<xsl:text> found in </xsl:text>
|
|
<xsl:value-of select="$bibliography.collection"/>
|
|
</xsl:message>
|
|
<xsl:value-of select="@id"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:choose>
|
|
<xsl:when test="$bibliography.numbered != 0">
|
|
<xsl:number from="bibliography" count="biblioentry|bibliomixed"
|
|
level="any" format="1"/>
|
|
</xsl:when>
|
|
<xsl:when test="local-name(*[1]) = 'abbrev'">
|
|
<xsl:apply-templates select="*[1]"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@id"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>]</xsl:text>
|
|
</xsl:template>
|
|
-->
|
|
|
|
<xsl:template match="glossary" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="glossentry" mode="xref-to">
|
|
<xsl:choose>
|
|
<xsl:when test="$glossentry.show.acronym = 'primary'">
|
|
<xsl:choose>
|
|
<xsl:when test="acronym|abbrev">
|
|
<xsl:apply-templates select="(acronym|abbrev)[1]"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-templates select="glossterm[1]" mode="xref-to"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-templates select="glossterm[1]" mode="xref-to"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="glossterm" mode="xref-to">
|
|
<xsl:apply-templates/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="index" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="listitem" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="section|simplesect
|
|
|sect1|sect2|sect3|sect4|sect5
|
|
|refsect1|refsect2|refsect3" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
<!-- What about "in Chapter X"? -->
|
|
</xsl:template>
|
|
|
|
<xsl:template match="bridgehead" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
<!-- What about "in Chapter X"? -->
|
|
</xsl:template>
|
|
|
|
<xsl:template match="qandaset" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="qandadiv" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="qandaentry" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="question[1]" mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="question|answer" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="part|reference" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="refentry" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:choose>
|
|
<xsl:when test="refmeta/refentrytitle">
|
|
<xsl:apply-templates select="refmeta/refentrytitle"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:apply-templates select="refnamediv/refname[1]"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:apply-templates select="refmeta/manvolnum"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="refnamediv" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="refname[1]" mode="xref-to">
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="refname" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates mode="xref-to">
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="step" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:call-template name="gentext">
|
|
<xsl:with-param name="key" select="'Step'"/>
|
|
</xsl:call-template>
|
|
<xsl:text> </xsl:text>
|
|
<xsl:apply-templates select="." mode="number"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="varlistentry" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="term[1]" mode="xref-to">
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="varlistentry/term" mode="xref-to">
|
|
<!-- to avoid the comma that will be generated if there are several terms -->
|
|
<xsl:apply-templates/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="co" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="callout-bug"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="book" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="para" mode="xref-to">
|
|
<xsl:param name="referrer"/>
|
|
<xsl:param name="xrefstyle"/>
|
|
|
|
<xsl:variable name="context" select="(ancestor::simplesect
|
|
|ancestor::section
|
|
|ancestor::sect1
|
|
|ancestor::sect2
|
|
|ancestor::sect3
|
|
|ancestor::sect4
|
|
|ancestor::sect5
|
|
|ancestor::refsection
|
|
|ancestor::refsect1
|
|
|ancestor::refsect2
|
|
|ancestor::refsect3
|
|
|ancestor::chapter
|
|
|ancestor::appendix
|
|
|ancestor::preface
|
|
|ancestor::partintro
|
|
|ancestor::dedication
|
|
|ancestor::colophon
|
|
|ancestor::bibliography
|
|
|ancestor::index
|
|
|ancestor::glossary
|
|
|ancestor::glossentry
|
|
|ancestor::listitem
|
|
|ancestor::varlistentry)[last()]"/>
|
|
|
|
<xsl:apply-templates select="$context" mode="xref-to"/>
|
|
<!--
|
|
<xsl:apply-templates select="." mode="object.xref.markup">
|
|
<xsl:with-param name="purpose" select="'xref'"/>
|
|
<xsl:with-param name="xrefstyle" select="$xrefstyle"/>
|
|
<xsl:with-param name="referrer" select="$referrer"/>
|
|
</xsl:apply-templates>
|
|
-->
|
|
</xsl:template>
|
|
|
|
</xsl:stylesheet>
|