source: stylesheets/lfs-xsl/xhtml/lfs-index.xsl@ d5fda0b

12.1 12.1-rc1 multilib trunk xry111/arm64 xry111/clfs-ng xry111/loongarch xry111/loongarch-12.1 xry111/mips64el xry111/update-glibc
Last change on this file since d5fda0b was d5fda0b, checked in by Pierre Labastie <pierre.labastie@…>, 5 months ago

Style sheets: fix docbook-xsl bug in autoidx

The template named generate-basic-index in
{docbook-xsl}/xhtml/autoidx.xsl has a bug that generates a div element
with a wrong xmlns:xlink attribute. See
https://github.com/docbook/xslt10-stylesheets/issues/239.
Rather than fixing docbook-xsl, which would work only in LFS (but we
want to be able to render on other distros), copy the faulty template
to our customization files (lfs-index.xsl), so that this one is used.
We can also simplify it a lot since we don't need all the cases
covered in general docbook-xsl.

  • Property mode set to 100644
File size: 16.9 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2
3<!DOCTYPE xsl:stylesheet [
4<!ENTITY lowercase "'Aa&#192;&#224;&#193;&#225;&#194;&#226;&#195;&#227;&#196;&#228;&#197;&#229;&#256;&#257;&#258;&#259;&#260;&#261;&#461;&#462;&#478;&#479;&#480;&#481;&#506;&#507;&#512;&#513;&#514;&#515;&#550;&#551;&#7680;&#7681;&#7834;&#7840;&#7841;&#7842;&#7843;&#7844;&#7845;&#7846;&#7847;&#7848;&#7849;&#7850;&#7851;&#7852;&#7853;&#7854;&#7855;&#7856;&#7857;&#7858;&#7859;&#7860;&#7861;&#7862;&#7863;Bb&#384;&#385;&#595;&#386;&#387;&#7682;&#7683;&#7684;&#7685;&#7686;&#7687;Cc&#199;&#231;&#262;&#263;&#264;&#265;&#266;&#267;&#268;&#269;&#391;&#392;&#597;&#7688;&#7689;Dd&#270;&#271;&#272;&#273;&#394;&#599;&#395;&#396;&#453;&#498;&#545;&#598;&#7690;&#7691;&#7692;&#7693;&#7694;&#7695;&#7696;&#7697;&#7698;&#7699;Ee&#200;&#232;&#201;&#233;&#202;&#234;&#203;&#235;&#274;&#275;&#276;&#277;&#278;&#279;&#280;&#281;&#282;&#283;&#516;&#517;&#518;&#519;&#552;&#553;&#7700;&#7701;&#7702;&#7703;&#7704;&#7705;&#7706;&#7707;&#7708;&#7709;&#7864;&#7865;&#7866;&#7867;&#7868;&#7869;&#7870;&#7871;&#7872;&#7873;&#7874;&#7875;&#7876;&#7877;&#7878;&#7879;Ff&#401;&#402;&#7710;&#7711;Gg&#284;&#285;&#286;&#287;&#288;&#289;&#290;&#291;&#403;&#608;&#484;&#485;&#486;&#487;&#500;&#501;&#7712;&#7713;Hh&#292;&#293;&#294;&#295;&#542;&#543;&#614;&#7714;&#7715;&#7716;&#7717;&#7718;&#7719;&#7720;&#7721;&#7722;&#7723;&#7830;Ii&#204;&#236;&#205;&#237;&#206;&#238;&#207;&#239;&#296;&#297;&#298;&#299;&#300;&#301;&#302;&#303;&#304;&#407;&#616;&#463;&#464;&#520;&#521;&#522;&#523;&#7724;&#7725;&#7726;&#7727;&#7880;&#7881;&#7882;&#7883;Jj&#308;&#309;&#496;&#669;Kk&#310;&#311;&#408;&#409;&#488;&#489;&#7728;&#7729;&#7730;&#7731;&#7732;&#7733;Ll&#313;&#314;&#315;&#316;&#317;&#318;&#319;&#320;&#321;&#322;&#410;&#456;&#564;&#619;&#620;&#621;&#7734;&#7735;&#7736;&#7737;&#7738;&#7739;&#7740;&#7741;Mm&#625;&#7742;&#7743;&#7744;&#7745;&#7746;&#7747;Nn&#209;&#241;&#323;&#324;&#325;&#326;&#327;&#328;&#413;&#626;&#414;&#544;&#459;&#504;&#505;&#565;&#627;&#7748;&#7749;&#7750;&#7751;&#7752;&#7753;&#7754;&#7755;Oo&#210;&#242;&#211;&#243;&#212;&#244;&#213;&#245;&#214;&#246;&#216;&#248;&#332;&#333;&#334;&#335;&#336;&#337;&#415;&#416;&#417;&#465;&#466;&#490;&#491;&#492;&#493;&#510;&#511;&#524;&#525;&#526;&#527;&#554;&#555;&#556;&#557;&#558;&#559;&#560;&#561;&#7756;&#7757;&#7758;&#7759;&#7760;&#7761;&#7762;&#7763;&#7884;&#7885;&#7886;&#7887;&#7888;&#7889;&#7890;&#7891;&#7892;&#7893;&#7894;&#7895;&#7896;&#7897;&#7898;&#7899;&#7900;&#7901;&#7902;&#7903;&#7904;&#7905;&#7906;&#7907;Pp&#420;&#421;&#7764;&#7765;&#7766;&#7767;Qq&#672;Rr&#340;&#341;&#342;&#343;&#344;&#345;&#528;&#529;&#530;&#531;&#636;&#637;&#638;&#7768;&#7769;&#7770;&#7771;&#7772;&#7773;&#7774;&#7775;Ss&#346;&#347;&#348;&#349;&#350;&#351;&#352;&#353;&#536;&#537;&#642;&#7776;&#7777;&#7778;&#7779;&#7780;&#7781;&#7782;&#7783;&#7784;&#7785;Tt&#354;&#355;&#356;&#357;&#358;&#359;&#427;&#428;&#429;&#430;&#648;&#538;&#539;&#566;&#7786;&#7787;&#7788;&#7789;&#7790;&#7791;&#7792;&#7793;&#7831;Uu&#217;&#249;&#218;&#250;&#219;&#251;&#220;&#252;&#360;&#361;&#362;&#363;&#364;&#365;&#366;&#367;&#368;&#369;&#370;&#371;&#431;&#432;&#467;&#468;&#469;&#470;&#471;&#472;&#473;&#474;&#475;&#476;&#532;&#533;&#534;&#535;&#7794;&#7795;&#7796;&#7797;&#7798;&#7799;&#7800;&#7801;&#7802;&#7803;&#7908;&#7909;&#7910;&#7911;&#7912;&#7913;&#7914;&#7915;&#7916;&#7917;&#7918;&#7919;&#7920;&#7921;Vv&#434;&#651;&#7804;&#7805;&#7806;&#7807;Ww&#372;&#373;&#7808;&#7809;&#7810;&#7811;&#7812;&#7813;&#7814;&#7815;&#7816;&#7817;&#7832;Xx&#7818;&#7819;&#7820;&#7821;Yy&#221;&#253;&#255;&#376;&#374;&#375;&#435;&#436;&#562;&#563;&#7822;&#7823;&#7833;&#7922;&#7923;&#7924;&#7925;&#7926;&#7927;&#7928;&#7929;Zz&#377;&#378;&#379;&#380;&#381;&#382;&#437;&#438;&#548;&#549;&#656;&#657;&#7824;&#7825;&#7826;&#7827;&#7828;&#7829;&#7829;'">
5<!ENTITY uppercase "'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABBBBBBBBBBBBBCCCCCCCCCCCCCCCCCDDDDDDDDDDDDDDDDDDDDDDDDEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEFFFFFFGGGGGGGGGGGGGGGGGGGGHHHHHHHHHHHHHHHHHHHHIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIJJJJJJKKKKKKKKKKKKKKLLLLLLLLLLLLLLLLLLLLLLLLLLMMMMMMMMMNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOPPPPPPPPQQQRRRRRRRRRRRRRRRRRRRRRRRSSSSSSSSSSSSSSSSSSSSSSSTTTTTTTTTTTTTTTTTTTTTTTTTUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUVVVVVVVVWWWWWWWWWWWWWWWXXXXXXYYYYYYYYYYYYYYYYYYYYYYYZZZZZZZZZZZZZZZZZZZZZ'">
6<!ENTITY primary 'normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = ""]))'>
7<!ENTITY secondary 'normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = ""]))'>
8<!ENTITY scope "count(ancestor::node()|$scope) = count(ancestor::node())">
9<!ENTITY section "(ancestor-or-self::set |ancestor-or-self::book |ancestor-or-self::part |ancestor-or-self::reference |ancestor-or-self::partintro |ancestor-or-self::chapter |ancestor-or-self::appendix |ancestor-or-self::preface |ancestor-or-self::article |ancestor-or-self::section |ancestor-or-self::sect1 |ancestor-or-self::sect2 |ancestor-or-self::sect3 |ancestor-or-self::sect4 |ancestor-or-self::sect5 |ancestor-or-self::refentry |ancestor-or-self::refsect1 |ancestor-or-self::refsect2 |ancestor-or-self::refsect3 |ancestor-or-self::simplesect |ancestor-or-self::bibliography |ancestor-or-self::glossary |ancestor-or-self::index |ancestor-or-self::webpage)[last()]">
10<!ENTITY section.id "generate-id(&section;)">
11<!ENTITY sep '" "'>
12]>
13
14<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
15 xmlns="http://www.w3.org/1999/xhtml"
16 version="1.0">
17
18 <!-- Change the file name of the index page from the default ix01.html.
19 There is no upstream template with match="index", only a global
20 match="*", thus the following is enough to override the index
21 filename. -->
22
23 <xsl:template match="index" mode="recursive-chunk-filename">
24 <xsl:text>longindex.html</xsl:text>
25 </xsl:template>
26
27 <!-- The original template in {docbook-xsl}/xhtml/autoidx.xsl has
28 a bug that generates a <div> with a wrong xmlns:xlink attribute,
29 so copy it here (and simplify it a lot)-->
30 <xsl:template name="generate-basic-index">
31 <xsl:param name="scope" select="NOTANODE"/>
32
33 <xsl:variable name="terms" select="//indexterm
34 [count(.|key('letter',
35 translate(substring(&primary;, 1, 1),
36 &lowercase;,
37 &uppercase;
38 )
39 ) [&scope;][1]) = 1]"/>
40 <div class="index">
41 <xsl:apply-templates select="$terms" mode="index-div-basic">
42 <xsl:with-param name="position" select="position()"/>
43 <xsl:with-param name="scope" select="$scope"/>
44 <xsl:sort select="translate(&primary;, &lowercase;, &uppercase;)"/>
45 </xsl:apply-templates>
46 </div>
47 </xsl:template>
48
49 <!-- Divisions:
50 Override the default division titles, translating them from the default
51 'A', 'B', etc. to 'Packages', 'Programs', etc.
52 Add gentext support to division titles.
53 Use h2 for division titles instead of the default h3.
54 Change main listings from dl to ul format.
55 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
56
57 <xsl:template match="indexterm" mode="index-div-basic">
58 <xsl:param name="scope" select="."/>
59 <xsl:variable name="key" select="translate(substring(&primary;, 1, 1),&lowercase;,&uppercase;)"/>
60 <xsl:variable name="divtitle" select="translate($key, &lowercase;, &uppercase;)"/>
61 <!-- Make sure that we don't generate a div if there are no terms in scope
62 -->
63 <xsl:if test="key('letter', $key)[&scope;] [count(.|key('primary', &primary;)[&scope;][1]) = 1]">
64 <xsl:if test="contains(concat(&lowercase;, &uppercase;), $key)">
65 <h2>
66 <xsl:choose>
67 <xsl:when test="$divtitle = 'A'">
68 <a id="package-index" name="package-index"/>
69 <xsl:call-template name="gentext">
70 <xsl:with-param name="key">Packages</xsl:with-param>
71 </xsl:call-template>
72 </xsl:when>
73 <xsl:when test="$divtitle = 'B'">
74 <a id="program-index" name="program-index"/>
75 <xsl:call-template name="gentext">
76 <xsl:with-param name="key">Programs</xsl:with-param>
77 </xsl:call-template>
78 </xsl:when>
79 <xsl:when test="$divtitle = 'C'">
80 <a id="library-index" name="library-index"/>
81 <xsl:call-template name="gentext">
82 <xsl:with-param name="key">Libraries</xsl:with-param>
83 </xsl:call-template>
84 </xsl:when>
85 <xsl:when test="$divtitle = 'D'">
86 <xsl:choose>
87 <xsl:when test="$book-type = 'blfs'">
88 <a id="kernel-config-index" name="kernel-config-index"/>
89 <xsl:call-template name="gentext">
90 <xsl:with-param name="key">Kernel Configuration</xsl:with-param>
91 </xsl:call-template>
92 </xsl:when>
93 <xsl:otherwise>
94 <a id="scripts-index" name="scripts-index"/>
95 <xsl:call-template name="gentext">
96 <xsl:with-param name="key">Scripts</xsl:with-param>
97 </xsl:call-template>
98 </xsl:otherwise>
99 </xsl:choose>
100 </xsl:when>
101 <xsl:when test="$divtitle = 'E'">
102 <xsl:choose>
103 <xsl:when test="$book-type = 'blfs'">
104 <a id="config-file-index" name="config-file-index"/>
105 <xsl:call-template name="gentext">
106 <xsl:with-param name="key">Configuration Files</xsl:with-param>
107 </xsl:call-template>
108 </xsl:when>
109 <xsl:otherwise>
110 <a id="other-index" name="other-index"/>
111 <xsl:call-template name="gentext">
112 <xsl:with-param name="key">Others</xsl:with-param>
113 </xsl:call-template>
114 </xsl:otherwise>
115 </xsl:choose>
116 </xsl:when>
117 <xsl:when test="$divtitle = 'F'">
118 <a id="bootscript-index" name="bootscript-index"/>
119 <xsl:call-template name="gentext">
120 <xsl:with-param name="key">Bootscripts</xsl:with-param>
121 </xsl:call-template>
122 </xsl:when>
123 <xsl:when test="$divtitle = 'G'">
124 <a id="other-index" name="other-index"/>
125 <xsl:call-template name="gentext">
126 <xsl:with-param name="key">Others</xsl:with-param>
127 </xsl:call-template>
128 </xsl:when>
129 <xsl:otherwise>
130 <xsl:value-of select="$divtitle"/>
131 </xsl:otherwise>
132 </xsl:choose>
133 </h2>
134 </xsl:if>
135 <ul>
136 <xsl:apply-templates select="key('letter', $key)[count(ancestor::node()|$scope) = count(ancestor::node())][count(.|key('primary', normalize-space(concat(primary/@sortas, &quot; &quot;, primary)))[count(ancestor::node()|$scope) = count(ancestor::node())][1])=1]" mode="index-primary">
137 <xsl:with-param name="scope" select="$scope"/>
138 <xsl:sort select="translate(&primary;, &lowercase;, &uppercase;)"/>
139 </xsl:apply-templates>
140 </ul>
141 </xsl:if>
142 </xsl:template>
143
144 <!-- Primary items:
145 Place term and separator into strong tags.
146 Place target links into a div.
147 Change main listings from dl to ul format.
148 Removed code for unused see and sealso children.
149 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
150 <xsl:template match="indexterm" mode="index-primary">
151 <xsl:param name="scope" select="."/>
152 <xsl:variable name="key" select="normalize-space(concat(primary/@sortas, &quot; &quot;, primary))"/>
153 <xsl:variable name="refs" select="key('primary', $key)[count(ancestor::node()|$scope) = count(ancestor::node())]"/>
154 <li>
155 <strong class="item">
156 <xsl:value-of select="primary"/>
157 <xsl:text>: </xsl:text>
158 </strong>
159 <span class='indexref'>
160 <xsl:for-each select="$refs[generate-id() = generate-id(key('primary-section',concat($key, &sep;, &section.id;))[&scope;][1])]">
161 <!--<xsl:for-each select="$refs[not(see) and not(secondary)][count(ancestor::node()|$scope) = count(ancestor::node()) = 0]">-->
162 <xsl:apply-templates select="." mode="reference">
163 <xsl:with-param name="scope" select="$scope"/>
164 </xsl:apply-templates>
165 </xsl:for-each>
166 </span>
167 <xsl:if test="$refs/secondary">
168 <ul>
169 <xsl:apply-templates select="$refs[secondary and count(.|key('secondary', concat($key, &quot; &quot;, normalize-space(concat(secondary/@sortas, &quot; &quot;, secondary))))[count(ancestor::node()|$scope) = count(ancestor::node()) ][1]) = 1]" mode="index-secondary">
170 <xsl:with-param name="scope" select="$scope"/>
171 <xsl:sort select="translate(&secondary;, &lowercase;, &uppercase;)"/>
172 </xsl:apply-templates>
173 </ul>
174 </xsl:if>
175 </li>
176 </xsl:template>
177
178 <!-- Secondary items:
179 Place term and separator into strong tags.
180 Place target links into a div.
181 Change main listings from dl to ul format.
182 Removed code for unused tertiary, see and sealso children.
183 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
184 <xsl:template match="indexterm" mode="index-secondary">
185 <xsl:param name="scope" select="."/>
186 <xsl:variable name="key" select="concat(normalize-space(concat(primary/@sortas, &quot; &quot;, primary)), &quot; &quot;, normalize-space(concat(secondary/@sortas, &quot; &quot;, secondary)))"/>
187 <xsl:variable name="refs" select="key('secondary', $key)[count(ancestor::node()|$scope) = count(ancestor::node())]"/>
188 <li>
189 <strong class="secitem">
190 <xsl:value-of select="secondary"/>
191 <xsl:text>: </xsl:text>
192 </strong>
193 <span class='indexref'>
194 <xsl:for-each select="$refs[generate-id() = generate-id(key('secondary-section', concat($key, &sep;, &section.id;))[&scope;][1])]">
195 <xsl:apply-templates select="." mode="reference">
196 <xsl:with-param name="scope" select="$scope"/>
197 </xsl:apply-templates>
198 </xsl:for-each>
199 </span>
200 </li>
201 </xsl:template>
202
203 <!-- Drop $term.separator and $number.separator from here as customized ones
204 are added in the output flow.
205 As all the indexterms in the book have @zone attributes, removed a lot of
206 unused code.
207 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
208 <xsl:template match="indexterm" mode="reference">
209 <xsl:param name="scope" select="."/>
210 <xsl:call-template name="reference">
211 <xsl:with-param name="zones" select="normalize-space(@zone)"/>
212 <xsl:with-param name="scope" select="$scope"/>
213 </xsl:call-template>
214 </xsl:template>
215
216 <!-- The target links:
217 Changed link separator
218 On the second @zone link, we use a fixed string for the text with gentext
219 support.
220 Assume that there are no more than 2 @zone in a indexterm.
221 Use href.target.uri named template to resolve the links. It is faster
222 than the default href.target named template.
223 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
224 <xsl:template name="reference">
225 <xsl:param name="scope" select="."/>
226 <xsl:param name="zones"/>
227 <xsl:choose>
228 <xsl:when test="contains($zones, ' ')">
229 <xsl:variable name="zone" select="substring-before($zones, ' ')"/>
230 <xsl:variable name="zone2" select="substring-after($zones, ' ')"/>
231 <xsl:variable name="target" select="key('sections', $zone)[&scope;]"/>
232 <xsl:variable name="target2" select="key('sections', $zone2)[&scope;]"/>
233 <a>
234 <xsl:attribute name="href">
235 <xsl:call-template name="href.target.uri">
236 <xsl:with-param name="object" select="$target[1]"/>
237 </xsl:call-template>
238 </xsl:attribute>
239 <xsl:apply-templates select="$target[1]" mode="index-title-content"/>
240 </a>
241 <xsl:text> -- </xsl:text>
242 <a>
243 <xsl:attribute name="href">
244 <xsl:call-template name="href.target.uri">
245 <xsl:with-param name="object" select="$target2[1]"/>
246 </xsl:call-template>
247 </xsl:attribute>
248 <xsl:call-template name="gentext">
249 <xsl:with-param name="key">description</xsl:with-param>
250 </xsl:call-template>
251 </a>
252 <br/>
253 </xsl:when>
254 <xsl:otherwise>
255 <xsl:variable name="zone" select="$zones"/>
256 <xsl:variable name="target" select="key('sections', $zone)[&scope;]"/>
257 <a>
258 <xsl:attribute name="href">
259 <xsl:call-template name="href.target.uri">
260 <xsl:with-param name="object" select="$target[1]"/>
261 </xsl:call-template>
262 </xsl:attribute>
263 <xsl:apply-templates select="$target[1]" mode="index-title-content"/>
264 </a>
265 </xsl:otherwise>
266 </xsl:choose>
267 </xsl:template>
268
269</xsl:stylesheet>
Note: See TracBrowser for help on using the repository browser.