Edit report at https://bugs.php.net/bug.php?id=63729&edit=1
ID: 63729 Updated by: ahar...@php.net Reported by: dinoel at gmail dot com Summary: E_DEPRECATED errors is not handled properly -Status: Open +Status: Not a bug Type: Bug Package: Scripting Engine problem Operating System: windows PHP Version: 5.4.9 Block user comment: N Private report: N New Comment: Ah, I see. I didn't get that from your original post, sorry. You are correct that certain E_DEPRECATED errors, such as assigning the return value of new by reference, occur at compile time, and hence before an error_reporting() call can take effect. This is expected behaviour â to control which compile errors are shown, you need to edit php.ini. Not a bug â closing. Previous Comments: ------------------------------------------------------------------------ [2012-12-10 10:19:18] dinoel at gmail dot com Hi, Yes, if you run testfile.php then error error reporting setting takes effect, but if you run testfile1.php then it does not. Please run testfile1.php (as explained in description) and you will see what i mean. This is clean install and no opcode caches/debug extensions been loaded. ------------------------------------------------------------------------ [2012-12-10 02:22:27] ahar...@php.net I can't reproduce this on 5.3 or 5.4: as expected, if I run testfile.php, the error reporting setting takes effect and hides the deprecation warning in the included file. What extensions do you have loaded? In particular, opcode caches and debugging extensions like xdebug and scream would be interesting, but a full list would be good. ------------------------------------------------------------------------ [2012-12-08 20:34:38] dinoel at gmail dot com Happens on 5.3.19 also. ------------------------------------------------------------------------ [2012-12-08 20:32:22] dinoel at gmail dot com Description: ------------ Hi, E_DEPRECATED is not handled properly if error handler / error reporting is set in same file. pre-requirements : error_reporting set to E_ALL in php.ini file I assume this is because E_DEPRECATED error is fired on "compile" time, not execution time.. Please notice that this problem happens only with " =& new ..." constructions (and probably some others) , other kind of E_DEPRECATED errors (like one which fired when i'm using deprecated functions, like ereg) are handled as expected. This bug is probably related : https://bugs.php.net/bug.php?id=61031 Test script: --------------- testfile.php <?php error_reporting(0); include('testfile1.php'); ?> testfile1.php <?php error_reporting(0); class foo { } $a =& new foo(); echo "success"; ?> Expected result: ---------------- php -f testfile.php success php -f testfile1.php success Actual result: -------------- php -f testfile.php "success" php -f testfile1.php PHP Deprecated: Assigning the return value of new by reference is deprecated in testfile1.php on line 6 Deprecated: Assigning the return value of new by reference is deprecated in testfile1.php on line 6 success ------------------------------------------------------------------------ -- Edit this bug report at https://bugs.php.net/bug.php?id=63729&edit=1