lfs-index.xsl 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. <?xml version='1.0' encoding='ISO-8859-1'?>
  2. <!DOCTYPE xsl:stylesheet [
  3. <!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;'">
  4. <!ENTITY uppercase "'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABBBBBBBBBBBBBCCCCCCCCCCCCCCCCCDDDDDDDDDDDDDDDDDDDDDDDDEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEFFFFFFGGGGGGGGGGGGGGGGGGGGHHHHHHHHHHHHHHHHHHHHIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIJJJJJJKKKKKKKKKKKKKKLLLLLLLLLLLLLLLLLLLLLLLLLLMMMMMMMMMNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOPPPPPPPPQQQRRRRRRRRRRRRRRRRRRRRRRRSSSSSSSSSSSSSSSSSSSSSSSTTTTTTTTTTTTTTTTTTTTTTTTTUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUVVVVVVVVWWWWWWWWWWWWWWWXXXXXXYYYYYYYYYYYYYYYYYYYYYYYZZZZZZZZZZZZZZZZZZZZZ'">
  5. <!ENTITY primary 'normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = ""]))'>
  6. <!ENTITY secondary 'normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = ""]))'>
  7. <!ENTITY scope "count(ancestor::node()|$scope) = count(ancestor::node()) and ($role = @role or $type = @type or (string-length($role) = 0 and string-length($type) = 0))">
  8. <!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()]">
  9. <!ENTITY section.id "generate-id(&section;)">
  10. <!ENTITY sep '" "'>
  11. ]>
  12. <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  13. xmlns="http://www.w3.org/1999/xhtml"
  14. version="1.0">
  15. <!-- This stylesheet controls how the Index is generated.
  16. Due how they are created, the original XHTML stylesheets don't make
  17. use of the entities from {docbook-xsl}/common/entities.ent.
  18. We add the relevant ones in the DOCTYPE to have more readable templates. -->
  19. <!-- The file name of the Index page.
  20. There is no upstream template with match="index", only a global
  21. match="*", thus the next template is enought to force the Index
  22. filename. -->
  23. <xsl:template match="index" mode="recursive-chunk-filename">
  24. <xsl:text>longindex.html</xsl:text>
  25. </xsl:template>
  26. <!-- The Index title in the longindex.html page:
  27. Removed a lot of code not useful for us.
  28. Forced h1 title size. -->
  29. <!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
  30. <xsl:template name="index.titlepage">
  31. <div class="titlepage">
  32. <h1 class="index">
  33. <xsl:call-template name="gentext">
  34. <xsl:with-param name="key" select="$index-title"/>
  35. </xsl:call-template>
  36. </h1>
  37. </div>
  38. </xsl:template>
  39. <!--Divisions:
  40. Translate alphabetical divisons titles to by-type titles.
  41. Added gettext support to divisions titles.
  42. Using h2 for divisions titles.
  43. Changed output from dl format to ul format. -->
  44. <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
  45. <xsl:template match="indexterm" mode="index-div-basic">
  46. <xsl:param name="scope" select="."/>
  47. <xsl:param name="role" select="''"/>
  48. <xsl:param name="type" select="''"/>
  49. <xsl:variable name="key" select="translate(substring(&primary;, 1, 1),&lowercase;,&uppercase;)"/>
  50. <xsl:variable name="divtitle" select="translate($key, &lowercase;, &uppercase;)"/>
  51. <!-- Make sure that we don't generate a div if there are no terms in scope -->
  52. <xsl:if test="key('letter', $key)[&scope;] [count(.|key('primary', &primary;)[&scope;][1]) = 1]">
  53. <div class="indexdiv">
  54. <xsl:if test="contains(concat(&lowercase;, &uppercase;), $key)">
  55. <h2>
  56. <xsl:choose>
  57. <xsl:when test="$divtitle = 'A'">
  58. <xsl:call-template name="gentext">
  59. <xsl:with-param name="key">Packages</xsl:with-param>
  60. </xsl:call-template>
  61. </xsl:when>
  62. <xsl:when test="$divtitle = 'B'">
  63. <xsl:call-template name="gentext">
  64. <xsl:with-param name="key">Programs</xsl:with-param>
  65. </xsl:call-template>
  66. </xsl:when>
  67. <xsl:when test="$divtitle = 'C'">
  68. <xsl:call-template name="gentext">
  69. <xsl:with-param name="key">Libraries</xsl:with-param>
  70. </xsl:call-template>
  71. </xsl:when>
  72. <xsl:when test="$divtitle = 'D'">
  73. <xsl:call-template name="gentext">
  74. <xsl:with-param name="key">Scripts</xsl:with-param>
  75. </xsl:call-template>
  76. </xsl:when>
  77. <xsl:when test="$divtitle = 'E'">
  78. <xsl:call-template name="gentext">
  79. <xsl:with-param name="key">Others</xsl:with-param>
  80. </xsl:call-template>
  81. </xsl:when>
  82. <xsl:otherwise>
  83. <xsl:value-of select="$divtitle"/>
  84. </xsl:otherwise>
  85. </xsl:choose>
  86. </h2>
  87. </xsl:if>
  88. <ul>
  89. <xsl:apply-templates select="key('letter', $key)[&scope;] [count(.|key('primary', &primary;)[&scope;][1])=1]"
  90. mode="index-primary">
  91. <xsl:with-param name="scope" select="$scope"/>
  92. <xsl:sort select="translate(&primary;, &lowercase;, &uppercase;)"/>
  93. </xsl:apply-templates>
  94. </ul>
  95. </div>
  96. </xsl:if>
  97. </xsl:template>
  98. <!-- Dropping $term.separator and $number.separator from here.
  99. We add our customized ones in the output flow.
  100. As all our indexterm have @zone attributes, removed a lot of
  101. unused code. -->
  102. <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
  103. <xsl:template match="indexterm" mode="reference">
  104. <xsl:param name="scope" select="."/>
  105. <xsl:param name="role" select="''"/>
  106. <xsl:param name="type" select="''"/>
  107. <xsl:call-template name="reference">
  108. <xsl:with-param name="zones" select="normalize-space(@zone)"/>
  109. <xsl:with-param name="scope" select="$scope"/>
  110. <xsl:with-param name="role" select="$role"/>
  111. <xsl:with-param name="type" select="$type"/>
  112. </xsl:call-template>
  113. </xsl:template>
  114. <!-- Primary items:
  115. Changed the output format from dl to ul.
  116. Placed the term and separator into strong tags.
  117. Removed code for unused see and sealso childs. -->
  118. <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
  119. <xsl:template match="indexterm" mode="index-primary">
  120. <xsl:param name="scope" select="."/>
  121. <xsl:param name="role" select="''"/>
  122. <xsl:param name="type" select="''"/>
  123. <xsl:variable name="key" select="&primary;"/>
  124. <xsl:variable name="refs" select="key('primary', $key)[&scope;]"/>
  125. <li>
  126. <strong class="item">
  127. <xsl:value-of select="primary"/>
  128. <xsl:text>: </xsl:text>
  129. </strong>
  130. <xsl:for-each select="$refs[generate-id() = generate-id(key('primary-section',concat($key, &sep;, &section.id;))[&scope;][1])]">
  131. <xsl:apply-templates select="." mode="reference">
  132. <xsl:with-param name="scope" select="$scope"/>
  133. <xsl:with-param name="role" select="$role"/>
  134. <xsl:with-param name="type" select="$type"/>
  135. </xsl:apply-templates>
  136. </xsl:for-each>
  137. <xsl:if test="$refs/secondary">
  138. <ul>
  139. <xsl:apply-templates select="$refs[secondary and count(.|key('secondary', concat($key, &sep;, &secondary;))[&scope;][1]) = 1]"
  140. mode="index-secondary">
  141. <xsl:with-param name="scope" select="$scope"/>
  142. <xsl:with-param name="role" select="$role"/>
  143. <xsl:with-param name="type" select="$type"/>
  144. <xsl:sort select="translate(&secondary;, &lowercase;, &uppercase;)"/>
  145. </xsl:apply-templates>
  146. </ul>
  147. </xsl:if>
  148. </li>
  149. </xsl:template>
  150. <!-- Secondary items:
  151. Changed the output format from dl to ul.
  152. Placed the term and separator into strong tags.
  153. Removed code for unused tertiary, see, and sealso childs. -->
  154. <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
  155. <xsl:template match="indexterm" mode="index-secondary">
  156. <xsl:param name="scope" select="."/>
  157. <xsl:param name="role" select="''"/>
  158. <xsl:param name="type" select="''"/>
  159. <xsl:variable name="key" select="concat(&primary;, &sep;, &secondary;)"/>
  160. <xsl:variable name="refs" select="key('secondary', $key)[&scope;]"/>
  161. <li>
  162. <strong class="secitem">
  163. <xsl:value-of select="secondary"/>
  164. <xsl:text>: </xsl:text>
  165. </strong>
  166. <xsl:for-each select="$refs[generate-id() = generate-id(key('secondary-section', concat($key, &sep;, &section.id;))[&scope;][1])]">
  167. <xsl:apply-templates select="." mode="reference">
  168. <xsl:with-param name="scope" select="$scope"/>
  169. <xsl:with-param name="role" select="$role"/>
  170. <xsl:with-param name="type" select="$type"/>
  171. </xsl:apply-templates>
  172. </xsl:for-each>
  173. </li>
  174. </xsl:template>
  175. <!-- The target links:
  176. Changed links separator.
  177. On the cecond @zone link, we use a fixed string for the text
  178. with gettext support.
  179. Assume that there is no more than 2 @zone in a indexentry. -->
  180. <!-- The original template is in {docbook-xsl}/xhtml/autoidx.xsl -->
  181. <xsl:template name="reference">
  182. <xsl:param name="scope" select="."/>
  183. <xsl:param name="role" select="''"/>
  184. <xsl:param name="type" select="''"/>
  185. <xsl:param name="zones"/>
  186. <xsl:choose>
  187. <xsl:when test="contains($zones, ' ')">
  188. <xsl:variable name="zone" select="substring-before($zones, ' ')"/>
  189. <xsl:variable name="zone2" select="substring-after($zones, ' ')"/>
  190. <xsl:variable name="target" select="key('sections', $zone)[&scope;]"/>
  191. <xsl:variable name="target2" select="key('sections', $zone2)[&scope;]"/>
  192. <a>
  193. <xsl:attribute name="href">
  194. <xsl:call-template name="href.target">
  195. <xsl:with-param name="object" select="$target[1]"/>
  196. <xsl:with-param name="context" select="//index[&scope;][1]"/>
  197. </xsl:call-template>
  198. </xsl:attribute>
  199. <xsl:apply-templates select="$target[1]" mode="index-title-content"/>
  200. </a>
  201. <xsl:text> -- </xsl:text>
  202. <a>
  203. <xsl:attribute name="href">
  204. <xsl:call-template name="href.target">
  205. <xsl:with-param name="object" select="$target2[1]"/>
  206. <xsl:with-param name="context" select="//index[&scope;][1]"/>
  207. </xsl:call-template>
  208. </xsl:attribute>
  209. <xsl:call-template name="gentext">
  210. <xsl:with-param name="key">description</xsl:with-param>
  211. </xsl:call-template>
  212. </a>
  213. </xsl:when>
  214. <xsl:otherwise>
  215. <xsl:variable name="zone" select="$zones"/>
  216. <xsl:variable name="target" select="key('sections', $zone)[&scope;]"/>
  217. <a>
  218. <xsl:attribute name="href">
  219. <xsl:call-template name="href.target">
  220. <xsl:with-param name="object" select="$target[1]"/>
  221. <xsl:with-param name="context" select="//index[&scope;][1]"/>
  222. </xsl:call-template>
  223. </xsl:attribute>
  224. <xsl:apply-templates select="$target[1]" mode="index-title-content"/>
  225. </a>
  226. </xsl:otherwise>
  227. </xsl:choose>
  228. </xsl:template>
  229. </xsl:stylesheet>