ID: 14687 User updated by: [EMAIL PROTECTED] Reported By: [EMAIL PROTECTED] Status: Closed Bug Type: Scripting Engine problem Operating System: Redhat 7.0, Solaris 7 PHP Version: 4.0.6 New Comment:
Ah, ok, thanks. - I understand now. It was only the meaning of the @ operator I didn't follow. I'd misinterpreted the docs. I thought that prepending an @ set the errorNum to 0 ( either that or it suppressed the call to the error handler), when in fact it sets the global error level to 0 for the @-ed expression. I thought the @ was: 'Supress errors' Actually it's: 'Trigger an error as normal, but with the error level temporarily set to 0' Thanks, Matt Previous Comments: ------------------------------------------------------------------------ [2001-12-28 09:09:27] [EMAIL PROTECTED] It's the programmer's responsibility to honor error_reporting in the error handler. The error handler will be called even if the error that occured is not inside the error_reporting mask - to allow you to conduct logging, recovery, etc. You can easily honor it by using the return value of error_reporting(), and compare it (using &) with the error level that you got. ------------------------------------------------------------------------ [2001-12-24 10:16:05] [EMAIL PROTECTED] <?php function myErrorHandler($errorNum) { echo "$errorNum\n"; } set_error_handler("myErrorHandler"); #error_reporting (E_ALL);#doesn't change the bug behaviour @$j=$i; ?> This echos: 8 Yet according to: http://www.php.net/manual/en/function.set-error-handler.php "Of particular note is that this value will be 0 if the statement that caused the error was prepended by the @ error-control operator. " I've tried this on 4.0.4pl1 and 4.0.6 The changelog for 4.1.0 doesn't mention a fix. The @ works fine for lines executed before set_error_handler(). Here's one of the configure lines, though (to me) it doesn't seem likely to be a compiley issue... './configure' '--with-db' '--enable-dba' '--with-gdbm' '--with-xml' '--with-oci8=/usr/local/oracle/' '--with-apxs=/usr/local/apache-1.3.14/bin/apxs' '--with-mysql=/usr/local/mysql' '--with-gd' '--with-sablot' Thanks! ------------------------------------------------------------------------ Edit this bug report at http://bugs.php.net/?id=14687&edit=1 -- PHP Development Mailing List <http://www.php.net/> To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED] To contact the list administrators, e-mail: [EMAIL PROTECTED]