Showing:

Documentation
Parameters
Used by
References
Included from
Source
Stylesheet targets.xsl
Included from
Template *collect.targets
Documentation
<doc:mode mode="collect.targets">
<refpurpose>Collects information for potential cross reference targets</refpurpose>
<refdescription id="collect.targets-desc">
<para>Processing the root element in the
<literal role="mode">collect.targets</literal> mode produces 
a set of target database elements that can be used by
the olink mechanism to resolve external cross references.
The collection process is controlled by the <literal>
collect.xref.targets</literal> parameter, which can be
<literal>yes</literal> to collect targets and process
the document for output, <literal>only</literal> to
only collect the targets, and <literal>no</literal>
(default) to not collect the targets and only process the document.
</para>
<para>
A <literal>targets.filename</literal> parameter must be
specified to receive the output if 
<literal>collect.xref.targets</literal> is
set to <literal>yes</literal> so as to
redirect the target data to a file separate from the
document output.
</para>
</refdescription>
</doc:mode>

Description

 ********************************************************************
     $Id$
     ********************************************************************

     This file is part of the XSL DocBook Stylesheet distribution.
     See ../README or http://docbook.sf.net/release/xsl/current/ for
     copyright and other information.

     ******************************************************************** 
 ==================================================================== 
 cross reference target collection  
 ============================================================ 
Namespace No namespace
Match *
Mode collect.targets
References
Import precedence 0
Source
<xsl:template match="*" mode="collect.targets">
  <xsl:choose>
    <xsl:when test="$collect.xref.targets = 'yes' and $targets.filename = ''">
      <xsl:message>Must specify a $targets.filename parameter when
        $collect.xref.targets is set to 'yes'.
        The xref targets were not collected.</xsl:message>
    </xsl:when>
    <xsl:otherwise>
      <xsl:choose>
        <xsl:when test="$targets.filename">
          <xsl:call-template name="write.chunk">
            <xsl:with-param name="filename" select="$targets.filename"/>
            <xsl:with-param name="method" select="'xml'"/>
            <xsl:with-param name="encoding" select="'utf-8'"/>
            <xsl:with-param name="omit-xml-declaration" select="'yes'"/>
            <xsl:with-param name="doctype-public" select="''"/>
            <xsl:with-param name="doctype-system" select="''"/>
            <xsl:with-param name="indent" select="'no'"/>
            <xsl:with-param name="quiet" select="0"/>
            <xsl:with-param name="content">
              <xsl:apply-templates select="." mode="olink.mode"/>
            </xsl:with-param>
          </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
          <!-- Else write to standard output -->
          <xsl:apply-templates select="." mode="olink.mode"/>
        </xsl:otherwise>
      </xsl:choose>
    </xsl:otherwise>
  </xsl:choose>
</xsl:template>
Template olink.href.target
Namespace No namespace
Used by
Template attrs
References
Parameter olink.base.uri
Template href.target
Parameters
QName Namespace Select
nd No namespace .
Import precedence 0
Source
<xsl:template name="olink.href.target">
  <xsl:param name="nd" select="."/>
  <xsl:value-of select="$olink.base.uri"/>
  <xsl:call-template name="href.target">
    <xsl:with-param name="object" select="$nd"/>
    <xsl:with-param name="context" select="NOTANODE"/>
  </xsl:call-template>
</xsl:template>
Template attrs
Documentation

Description

 Templates for extracting cross reference information
     from a document for use in an xref database.
Namespace No namespace
Used by
Templates div; obj
References
Parameters
QName Namespace Select
nd No namespace .
Import precedence 0
Source
<xsl:template name="attrs">
  <xsl:param name="nd" select="."/>
  <xsl:attribute name="element">
    <xsl:value-of select="local-name(.)"/>
  </xsl:attribute>
  <xsl:attribute name="href">
    <xsl:call-template name="olink.href.target">
      <xsl:with-param name="nd" select="$nd"/>
    </xsl:call-template>
  </xsl:attribute>
  <xsl:variable name="num">
    <xsl:apply-templates select="$nd" mode="label.markup">
      <xsl:with-param name="verbose" select="0"/>
    </xsl:apply-templates>
  </xsl:variable>
  <xsl:if test="$num">
    <xsl:attribute name="number">
      <xsl:value-of select="$num"/>
    </xsl:attribute>
  </xsl:if>
  <xsl:choose>
    <xsl:when test="$nd/@id">
      <xsl:attribute name="targetptr">
        <xsl:value-of select="$nd/@id"/>
      </xsl:attribute>
    </xsl:when>
    <xsl:when test="$nd/@xml:id">
      <xsl:attribute name="targetptr">
        <xsl:value-of select="$nd/@xml:id"/>
      </xsl:attribute>
    </xsl:when>
  </xsl:choose>
  <xsl:if test="$nd/@lang">
    <xsl:attribute name="lang">
      <xsl:value-of select="$nd/@lang"/>
    </xsl:attribute>
  </xsl:if>
</xsl:template>
Template div
Namespace No namespace
Used by
References
Templates attrs; xref.xreflabel
Parameters
QName Namespace Select
nd No namespace .
Import precedence 0
Source
<xsl:template name="div">
  <xsl:param name="nd" select="."/>
  <div>
    <xsl:call-template name="attrs">
      <xsl:with-param name="nd" select="$nd"/>
    </xsl:call-template>
    <ttl>
      <xsl:apply-templates select="$nd" mode="title.markup">
        <xsl:with-param name="verbose" select="0"/>
      </xsl:apply-templates>
    </ttl>
    <xreftext>
      <xsl:choose>
        <xsl:when test="$nd/@xreflabel">
          <xsl:call-template name="xref.xreflabel">
            <xsl:with-param name="target" select="$nd"/>
          </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
          <xsl:apply-templates select="$nd" mode="xref-to">
            <xsl:with-param name="verbose" select="0"/>
          </xsl:apply-templates>
        </xsl:otherwise>
      </xsl:choose>
    </xreftext>
    <xsl:apply-templates mode="olink.mode"/>
  </div>
</xsl:template>
Template obj
Namespace No namespace
Used by
References
Templates attrs; xref.xreflabel
Parameters
QName Namespace Select
nd No namespace .
Import precedence 0
Source
<xsl:template name="obj">
  <xsl:param name="nd" select="."/>
  <obj>
    <xsl:call-template name="attrs">
      <xsl:with-param name="nd" select="$nd"/>
    </xsl:call-template>
    <ttl>
      <xsl:apply-templates select="$nd" mode="title.markup">
        <xsl:with-param name="verbose" select="0"/>
      </xsl:apply-templates>
    </ttl>
    <xreftext>
      <xsl:choose>
        <xsl:when test="$nd/@xreflabel">
          <xsl:call-template name="xref.xreflabel">
            <xsl:with-param name="target" select="$nd"/>
          </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
          <xsl:apply-templates select="$nd" mode="xref-to">
            <xsl:with-param name="verbose" select="0"/>
          </xsl:apply-templates>
        </xsl:otherwise>
      </xsl:choose>
    </xreftext>
  </obj>
</xsl:template>
Template text()|processing-instruction()|comment()olink.mode
Namespace No namespace
Match text()|processing-instruction()|comment()
Mode olink.mode
Import precedence 0
Source
<xsl:template match="text()|processing-instruction()|comment()" mode="olink.mode">
  <!-- nop -->
</xsl:template>
Template d:setolink.mode
Documentation

Description

<xsl:template match="*" mode="olink.mode">
</xsl:template>
Namespace No namespace
Match d:set
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:set" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:bookolink.mode
Namespace No namespace
Match d:book
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:book" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:preface|d:chapter|d:appendixolink.mode
Namespace No namespace
Match d:preface|d:chapter|d:appendix
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:preface|d:chapter|d:appendix" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:part|d:referenceolink.mode
Namespace No namespace
Match d:part|d:reference
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:part|d:reference" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:articleolink.mode
Namespace No namespace
Match d:article
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:article" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:bibliography|d:bibliodivolink.mode
Namespace No namespace
Match d:bibliography|d:bibliodiv
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:bibliography|d:bibliodiv" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:biblioentry|d:bibliomixedolink.mode
Namespace No namespace
Match d:biblioentry|d:bibliomixed
Mode olink.mode
References
Template obj
Import precedence 0
Source
<xsl:template match="d:biblioentry|d:bibliomixed" mode="olink.mode">
  <xsl:call-template name="obj"/>
</xsl:template>
Template d:refentryolink.mode
Namespace No namespace
Match d:refentry
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:refentry" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:section|d:sect1|d:sect2|d:sect3|d:sect4|d:sect5olink.mode
Namespace No namespace
Match d:section|d:sect1|d:sect2|d:sect3|d:sect4|d:sect5
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:section|d:sect1|d:sect2|d:sect3|d:sect4|d:sect5" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:refsection|d:refsect1|d:refsect2|d:refsect3olink.mode
Namespace No namespace
Match d:refsection|d:refsect1|d:refsect2|d:refsect3
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:refsection|d:refsect1|d:refsect2|d:refsect3" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:figure|d:example|d:tableolink.mode
Namespace No namespace
Match d:figure|d:example|d:table
Mode olink.mode
References
Template obj
Import precedence 0
Source
<xsl:template match="d:figure|d:example|d:table" mode="olink.mode">
  <xsl:call-template name="obj"/>
  <xsl:apply-templates mode="olink.mode"/>
</xsl:template>
Template d:equation[d:title or d:info/d:title]olink.mode
Namespace No namespace
Match d:equation[d:title or d:info/d:title]
Mode olink.mode
References
Template obj
Import precedence 0
Source
<xsl:template match="d:equation[d:title or d:info/d:title]" mode="olink.mode">
  <xsl:call-template name="obj"/>
</xsl:template>
Template d:qandaset|d:qandaentryolink.mode
Namespace No namespace
Match d:qandaset|d:qandaentry
Mode olink.mode
References
Template div
Import precedence 0
Source
<xsl:template match="d:qandaset|d:qandaentry" mode="olink.mode">
  <xsl:call-template name="div"/>
</xsl:template>
Template d:glossary[@role='auto']olink.mode
Documentation

Description

 handle an glossary collection 
Namespace No namespace
Match d:glossary[@role='auto']
Mode olink.mode
References
Import precedence 0
Priority 2
Source
<xsl:template match="d:glossary[@role='auto']" mode="olink.mode" priority="2">
  <xsl:variable name="collection" select="document($glossary.collection, .)"/>
  <xsl:if test="$glossary.collection = ''">
    <xsl:message>
      <xsl:text>Warning: processing automatic glossary </xsl:text>
      <xsl:text>without a glossary.collection file.</xsl:text>
    </xsl:message>
  </xsl:if>
  <xsl:if test="not($collection) and $glossary.collection != ''">
    <xsl:message>
      <xsl:text>Warning: processing automatic glossary but unable to </xsl:text>
      <xsl:text>open glossary.collection file '</xsl:text>
      <xsl:value-of select="$glossary.collection"/>
      <xsl:text>'</xsl:text>
    </xsl:message>
  </xsl:if>
  <xsl:if test="$exsl.node.set.available != 0">
    <xsl:variable name="auto.glossary">
      <xsl:apply-templates select="." mode="assemble.auto.glossary"/>
    </xsl:variable>
    <xsl:variable name="auto.glossary.nodeset" select="exsl:node-set($auto.glossary)"/>
    <xsl:apply-templates select="$auto.glossary.nodeset/*" mode="olink.mode"/>
  </xsl:if>
</xsl:template>
Template d:glossaryassemble.auto.glossary
Documentation

Description

 construct a glossary in memory 
Namespace No namespace
Match d:glossary
Mode assemble.auto.glossary
References
Import precedence 0
Source
<xsl:template match="d:glossary" mode="assemble.auto.glossary">
  <xsl:copy>
    <xsl:copy-of select="@*[not(local-name() = 'role')]"/>
    <xsl:apply-templates select="node()" mode="assemble.auto.glossary"/>
    <xsl:call-template name="select.glossentries"/>
  </xsl:copy>
</xsl:template>
Template select.glossentries
Namespace No namespace
Used by
References
Parameters
QName Namespace Select
collection No namespace document($glossary.collection, .)
terms No namespace //d:glossterm[not(parent::d:glossdef)]|//d:firstterm
Import precedence 0
Source
<xsl:template name="select.glossentries">
  <xsl:param name="collection" select="document($glossary.collection, .)"/>
  <xsl:param name="terms" select="//d:glossterm[not(parent::d:glossdef)]|//d:firstterm"/>
  <xsl:for-each select="$collection//d:glossentry">
    <xsl:variable name="cterm" select="d:glossterm"/>
    <xsl:if test="$terms[@baseform = $cterm or . = $cterm]">
      <xsl:copy-of select="."/>
    </xsl:if>
  </xsl:for-each>
</xsl:template>
Template d:glossentryassemble.auto.glossary
Namespace No namespace
Match d:glossentry
Mode assemble.auto.glossary
Import precedence 0
Source
<xsl:template match="d:glossentry" mode="assemble.auto.glossary">
  <!-- skip the dummy entries -->
</xsl:template>
Template *assemble.auto.glossary
Namespace No namespace
Match *
Mode assemble.auto.glossary
Import precedence 0
Source
<xsl:template match="*" mode="assemble.auto.glossary">
  <!-- pass through any titles and intro stuff -->
  <xsl:copy-of select="."/>
</xsl:template>
Template *olink.mode
Namespace No namespace
Match *
Mode olink.mode
References
Template obj
Import precedence 0
Source
<xsl:template match="*" mode="olink.mode">
  <xsl:if test="@id or @xml:id">
    <xsl:call-template name="obj"/>
  </xsl:if>
  <xsl:apply-templates mode="olink.mode"/>
</xsl:template>