syntax-braces.xsl 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!--
  3. This file is part of the DITA Open Toolkit project.
  4. Copyright 2004, 2005 IBM Corporation
  5. See the accompanying LICENSE file for applicable license.
  6. -->
  7. <xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  8. <!-- syntax diagram -->
  9. <!-- set up global vars and parms -->
  10. <!-- Logical containers -->
  11. <xsl:template match="*[contains(@class,' pr-d/syntaxdiagram ')]">
  12. <div style="display: block; border: 1 black solid; padding: 2pt; color: maroon; margin-bottom: 6pt;">
  13. <xsl:apply-templates mode="process-syntaxdiagram"/>
  14. </div>
  15. </xsl:template>
  16. <xsl:template match="*[contains(@class,' pr-d/fragment ')]" mode="process-syntaxdiagram">
  17. <div>
  18. <a><xsl:attribute name="name"><xsl:value-of select="*[contains(@class,' topic/title ')]"/></xsl:attribute> </a>
  19. <xsl:apply-templates mode="process-syntaxdiagram"/>
  20. </div>
  21. </xsl:template>
  22. <xsl:template match="*[contains(@class,' pr-d/synblk ')]" mode="process-syntaxdiagram">
  23. <span>
  24. <xsl:call-template name="commonattributes"/>
  25. <xsl:apply-templates select="@id"/>
  26. <xsl:call-template name="apply-for-phrases"/>
  27. </span>
  28. </xsl:template>
  29. <!-- titles for logical containers -->
  30. <xsl:template match="*[contains(@class,' pr-d/syntaxdiagram ')]/*[contains(@class,' topic/title ')]" mode="process-syntaxdiagram">
  31. <h3>
  32. <xsl:value-of select="."/>
  33. </h3>
  34. </xsl:template>
  35. <xsl:template match="*[contains(@class,' pr-d/fragment ')]/*[contains(@class,' topic/title ')]" mode="process-syntaxdiagram">
  36. <h4><xsl:apply-templates mode="process-syntaxdiagram"/></h4>
  37. </xsl:template>
  38. <!-- This should test to see if there's a fragment with matching title
  39. and if so, produce an associative link. -->
  40. <xsl:template match="*[contains(@class,' pr-d/fragref ')]" mode="process-syntaxdiagram">
  41. <kbd>
  42. <a><xsl:attribute name="href">#<xsl:value-of select="."/></xsl:attribute>
  43. &lt;<xsl:value-of select="."/>&gt;</a>
  44. </kbd>
  45. </xsl:template>
  46. <xsl:template match="*[contains(@class,' pr-d/var ')]" mode="process-syntaxdiagram">
  47. <var>
  48. <xsl:if test="parent::*[contains(@class,' pr-d/groupchoice ')]"><xsl:if test="count(preceding-sibling::*)!=0"> | </xsl:if></xsl:if>
  49. <xsl:if test="@importance='optional'"> [</xsl:if>
  50. <xsl:choose>
  51. <xsl:when test="@importance='default'"><u><xsl:value-of select="."/></u></xsl:when>
  52. <xsl:otherwise><xsl:value-of select="."/></xsl:otherwise>
  53. </xsl:choose>
  54. <xsl:if test="@importance='optional'">] </xsl:if>
  55. </var>
  56. </xsl:template>
  57. <!-- fragment block and title (echo same for syntaxdiagram?) -->
  58. <xsl:template match="*[contains(@class,' pr-d/fragment ')]/groupcomp|*[contains(@class,' pr-d/fragment ')]/groupchoice|*[contains(@class,' pr-d/fragment ')]/groupseq" mode="process-syntaxdiagram">
  59. <blockquote>
  60. <xsl:call-template name="dogroup"/>
  61. </blockquote>
  62. </xsl:template>
  63. <!-- GROUP CONTAINER PROCESSING, ALL PERMUTAIONS -->
  64. <!-- set up group containers (similar to same area management as for syntaxdiagram, synblk, and fragment) -->
  65. <xsl:template match="syntaxdiagram/*[contains(@class,' pr-d/groupcomp ')]|syntaxdiagram/*[contains(@class,' pr-d/groupseq ')]|syntaxdiagram/*[contains(@class,' pr-d/groupchoice ')]" mode="process-syntaxdiagram">
  66. <xsl:call-template name="dogroup"/>
  67. </xsl:template>
  68. <!-- handle group titles (by skipping over them for now -->
  69. <xsl:template match="*[contains(@class,' pr-d/groupcomp ')]/*[contains(@class,' topic/title ')]|*[contains(@class,' pr-d/groupseq ')]/*[contains(@class,' topic/title ')]|*[contains(@class,' pr-d/groupseq ')]/*[contains(@class,' topic/title ')]" mode="process-syntaxdiagram"/> <!-- Consume title -->
  70. <!-- okay, here we have to work each permutation because figgroup/figroup fallback is too general -->
  71. <xsl:template match="*[contains(@class,' pr-d/groupcomp ')]/*[contains(@class,' pr-d/groupcomp ')]" mode="process-syntaxdiagram">
  72. <xsl:call-template name="dogroup"/>
  73. </xsl:template>
  74. <xsl:template match="*[contains(@class,' pr-d/groupchoice ')]/*[contains(@class,' pr-d/groupchoice ')]" mode="process-syntaxdiagram">
  75. <xsl:call-template name="dogroup"/>
  76. </xsl:template>
  77. <xsl:template match="*[contains(@class,' pr-d/groupseq ')]/*[contains(@class,' pr-d/groupseq ')]" mode="process-syntaxdiagram">
  78. <xsl:call-template name="dogroup"/>
  79. </xsl:template>
  80. <xsl:template match="*[contains(@class,' pr-d/groupchoice ')]/*[contains(@class,' pr-d/groupcomp ')]" mode="process-syntaxdiagram">
  81. <xsl:call-template name="dogroup"/>
  82. </xsl:template>
  83. <xsl:template match="*[contains(@class,' pr-d/groupchoice ')]/*[contains(@class,' pr-d/groupseq ')]" mode="process-syntaxdiagram">
  84. <xsl:call-template name="dogroup"/>
  85. </xsl:template>
  86. <xsl:template match="*[contains(@class,' pr-d/groupcomp ')]/*[contains(@class,' pr-d/groupchoice ')]" mode="process-syntaxdiagram">
  87. <xsl:call-template name="dogroup"/>
  88. </xsl:template>
  89. <xsl:template match="*[contains(@class,' pr-d/groupcomp ')]/*[contains(@class,' pr-d/groupseq ')]" mode="process-syntaxdiagram">
  90. <xsl:call-template name="dogroup"/>
  91. </xsl:template>
  92. <xsl:template match="*[contains(@class,' pr-d/groupseq ')]/*[contains(@class,' pr-d/groupchoice ')]" mode="process-syntaxdiagram">
  93. <xsl:call-template name="dogroup"/>
  94. </xsl:template>
  95. <xsl:template match="*[contains(@class,' pr-d/groupseq ')]/*[contains(@class,' pr-d/groupcomp ')]" mode="process-syntaxdiagram">
  96. <xsl:call-template name="dogroup"/>
  97. </xsl:template>
  98. <xsl:template name="dogroup">
  99. <xsl:if test="parent::*[contains(@class,' pr-d/groupchoice ')]">
  100. <xsl:if test="count(preceding-sibling::*)!=0"> |</xsl:if>
  101. </xsl:if>
  102. <xsl:if test="@importance='optional'"> [</xsl:if>
  103. <xsl:if test="contains(@class,' pr-d/groupchoice ')"> {</xsl:if>
  104. <xsl:text> </xsl:text><xsl:apply-templates mode="process-syntaxdiagram"/><xsl:text> </xsl:text>
  105. <!-- repid processed here before -->
  106. <xsl:if test="contains(@class,' pr-d/groupchoice ')">} </xsl:if>
  107. <xsl:if test="@importance='optional'">] </xsl:if>
  108. </xsl:template>
  109. <!-- these cases are valid also outside of syntax diagram; we test for context
  110. to ensure contextually correct rendering when in a diagram -->
  111. <!-- Basically, we want to hide his content. -->
  112. <xsl:template match="*[contains(@class,' pr-d/repsep ')]" mode="process-syntaxdiagram"/>
  113. <xsl:template match="*[contains(@class,' pr-d/syntaxdiagram ')]//*[contains(@class,' pr-d/kwd ')] | *[contains(@class,' pr-d/synph ')]//*[contains(@class,' pr-d/kwd ')]" mode="process-syntaxdiagram">
  114. <kbd><b>
  115. <xsl:if test="parent::*[contains(@class,' pr-d/groupchoice ')]"><xsl:if test="count(preceding-sibling::*)!=0"> | </xsl:if></xsl:if>
  116. <xsl:if test="@importance='optional'"> [</xsl:if>
  117. <xsl:choose>
  118. <xsl:when test="@importance='default'"><u><xsl:value-of select="."/></u></xsl:when>
  119. <xsl:otherwise><xsl:value-of select="."/></xsl:otherwise>
  120. </xsl:choose>
  121. <xsl:if test="@importance='optional'">] </xsl:if>
  122. </b>&#32;</kbd> <!-- force a space to follow the bold endtag, which has a concat behavior otherwise -->
  123. </xsl:template>
  124. <xsl:template match="*[contains(@class,' pr-d/oper ')]" mode="process-syntaxdiagram">
  125. <xsl:if test="parent::*[contains(@class,' pr-d/groupchoice ')]"><xsl:if test="count(preceding-sibling::*)!=0"> | </xsl:if></xsl:if>
  126. <kbd>
  127. <xsl:call-template name="commonattributes"/>
  128. <xsl:apply-templates select="@id"/>
  129. <xsl:call-template name="apply-for-phrases"/>
  130. </kbd>
  131. </xsl:template>
  132. <xsl:template match="*[contains(@class,' pr-d/delim ')]" mode="process-syntaxdiagram">
  133. <xsl:if test="parent::*[contains(@class,' pr-d/groupchoice ')]"><xsl:if test="count(preceding-sibling::*)!=0"> | </xsl:if></xsl:if>
  134. <kbd>
  135. <xsl:call-template name="commonattributes"/>
  136. <xsl:apply-templates select="@id"/>
  137. <xsl:call-template name="apply-for-phrases"/>
  138. </kbd>
  139. </xsl:template>
  140. <xsl:template match="*[contains(@class,' pr-d/sep ')]" mode="process-syntaxdiagram">
  141. <xsl:if test="parent::*[contains(@class,' pr-d/groupchoice ')]"><xsl:if test="count(preceding-sibling::*)!=0"> | </xsl:if></xsl:if>
  142. <kbd>
  143. <xsl:call-template name="commonattributes"/>
  144. <xsl:apply-templates select="@id"/>
  145. <xsl:call-template name="apply-for-phrases"/>
  146. </kbd>
  147. </xsl:template>
  148. <!-- annotation related to syntaxdiagram -->
  149. <xsl:template name="gen-synnotes">
  150. <h3>Notes:</h3>
  151. <xsl:for-each select="//*[contains(@class,' pr-d/synnote ')]">
  152. <xsl:call-template name="dosynnt"/>
  153. </xsl:for-each>
  154. </xsl:template>
  155. <xsl:template name="dosynnt"> <!-- creates a list of endnotes of synnt content -->
  156. <xsl:variable name="callout">
  157. <xsl:choose>
  158. <xsl:when test="@callout"><xsl:value-of select="@callout"/></xsl:when>
  159. <xsl:otherwise><xsl:value-of select="@id"/></xsl:otherwise>
  160. </xsl:choose>
  161. </xsl:variable>
  162. <a name="{@id}">{<xsl:value-of select="$callout"/>}</a>
  163. <table border="1" cellpadding="6">
  164. <tr><td bgcolor="LightGrey">
  165. <xsl:apply-templates mode="process-syntaxdiagram"/>
  166. </td></tr>
  167. </table>
  168. </xsl:template>
  169. <xsl:template match="*[contains(@class,' pr-d/synnoteref ')]" mode="process-syntaxdiagram">
  170. <sup>
  171. <a href="#FNsrc_{@refid}">
  172. <xsl:text>[</xsl:text>
  173. <xsl:value-of select="@refid"/>
  174. <xsl:text>]</xsl:text>
  175. </a>
  176. </sup>
  177. </xsl:template>
  178. <xsl:template match="*[contains(@class,' pr-d/synnote ')]" mode="process-syntaxdiagram">
  179. <xsl:choose>
  180. <xsl:when test="not(@id='')"> <!-- case of an explicit id -->
  181. <sup>(explicit id <xsl:value-of select="@id"/>)
  182. <a name="FNsrc_{@id}" href="#FNtarg_{@id}">
  183. <xsl:value-of select="@id"/>
  184. </a>
  185. </sup>
  186. </xsl:when>
  187. <xsl:when test="not(@callout='')"> <!-- case of an explicit callout (presume id for now) -->
  188. <sup>(callout <xsl:value-of select="@callout"/>)
  189. <a name="FNsrc_{@id}" href="#FNtarg_{@id}">
  190. <xsl:value-of select="@callout"/>
  191. </a>
  192. </sup>
  193. </xsl:when>
  194. <xsl:otherwise>
  195. <a href="#">
  196. <xsl:attribute name="onMouseOver">
  197. <xsl:text>alert('</xsl:text><xsl:apply-templates mode="process-syntaxdiagram"/><xsl:text>')</xsl:text>
  198. </xsl:attribute>
  199. <xsl:text>*</xsl:text>
  200. </a>
  201. </xsl:otherwise>
  202. </xsl:choose>
  203. </xsl:template>
  204. <!-- generate null filler if the phrase is evidently empty -->
  205. <xsl:template name="apply-for-phrases">
  206. <xsl:choose>
  207. <xsl:when test="not(text()[normalize-space(.)] | *)"><xsl:comment>null</xsl:comment></xsl:when>
  208. <xsl:otherwise><xsl:apply-templates mode="process-syntaxdiagram"/></xsl:otherwise>
  209. </xsl:choose>
  210. </xsl:template>
  211. </xsl:stylesheet>