ID: 17264
Updated by: [EMAIL PROTECTED]
Reported By: [EMAIL PROTECTED]
-Status: Open
+Status: Bogus
Bug Type: Class/Object related
Operating System: Linux
PHP Version: 4.2.1
New Comment:
You need to escape the '$', e.g.:
$whatever = preg_replace( $pattern,"\$this->whatever('\\1')", $value );
Previous Comments:
------------------------------------------------------------------------
[2002-05-15 22:15:11] [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=17264&edit=1