From: [EMAIL PROTECTED]
Operating system: Debian GNU/Linux 2.4.19
PHP version: 4.2.3
PHP Bug Type: XSLT related
Bug description: PHP stops executing script when using sax handlers
When using xslt_set_sax_handlers, php stops executing after xslt_process.
Below a script that should reproduce the problem (I tested it on 2 servers
to be sure):
<?php
$resXSL=xslt_create();
xslt_set_sax_handlers($resXSL,array('element'=>array('start_element','end_element')));
$aryArg['xml']=implode("\n",file(dirname(__FILE__).'/test.xml'));
$aryArg['xsl']=implode("\n",file(dirname(__FILE__).'/test.xsl'));
$strHTML = xslt_process($resXSL,'arg:xml','arg:xsl',NULL,$aryArg);
xslt_free($resXSL);
echo $strHTML;
function start_element($resParser,$strName,$aryAttribs) {
echo 'Start of '.$strName;
}
function end_element($resParser,$strName) {
echo 'End of '.$strName;
}
?>
When this is executed there is no output, when I comment the line where I
use xslt_set_sax_handlers, it works fine (the html is shown). When I
enable xslt logging sablotron seems to be in an endless loop:
Sablotron Message on line none, level log: Parsing 'arg:/xsl'...
Sablotron Message on line none, level log: Parse done in 0.002 seconds
Sablotron Message on line none, level log: Parsing 'arg:/xml'...
Sablotron Message on line none, level log: Parse done in 0.000 seconds
Sablotron Message on line none, level log: Executing stylesheet
'arg:/xsl'...
These lines are printed into the logfile about let's say 30 times, the
first time the message
Sablotron Message on line none, level log: Execution done in 0.002
seconds
appears, the other let's say 29 times not.
When I comment the xslt_set_sax_handlers line the logfile only shows the 5
lines mentioned before and also the 'Execution don in .... seconds' line
as you would expect
My guess is that sablotron is stuck in a loop...
PHP is compiled with: --with-dom --with-sablot --with-expat -with-dom-xslt
--with-dom-exslt --enable-xslt' --with-xslt-sablot
If you want to get the xml/xsl files I used, you can get them at
http://bruno.webfx.be/xslt_test/
Thanks in advance,
Bruno
--
Edit bug report at http://bugs.php.net/?id=20939&edit=1
--
Try a CVS snapshot: http://bugs.php.net/fix.php?id=20939&r=trysnapshot
Fixed in CVS: http://bugs.php.net/fix.php?id=20939&r=fixedcvs
Fixed in release: http://bugs.php.net/fix.php?id=20939&r=alreadyfixed
Need backtrace: http://bugs.php.net/fix.php?id=20939&r=needtrace
Try newer version: http://bugs.php.net/fix.php?id=20939&r=oldversion
Not developer issue: http://bugs.php.net/fix.php?id=20939&r=support
Expected behavior: http://bugs.php.net/fix.php?id=20939&r=notwrong
Not enough info: http://bugs.php.net/fix.php?id=20939&r=notenoughinfo
Submitted twice: http://bugs.php.net/fix.php?id=20939&r=submittedtwice
register_globals: http://bugs.php.net/fix.php?id=20939&r=globals
PHP 3 support discontinued: http://bugs.php.net/fix.php?id=20939&r=php3
Daylight Savings: http://bugs.php.net/fix.php?id=20939&r=dst
IIS Stability: http://bugs.php.net/fix.php?id=20939&r=isapi