mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-31 10:05:31 +00:00
47a8ff9979
The various objects we generate API for may have empty description in which case an empty div would be generated when processing the API description. As we're using XML output mode the generator would shorten such divs to the non-pair empty element version, which doesn't work well with HTML5 parsers requiring a pair tag for <div> Avoid empty description <div> elements altogether by skipping it if the description is empty. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
837 lines
28 KiB
XML
837 lines
28 KiB
XML
<?xml version="1.0"?>
|
|
<!--
|
|
Stylesheet to generate the HTML documentation from an XML API descriptions:
|
|
xsltproc newapi.xsl libvirt-api.xml
|
|
|
|
Daniel Veillard
|
|
-->
|
|
<xsl:stylesheet version="1.0"
|
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
xmlns:html="http://www.w3.org/1999/xhtml"
|
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
xmlns:exsl="http://exslt.org/common"
|
|
xmlns:str="http://exslt.org/strings"
|
|
extension-element-prefixes="exsl str"
|
|
exclude-result-prefixes="exsl str">
|
|
|
|
<!-- Import the main part of the site stylesheets -->
|
|
<xsl:import href="page.xsl"/>
|
|
|
|
<!-- Build keys for all symbols -->
|
|
<xsl:key name="symbols" match="/api/symbols/*" use="@name"/>
|
|
|
|
<!-- the target directory for the HTML output -->
|
|
<xsl:variable name="htmldir">html</xsl:variable>
|
|
|
|
<xsl:template name="aclinfo">
|
|
<xsl:param name="acl"/>
|
|
|
|
<xsl:if test="count($acl/check) > 0 or count($acl/filter) > 0">
|
|
<div class="acl">
|
|
<xsl:if test="count($acl/check) > 0">
|
|
<h5>Access control parameter checks</h5>
|
|
<table>
|
|
<thead>
|
|
<tr>
|
|
<th>Object</th>
|
|
<th>Permission</th>
|
|
<th>Condition</th>
|
|
</tr>
|
|
</thead>
|
|
<xsl:apply-templates select="$acl/check" mode="acl"/>
|
|
</table>
|
|
</xsl:if>
|
|
<xsl:if test="count($acl/filter) > 0">
|
|
<h5>Access control return value filters</h5>
|
|
<table>
|
|
<thead>
|
|
<tr>
|
|
<th>Object</th>
|
|
<th>Permission</th>
|
|
</tr>
|
|
</thead>
|
|
<xsl:apply-templates select="$acl/filter" mode="acl"/>
|
|
</table>
|
|
</xsl:if>
|
|
</div>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="check" mode="acl">
|
|
<tr>
|
|
<td><a href="../acl.html#object_{@object}"><xsl:value-of select="@object"/></a></td>
|
|
<td><a href="../acl.html#perm_{@object}_{@perm}"><xsl:value-of select="@perm"/></a></td>
|
|
<xsl:choose>
|
|
<xsl:when test="@flags">
|
|
<td><xsl:value-of select="@flags"/></td>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<td>-</td>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</tr>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="filter" mode="acl">
|
|
<tr>
|
|
<td><xsl:value-of select="@object"/></td>
|
|
<td><xsl:value-of select="@perm"/></td>
|
|
</tr>
|
|
</xsl:template>
|
|
|
|
|
|
<!-- This is convoluted but needed to force the current document to
|
|
be the API one and not the result tree from the tokenize() result,
|
|
because the keys are only defined on the main document -->
|
|
<xsl:template mode="dumptoken" match='*'>
|
|
<xsl:param name="token"/>
|
|
<xsl:variable name="stem" select="translate($token, '(),.:;@', '')"/>
|
|
<xsl:variable name="ref" select="key('symbols', $stem)"/>
|
|
<xsl:choose>
|
|
<xsl:when test="$ref">
|
|
<xsl:value-of select="substring-before($token, $stem)"/>
|
|
<a href="libvirt-{$ref/@file}.html#{$ref/@name}"><xsl:value-of select="$stem"/></a>
|
|
<xsl:value-of select="substring-after($token, $stem)"/>
|
|
</xsl:when>
|
|
<xsl:when test="starts-with($token, 'http://')">
|
|
<a href="{$token}">
|
|
<xsl:value-of select="$token"/>
|
|
</a>
|
|
</xsl:when>
|
|
<xsl:when test="starts-with($token, 'https://')">
|
|
<a href="{$token}">
|
|
<xsl:value-of select="$token"/>
|
|
</a>
|
|
</xsl:when>
|
|
<xsl:when test="starts-with($token, '<http://') and contains($token, '>')">
|
|
<xsl:variable name="link"
|
|
select="substring(substring-before($token, '>'), 2)"/>
|
|
<a href="{$link}">
|
|
<xsl:value-of select="$link"/>
|
|
</a>
|
|
<xsl:value-of select="substring-after($token, '>')"/>
|
|
</xsl:when>
|
|
<xsl:when test="contains($token, '@')">
|
|
<xsl:variable name="prologue" select="substring-before($token, '@')"/>
|
|
<xsl:value-of select="$prologue"/>
|
|
<code><xsl:value-of select="$stem"/></code>
|
|
<xsl:value-of select="substring($token, string-length($prologue) + string-length($stem) + 2)"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="$token"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<!-- dumps a string, making cross-reference links -->
|
|
<xsl:template name="dumptext">
|
|
<xsl:param name="text"/>
|
|
<xsl:variable name="ctxt" select='.'/>
|
|
<!-- <xsl:value-of select="$text"/> -->
|
|
<xsl:for-each select="str:tokenize($text, ' 	 ')">
|
|
<xsl:apply-templates select="$ctxt" mode='dumptoken'>
|
|
<xsl:with-param name="token" select="string(.)"/>
|
|
</xsl:apply-templates>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text> </xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each>
|
|
</xsl:template>
|
|
|
|
|
|
<!-- process blocks of text. blocks are separated by two consecutive line -->
|
|
<!-- breaks. -->
|
|
<!-- -->
|
|
<!-- blocks indented with at least 2 spaces are considered code blocks. -->
|
|
<!-- -->
|
|
<!-- consecutive code blocks are collapsed into a single code block. -->
|
|
<xsl:template name="formatblock">
|
|
<xsl:param name="block"/>
|
|
<xsl:param name="rest"/>
|
|
|
|
<xsl:variable name="multipleCodeBlocks"
|
|
select="starts-with($block, ' ') and starts-with($rest, ' ')"/>
|
|
|
|
<xsl:choose>
|
|
<xsl:when test="$multipleCodeBlocks">
|
|
<xsl:call-template name="formatblock">
|
|
<xsl:with-param name="block">
|
|
<xsl:choose>
|
|
<xsl:when test="contains($rest, '

')">
|
|
<xsl:value-of select="concat($block, '
 
',
|
|
substring-before($rest, '

'))" />
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="concat($block, '
 
', $rest)" />
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:with-param>
|
|
<xsl:with-param name="rest" select="substring-after($rest, '

')"/>
|
|
</xsl:call-template>
|
|
</xsl:when>
|
|
<xsl:when test="starts-with($block, ' ')">
|
|
<pre class="code"><xsl:for-each select="str:tokenize($block, '
')">
|
|
<xsl:choose>
|
|
<xsl:when test="starts-with(., ' ')">
|
|
<xsl:value-of select="substring(., 3)"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="."/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text>
</xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each></pre>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<p>
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="$block"/>
|
|
</xsl:call-template>
|
|
</p>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:if test="not($multipleCodeBlocks)">
|
|
<xsl:call-template name="formattext">
|
|
<xsl:with-param name="text" select="$rest"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<xsl:template name="formattext">
|
|
<xsl:param name="text" />
|
|
|
|
<xsl:if test="$text">
|
|
<xsl:variable name="head" select="substring-before($text, '

')"/>
|
|
<xsl:variable name="rest" select="substring-after($text, '

')"/>
|
|
|
|
<xsl:call-template name="formatblock">
|
|
<xsl:with-param name="block">
|
|
<xsl:choose>
|
|
<xsl:when test="contains($text, '

')">
|
|
<xsl:value-of select="$head"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="$text"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:with-param>
|
|
<xsl:with-param name="rest" select="$rest"/>
|
|
</xsl:call-template>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<xsl:template name="formattextdiv">
|
|
<xsl:param name="text"/>
|
|
<xsl:param name="divclass"/>
|
|
|
|
<xsl:if test="$text">
|
|
<div class="{$divclass}">
|
|
<xsl:call-template name="formattext">
|
|
<xsl:with-param name="text" select="$text"/>
|
|
</xsl:call-template>
|
|
</div>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="macro" mode="toc">
|
|
<span class="directive">#define</span><xsl:text> </xsl:text>
|
|
<a href="#{@name}"><xsl:value-of select="@name"/></a>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="variable" mode="toc">
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="string(@type)"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text> </xsl:text>
|
|
<a id="{@name}"></a>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="typedef" mode="toc">
|
|
<span class="keyword">typedef</span>
|
|
<xsl:text> </xsl:text><xsl:variable name="name" select="string(@name)"/>
|
|
<xsl:choose>
|
|
<xsl:when test="@type = 'enum'">
|
|
<span class="keyword">enum</span><xsl:text> </xsl:text>
|
|
<a href="#{$name}"><xsl:value-of select="$name"/></a>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text> </xsl:text>
|
|
<a href="#{$name}"><xsl:value-of select="$name"/></a>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
|
|
<xsl:template name="enumvalue">
|
|
<xsl:param name="value" select="@value"/>
|
|
<xsl:param name="valuehex" select="@value_hex"/>
|
|
<xsl:param name="valuebitshift" select="@value_bitshift"/>
|
|
<xsl:value-of select="@value"/>
|
|
<xsl:if test="$valuehex != '' or $valuebitshift != ''">
|
|
<xsl:text> (</xsl:text>
|
|
<xsl:if test="$valuehex != ''">
|
|
<xsl:value-of select="@value_hex"/>
|
|
</xsl:if>
|
|
<xsl:if test="$valuebitshift != ''">
|
|
<xsl:text>; 1 << </xsl:text>
|
|
<xsl:value-of select="@value_bitshift"/>
|
|
</xsl:if>
|
|
<xsl:text>)</xsl:text>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="typedef[@type = 'enum']">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<h3><a id="{$name}"><code><xsl:value-of select="$name"/></code></a></h3>
|
|
<xsl:call-template name="formattextdiv">
|
|
<xsl:with-param name="text" select="info"/>
|
|
<xsl:with-param name="divclass">description</xsl:with-param>
|
|
</xsl:call-template>
|
|
<div class="api">
|
|
<pre>
|
|
<span class="keyword">enum</span><xsl:text> </xsl:text>
|
|
<xsl:value-of select="$name"/>
|
|
<xsl:text> {
|
|
</xsl:text>
|
|
</pre>
|
|
<table>
|
|
<xsl:for-each select="/api/symbols/enum[@type = $name]">
|
|
<xsl:sort select="@value" data-type="number" order="ascending"/>
|
|
<tr>
|
|
<td><a id="{@name}"><xsl:value-of select="@name"/></a></td>
|
|
<td><xsl:text> = </xsl:text></td>
|
|
<xsl:choose>
|
|
<xsl:when test="@info != ''">
|
|
<td class="enumvalue"><xsl:call-template name="enumvalue"/></td>
|
|
<td>
|
|
<div class="comment">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@info"/>
|
|
</xsl:call-template>
|
|
</div>
|
|
</td>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<td colspan="2" class="enumvalue"><xsl:call-template name="enumvalue"/></td>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</tr>
|
|
</xsl:for-each>
|
|
</table>
|
|
<pre>
|
|
<xsl:text>}
|
|
</xsl:text>
|
|
</pre>
|
|
</div>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="typedef">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<xsl:variable name="type" select="string(@type)"/>
|
|
<h3><a id="{$name}"><code><xsl:value-of select="$name"/></code></a></h3>
|
|
<div class="api">
|
|
<pre>
|
|
<span class="keyword">typedef</span><xsl:text> </xsl:text>
|
|
<xsl:value-of select="$type"/>
|
|
<xsl:text> </xsl:text>
|
|
<xsl:value-of select="$name"/>
|
|
<xsl:text>;</xsl:text>
|
|
</pre>
|
|
</div>
|
|
<xsl:call-template name="formattextdiv">
|
|
<xsl:with-param name="text" select="info"/>
|
|
<xsl:with-param name="divclass">description</xsl:with-param>
|
|
</xsl:call-template>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="struct" mode="toc">
|
|
<span class="keyword">typedef</span><xsl:text> </xsl:text>
|
|
<span class="type"><xsl:value-of select="@type"/></span>
|
|
<xsl:text> </xsl:text>
|
|
<a href="#{@name}"><xsl:value-of select="@name"/></a>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="struct">
|
|
<h3><a id="{@name}"><code><xsl:value-of select="@name"/></code></a></h3>
|
|
<div class="api">
|
|
<pre>
|
|
<span class="keyword">struct </span>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:text> {
|
|
</xsl:text>
|
|
</pre>
|
|
<xsl:if test="field">
|
|
<table>
|
|
<xsl:for-each select="field">
|
|
<xsl:choose>
|
|
<xsl:when test='@type = "union"'>
|
|
<tr><td><span class="keyword">union</span> {</td></tr>
|
|
<tr>
|
|
<td><table>
|
|
<xsl:for-each select="union/field">
|
|
<tr>
|
|
<td>
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
</td>
|
|
<td><xsl:value-of select="@name"/></td>
|
|
<xsl:if test="@info != ''">
|
|
<td>
|
|
<div class="comment">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@info"/>
|
|
</xsl:call-template>
|
|
</div>
|
|
</td>
|
|
</xsl:if>
|
|
</tr>
|
|
</xsl:for-each>
|
|
</table></td>
|
|
<td></td></tr>
|
|
<tr><td>}</td>
|
|
<td><xsl:value-of select="@name"/></td>
|
|
<xsl:if test="@info != ''">
|
|
<td>
|
|
<div class="comment">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@info"/>
|
|
</xsl:call-template>
|
|
</div>
|
|
</td>
|
|
</xsl:if>
|
|
<td></td></tr>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<tr>
|
|
<td>
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
</td>
|
|
<td><xsl:value-of select="@name"/></td>
|
|
<xsl:if test="@info != ''">
|
|
<td>
|
|
<div class="comment">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@info"/>
|
|
</xsl:call-template>
|
|
</div>
|
|
</td>
|
|
</xsl:if>
|
|
</tr>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:for-each>
|
|
</table>
|
|
</xsl:if>
|
|
<xsl:if test="not(field)">
|
|
<div class="undisclosed">The content of this structure is not made public by the API</div>
|
|
</xsl:if>
|
|
<pre>
|
|
<xsl:text>
|
|
}
|
|
</xsl:text>
|
|
</pre>
|
|
</div>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="macro">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<h3><a id="{$name}"><code><xsl:value-of select="$name"/></code></a></h3>
|
|
<pre class="api"><span class="directive">#define</span><xsl:text> </xsl:text><xsl:value-of select="$name"/></pre>
|
|
<xsl:call-template name="formattextdiv">
|
|
<xsl:with-param name="text" select="info"/>
|
|
<xsl:with-param name="divclass">description</xsl:with-param>
|
|
</xsl:call-template>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="function" mode="toc">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<xsl:variable name="nlen" select="string-length($name)"/>
|
|
<xsl:variable name="tlen" select="string-length(return/@type)"/>
|
|
<xsl:variable name="blen" select="(($nlen + 8) - (($nlen + 8) mod 8)) + (($tlen + 8) - (($tlen + 8) mod 8))"/>
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="return/@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text>	</xsl:text>
|
|
<a href="#{@name}"><xsl:value-of select="@name"/></a>
|
|
<xsl:if test="$blen - 40 < -8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 < 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>	(</xsl:text>
|
|
<xsl:if test="not(arg)">
|
|
<span class="type">void</span>
|
|
</xsl:if>
|
|
<xsl:for-each select="arg">
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text> </xsl:text>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text>, </xsl:text><br/>
|
|
<xsl:if test="$blen - 40 > 8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 > 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>					 </xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each>
|
|
<xsl:text>)
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="functype" mode="toc">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<xsl:variable name="nlen" select="string-length($name)"/>
|
|
<xsl:variable name="tlen" select="string-length(return/@type)"/>
|
|
<xsl:variable name="blen" select="(($nlen + 8) - (($nlen + 8) mod 8)) + (($tlen + 8) - (($tlen + 8) mod 8))"/>
|
|
<span class="keyword">typedef</span><xsl:text> </xsl:text>
|
|
<a href="#{$name}"><xsl:value-of select="$name"/></a>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="return/@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text>	</xsl:text>
|
|
<a href="#{$name}"><xsl:value-of select="$name"/></a>
|
|
<xsl:if test="$blen - 40 < -8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 < 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>	(</xsl:text>
|
|
<xsl:if test="not(arg)">
|
|
<span class="type">void</span>
|
|
</xsl:if>
|
|
<xsl:for-each select="arg">
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text> </xsl:text>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text>, </xsl:text><br/>
|
|
<xsl:if test="$blen - 40 > 8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 > 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>					 </xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each>
|
|
<xsl:text>)
|
|
</xsl:text>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="functype">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<xsl:variable name="nlen" select="string-length($name)"/>
|
|
<xsl:variable name="tlen" select="string-length(return/@type)"/>
|
|
<xsl:variable name="blen" select="(($nlen + 8) - (($nlen + 8) mod 8)) + (($tlen + 8) - (($tlen + 8) mod 8))"/>
|
|
<h3><a id="{$name}"><code><xsl:value-of select="$name"/></code></a></h3>
|
|
<pre class="api">
|
|
<span class="keyword">typedef</span><xsl:text> </xsl:text>
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="return/@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text>	(*</xsl:text>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:if test="$blen - 40 < -8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 < 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>)	(</xsl:text>
|
|
<xsl:if test="not(arg)">
|
|
<span class="type">void</span>
|
|
</xsl:if>
|
|
<xsl:for-each select="arg">
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text> </xsl:text>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text>,
|
|
</xsl:text>
|
|
<xsl:if test="$blen - 40 > 8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 > 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>					 </xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each>
|
|
<xsl:text>)
|
|
</xsl:text>
|
|
</pre>
|
|
<xsl:call-template name="formattextdiv">
|
|
<xsl:with-param name="text" select="info"/>
|
|
<xsl:with-param name="divclass">description</xsl:with-param>
|
|
</xsl:call-template>
|
|
<xsl:if test="arg | return">
|
|
<dl class="variablelist">
|
|
<xsl:for-each select="arg">
|
|
<dt><xsl:value-of select="@name"/></dt>
|
|
<dd>
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@info"/>
|
|
</xsl:call-template>
|
|
</dd>
|
|
</xsl:for-each>
|
|
<xsl:if test="return/@info">
|
|
<dt>Returns</dt>
|
|
<dd>
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="return/@info"/>
|
|
</xsl:call-template>
|
|
</dd>
|
|
</xsl:if>
|
|
</dl>
|
|
</xsl:if>
|
|
<br/>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="function">
|
|
<xsl:variable name="name" select="string(@name)"/>
|
|
<xsl:variable name="nlen" select="string-length($name)"/>
|
|
<xsl:variable name="tlen" select="string-length(return/@type)"/>
|
|
<xsl:variable name="blen" select="(($nlen + 8) - (($nlen + 8) mod 8)) + (($tlen + 8) - (($tlen + 8) mod 8))"/>
|
|
<h3><a id="{$name}"><code><xsl:value-of select="$name"/></code></a></h3>
|
|
<pre class="api">
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="return/@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text>	</xsl:text>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:if test="$blen - 40 < -8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 < 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>	(</xsl:text>
|
|
<xsl:if test="not(arg)">
|
|
<span class="type">void</span>
|
|
</xsl:if>
|
|
<xsl:for-each select="arg">
|
|
<span class="type">
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@type"/>
|
|
</xsl:call-template>
|
|
</span>
|
|
<xsl:text> </xsl:text>
|
|
<xsl:value-of select="@name"/>
|
|
<xsl:if test="position() != last()">
|
|
<xsl:text>,
|
|
</xsl:text>
|
|
<xsl:if test="$blen - 40 > 8">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:if test="$blen - 40 > 0">
|
|
<xsl:text>	</xsl:text>
|
|
</xsl:if>
|
|
<xsl:text>					 </xsl:text>
|
|
</xsl:if>
|
|
</xsl:for-each>
|
|
<xsl:text>)</xsl:text>
|
|
</pre>
|
|
<xsl:call-template name="formattextdiv">
|
|
<xsl:with-param name="text" select="info"/>
|
|
<xsl:with-param name="divclass">description</xsl:with-param>
|
|
</xsl:call-template>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
<xsl:if test="arg | return/@info">
|
|
<dl class="variablelist">
|
|
<xsl:for-each select="arg">
|
|
<dt><xsl:value-of select="@name"/></dt>
|
|
<dd>
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="@info"/>
|
|
</xsl:call-template>
|
|
</dd>
|
|
</xsl:for-each>
|
|
<xsl:if test="return/@info">
|
|
<dt>Returns</dt>
|
|
<dd>
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="return/@info"/>
|
|
</xsl:call-template>
|
|
</dd>
|
|
</xsl:if>
|
|
</dl>
|
|
</xsl:if>
|
|
<xsl:call-template name="aclinfo">
|
|
<xsl:with-param name="acl" select="acls"/>
|
|
</xsl:call-template>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="exports" mode="toc">
|
|
<xsl:apply-templates select="key('symbols', string(@symbol))[1]" mode="toc"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="exports">
|
|
<xsl:apply-templates select="key('symbols', string(@symbol))[1]"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template name="description">
|
|
<xsl:if test="deprecated">
|
|
<h2 style="font-weight:bold;color:red;text-align:center">This module is deprecated</h2>
|
|
</xsl:if>
|
|
<xsl:if test="description">
|
|
<p>
|
|
<xsl:call-template name="dumptext">
|
|
<xsl:with-param name="text" select="description"/>
|
|
</xsl:call-template>
|
|
</p>
|
|
</xsl:if>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="file">
|
|
<xsl:variable name="name" select="@name"/>
|
|
<xsl:variable name="title">Module <xsl:value-of select="$name"/> from <xsl:value-of select="/api/@name"/></xsl:variable>
|
|
<xsl:text disable-output-escaping="yes"><!DOCTYPE html>
|
|
</xsl:text>
|
|
<html>
|
|
<body>
|
|
<div class="document">
|
|
<h1><xsl:value-of select="$title"/></h1>
|
|
<xsl:call-template name="description"/>
|
|
<h2>Table of Contents</h2>
|
|
<xsl:if test="count(exports[@type='macro']) > 0">
|
|
<h3><a href="#macros">Macros</a></h3>
|
|
<pre class="api">
|
|
<xsl:apply-templates select="exports[@type='macro']" mode="toc">
|
|
<xsl:sort select='@symbol'/>
|
|
</xsl:apply-templates>
|
|
</pre>
|
|
</xsl:if>
|
|
<xsl:if test="count(exports[@type='typedef']) > 0">
|
|
<h3><a href="#types">Types</a></h3>
|
|
<pre class="api">
|
|
<xsl:apply-templates select="exports[@type='typedef']" mode="toc">
|
|
<xsl:sort select='@symbol'/>
|
|
</xsl:apply-templates>
|
|
</pre>
|
|
</xsl:if>
|
|
<xsl:if test="count(exports[@type='function']) > 0">
|
|
<h3><a href="#functions">Functions</a></h3>
|
|
<pre class="api">
|
|
<xsl:apply-templates select="exports[@type='function']" mode="toc">
|
|
<xsl:sort select='@symbol'/>
|
|
</xsl:apply-templates>
|
|
</pre>
|
|
</xsl:if>
|
|
|
|
<h2>Description</h2>
|
|
|
|
<xsl:if test="count(exports[@type='macro']) > 0">
|
|
<h3><a id="macros">Macros</a></h3>
|
|
<xsl:apply-templates select="exports[@type='macro']">
|
|
<xsl:sort select='@symbol'/>
|
|
</xsl:apply-templates>
|
|
</xsl:if>
|
|
<xsl:if test="count(exports[@type='typedef']) > 0">
|
|
<h3><a id="types">Types</a></h3>
|
|
<xsl:apply-templates select="exports[@type='typedef']">
|
|
<xsl:sort select='@symbol'/>
|
|
</xsl:apply-templates>
|
|
</xsl:if>
|
|
<xsl:if test="count(exports[@type='function']) > 0">
|
|
<h3><a id="functions">Functions</a></h3>
|
|
<xsl:apply-templates select="exports[@type='function']">
|
|
<xsl:sort select='@symbol'/>
|
|
</xsl:apply-templates>
|
|
</xsl:if>
|
|
</div>
|
|
</body>
|
|
</html>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="file" mode="toc">
|
|
<xsl:variable name="name" select="@name"/>
|
|
<li>
|
|
<a href="libvirt-{$name}.html"><xsl:value-of select="$name"/></a>
|
|
<xsl:text>: </xsl:text>
|
|
<xsl:value-of select="summary"/>
|
|
</li>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="/">
|
|
<xsl:for-each select="/api/files/file">
|
|
<xsl:variable name="subpage">
|
|
<xsl:apply-templates select="."/>
|
|
</xsl:variable>
|
|
|
|
<xsl:document
|
|
href="{concat($htmldir, '/libvirt-', @name, '.html')}"
|
|
method="xml"
|
|
omit-xml-declaration="yes"
|
|
encoding="UTF-8"
|
|
indent="yes">
|
|
<xsl:apply-templates select="exsl:node-set($subpage)" mode="page">
|
|
<xsl:with-param name="timestamp" select="$timestamp"/>
|
|
<xsl:with-param name="link_href_base" select="$href_base"/>
|
|
<xsl:with-param name="asset_href_base" select="$href_base"/>
|
|
</xsl:apply-templates>
|
|
</xsl:document>
|
|
</xsl:for-each>
|
|
</xsl:template>
|
|
|
|
</xsl:stylesheet>
|