syntax-braces.xsl 10 KB

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