********************************************************************
$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.
********************************************************************
<xsl:template match="d:index"><!-- some implementations use completely empty index tags to indicate --><!-- where an automatically generated index should be inserted. so --><!-- if the index is completely empty, skip it. Unless generate.index --><!-- is non-zero, in which case, this is where the automatically --><!-- generated index should go. --><xsl:call-template name="id.warning"/><xsl:if test="count(*)>0 or $generate.index != '0'"><div><xsl:apply-templates select="." mode="common.html.attributes"/><xsl:if test="$generate.id.attributes != 0"><xsl:attribute name="id"><xsl:call-template name="object.id"/></xsl:attribute></xsl:if><xsl:call-template name="index.titlepage"/><xsl:choose><xsl:when test="d:indexdiv"><xsl:apply-templates/></xsl:when><xsl:otherwise><xsl:apply-templates select="*[not(self::d:indexentry)]"/><!-- Because it's actually valid for Index to have neither any --><!-- Indexdivs nor any Indexentries, we need to check and make --><!-- sure that at least one Indexentry exists, and generate a --><!-- wrapper dl if there is at least one; otherwise, do nothing. --><xsl:if test="d:indexentry"><!-- The indexentry template assumes a parent dl wrapper has --><!-- been generated; for Indexes that have Indexdivs, the dl --><!-- wrapper is generated by the indexdiv template; however, --><!-- for Indexes that lack Indexdivs, if we don't generate a --><!-- dl here, HTML output will not be valid. --><dl><xsl:apply-templates select="d:indexentry"/></dl></xsl:if></xsl:otherwise></xsl:choose><xsl:if test="count(d:indexentry) = 0 and count(d:indexdiv) = 0"><xsl:call-template name="generate-index"><xsl:with-param name="scope" select="(ancestor::d:book|/)[last()]"/></xsl:call-template></xsl:if><xsl:if test="not(parent::d:article)"><xsl:call-template name="process.footnotes"/></xsl:if></div></xsl:if></xsl:template>
<xsl:template match="d:setindex"><!-- some implementations use completely empty index tags to indicate --><!-- where an automatically generated index should be inserted. so --><!-- if the index is completely empty, skip it. Unless generate.index --><!-- is non-zero, in which case, this is where the automatically --><!-- generated index should go. --><xsl:call-template name="id.warning"/><xsl:if test="count(*)>0 or $generate.index != '0'"><div><xsl:apply-templates select="." mode="common.html.attributes"/><xsl:if test="$generate.id.attributes != 0"><xsl:attribute name="id"><xsl:call-template name="object.id"/></xsl:attribute></xsl:if><xsl:call-template name="setindex.titlepage"/><xsl:apply-templates/><xsl:if test="count(d:indexentry) = 0 and count(d:indexdiv) = 0"><xsl:call-template name="generate-index"><xsl:with-param name="scope" select="/"/></xsl:call-template></xsl:if><xsl:if test="not(parent::d:article)"><xsl:call-template name="process.footnotes"/></xsl:if></div></xsl:if></xsl:template>
<xsl:template match="d:indexterm"><!-- this one must have a name, even if it doesn't have an ID --><xsl:variable name="id"><xsl:call-template name="object.id"/></xsl:variable><a id="{$id}" class="indexterm"/></xsl:template>
<xsl:template match="d:secondaryie" mode="indexentry"><dl><dt><xsl:apply-templates/></dt><dd><!-- select following see* elements up to next secondaryie or tertiary or end --><xsl:variable name="after.this" select="following-sibling::*"/><xsl:variable name="next.entry" select="(following-sibling::d:secondaryie|following-sibling::d:tertiaryie)[1]"/><xsl:variable name="before.entry" select="$next.entry/preceding-sibling::*"/><xsl:variable name="see.intersection" select="$after.this[count(.|$before.entry) = count($before.entry)] [self::d:seeie or self::d:seealsoie]"/><xsl:choose><xsl:when test="count($see.intersection) != 0"><xsl:apply-templates select="$see.intersection" mode="indexentry"/></xsl:when><xsl:when test="count($next.entry) = 0"><xsl:apply-templates select="following-sibling::d:seeie" mode="indexentry"/><xsl:apply-templates select="following-sibling::d:seealsoie" mode="indexentry"/></xsl:when></xsl:choose><!-- now process any tertiaryie before the next secondaryie --><xsl:variable name="before.next.secondary" select="following-sibling::d:secondaryie[1]/preceding-sibling::*"/><xsl:variable name="tertiary.intersection" select="$after.this[count(.|$before.next.secondary) = count($before.next.secondary)] [not(self::d:seeie) and not(self::d:seealsoie)]"/><xsl:choose><xsl:when test="count($tertiary.intersection) != 0"><xsl:apply-templates select="$tertiary.intersection" mode="indexentry"/></xsl:when><xsl:when test="not(following-sibling::d:secondaryie)"><xsl:apply-templates select="following-sibling::d:tertiaryie" mode="indexentry"/></xsl:when></xsl:choose></dd></dl></xsl:template>
Template
d:tertiaryieindexentry
Namespace
No namespace
Match
d:tertiaryie
Mode
indexentry
Import precedence
0
Source
<xsl:template match="d:tertiaryie" mode="indexentry"><dl><dt><xsl:apply-templates/></dt><dd><!-- select following see* elements up to next secondaryie or tertiary or end --><xsl:variable name="after.this" select="following-sibling::*"/><xsl:variable name="next.entry" select="(following-sibling::d:secondaryie|following-sibling::d:tertiaryie)[1]"/><xsl:variable name="before.entry" select="$next.entry/preceding-sibling::*"/><xsl:variable name="see.intersection" select="$after.this[count(.|$before.entry) = count($before.entry)] [self::d:seeie or self::d:seealsoie]"/><xsl:choose><xsl:when test="count($see.intersection) != 0"><xsl:apply-templates select="$see.intersection" mode="indexentry"/></xsl:when><xsl:when test="count($next.entry) = 0"><xsl:apply-templates select="following-sibling::d:seeie" mode="indexentry"/><xsl:apply-templates select="following-sibling::d:seealsoie" mode="indexentry"/></xsl:when></xsl:choose></dd></dl></xsl:template>