extension-points.xsl 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  3. xmlns:xs="http://www.w3.org/2001/XMLSchema"
  4. exclude-result-prefixes="xs"
  5. version="2.0">
  6. <xsl:output doctype-public="-//OASIS//DTD DITA Reference//EN"
  7. doctype-system="reference.dtd"/>
  8. <xsl:strip-space elements="*"/>
  9. <xsl:param name="output-dir.url"/>
  10. <xsl:template match="/">
  11. <xsl:call-template name="all"/>
  12. <xsl:call-template name="separate"/>
  13. </xsl:template>
  14. <xsl:template name="all">
  15. <xsl:comment> Generated from plugin source, do not edit! </xsl:comment>
  16. <reference id="all-extension-points">
  17. <title id="title" outputclass="generated">All DITA-OT extension points</title>
  18. <titlealts>
  19. <navtitle>All extension points</navtitle>
  20. </titlealts>
  21. <shortdesc id="shortdesc">The pre-defined extension points can be used to extend the functionality of the
  22. DITA-OT. If your toolkit installation includes custom plug-ins that define additional extension points, you can
  23. add to this list by rebuilding the DITA-OT documentation.</shortdesc>
  24. <refbody>
  25. <section>
  26. <dl>
  27. <xsl:apply-templates select="//extension-point">
  28. <xsl:sort select="@name"/>
  29. </xsl:apply-templates>
  30. </dl>
  31. </section>
  32. </refbody>
  33. </reference>
  34. </xsl:template>
  35. <xsl:template name="separate">
  36. <!--xsl:for-each select="//transtype/param"-->
  37. <xsl:for-each select="//plugin">
  38. <xsl:variable name="id" select="@id"/>
  39. <xsl:message>Writing <xsl:value-of select="$output-dir.url"/>extension-point-<xsl:value-of select="$id"/>.dita</xsl:message>
  40. <xsl:result-document href="{$output-dir.url}/extension-point-{$id}.dita"
  41. doctype-public="-//OASIS//DTD DITA Reference//EN"
  42. doctype-system="reference.dtd">
  43. <xsl:comment> Generated from plugin source, do not edit! </xsl:comment>
  44. <reference id="{$id}-extension-points">
  45. <title outputclass="generated">
  46. <xsl:value-of select="@id"/>
  47. <xsl:text> extension points</xsl:text>
  48. </title>
  49. <titlealts>
  50. <navtitle>
  51. <xsl:value-of select="@desc"/>
  52. </navtitle>
  53. </titlealts>
  54. <shortdesc id="shortdesc"/>
  55. <refbody>
  56. <section>
  57. <dl>
  58. <xsl:apply-templates select="extension-point">
  59. <xsl:sort select="@id"/>
  60. </xsl:apply-templates>
  61. </dl>
  62. </section>
  63. </refbody>
  64. </reference>
  65. </xsl:result-document>
  66. </xsl:for-each>
  67. </xsl:template>
  68. <!--xsl:template match="transtype" mode="inherit" as="element(param)*">
  69. <xsl:sequence select="param"/>
  70. <xsl:variable name="extends" as="xs:string?">
  71. <xsl:choose>
  72. <xsl:when test="@name = 'base'"/>
  73. <xsl:when test="@extends">
  74. <xsl:value-of select="@extends"/>
  75. </xsl:when>
  76. <xsl:otherwise>base</xsl:otherwise>
  77. </xsl:choose>
  78. </xsl:variable>
  79. <xsl:if test="exists($extends)">
  80. <xsl:apply-templates select="//transtype[tokenize(@name, '\s+') = $extends]" mode="inherit"/>
  81. </xsl:if>
  82. </xsl:template-->
  83. <xsl:template match="extension-point">
  84. <dlentry id="{@id}">
  85. <xsl:if test="@deprecated = 'true'">
  86. <xsl:attribute name="importance">deprecated</xsl:attribute>
  87. </xsl:if>
  88. <xsl:if test="@required = 'true'">
  89. <xsl:attribute name="importance">required</xsl:attribute>
  90. </xsl:if>
  91. <dt>
  92. <parmname>
  93. <xsl:value-of select="@id"/>
  94. </parmname>
  95. </dt>
  96. <dd id="{@id}.desc">
  97. <xsl:value-of select="@name"/>
  98. </dd>
  99. </dlentry>
  100. </xsl:template>
  101. </xsl:stylesheet>