source: stylesheets/lfs-xsl/xhtml/lfs-index.xsl@ 869909a

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 9.1 kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 869909a was 869909a, checked in by Pierre Labastie <pieere@…>, 5 years ago

Allows using system docbook-xsl stylesheets:

  • with a slight change of the css stylesheet, allows having the glossary title in the same style as the others
  • tested with docbook-xsl 1.78.1, 1.79.1, 1.79.2

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@22137 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 16.8 KB
RevLine 
[65b2904]1<?xml version='1.0' encoding='ISO-8859-1'?>
2
3<!--
4$LastChangedBy$
5$Date$
6-->
7
8<!DOCTYPE xsl:stylesheet [
9<!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;'">
10<!ENTITY uppercase "'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABBBBBBBBBBBBBCCCCCCCCCCCCCCCCCDDDDDDDDDDDDDDDDDDDDDDDDEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEFFFFFFGGGGGGGGGGGGGGGGGGGGHHHHHHHHHHHHHHHHHHHHIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIJJJJJJKKKKKKKKKKKKKKLLLLLLLLLLLLLLLLLLLLLLLLLLMMMMMMMMMNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOPPPPPPPPQQQRRRRRRRRRRRRRRRRRRRRRRRSSSSSSSSSSSSSSSSSSSSSSSTTTTTTTTTTTTTTTTTTTTTTTTTUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUVVVVVVVVWWWWWWWWWWWWWWWXXXXXXYYYYYYYYYYYYYYYYYYYYYYYZZZZZZZZZZZZZZZZZZZZZ'">
11<!ENTITY primary 'normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = ""]))'>
12<!ENTITY secondary 'normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = ""]))'>
13<!ENTITY scope "count(ancestor::node()|$scope) = count(ancestor::node())">
14<!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()]">
15<!ENTITY section.id "generate-id(&section;)">
16<!ENTITY sep '" "'>
17]>
18
19<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
20 xmlns="http://www.w3.org/1999/xhtml"
21 version="1.0">
22
23 <!-- This stylesheet controls how the Index is generated.
24 Due how they are created, the original XHTML stylesheets don't make
25 use of the entities from {docbook-xsl}/common/entities.ent.
26 We add the relevant ones in the DOCTYPE to have more readable templates.
27 Also, we remove support for @role and @type based Index due that it is
28 broken when used with @zone based cross-references. -->
29
30 <!-- The file name of the Index page.
31 There is no upstream template with match="index", only a global
32 match="*", thus the next template is enought to force the Index
33 filename. -->
34 <xsl:template match="index" mode="recursive-chunk-filename">
35 <xsl:text>longindex.html</xsl:text>
36 </xsl:template>
37
[869909a]38 <!-- The Index title in the longindex.html page:
39 Removed a lot of code not useful for us.
40 Forced h1 title size.
41 The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl
42 Use the original template now (as in LFS)
[65b2904]43 <xsl:template name="index.titlepage">
44 <h1 class="index">
45 <xsl:call-template name="gentext">
46 <xsl:with-param name="key" select="$index-title"/>
47 </xsl:call-template>
48 </h1>
[869909a]49 </xsl:template>-->
[65b2904]50
51 <!--Divisions:
[c4b0455]52 Translate alphabetical divisions titles to by-type titles.
[65b2904]53 Added gentext support to divisions titles.
54 Using h2 for divisions titles.
55 Changed output from dl format to ul format. -->
56 <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
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 <xsl:if test="key('letter', $key)[&scope;] [count(.|key('primary', &primary;)[&scope;][1]) = 1]">
63 <xsl:if test="contains(concat(&lowercase;, &uppercase;), $key)">
64 <h2>
65 <xsl:choose>
66 <xsl:when test="$divtitle = 'A'">
67 <a id="package-index" name="package-index"/>
68 <xsl:call-template name="gentext">
69 <xsl:with-param name="key">Packages</xsl:with-param>
70 </xsl:call-template>
71 </xsl:when>
72 <xsl:when test="$divtitle = 'B'">
73 <a id="program-index" name="program-index"/>
74 <xsl:call-template name="gentext">
75 <xsl:with-param name="key">Programs</xsl:with-param>
76 </xsl:call-template>
77 </xsl:when>
78 <xsl:when test="$divtitle = 'C'">
79 <a id="library-index" name="library-index"/>
80 <xsl:call-template name="gentext">
81 <xsl:with-param name="key">Libraries</xsl:with-param>
82 </xsl:call-template>
83 </xsl:when>
84 <xsl:when test="$divtitle = 'D'">
85 <xsl:choose>
86 <xsl:when test="$book-type = 'blfs'">
87 <a id="kernel-config-index" name="kernel-config-index"/>
88 <xsl:call-template name="gentext">
89 <xsl:with-param name="key">Kernel Configuration</xsl:with-param>
90 </xsl:call-template>
91 </xsl:when>
92 <xsl:otherwise>
93 <a id="scripts-index" name="scripts-index"/>
94 <xsl:call-template name="gentext">
95 <xsl:with-param name="key">Scripts</xsl:with-param>
96 </xsl:call-template>
97 </xsl:otherwise>
98 </xsl:choose>
99 </xsl:when>
100 <xsl:when test="$divtitle = 'E'">
101 <xsl:choose>
102 <xsl:when test="$book-type = 'blfs'">
103 <a id="config-file-index" name="config-file-index"/>
104 <xsl:call-template name="gentext">
105 <xsl:with-param name="key">Configuration Files</xsl:with-param>
106 </xsl:call-template>
107 </xsl:when>
108 <xsl:otherwise>
109 <a id="other-index" name="other-index"/>
110 <xsl:call-template name="gentext">
111 <xsl:with-param name="key">Others</xsl:with-param>
112 </xsl:call-template>
113 </xsl:otherwise>
114 </xsl:choose>
115 </xsl:when>
116 <xsl:when test="$divtitle = 'F'">
117 <a id="bootscript-index" name="bootscript-index"/>
118 <xsl:call-template name="gentext">
119 <xsl:with-param name="key">Bootscripts</xsl:with-param>
120 </xsl:call-template>
121 </xsl:when>
122 <xsl:when test="$divtitle = 'G'">
123 <a id="other-index" name="other-index"/>
124 <xsl:call-template name="gentext">
125 <xsl:with-param name="key">Others</xsl:with-param>
126 </xsl:call-template>
127 </xsl:when>
128 <xsl:otherwise>
129 <xsl:value-of select="$divtitle"/>
130 </xsl:otherwise>
131 </xsl:choose>
132 </h2>
133 </xsl:if>
134 <ul>
[869909a]135 <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">
136 <xsl:with-param name="scope" select="$scope"/>
137 <xsl:sort select="translate(&primary;, &lowercase;, &uppercase;)"/>
138 </xsl:apply-templates>
[65b2904]139 </ul>
140 </xsl:if>
141 </xsl:template>
142
143 <!-- Primary items:
144 Changed the output format from dl to ul.
145 Placed the term and separator into strong tags.
146 Placed the target links into a div.
147 Removed code for unused see and sealso childs. -->
148 <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
149 <xsl:template match="indexterm" mode="index-primary">
150 <xsl:param name="scope" select="."/>
[869909a]151 <xsl:variable name="key" select="normalize-space(concat(primary/@sortas, &quot; &quot;, primary))"/>
152 <xsl:variable name="refs" select="key('primary', $key)[count(ancestor::node()|$scope) = count(ancestor::node())]"/>
[65b2904]153 <li>
154 <strong class="item">
155 <xsl:value-of select="primary"/>
156 <xsl:text>: </xsl:text>
157 </strong>
158 <span class='indexref'>
159 <xsl:for-each select="$refs[generate-id() = generate-id(key('primary-section',concat($key, &sep;, &section.id;))[&scope;][1])]">
160 <xsl:apply-templates select="." mode="reference">
161 <xsl:with-param name="scope" select="$scope"/>
162 </xsl:apply-templates>
163 </xsl:for-each>
164 </span>
165 <xsl:if test="$refs/secondary">
166 <ul>
[869909a]167 <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">
[65b2904]168 <xsl:with-param name="scope" select="$scope"/>
169 <xsl:sort select="translate(&secondary;, &lowercase;, &uppercase;)"/>
170 </xsl:apply-templates>
171 </ul>
172 </xsl:if>
173 </li>
174 </xsl:template>
175
176 <!-- Secondary items:
177 Changed the output format from dl to ul.
178 Placed the term and separator into strong tags.
179 Placed the target links into a div.
180 Removed code for unused tertiary, see, and sealso childs. -->
181 <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
182 <xsl:template match="indexterm" mode="index-secondary">
183 <xsl:param name="scope" select="."/>
[869909a]184 <xsl:variable name="key" select="concat(normalize-space(concat(primary/@sortas, &quot; &quot;, primary)), &quot; &quot;, normalize-space(concat(secondary/@sortas, &quot; &quot;, secondary)))"/>
185 <xsl:variable name="refs" select="key('secondary', $key)[count(ancestor::node()|$scope) = count(ancestor::node())]"/>
[65b2904]186 <li>
187 <strong class="secitem">
188 <xsl:value-of select="secondary"/>
189 <xsl:text>: </xsl:text>
190 </strong>
191 <span class='indexref'>
192 <xsl:for-each select="$refs[generate-id() = generate-id(key('secondary-section', concat($key, &sep;, &section.id;))[&scope;][1])]">
193 <xsl:apply-templates select="." mode="reference">
194 <xsl:with-param name="scope" select="$scope"/>
195 </xsl:apply-templates>
196 </xsl:for-each>
197 </span>
198 </li>
199 </xsl:template>
200
[869909a]201 <!-- Drop $term.separator and $number.separator from here as customized ones
202 are added in the output flow.
203 As all the indexterms in the book have @zone attributes, removed a lot of
204 unused code.
205 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
206 <xsl:template match="indexterm" mode="reference">
207 <xsl:param name="scope" select="."/>
208 <xsl:call-template name="reference">
209 <xsl:with-param name="zones" select="normalize-space(@zone)"/>
210 <xsl:with-param name="scope" select="$scope"/>
211 </xsl:call-template>
212 </xsl:template>
213
214 <!-- The target links:
215 Changed link separator
216 On the second @zone link, we use a fixed string for the text with gentext
217 support.
218 Assume that there are no more than 2 @zone in a indexterm.
219 Use href.target.uri named template to resolve the links. It is faster
220 than the default href.target named template.
221 The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
[65b2904]222 <xsl:template name="reference">
223 <xsl:param name="scope" select="."/>
224 <xsl:param name="zones"/>
225 <xsl:choose>
226 <xsl:when test="contains($zones, ' ')">
227 <xsl:variable name="zone" select="substring-before($zones, ' ')"/>
228 <xsl:variable name="zone2" select="substring-after($zones, ' ')"/>
229 <xsl:variable name="target" select="key('sections', $zone)[&scope;]"/>
230 <xsl:variable name="target2" select="key('sections', $zone2)[&scope;]"/>
231 <a>
232 <xsl:attribute name="href">
233 <xsl:call-template name="href.target.uri">
234 <xsl:with-param name="object" select="$target[1]"/>
235 </xsl:call-template>
236 </xsl:attribute>
237 <xsl:apply-templates select="$target[1]" mode="index-title-content"/>
238 </a>
239 <xsl:text> -- </xsl:text>
240 <a>
241 <xsl:attribute name="href">
242 <xsl:call-template name="href.target.uri">
243 <xsl:with-param name="object" select="$target2[1]"/>
244 </xsl:call-template>
245 </xsl:attribute>
246 <xsl:call-template name="gentext">
247 <xsl:with-param name="key">description</xsl:with-param>
248 </xsl:call-template>
249 </a>
250 <br/>
251 </xsl:when>
252 <xsl:otherwise>
253 <xsl:variable name="zone" select="$zones"/>
254 <xsl:variable name="target" select="key('sections', $zone)[&scope;]"/>
255 <a>
256 <xsl:attribute name="href">
257 <xsl:call-template name="href.target.uri">
258 <xsl:with-param name="object" select="$target[1]"/>
259 </xsl:call-template>
260 </xsl:attribute>
261 <xsl:apply-templates select="$target[1]" mode="index-title-content"/>
262 </a>
[fa068b9]263 <br/>
[65b2904]264 </xsl:otherwise>
265 </xsl:choose>
266 </xsl:template>
267
268</xsl:stylesheet>
Note: See TracBrowser for help on using the repository browser.