forked from apache/xalan-test
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathviewResults.xsl
465 lines (423 loc) · 20.6 KB
/
viewResults.xsl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0"
xmlns:lxslt="http://xml.apache.org/xslt"
xmlns:redirect="org.apache.xalan.lib.Redirect"
extension-element-prefixes="redirect">
<xsl:output method="html"/>
<!-- FileName: viewResults.xsl -->
<!-- Author: shane_curcuru@lotus.com -->
<!-- Purpose: Handy viewer for org.apache.qetest.XMLFileLogger
logFile results put into simple HTML pages -->
<!-- Include constant definitions for results file elements,
attributes, and values, copied from relevant Java code -->
<xsl:include href="resultsConstants.xsl"/>
<!-- Explicitly declare the redirect extension -->
<lxslt:component prefix="redirect" elements="write open close" functions="">
<lxslt:script lang="javaclass" src="org.apache.xalan.lib.Redirect"/>
</lxslt:component>
<!-- ======================================================= -->
<!-- INPUT PARAMETERS can be set from external command lines -->
<!-- When set to true, skips (does not) output any checkresult[@result='PASS'] -->
<xsl:param name="failsonly">false</xsl:param>
<!-- When set to true, also outputs perf-related stuff -->
<xsl:param name="perfLogging">false</xsl:param>
<!-- File listing known bugs, so that when we get a result
checkresult[@result='$FAIL'] who has an @id that also
matches a known bug, we can print 'SPR' instead of 'Fail' -->
<xsl:param name="bugfile">../java/bugs.xml</xsl:param>
<!-- Skip any message[@level<=loggingLevel] -->
<xsl:param name="loggingLevel">50</xsl:param>
<!-- Only print out a bare summary; nothing else -->
<xsl:param name="summary">false</xsl:param>
<!-- Cheap color background for errors, fails, and messages likely related thereto -->
<xsl:param name="errfailcolor">red</xsl:param>
<xsl:param name="knownfailcolor">pink</xsl:param>
<!-- File to redirect mini-summary to -->
<xsl:param name="summaryfile">summary_.xml</xsl:param>
<!-- ================================== -->
<!-- Main template-standalone: output an HTML page -->
<!-- The resultfile element must be present. It should include one or more
testfile elements, and may include other elements in some cases. -->
<xsl:template match="resultsfile">
<HTML>
<HEAD><TITLE><xsl:text>Test Results file: </xsl:text><xsl:value-of select="./@logFile"/></TITLE></HEAD>
<BODY>
<!-- TODO: This case is only valid if we have a single testfile!!! -->
<xsl:call-template name="doResultsFile"/>
</BODY>
</HTML>
</xsl:template>
<!-- ================================== -->
<!-- Main template-multiple-files: output an HTML page -->
<!-- The resultfile element must be present. It should include one or more
testfile elements, and may include other elements in some cases. -->
<!-- Note that this is only called when MultiViewResults.xsl is including us. -->
<xsl:template name="mainResultsFile"> <!-- equivalent match="resultsfile" -->
<H2><xsl:text>Test Results file: </xsl:text><xsl:value-of select="./@logFile"/></H2>
<xsl:call-template name="doResultsFile"/>
</xsl:template>
<xsl:template name="doResultsFile"> <!-- equivalent match="resultsfile" -->
<!-- We are expecting testfile and hashtable elements. However a test
may also output other elements that we should also report -->
<xsl:apply-templates select="testfile | hashtable | message | arbitrary | checkresult"/>
</xsl:template>
<!-- Grab the testfile's name and overall results first, then output the rest -->
<xsl:template match="testfile">
<!-- Cache the value of the desc attribute for later use -->
<xsl:variable name="testfilename" select="@filename"></xsl:variable>
<H3><B><xsl:text>Testfile: </xsl:text><xsl:value-of select="$testfilename"/>
<xsl:text> begins: </xsl:text></B><xsl:value-of select="@desc"/></H3>
<!-- First dump out an overall summary table -->
<xsl:call-template name="restable">
<xsl:with-param name="linkname" select="$testfilename"></xsl:with-param>
</xsl:call-template>
<!-- Simply skip the rest if we're only doing summary -->
<xsl:if test="$summary='false'">
<!-- Optimization: dump most info first; then any testfile-level
hashtables at the very end of the report. -->
<!-- Create a link to the hashtables for this file -->
<FONT size="-1">
<xsl:element name="a">
<xsl:attribute name="href"><xsl:value-of select="$hash-marker"/><xsl:value-of select="$testfilename"/></xsl:attribute>
<xsl:text>Hashtables and System.properties</xsl:text>
</xsl:element>
</FONT>
<xsl:apply-templates select="testcase | message | arbitrary | checkresult"/>
<!-- @todo optimize so anchor only appears if there are hashtables -->
<xsl:element name="a">
<xsl:attribute name="name"><xsl:value-of select="$hash-marker"/><xsl:value-of select="$testfilename"/></xsl:attribute>
<xsl:text> </xsl:text><!-- Only need a blank space to anchor to -->
</xsl:element>
<xsl:apply-templates select="hashtable"/>
<H3><B><xsl:text>Testfile (</xsl:text><xsl:value-of select="fileresult/@result"/><xsl:text>) ends: </xsl:text></B>
<xsl:value-of select="$testfilename"/></H3>
<FONT size="-1">
<xsl:element name="a">
<xsl:attribute name="href"><xsl:value-of select="$file-results-marker"/><xsl:value-of select="$testfilename"/></xsl:attribute>
<xsl:text>Overall testfile results</xsl:text>
</xsl:element>
</FONT>
</xsl:if>
<P><xsl:text>Test time (milliseconds): </xsl:text><xsl:value-of select="(statistic[starts-with(@desc,$TEST_STOP)]/longval) - (statistic[starts-with(@desc,$TEST_START)]/longval)"/></P>
</xsl:template>
<!-- Process each testcase as a table in HTML -->
<xsl:template match="testcase">
<TABLE frame="box" border="1" rules="groups" width="95%" cellspacing="2" cellpadding="5">
<CAPTION><xsl:text>Testcase begins: </xsl:text><xsl:value-of select="@desc"/></CAPTION>
<!-- fake row to establish widths -->
<TR><TD width="20%"></TD><TD width="80%"></TD></TR>
<!-- It is illegal for a testcase to contain another testcase, so don't bother
selecting them: however you must check for every other kind of item -->
<!-- fileref comes from XSLDirectoryIterator when a test has a non-pass checkresult -->
<xsl:apply-templates select="message | arbitrary | checkresult | hashtable | fileref | statistic | perf"/>
<TR><TD></TD><TD><xsl:text>Case time (milliseconds): </xsl:text>
<xsl:value-of select="(statistic[starts-with(@desc,$CASE_STOP)]/longval) - (statistic[starts-with(@desc,$CASE_START)]/longval)"/></TD></TR>
<!-- Print out the overall caseresult at the end -->
<xsl:apply-templates select="caseresult"/>
</TABLE>
</xsl:template>
<!-- Note: must match values in XMLFileReporter for attributes and values! -->
<!-- Different processing for different kinds of checkresults,
normally only used within testcase elements -->
<xsl:template match="checkresult[@result=$FAIL] | checkresult[@result=$ERRR]">
<TR>
<xsl:choose>
<!-- This needs to be updated to read some bugs.xml file, and
then print this for checkresults where the id is found in
bugs.xml somewhere
/Sprs/Spr/Name
COMMENT OUT 09-Jul-01 SC since we no longer use bugs.xml.
Eventually we should replace this with a better mechanisim
<xsl:when test="@id = document($bugfile)/Sprs/Spr/Name">
<TD bgcolor="{$knownfailcolor}"><B><xsl:text>Bug #</xsl:text><xsl:value-of select="@id"/></B></TD>
</xsl:when>
-->
<xsl:when test="@id = 'known-bug'">
<TD bgcolor="{$knownfailcolor}"><B><xsl:text>Reported bug</xsl:text></B></TD>
</xsl:when>
<xsl:otherwise>
<TD bgcolor="{$errfailcolor}"><B><xsl:value-of select="@result"/></B></TD>
</xsl:otherwise>
</xsl:choose>
<TD>
<xsl:if test="@id">
<xsl:text>[</xsl:text><xsl:value-of select="@id"/><xsl:text>] </xsl:text>
</xsl:if>
<xsl:value-of select="@desc"/>
</TD>
</TR>
</xsl:template>
<xsl:template match="checkresult[@result=$AMBG] | checkresult[@result=$INCP]">
<TR>
<TD><I><xsl:value-of select="@result"/></I></TD>
<TD>
<xsl:if test="@id">
<xsl:text>[</xsl:text><xsl:value-of select="@id"/><xsl:text>] </xsl:text>
</xsl:if>
<xsl:value-of select="@desc"/>
</TD>
</TR>
</xsl:template>
<!-- If users want a 'condensed' report, set failsonly=true, and then we skip all pass records -->
<xsl:template match="statistic">
<xsl:if test="$perfLogging='true'">
<xsl:call-template name="log-statistic"/>
</xsl:if>
</xsl:template>
<xsl:template name="log-statistic">
<!-- //@todo Note assumption we're in a table -->
<TR>
<TD><xsl:value-of select="@level"/></TD>
<TD><xsl:value-of select="@desc"/><xsl:text> </xsl:text><xsl:value-of select="longval"/></TD>
</TR>
</xsl:template>
<xsl:template match="perf">
<xsl:if test="$perfLogging='true'">
<xsl:call-template name="log-perf"/>
</xsl:if>
</xsl:template>
<xsl:template name="log-perf">
<!-- //@todo Note assumption we're in a table -->
<TR>
<TD><xsl:value-of select="@idref"/></TD>
<TD>
<xsl:variable name="perfattrs" select="'avgparsexsl singletransform unparsedxml parsexsl avgetoe avgunparsedxml etoe OVERALL XSLREAD XSLBUILD XMLREAD XMLBUILD TRANSFORM RESULTWRITE FIRSTLATENCY'"/>
<xsl:for-each select="attribute::*">
<xsl:sort select="name()"/>
<xsl:if test="contains($perfattrs, name())">
<xsl:text> </xsl:text><xsl:value-of select="name()"/><xsl:text>=</xsl:text><xsl:value-of select="."/>
</xsl:if>
</xsl:for-each>
</TD>
</TR>
</xsl:template>
<!--
Cheap-o way to output local filesystem links to the actual test files.
We should actually tie the fileref together with the checkresult that
goes with it via fileref/@idref = checkresult/@id somehow, but
this would be closely related to XSLDirectoryIterator.
-->
<xsl:template match="fileref">
<TR>
<TD><xsl:text>[</xsl:text><xsl:value-of select="@idref"/><xsl:text>] </xsl:text></TD>
<TD>
<!-- //@todo NOTE: use new StylesheetTestlet-output baseref as
the start of each href attr, but only if it's relative
(i.e. if the @inputName, etc. is absolute, leave it alone)
-->
<xsl:element name="a">
<xsl:attribute name="href"><xsl:value-of select="@inputName"/></xsl:attribute>
<xsl:text>xsl</xsl:text>
</xsl:element><xsl:text>, </xsl:text>
<xsl:element name="a">
<xsl:attribute name="href"><xsl:value-of select="@xmlName"/></xsl:attribute>
<xsl:text>xml</xsl:text>
</xsl:element><xsl:text>, </xsl:text>
<xsl:element name="a">
<xsl:attribute name="href"><xsl:value-of select="@outputName"/></xsl:attribute>
<xsl:text>output</xsl:text>
</xsl:element><xsl:text>, </xsl:text>
<xsl:element name="a">
<xsl:attribute name="href"><xsl:value-of select="@goldName"/></xsl:attribute>
<xsl:text>gold</xsl:text>
</xsl:element>
</TD>
</TR>
</xsl:template>
<!-- Output simplistic performance data if asked -->
<xsl:template match="checkresult[@result=$PASS]">
<xsl:if test="$failsonly='false'">
<TR><TD><xsl:value-of select="@result"/></TD><TD><xsl:value-of select="@desc"/></TD></TR>
</xsl:if>
</xsl:template>
<!-- Differentiate results that are not within a testcase!
These get their own table element so they stand out. Also,
use trickery: the more specific template should be called for
Errr or Fail results below. -->
<xsl:template match="checkresult[parent::resultsfile or parent::testfile]">
<TABLE frame="box" border="1" width="80%" cellspacing="1"><TR><TD><B><xsl:value-of select="@result"/></B></TD><TD><xsl:value-of select="@desc"/></TD></TR></TABLE>
</xsl:template>
<xsl:template match="checkresult[@result=$FAIL or @result=$ERRR][parent::resultsfile or parent::testfile]">
<TABLE frame="box" border="1" width="80%" cellspacing="1"><TR><TD bgcolor="red"><B><xsl:value-of select="@result"/></B></TD><TD><xsl:value-of select="@desc"/></TD></TR></TABLE>
</xsl:template>
<!-- Only print out messages that are below or equal to our logging level -->
<!-- Note we should 'prettify' these when they're not within a testcase -->
<xsl:template match="message[@level<=$loggingLevel]">
<xsl:choose>
<!-- Special processing when it's outside of a testcase! -->
<xsl:when test="parent::resultsfile or parent::testfile">
<TABLE frame="box" border="1" width="80%" cellspacing="1">
<xsl:call-template name="othermessage"/>
</TABLE>
</xsl:when>
<!-- Otherwise, different processing when it's related to a fail or error -->
<xsl:when test="following-sibling::checkresult[position()=1]/@result=$ERRR">
<xsl:call-template name="errfailmessage"/>
</xsl:when>
<xsl:when test="following-sibling::checkresult[position()=1]/@result=$FAIL">
<xsl:call-template name="errfailmessage"/>
</xsl:when>
<xsl:otherwise>
<xsl:call-template name="othermessage"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
<!-- For messages, change the font size based on the level (which equates to importance) -->
<xsl:template name="othermessage">
<TR>
<xsl:choose>
<xsl:when test="@level<=$FAILSONLY">
<TD><FONT size="+1"><xsl:value-of select="@level"/></FONT></TD><TD><FONT size="+1"><xsl:value-of select="."/></FONT></TD>
</xsl:when>
<xsl:when test="@level>=$INFOMSG">
<TD><FONT size="-1"><xsl:value-of select="@level"/></FONT></TD><TD><FONT size="-1"><xsl:value-of select="."/></FONT></TD>
</xsl:when>
<xsl:otherwise>
<TD><xsl:value-of select="@level"/></TD><TD><xsl:value-of select="."/></TD>
</xsl:otherwise>
</xsl:choose>
</TR>
</xsl:template>
<!-- Messages related to errors or fails get a special background -->
<xsl:template name="errfailmessage">
<TR>
<xsl:choose>
<xsl:when test="@level<=$FAILSONLY">
<TD bgcolor="{$errfailcolor}"><FONT size="+1"><xsl:value-of select="@level"/></FONT></TD><TD><FONT size="+1"><xsl:value-of select="."/></FONT></TD>
</xsl:when>
<xsl:when test="@level>=$INFOMSG">
<TD bgcolor="{$errfailcolor}"><FONT size="-1"><xsl:value-of select="@level"/></FONT></TD><TD><FONT size="-1"><xsl:value-of select="."/></FONT></TD>
</xsl:when>
<xsl:otherwise>
<TD bgcolor="{$errfailcolor}"><xsl:value-of select="@level"/></TD><TD><xsl:value-of select="."/></TD>
</xsl:otherwise>
</xsl:choose>
</TR>
</xsl:template>
<!-- Likewise print out any arbitrary messages that are below or equal to our logging level -->
<!-- TODO: handle case where arbitrary is not a child of a testcase (which has a TABLE element already) -->
<xsl:template match="arbitrary[@level<=$loggingLevel]">
<TR><TD><FONT size="-1"><xsl:value-of select="@level"/></FONT></TD><TD><I><xsl:value-of select="."/></I></TD></TR>
</xsl:template>
<xsl:template match="caseresult">
<TR><TD><xsl:text>----></xsl:text></TD><TD><xsl:text>Testcase result: </xsl:text><FONT size="+1"><xsl:value-of select="@result"/></FONT></TD></TR>
</xsl:template>
<!-- Dump hashtables and etc. FIXME: make settable so these can go at the end of a report -->
<!-- FIXME: have it simply call a hashitem template directly, since we know there
shouldn't be anything else in a hashtable besides hashitems... -->
<xsl:template match="hashtable">
<BR/><FONT size="-1"><xsl:text>Hashtable logged: </xsl:text><xsl:value-of select="@desc"/></FONT>
<TABLE border="1" width="80%" cellspacing="1" cellpadding="2">
<xsl:apply-templates select="hashitem"/>
</TABLE>
</xsl:template>
<xsl:template match="hashtable[parent::testcase]">
<TR><TD><xsl:text>---begin---</xsl:text></TD><TD><xsl:text>[Hashtable logged] </xsl:text><xsl:value-of select="@desc"/></TD></TR>
<xsl:apply-templates select="hashitem"/>
<TR><TD><xsl:text>----end----</xsl:text></TD><TD><xsl:text>[Hashtable logged] </xsl:text><xsl:value-of select="@desc"/></TD></TR>
</xsl:template>
<xsl:template match="hashitem">
<TR><TD><xsl:value-of select="@key"/></TD><TD><xsl:value-of select="."/></TD></TR>
</xsl:template>
<!-- Special processing for java.class.path! This, more specific template must be after the generic one -->
<xsl:template match="hashitem[@key='java.class.path']">
<TR><TD bgcolor="yellow"><xsl:value-of select="@key"/></TD><TD><xsl:value-of select="."/></TD></TR>
<TR><TD bgcolor="yellow"></TD><TD><xsl:call-template name="ClasspathItems"/></TD></TR>
</xsl:template>
<!-- Output the special messages that the Harness outputs showing which exact
JARS it found on the actual classpath at runtime. Note this is not terribly
efficient, and it may not be applicable to single test output. -->
<xsl:template name="ClasspathItems">
<P><xsl:text>ClasspathItems found (when applicable): </xsl:text><BR/>
<xsl:for-each select="//testfile/message[starts-with(.,'ClasspathItem')]">
<xsl:value-of select="."/><BR/>
</xsl:for-each></P>
</xsl:template>
<!-- Print an overall summary of pass/fail numbers. Note that these are
grabbed from the testfile's statistics, and not actually counted as we parse.
This template is presumably called from the testfile level. -->
<xsl:template name="restable">
<xsl:param name="linkname" select="none"/>
<!-- Note this is horribly inefficent, but it gets the job done.
I'd welcome any optimizations for this stylesheet!
-->
<xsl:variable name="passcount" select="count(//checkresult[@result=$PASS])"/>
<xsl:variable name="failcount" select="count(//checkresult[@result=$FAIL])"/>
<xsl:variable name="errrcount" select="count(//checkresult[@result=$ERRR])"/>
<xsl:variable name="ambgcount" select="count(//checkresult[@result=$AMBG])"/>
<xsl:variable name="incpcount" select="count(//checkresult[@result=$INCP])"/>
<TABLE FRAME="box" BORDER="1" CELLPADDING="2" WIDTH="80%">
<TR>
<TD>
<xsl:element name="a">
<xsl:attribute name="name"><xsl:value-of select="$file-results-marker"/><xsl:value-of select="$linkname"/></xsl:attribute>
<B><xsl:text>Overall Result: </xsl:text></B>
</xsl:element>
<xsl:value-of select="fileresult/@result"/>
</TD>
<TD>
<B><xsl:text>Test Cases</xsl:text></B>
</TD>
<TD>
<B><xsl:text>Test Points</xsl:text></B><xsl:text> (from script)</xsl:text>
</TD>
<TD>
<B><xsl:text>Test Points</xsl:text></B><xsl:text> (from count)</xsl:text>
</TD>
</TR>
<TR>
<TD><xsl:text>Pass</xsl:text></TD>
<TD><xsl:value-of select="./statistic[@desc='passCount[CASES]']/longval"/></TD>
<TD><xsl:value-of select="statistic[@desc='passCount[CHECKS]']/longval"/></TD>
<TD><xsl:value-of select="$passcount"/></TD>
</TR>
<TR>
<TD><B><xsl:text>Fail</xsl:text></B></TD>
<TD><xsl:value-of select="./statistic[@desc='failCount[CASES]']/longval"/></TD>
<TD><xsl:value-of select="statistic[@desc='failCount[CHECKS]']/longval"/></TD>
<TD><xsl:value-of select="$failcount"/></TD>
</TR>
<TR>
<TD><I><xsl:text>Error</xsl:text></I></TD>
<TD><xsl:value-of select="./statistic[@desc='errrCount[CASES]']/longval"/></TD>
<TD><xsl:value-of select="statistic[@desc='errrCount[CHECKS]']/longval"/></TD>
<TD><xsl:value-of select="$errrcount"/></TD>
</TR>
<TR>
<TD><I><xsl:text>Ambiguous</xsl:text></I></TD>
<TD><xsl:value-of select="./statistic[@desc='ambgCount[CASES]']/longval"/></TD>
<TD><xsl:value-of select="statistic[@desc='ambgCount[CHECKS]']/longval"/></TD>
<TD><xsl:value-of select="$ambgcount"/></TD>
</TR>
<TR>
<TD><I><xsl:text>Incomplete</xsl:text></I></TD>
<TD><xsl:value-of select="./statistic[@desc='incpCount[CASES]']/longval"/></TD>
<TD><xsl:value-of select="statistic[@desc='incpCount[CHECKS]']/longval"/></TD>
<TD><xsl:value-of select="$incpcount"/></TD>
</TR>
</TABLE><BR/>
<redirect:write select="$summaryfile" file="viewResults-redirected-output.xml">
<xsl:element name="summary">
<xsl:attribute name="filename"><xsl:value-of select="$linkname"/></xsl:attribute>
<xsl:if test="$passcount">
<xsl:text>P:</xsl:text><xsl:value-of select="$passcount"/>
</xsl:if>
<xsl:if test="$failcount">
<xsl:text>, F:</xsl:text><xsl:value-of select="$failcount"/>
</xsl:if>
<xsl:if test="$errrcount">
<xsl:text>, E:</xsl:text><xsl:value-of select="$errrcount"/>
</xsl:if>
<xsl:if test="$ambgcount">
<xsl:text>, A:</xsl:text><xsl:value-of select="$ambgcount"/>
</xsl:if>
<xsl:if test="$incpcount">
<xsl:text>, I:</xsl:text><xsl:value-of select="$incpcount"/>
</xsl:if>
</xsl:element>
</redirect:write>
</xsl:template>
<!-- Override default text node processing, so statistics, arbitrary messages, and other stuff is skipped -->
<xsl:template match="text()"/>
</xsl:stylesheet>