ID: 30541
Updated by: [EMAIL PROTECTED]
Reported By: php at dush dot student dot utwente dot nl
-Status: Open
+Status: Bogus
Bug Type: Unknown/Other Function
Operating System: linux 2.6
PHP Version: 5.0.2
New Comment:
Can't find any errors here:
<?
eval('echo $blah;');
var_dump($php_errormsg);
echo $bla;
var_dump($php_errormsg);
?>
outputs:
---
Notice: Undefined variable: blah in /www/index.php(3) : eval()'d code
on line 1
string(24) "Undefined variable: blah"
Notice: Undefined variable: bla in /www/index.php on line 7
string(23) "Undefined variable: bla"
---
Check your code.
Previous Comments:
------------------------------------------------------------------------
[2004-10-23 16:49:20] php at dush dot student dot utwente dot nl
Description:
------------
in debug mode, my script stores every error that occured in the script.
when an error occurs in eval(), the error is stored correctly in
$php_errormsg. however when the error occured in a function called by
eval() the error isn't stored anymore.
Reproduce code:
---------------
register_tick_function("store_errors", true);
function &store_errors($do_tick = true) {
GLOBAL $php_errormsg;
static $errors = array();
if ($do_tick) {
if (isset($php_errormsg) && $php_errormsg != "") {
if ($trace = debug_backtrace()) {
$func = $trace[1]['function'];
if (isset($trace[1]['class']))
$func =
$trace[1]['class'].$trace[1]['type'].$func;
}else {
$func = 'unknown';
}
$errors[] = array(
0 => $php_errormsg,
1 => $func
);
$php_errormsg = "";
}
}else {
return $errors;
}
}
/* stupid test function */
function blah() { echo $blah2; echo "error is set here:
$php_errormsg<br>"; }
eval ('echo $blah1; blah();');
$ar = store_errors(false);
while(list($key,$val) = each($ar)) {
echo "{$key} => {$val[0]} in {$val[1]}<br>\n";
}
Expected result:
----------------
Notice: Undefined variable: blah1 in
/home/dush/public_html/core/loader.inc.php(28) : eval()'d code on line
1
Notice: Undefined variable: blah2 in
/home/dush/public_html/core/loader.inc.php on line 27
error is set here: Undefined variable: blah2
0 => Undefined variable: blah1 in unknown
1 => Undefined variable: blah2 in blah
Actual result:
--------------
Notice: Undefined variable: blah1 in
/home/dush/public_html/core/loader.inc.php(28) : eval()'d code on line
1
Notice: Undefined variable: blah2 in
/home/dush/public_html/core/loader.inc.php on line 27
error is set here: Undefined variable: blah2
0 => Undefined variable: blah1 in unknown
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=30541&edit=1