Pretty-print the control stack argument.
git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk/avrdude@604 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
parent
abda4d9276
commit
ee7915be66
|
@ -43,7 +43,10 @@
|
||||||
'PP')]">
|
'PP')]">
|
||||||
<xsl:if test="self::node()[name() = 'PPControlStack']"
|
<xsl:if test="self::node()[name() = 'PPControlStack']"
|
||||||
> pp_controlstack =
|
> pp_controlstack =
|
||||||
<xsl:value-of select="translate(current(), ' ', ',')" />;
|
<xsl:call-template name="format_cstack">
|
||||||
|
<xsl:with-param name="stack" select="." />
|
||||||
|
<xsl:with-param name="count" select="0" />
|
||||||
|
</xsl:call-template>;
|
||||||
</xsl:if> <!-- PPControlStack -->
|
</xsl:if> <!-- PPControlStack -->
|
||||||
|
|
||||||
<xsl:if test="self::node()[name() = 'PpEnterProgMode']">
|
<xsl:if test="self::node()[name() = 'PpEnterProgMode']">
|
||||||
|
@ -126,7 +129,10 @@
|
||||||
|
|
||||||
<xsl:if test="self::node()[name() = 'HvspControlStack']"
|
<xsl:if test="self::node()[name() = 'HvspControlStack']"
|
||||||
> hvsp_controlstack =
|
> hvsp_controlstack =
|
||||||
<xsl:value-of select="translate(current(), ' ', ',')" />;
|
<xsl:call-template name="format_cstack">
|
||||||
|
<xsl:with-param name="stack" select="." />
|
||||||
|
<xsl:with-param name="count" select="0" />
|
||||||
|
</xsl:call-template>;
|
||||||
</xsl:if> <!-- HvspControlStack -->
|
</xsl:if> <!-- HvspControlStack -->
|
||||||
|
|
||||||
<xsl:if test="self::node()[name() = 'HvspEnterProgMode']">
|
<xsl:if test="self::node()[name() = 'HvspEnterProgMode']">
|
||||||
|
@ -202,4 +208,47 @@
|
||||||
</xsl:for-each> <!-- All nodes -->
|
</xsl:for-each> <!-- All nodes -->
|
||||||
|
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
* Format the control stack argument: replace space-separated
|
||||||
|
* list by a list separated with commas, followed by either
|
||||||
|
* a space or a newline, dependend on the current argument
|
||||||
|
* count.
|
||||||
|
* This template calls itself recursively, until the entire
|
||||||
|
* argument $stack has been processed.
|
||||||
|
-->
|
||||||
|
<xsl:template name="format_cstack">
|
||||||
|
<xsl:param name="stack" />
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="string-length($stack) <= 4">
|
||||||
|
<!-- Last element, print it, and leave template. -->
|
||||||
|
<xsl:value-of select="$stack" />
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<!--
|
||||||
|
* More arguments follow, print first value,
|
||||||
|
* followed by a comma, decide whether a space
|
||||||
|
* or a newline needs to be emitted, and recurse
|
||||||
|
* with the remaining part of $stack.
|
||||||
|
-->
|
||||||
|
<xsl:value-of select="substring($stack, 1, 4)" />
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="$count mod 8 = 7">
|
||||||
|
<!-- comma, newline, 8 spaces indentation -->
|
||||||
|
<xsl:text>,
|
||||||
|
</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<!-- comma, space -->
|
||||||
|
<xsl:text>, </xsl:text>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
<xsl:call-template name="format_cstack">
|
||||||
|
<xsl:with-param name="stack" select="substring($stack, 6)"
|
||||||
|
/>
|
||||||
|
<xsl:with-param name="count" select="$count + 1" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
</xsl:stylesheet>
|
</xsl:stylesheet>
|
||||||
|
|
Loading…
Reference in New Issue