I have the below xml
<ResultCollection>
<Result Id="551550" Pass="23" Fail="0" Owner="Dong"/>
<Result Id="551565" Pass="4" Fail="3" Owner="Dong"/>
<Result Id="551567" Pass="61" Fail="0" Owner="Mei"/>
<Result Id="551580" Pass="10" Fail="1" Owner="Dong"/>
<Result Id="551580" Pass="0" Fail="4" Owner="Sen"/>
<Result Id="551548" Pass="1" Fail="12" Owner="Sen"/>
</ResultCollection>
And I have an xsl that generates the below summary
Owner Total Pass Fail
Dong 41 37 4
Mei 61 61 0
Sen 17 1 16
How can I sort this result based on Pass or Fail?
My xsl looks like this
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="xml" indent="yes"/>
<xsl:key name="FeatureOwner" match="Result" use="@Owner" />
<xsl:template match="/">
<html>
<head>
<title>Result Summary</title>
</head>
<body>
<table>
<tr>
<td>
<b>Owner</b></td>
<td>
<b>Total</b>
</td>
<td>
<b>Pass</b>
</td>
<td>
<b>Fail</b>
</td>
</tr>
<xsl:for-each select="ResultCollection/Result[generate-id(.) = generate-id(key('FeatureOwner', @Owner)[1])]">
<xsl:variable name="varFeatureOwner">
<xsl:value-of select="@Owner" />
</xsl:variable>
<xsl:variable name="totFailures" select="sum(//ResultCollection/Result[@Owner=$varFeatureOwner]/@Fail)" />
<xsl:variable name="totPass" select="sum(//ResultCollection/Result[@Owner=$varFeatureOwner]/@Pass)" />
<xsl:variable name="total" select="$totPass+$totFailures" />
<tr>
<td>
<xsl:value-of select="$varFeatureOwner"/>
</td>
<td>
<xsl:value-of select="$total"/>
</td>
<td>
<xsl:value-of select="$totPass"/>
</td>
<td>
<xsl:value-of select="$totFailures"/>
</td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>