1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184
|
<?xml version="1.0"?>
<!--
Purpose:
Make the anchor template dysfunctional.
See Also:
* http://docbook.sourceforge.net/release/xsl/current/doc/html/index.html
Author(s): Stefan Knorr <sknorr@suse.de>
Copyright: 2012, Stefan Knorr
-->
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns="http://www.w3.org/1999/xhtml">
<xsl:template name="anchor">
<xsl:param name="node" select="."/>
<xsl:param name="conditional" select="1"/>
<xsl:if test="local-name($node) = 'figure'">
<xsl:attribute name="id">
<xsl:call-template name="object.id">
<xsl:with-param name="object" select="$node"/>
</xsl:call-template>
</xsl:attribute>
</xsl:if>
</xsl:template>
<xsl:template match="question" mode="xref-to">
<xsl:param name="referrer"/>
<xsl:param name="xrefstyle"/>
<xsl:param name="verbose" select="1"/>
<xsl:variable name="teaser">
<xsl:apply-templates select="para[1]" mode="question"/>
</xsl:variable>
<xsl:variable name="teaser-length">
<xsl:value-of select="string-length(normalize-space($teaser))"/>
</xsl:variable>
<xsl:variable name="interpunction">
<xsl:if test="$teaser-length > 100">
<xsl:choose>
<xsl:when test="substring-before(substring($teaser,99,$teaser-length),'?')
!= ''">..?</xsl:when>
<xsl:otherwise>…</xsl:otherwise>
</xsl:choose>
</xsl:if>
</xsl:variable>
<em>
<xsl:choose>
<xsl:when test="$teaser-length > 100">
<xsl:value-of select="substring(normalize-space($teaser),1,100)"/>
<xsl:value-of select="$interpunction"/>
</xsl:when>
<xsl:otherwise>
<xsl:apply-templates select="para[1]" mode="question"/>
</xsl:otherwise>
</xsl:choose>
</em>
</xsl:template>
<xsl:template match="question/para[1]" mode="question">
<!-- We don't want a block here: we just process the next
child inside a para
-->
<xsl:apply-templates mode="question"/>
</xsl:template>
<xsl:template match="*" mode="qanda">
<!-- Fallback to default mode -->
<xsl:apply-templates select="."/>
</xsl:template>
<xsl:template match="ulink" name="ulink">
<xsl:param name="url" select="@url"/>
<xsl:variable name="link-text">
<xsl:apply-templates mode="no.anchor.mode"/>
</xsl:variable>
<xsl:variable name="flat-link-text">
<xsl:value-of select="$link-text"/>
</xsl:variable>
<a>
<xsl:apply-templates select="." mode="common.html.attributes"/>
<xsl:if test="@id or @xml:id">
<xsl:choose>
<xsl:when test="$generate.id.attributes = 0">
<xsl:attribute name="name">
<xsl:value-of select="(@id|@xml:id)[1]"/>
</xsl:attribute>
</xsl:when>
<xsl:otherwise>
<xsl:attribute name="id">
<xsl:value-of select="(@id|@xml:id)[1]"/>
</xsl:attribute>
</xsl:otherwise>
</xsl:choose>
</xsl:if>
<xsl:attribute name="href"><xsl:value-of select="$url"/></xsl:attribute>
<xsl:if test="$ulink.target != ''">
<xsl:attribute name="target">
<xsl:value-of select="$ulink.target"/>
</xsl:attribute>
</xsl:if>
<xsl:choose>
<!-- Don't just test for the existence of child nodes: The author may
have added a space between start and end tag and it would throw us
off. -->
<xsl:when test="normalize-space($flat-link-text) = ''">
<xsl:value-of select="$url"/>
</xsl:when>
<xsl:otherwise>
<xsl:copy-of select="$link-text"/>
<span class="ulink-url"> (<xsl:value-of select="$url"/>)</span>
</xsl:otherwise>
</xsl:choose>
</a>
</xsl:template>
<xsl:template match="xref" name="xref">
<xsl:variable name="targets" select="key('id',@linkend)"/>
<xsl:variable name="target" select="$targets[1]"/>
<xsl:variable name="refelem" select="local-name($target)"/>
<xsl:variable name="target.book" select="($target/ancestor-or-self::article|$target/ancestor-or-self::book)[1]"/>
<xsl:variable name="this.book" select="(ancestor-or-self::article|ancestor-or-self::book)[1]"/>
<xsl:variable name="lang" select="(ancestor-or-self::*/@lang|ancestor-or-self::*/@xml:lang)[1]"/>
<xsl:variable name="xref.in.samebook">
<xsl:call-template name="is.xref.in.samebook">
<xsl:with-param name="target" select="$target"/>
</xsl:call-template>
</xsl:variable>
<xsl:call-template name="check.id.unique">
<xsl:with-param name="linkend" select="@linkend"/>
</xsl:call-template>
<!--
The xref resolution is a bit tricky. We need to distinguish 3 cases:
1. if $rootid = '' -> use original code
2. if $rootid != '' and rootid points to the root node -> use original code
3. if (1) or (2) does not apply -> reference into another book
-->
<xsl:choose>
<xsl:when test="$rootid = ''">
<xsl:apply-imports/>
</xsl:when>
<xsl:when test="$rootid != '' and $xref.in.samebook != 0">
<xsl:apply-imports/>
</xsl:when>
<xsl:when test="$xref.in.samebook != 0 or /set/@id=$rootid or /article/@id=$rootid">
<!-- An xref that stays inside the current book or when $rootid
pointing to the root element, then use the defaults -->
<xsl:apply-imports/>
</xsl:when>
<xsl:otherwise>
<!-- A reference into another book -->
<xsl:variable name="target.chapandapp"
select="($target/ancestor-or-self::chapter[@lang!='']
| $target/ancestor-or-self::appendix[@lang!='']
| $target/ancestor-or-self::chapter[@xml:lang!='']
| $target/ancestor-or-self::appendix[@xml:lang!=''])[1]"/>
<xsl:if test="$warn.xrefs.into.diff.lang != 0 and
$target.chapandapp/@lang != $this.book/@lang">
<xsl:message>WARNING: The xref '<xsl:value-of
select="@linkend"/>' points to a chapter (id='<xsl:value-of
select="$target.chapandapp/@id"/>') with a different language than the main book.</xsl:message>
</xsl:if>
<span class="intraxref">
<xsl:call-template name="create.linkto.other.book">
<xsl:with-param name="target" select="$target"/>
</xsl:call-template>
</span>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>
|