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