ID: 17429
Updated by: [EMAIL PROTECTED]
Reported By: [EMAIL PROTECTED]
-Status: Open
+Status: Bogus
Bug Type: PCRE related
Operating System: Linux Redhat 7.3
PHP Version: 4.2.1
New Comment:
You forgot to escape the '$' character:
$whatever=preg_replace( $pattern,"\$this->whatever('\\1')", $value );
Previous Comments:
------------------------------------------------------------------------
[2002-05-25 19:23:18] [EMAIL PROTECTED]
If you use preg_replace with the /e option from within a class you may
want to call a method of the current class to perform the lookup.
Intuativly a user might expect this code to work:
$whatever=preg_replace( $pattern,"$this->whatever('\\1')", $value );
That 2nd parameter is being evaluated outside the current class... In
this context "$this" has no meaning outside the object, So a method
like "$this->whatever{foo)" can never be evaluated directly by this
command.
The function works fine if you use it according to the instructions -
that is you provide it with a globally available function it will work
perfectly.
To check version & config of the my offending server:
http://sharesite.stodge.org/test.php
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=17429&edit=1