diff options
Diffstat (limited to 'buildscripts/phing/etc/coverage-frames.xsl')
-rwxr-xr-x[-rw-r--r--] | buildscripts/phing/etc/coverage-frames.xsl | 536 |
1 files changed, 467 insertions, 69 deletions
diff --git a/buildscripts/phing/etc/coverage-frames.xsl b/buildscripts/phing/etc/coverage-frames.xsl index 5e8d8e3e..251faff6 100644..100755 --- a/buildscripts/phing/etc/coverage-frames.xsl +++ b/buildscripts/phing/etc/coverage-frames.xsl @@ -1,3 +1,4 @@ +<?xml version="1.0"?> <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0" xmlns:exsl="http://exslt.org/common" xmlns:date="http://exslt.org/dates-and-times" @@ -29,13 +30,15 @@ It creates a set of HTML files a la javadoc where you can browse easily through all packages and classes. - @author Michiel Rook <a href="mailto:michiel@trendserver.nl"/> + @author Michiel Rook <a href="mailto:michiel.rook@gmail.com"/> @author Stephane Bailliez <a href="mailto:sbailliez@apache.org"/> --> <!-- default output directory is current directory --> <xsl:param name="output.dir" select="'.'"/> +<xsl:param name="output.sorttable" select="'.'"/> +<xsl:param name="document.title" select="''"/> <!-- ====================================================================== Root element @@ -47,7 +50,7 @@ </exsl:document> <!-- create the stylesheet.css --> - <exsl:document href="efile://{$output.dir}/stylesheet.css"> + <exsl:document omit-xml-declaration="yes" href="efile://{$output.dir}/stylesheet.css"> <xsl:call-template name="stylesheet.css"/> </exsl:document> @@ -68,6 +71,9 @@ <!-- process all packages --> <xsl:apply-templates select="./package" mode="write"/> + + <!-- process all subpackages --> + <xsl:apply-templates select="./package/subpackage" mode="write"/> </xsl:template> <!-- ======================================================================= @@ -76,7 +82,7 @@ ======================================================================= --> <xsl:template name="index.html"> <html> - <head><title>Coverage Results.</title></head> + <head><title><xsl:value-of select="$document.title"/> Coverage Results</title></head> <frameset cols="20%,80%"> <frameset rows="30%,70%"> <frame src="overview-frame.html" name="packageListFrame"/> @@ -98,6 +104,11 @@ ======================================================================= --> <!-- this is the stylesheet css to use for nearly everything --> <xsl:template name="stylesheet.css"> + <xsl:if test="$output.sorttable = 1"> + .sortable th { + cursor: pointer; + } + </xsl:if> .bannercell { border: 0px; padding: 0px; @@ -155,6 +166,41 @@ .small { font-size: 9px; } + td.legendItem { + font-weight: bold; + padding-bottom: 2px; + padding-right: 6px; + padding-top: 6px; + text-align: right; + } + td.legendValue { + color: #2E3436; + font-weight: bold; + padding-bottom: 2px; + padding-top: 6px; + text-align: left; + } + span.LegendCovered { + background-color: #8AE234; + margin-right: 2px; + padding-left: 10px; + padding-right: 10px; + text-align: center; + } + span.LegendUncovered { + background-color: #F0C8C8; + margin-right: 2px; + padding-left: 10px; + padding-right: 10px; + text-align: center; + } + span.LegendDeadCode { + background-color: #D3D7CF; + margin-right: 2px; + padding-left: 10px; + padding-right: 10px; + text-align: center; + } TD.empty { FONT-SIZE: 2px; BACKGROUND: #c0c0c0; BORDER:#9c9c9c 1px solid; color: #c0c0c0; @@ -174,22 +220,41 @@ TD.uncovered { PRE.srcLine { BACKGROUND: #ffffff; MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px; } + PRE.srcLineUncovered { + BACKGROUND: #F0C8C8; MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px; +} + PRE.srcLineCovered { + BACKGROUND: #8AE234; MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px; + } + PRE.srcLineDeadCode { + BACKGROUND: #D3D7CF; MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px; + } td.lineCount, td.coverageCount { BACKGROUND: #F0F0F0; PADDING-RIGHT: 3px; text-align: right; } -td.lineCountHighlight { - background: #C8C8F0; PADDING-RIGHT: 3px; + td.lineCountCovered, td.coverageCountCovered { + background: #8AE234; PADDING-RIGHT: 3px; text-align: right; } -td.coverageCountHighlight { + td.srcLineCovered { + background: #8AE234; + } + td.lineCountUncovered, td.coverageCountUncovered { background: #F0C8C8; PADDING-RIGHT: 3px; text-align: right; } -span.srcLineHighlight { + td.srcLineUncovered { background: #F0C8C8; } -span.srcLine { + td.lineCountDeadCode, td.coverageCountDeadCode { + background: #D3D7CF; PADDING-RIGHT: 3px; + text-align: right; + } + td.srcLineDeadCode { + background: #D3D7CF; + } +td.srcLine { background: #C8C8F0; } TD.srcLineClassStart { @@ -230,7 +295,7 @@ TD.srcLineClassStart { <xsl:variable name="package.name" select="(ancestor::package)[last()]/@name"/> <xsl:variable name="link"> <xsl:if test="not($package.name='')"> - <xsl:value-of select="translate($package.name,'.','/')"/><xsl:text>/</xsl:text> + <xsl:value-of select="translate($package.name,'._','//')"/><xsl:text>/</xsl:text> </xsl:if><xsl:value-of select="@name"/><xsl:text>.html</xsl:text> </xsl:variable> <tr> @@ -247,6 +312,33 @@ TD.srcLineClassStart { </td> </tr> </xsl:for-each> + <xsl:for-each select="package/subpackage/class"> + <xsl:sort select="@name"/> + <xsl:variable name="package.name" select="(ancestor::package)[last()]/@name"/> + <xsl:variable name="subpackage.name" select="(ancestor::subpackage)[last()]/@name"/> + <xsl:variable name="link"> + <xsl:if test="not($package.name='')"> + <xsl:value-of select="translate($package.name,'._','//')"/><xsl:text>/</xsl:text> + </xsl:if> + <xsl:if test="not($subpackage.name='')"> + <xsl:value-of select="translate($subpackage.name,'._','//')"/><xsl:text>/</xsl:text> + </xsl:if> + <xsl:value-of select="@name"/><xsl:text>.html</xsl:text> + </xsl:variable> + <tr> + <td nowrap="nowrap"> + <a target="classFrame" href="{$link}"><xsl:value-of select="@name"/></a> + <xsl:choose> + <xsl:when test="@totalcount=0"> + <i> (-)</i> + </xsl:when> + <xsl:otherwise> + <i> (<xsl:value-of select="format-number(@totalcovered div @totalcount, '0.0%')"/>)</i> + </xsl:otherwise> + </xsl:choose> + </td> + </tr> + </xsl:for-each> </table> </body> </html> @@ -266,7 +358,7 @@ TD.srcLineClassStart { <xsl:sort select="@name" order="ascending"/> <tr> <td nowrap="nowrap"> - <a href="{translate(@name,'.','/')}/package-summary.html" target="classFrame"> + <a href="{translate(@name,'._','//')}/package-summary.html" target="classFrame"> <xsl:value-of select="@name"/> </a> </td> @@ -281,6 +373,10 @@ TD.srcLineClassStart { <xsl:template match="snapshot" mode="overview.packages"> <html> <head> + <title>Coverage Results Overview</title> + <xsl:if test="$output.sorttable = 1"> + <script language="JavaScript" src="http://www.phing.info/support/sorttable.js"/> + </xsl:if> <xsl:call-template name="create.stylesheet.link"/> </head> <body onload="open('allclasses-frame.html','classListFrame')"> @@ -288,12 +384,13 @@ TD.srcLineClassStart { <table class="log" cellpadding="5" cellspacing="0" width="100%"> <tr class="a"> <td class="small">Packages: <xsl:value-of select="count(package)"/></td> - <td class="small">Classes: <xsl:value-of select="count(package/class)"/></td> + <td class="small">Subpackages: <xsl:value-of select="count(package/subpackage)"/></td> + <td class="small">Classes: <xsl:value-of select="count(package/class) + count(package/subpackage/class)"/></td> <td class="small">Methods: <xsl:value-of select="@methodcount"/></td> - <td class="small">LOC: <xsl:value-of select="count(package/class/sourcefile/sourceline)"/></td> + <td class="small">LOC: <xsl:value-of select="count(package/class/sourcefile/sourceline) + count(package/subpackage/class/sourcefile/sourceline)"/></td> <td class="small">Statements: <xsl:value-of select="@statementcount"/></td> </tr> - </table> + </table> <br/> <table class="log" cellpadding="5" cellspacing="0" width="100%"> @@ -304,12 +401,13 @@ TD.srcLineClassStart { <th width="350" colspan="2" nowrap="nowrap">Total coverage</th> </tr> <tr class="a"> - <td><b>Project</b></td> + <td><b>Project <xsl:value-of select="$document.title"/></b></td> <xsl:call-template name="stats.formatted"/> </tr> - <tr> - <td colspan="3"><br/></td> - </tr> + <tr><td colspan="4"><br/></td></tr> + </table> + + <table class="log sortable" cellpadding="5" cellspacing="0" width="100%"> <tr> <th width="100%">Packages</th> <th>Statements</th> @@ -321,7 +419,7 @@ TD.srcLineClassStart { <xsl:sort data-type="number" select="@totalcovered div @totalcount"/> <tr> <xsl:call-template name="alternate-row"/> - <td><a href="{translate(@name,'.','/')}/package-summary.html"><xsl:value-of select="@name"/></a></td> + <td><a href="{translate(@name,'._','//')}/package-summary.html"><xsl:value-of select="@name"/></a></td> <xsl:call-template name="stats.formatted"/> </tr> </xsl:for-each> @@ -337,7 +435,7 @@ TD.srcLineClassStart { --> <xsl:template match="package" mode="write"> <xsl:variable name="package.dir"> - <xsl:if test="not(@name = '')"><xsl:value-of select="translate(@name,'.','/')"/></xsl:if> + <xsl:if test="not(@name = '')"><xsl:value-of select="translate(@name,'._','//')"/></xsl:if> <xsl:if test="@name = ''">.</xsl:if> </xsl:variable> @@ -351,23 +449,63 @@ TD.srcLineClassStart { <xsl:apply-templates select="." mode="package.summary"/> </exsl:document> - <!-- for each class, creates a @name.html --> - <xsl:for-each select="class"> + <!-- for each class in package, creates a @name.html --> + <xsl:for-each select="./class"> <exsl:document href="efile://{$output.dir}/{$package.dir}/{@name}.html"> <xsl:apply-templates select="." mode="class.details"/> </exsl:document> </xsl:for-each> + + <!-- for each class in subpackage, creates a @name.html --> + <xsl:for-each select="subpackage"> + <xsl:variable name="subpackage.dir"> + <xsl:if test="not(@name = '')"><xsl:value-of select="translate(@name,'._','//')"/></xsl:if> + <xsl:if test="@name = ''">.</xsl:if> + </xsl:variable> + <xsl:for-each select="./class"> + <exsl:document href="efile://{$output.dir}/{$package.dir}/{$subpackage.dir}/{@name}.html"> + <xsl:apply-templates select="." mode="class.details"/> + </exsl:document> + </xsl:for-each> + </xsl:for-each> +</xsl:template> + +<!-- + detailed info for a subpackage. It will output the list of classes and the summary page +--> +<xsl:template match="subpackage" mode="write"> + <xsl:variable name="package.name" select="(ancestor::package)[last()]/@name"/> + + <xsl:variable name="package.dir"> + <xsl:if test="not($package.name = '')"><xsl:value-of select="translate($package.name,'._','//')"/></xsl:if> + <xsl:if test="$package.name = ''">.</xsl:if> + </xsl:variable> + + <xsl:variable name="subpackage.dir"> + <xsl:if test="not(@name = '')"><xsl:value-of select="translate(@name,'._','//')"/></xsl:if> + <xsl:if test="@name = ''">.</xsl:if> + </xsl:variable> + + <!-- create a classes-list.html in the subpackage directory --> + <exsl:document href="efile://{$output.dir}/{$package.dir}/{$subpackage.dir}/subpackage-frame.html"> + <xsl:apply-templates select="." mode="classes.list"/> + </exsl:document> + + <!-- create a subpackage-summary.html in the subpackage directory --> + <exsl:document href="efile://{$output.dir}/{$package.dir}/{$subpackage.dir}/subpackage-summary.html"> + <xsl:apply-templates select="." mode="subpackage.summary"/> + </exsl:document> </xsl:template> <!-- list of classes in a package --> <xsl:template match="package" mode="classes.list"> <html> - <HEAD> + <head> <xsl:call-template name="create.stylesheet.link"> <xsl:with-param name="package.name" select="@name"/> </xsl:call-template> - </HEAD> - <BODY> + </head> + <body> <table width="100%"> <tr> <td nowrap="nowrap"> @@ -376,8 +514,28 @@ TD.srcLineClassStart { </tr> </table> - <H2>Classes</H2> - <TABLE WIDTH="100%"> + <h2>Subpackages</h2> + <table width="100%"> + <xsl:for-each select="subpackage"> + <xsl:sort select="@name"/> + <tr> + <td nowrap="nowrap"> + <a href="{translate(@name,'._','//')}/subpackage-summary.html" target="classFrame"><xsl:value-of select="@name"/></a> + <xsl:choose> + <xsl:when test="@totalcount=0"> + <i> (-)</i> + </xsl:when> + <xsl:otherwise> + <i> (<xsl:value-of select="format-number(@totalcovered div @totalcount, '0.0%')"/>)</i> + </xsl:otherwise> + </xsl:choose> + </td> + </tr> + </xsl:for-each> + </table> + + <h2>Classes</h2> + <table width="100%"> <xsl:for-each select="class"> <xsl:sort select="@name"/> <tr> @@ -394,27 +552,96 @@ TD.srcLineClassStart { </td> </tr> </xsl:for-each> - </TABLE> - </BODY> + </table> + </body> + </html> +</xsl:template> + +<!-- list of classes in a subpackage --> +<xsl:template match="subpackage" mode="classes.list"> + <xsl:variable name="fullpackage.name"> + <xsl:value-of select="(ancestor::package)[last()]/@name"/> + <!-- append subpackage name if exists --> + <xsl:if test="not(@name='')"> + <xsl:choose> + <!-- determine path separator --> + <xsl:when test="contains((ancestor::package)[last()]/@name, '_') or contains(@name, '_')"> + <xsl:text>_</xsl:text> + </xsl:when> + <xsl:otherwise> + <xsl:text>.</xsl:text> + </xsl:otherwise> + </xsl:choose> + <xsl:value-of select="@name"/> + </xsl:if> + </xsl:variable> + + <xsl:variable name="package.name" select="(ancestor::package)[last()]/@name"/> + + <html> + <head> + <xsl:call-template name="create.stylesheet.link"> + <xsl:with-param name="package.name" select="$fullpackage.name"/> + </xsl:call-template> + </head> + <body> + <table width="100%"> + <tr> + <td nowrap="nowrap"> + <H2> + <xsl:call-template name="create.package-summary.link"> + <xsl:with-param name="package.name" select="$package.name"/> + <xsl:with-param name="fullpackage.name" select="$fullpackage.name"/> + </xsl:call-template>::<a href="subpackage-summary.html" target="classFrame"><xsl:value-of select="@name"/></a> + </H2> + </td> + </tr> + </table> + + <h2>Classes</h2> + <table width="100%"> + <xsl:for-each select="class"> + <xsl:sort select="@name"/> + <tr> + <td nowrap="nowrap"> + <a href="{@name}.html" target="classFrame"><xsl:value-of select="@name"/></a> + <xsl:choose> + <xsl:when test="@totalcount=0"> + <i> (-)</i> + </xsl:when> + <xsl:otherwise> + <i> (<xsl:value-of select="format-number(@totalcovered div @totalcount, '0.0%')"/>)</i> + </xsl:otherwise> + </xsl:choose> + </td> + </tr> + </xsl:for-each> + </table> + </body> </html> </xsl:template> <!-- summary of a package --> <xsl:template match="package" mode="package.summary"> - <HTML> - <HEAD> + <html> + <head> + <title>Coverage Results for <xsl:value-of select="@name"/></title> + <xsl:if test="$output.sorttable = 1"> + <script language="JavaScript" src="http://www.phing.info/support/sorttable.js"/> + </xsl:if> <xsl:call-template name="create.stylesheet.link"> <xsl:with-param name="package.name" select="@name"/> </xsl:call-template> - </HEAD> + </head> <!-- when loading this package, it will open the classes into the frame --> - <BODY onload="open('package-frame.html','classListFrame')"> + <body onload="open('package-frame.html','classListFrame')"> <xsl:call-template name="pageHeader"/> <table class="log" cellpadding="5" cellspacing="0" width="100%"> <tr class="a"> - <td class="small">Classes: <xsl:value-of select="count(class)"/></td> + <td class="small">Subpackages: <xsl:value-of select="count(subpackage)"/></td> + <td class="small">Classes: <xsl:value-of select="count(class) + count(subpackage/class)"/></td> <td class="small">Methods: <xsl:value-of select="@methodcount"/></td> - <td class="small">LOC: <xsl:value-of select="count(class/sourcefile/sourceline)"/></td> + <td class="small">LOC: <xsl:value-of select="count(class/sourcefile/sourceline) + count(subpackage/class/sourcefile/sourceline)"/></td> <td class="small">Statements: <xsl:value-of select="@statementcount"/></td> </tr> </table> @@ -428,6 +655,92 @@ TD.srcLineClassStart { <th width="350" colspan="2" nowrap="nowrap">Total coverage</th> </tr> <xsl:apply-templates select="." mode="stats"/> + <tr> + <td colspan="5"><br/></td> + </tr> + </table> + + <xsl:if test="count(subpackage) > 0"> + <table class="log sortable" cellpadding="5" cellspacing="0" width="100%"> + <tr> + <th width="100%">Subpackages</th> + <th>Statements</th> + <th>Methods</th> + <th width="350" colspan="2" nowrap="nowrap">Total coverage</th> + </tr> + <xsl:apply-templates select="subpackage" mode="stats"> + <xsl:sort data-type="number" select="@totalcovered div @totalcount"/> + </xsl:apply-templates> + <tr> + <td colspan="5"><br/></td> + </tr> + </table> + </xsl:if> + + <xsl:if test="count(class) > 0"> + <table class="log sortable" cellpadding="5" cellspacing="0" width="100%"> + <tr> + <th width="100%">Classes</th> + <th>Statements</th> + <th>Methods</th> + <th width="350" colspan="2" nowrap="nowrap">Total coverage</th> + </tr> + <xsl:apply-templates select="class" mode="stats"> + <xsl:sort data-type="number" select="@totalcovered div @totalcount"/> + </xsl:apply-templates> + </table> + </xsl:if> + <xsl:call-template name="pageFooter"/> + </body> + </html> +</xsl:template> + +<!-- summary of a subpackage --> +<xsl:template match="subpackage" mode="subpackage.summary"> + <xsl:variable name="fullpackage.name"> + <xsl:value-of select="(ancestor::package)[last()]/@name"/> + <!-- append subpackage name if exists --> + <xsl:if test="not(@name='')"> + <xsl:choose> + <!-- determine path separator --> + <xsl:when test="contains((ancestor::package)[last()]/@name, '_') or contains(@name, '_')"> + <xsl:text>_</xsl:text> + </xsl:when> + <xsl:otherwise> + <xsl:text>.</xsl:text> + </xsl:otherwise> + </xsl:choose> + <xsl:value-of select="@name"/> + </xsl:if> + </xsl:variable> + + <html> + <head> + <xsl:call-template name="create.stylesheet.link"> + <xsl:with-param name="package.name" select="$fullpackage.name"/> + </xsl:call-template> + </head> + <!-- when loading this subpackage, it will open the classes into the frame --> + <body onload="open('subpackage-frame.html','classListFrame')"> + <xsl:call-template name="pageHeader"/> + <table class="log" cellpadding="5" cellspacing="0" width="100%"> + <tr class="a"> + <td class="small">Classes: <xsl:value-of select="count(class)"/></td> + <td class="small">Methods: <xsl:value-of select="@methodcount"/></td> + <td class="small">LOC: <xsl:value-of select="count(class/sourcefile/sourceline)"/></td> + <td class="small">Statements: <xsl:value-of select="@statementcount"/></td> + </tr> + </table> + <br/> + + <table class="log" cellpadding="5" cellspacing="0" width="100%"> + <tr> + <th width="100%">Subpackage</th> + <th>Statements</th> + <th>Methods</th> + <th width="350" colspan="2" nowrap="nowrap">Total coverage</th> + </tr> + <xsl:apply-templates select="." mode="stats.summary"/> <xsl:if test="count(class) > 0"> <tr> @@ -445,20 +758,38 @@ TD.srcLineClassStart { </xsl:if> </table> <xsl:call-template name="pageFooter"/> - </BODY> - </HTML> + </body> + </html> </xsl:template> <!-- details of a class --> <xsl:template match="class" mode="class.details"> - <xsl:variable name="package.name" select="(ancestor::package)[last()]/@name"/> - <HTML> - <HEAD> + <xsl:variable name="subpackage.name" select="(ancestor::subpackage)[last()]/@name"/> + + <xsl:variable name="fullpackage.name"> + <xsl:value-of select="(ancestor::package)[last()]/@name"/> + <!-- append subpackage name if exists --> + <xsl:if test="not($subpackage.name='')"> + <xsl:choose> + <!-- determine path/package separator --> + <xsl:when test="contains((ancestor::package)[last()]/@name, '_') or contains($subpackage.name, '_')"> + <xsl:text>_</xsl:text> + </xsl:when> + <xsl:otherwise> + <xsl:text>.</xsl:text> + </xsl:otherwise> + </xsl:choose> + <xsl:value-of select="$subpackage.name"/> + </xsl:if> + </xsl:variable> + + <html> + <head> <xsl:call-template name="create.stylesheet.link"> - <xsl:with-param name="package.name" select="$package.name"/> + <xsl:with-param name="package.name" select="$fullpackage.name"/> </xsl:call-template> - </HEAD> - <BODY> + </head> + <body> <xsl:call-template name="pageHeader"/> <table class="log" cellpadding="5" cellspacing="0" width="100%"> <tr class="a"> @@ -467,7 +798,20 @@ TD.srcLineClassStart { <td class="small">Statements: <xsl:value-of select="@statementcount"/></td> </tr> </table> - <br/> + + <!-- legend --> + <table class="log" cellpadding="5" cellspacing="0" width="100%"> + <tbody> + <tr> + <td class="legendItem" width="0%">Legend:</td> + <td class="legendValue" width="100%"> + <span class="legendCovered">executed</span> + <span class="legendUncovered">not executed</span> + <span class="legendDeadCode">dead code</span> + </td> + </tr> + </tbody> + </table> <!-- class summary --> <table class="log" cellpadding="5" cellspacing="0" width="100%"> @@ -488,9 +832,8 @@ TD.srcLineClassStart { </table> <br/> <xsl:call-template name="pageFooter"/> - </BODY> - </HTML> - + </body> + </html> </xsl:template> <!-- Page Header --> @@ -499,14 +842,14 @@ TD.srcLineClassStart { <table border="0" cellpadding="0" cellspacing="0" width="100%"> <tr> <td class="bannercell" rowspan="2"> - <a href="http://phing.info/"> - <img src="http://phing.info/images/phing.gif" alt="http://phing.info/" align="left" border="0"/> + <a href="http://www.phing.info/"> + <img src="http://www.phing.info/images/phing.gif" alt="http://www.phing.info/" align="left" border="0"/> </a> </td> <td style="text-align:right"><h2>Source Code Coverage</h2></td> </tr> <tr> - <td style="text-align:right">Designed for use with <a href='http://pear.php.net/package/PHPUnit2'>PHPUnit2</a>, <a href='http://www.xdebug.org/'>Xdebug</a> and <a href='http://phing.info/'>Phing</a>.</td> + <td style="text-align:right">Designed for use with <a href='http://www.phpunit.de'>PHPUnit</a>, <a href='http://www.xdebug.org/'>Xdebug</a> and <a href='http://www.phing.info/'>Phing</a>.</td> </tr> </table> <hr size="1"/> @@ -528,6 +871,22 @@ TD.srcLineClassStart { </tr> </xsl:template> +<xsl:template match="subpackage" mode="stats"> + <tr> + <xsl:call-template name="alternate-row"/> + <td><a href="{translate(@name,'._','//')}/subpackage-summary.html" target="classFrame"><xsl:value-of select="@name"/></a></td> + <xsl:call-template name="stats.formatted"/> + </tr> +</xsl:template> + +<xsl:template match="subpackage" mode="stats.summary"> + <tr> + <xsl:call-template name="alternate-row"/> + <td><xsl:value-of select="@name"/></td> + <xsl:call-template name="stats.formatted"/> + </tr> +</xsl:template> + <xsl:template match="class" mode="stats"> <tr> <xsl:call-template name="alternate-row"/> @@ -600,40 +959,60 @@ TD.srcLineClassStart { <xsl:template match="sourceline"> <tr> <xsl:if test="@coveredcount>0"> - <td class="lineCountHighlight"><xsl:value-of select="position()"/></td> - <td class="lineCountHighlight"><xsl:value-of select="@coveredcount"/></td> + <td class="lineCountCovered"><xsl:value-of select="position()"/></td> + <td class="lineCountCovered"><xsl:value-of select="@coveredcount"/></td> </xsl:if> - <xsl:if test="@coveredcount<0"> - <td class="lineCountHighlight"><xsl:value-of select="position()"/></td> - <td class="coverageCountHighlight">0</td> + <xsl:if test="@coveredcount=-1"> + <td class="lineCountUncovered"><xsl:value-of select="position()"/></td> + <td class="coverageCountUncovered"></td> + </xsl:if> + <xsl:if test="@coveredcount=-2"> + <td class="lineCountDeadCode"><xsl:value-of select="position()"/></td> + <td class="coverageCountDeadCode"></td> </xsl:if> <xsl:if test="@coveredcount=0"> <td class="lineCount"><xsl:value-of select="position()"/></td> <td class="coverageCount"></td> </xsl:if> - <td> - <xsl:if test="@startclass=1"> + + <xsl:if test="@coveredcount>0"> + <td class="srcLineCovered"> + <xsl:if test="@startclass=1"> <xsl:attribute name="class">srcLineClassStart</xsl:attribute> </xsl:if> - <xsl:if test="@coveredcount>0"> - <span class="srcLine"> - <pre class="srcLine"><xsl:value-of select="."/></pre> - </span> + <pre class="srcLineCovered"><xsl:value-of select="."/></pre> + </td> </xsl:if> - <xsl:if test="@coveredcount<0"> - <span class="srcLineHighlight"> - <pre class="srcLine"><xsl:value-of select="."/></pre> - </span> + <xsl:if test="@coveredcount=-1"> + <td class="srcLineUncovered"> + <xsl:if test="@startclass=1"> + <xsl:attribute name="class">srcLineClassStart</xsl:attribute> </xsl:if> + <pre class="srcLineUncovered"><xsl:value-of select="."/></pre> + </td> + </xsl:if> + <xsl:if test="@coveredcount=-2"> + <td class="srcLineDeadCode"> + <xsl:if test="@startclass=1"> + <xsl:attribute name="class">srcLineClassStart</xsl:attribute> + </xsl:if> + <pre class="srcLineDeadCode"><xsl:value-of select="."/></pre> + </td> + </xsl:if> <xsl:if test="@coveredcount=0"> + <td> + <xsl:if test="@startclass=1"> + <xsl:attribute name="class">srcLineClassStart</xsl:attribute> + </xsl:if> <pre class="srcLine"><xsl:value-of select="."/></pre> + </td> </xsl:if> - </td> </tr> </xsl:template> <!-- transform string like a.b.c to ../../../ + transform string like a_b_c to ../../../ @param path the path to transform into a descending directory path --> <xsl:template name="path"> @@ -644,18 +1023,39 @@ TD.srcLineClassStart { <xsl:with-param name="path"><xsl:value-of select="substring-after($path,'.')"/></xsl:with-param> </xsl:call-template> </xsl:if> - <xsl:if test="not(contains($path,'.')) and not($path = '')"> + <xsl:if test="contains($path,'_')"> + <xsl:text>../</xsl:text> + <xsl:call-template name="path"> + <xsl:with-param name="path"><xsl:value-of select="substring-after($path,'_')"/></xsl:with-param> + </xsl:call-template> + </xsl:if> + <xsl:if test="not(contains($path,'.')) and not(contains($path,'_')) and not($path = '')"> <xsl:text>../</xsl:text> </xsl:if> </xsl:template> - <!-- create the link to the stylesheet based on the package name --> <xsl:template name="create.stylesheet.link"> <xsl:param name="package.name"/> <LINK REL ="stylesheet" TYPE="text/css" TITLE="Style"><xsl:attribute name="href"><xsl:if test="not($package.name = 'unnamed package')"><xsl:call-template name="path"><xsl:with-param name="path" select="$package.name"/></xsl:call-template></xsl:if>stylesheet.css</xsl:attribute></LINK> </xsl:template> +<!-- create the link to the package summary --> +<xsl:template name="create.package-summary.link"> + <xsl:param name="package.name"/> + <xsl:param name="fullpackage.name"/> + <a target="classFrame"> + <xsl:attribute name="href"> + <xsl:if test="not($fullpackage.name = 'unnamed package')"> + <xsl:call-template name="path"> + <xsl:with-param name="path" select="$fullpackage.name"/> + </xsl:call-template> + </xsl:if> + <xsl:value-of select="translate($package.name,'._','//')"/>/package-summary.html</xsl:attribute> + <xsl:value-of select="$package.name"/> + </a> +</xsl:template> + <!-- alternated row style --> <xsl:template name="alternate-row"> <xsl:attribute name="class"> @@ -665,5 +1065,3 @@ TD.srcLineClassStart { </xsl:template> </xsl:stylesheet> - - |