Edit report at https://bugs.php.net/bug.php?id=51001&edit=1

 ID:               51001
 Updated by:       php-bugs@lists.php.net
 Reported by:      abdallah at gmx dot com
 Summary:          Always shows stack trace when a Fatal error occurs
-Status:           Feedback
+Status:           No Feedback
 Type:             Feature/Change Request
 Package:          Scripting Engine problem
 Operating System: Windows 7
 PHP Version:      5.3.1

 New Comment:

No feedback was provided. The bug is being suspended because
we assume that you are no longer experiencing the problem.
If this is not the case and you are able to provide the
information that was requested earlier, please do so and
change the status of the bug back to "Open". Thank you.


Previous Comments:
------------------------------------------------------------------------
[2012-12-05 16:19:43] anrdaemon at freemail dot ru

I'm facing a problem in tracking down various issues in a complex project, and 
I would greatly benefit from ability to call Exception::getTraceAsString() 
statically.

So that instead of doing something like

      default:
        if(isset($GLOBALS['toolDebugfilterEnabled']) && 
$GLOBALS['toolDebugfilterEnabled'] === true)
        {
          print('Breakpoint reached in: ');
          $e = new Exception($mode);
          print($e->getTraceAsString());

I could just do a

      default:
        if(isset($GLOBALS['toolDebugfilterEnabled']) && 
$GLOBALS['toolDebugfilterEnabled'] === true)
        {
          print('Breakpoint reached in: ');
          print(Exception::getTraceAsString());

and be done with it.

------------------------------------------------------------------------
[2011-04-12 20:40:30] dharkness at gmail dot com

You actually have to remove the try/catch to reproduce the problem. When you 
catch the exception, no fatal error is raised and you can see the stack trace. 
If 
you don't catch the exception, the PHP engine raises an E_FATAL error which 
cannot be trapped.

We use a shutdown hook and check for fatal errors so we can report the issue, 
but 
at that point there's no stack trace--just the file and line where the error 
occurred. It would be nice to have a similar function to error_get_last() to 
get 
the stack trace, such as backtrace_get_last().

------------------------------------------------------------------------
[2010-11-24 09:44:26] j...@php.net

I do get a trace here using your reproduce script with PHP 5.3.4RC1. So what is 
the problem?

------------------------------------------------------------------------
[2010-04-10 01:51:31] a at b dot c dot de

An observation from me:

A stack trace is dumped in the event of a fatal error (depending on the error 
reporting level); but it's only when an uncaught exception reaches the top of 
the call stack without being handled that such an error occurs. If it is 
caught, then it's not an uncaught exception and therefore not a Fatal error.

------------------------------------------------------------------------
[2010-02-10 20:05:24] abdallah at gmx dot com

Description:
------------
Always shows stack trace when a Fatal error occurs without having to do always 
something like this :

<?php
function test() {
    throw new Exception;
}

try {
    test();
} catch(Exception $e) {
    echo $e->getTraceAsString();
}
?>


Reproduce code:
---------------
<?php
function test() {
    throw new Exception;
}

try {
    test();
} catch(Exception $e) {
    echo $e->getTraceAsString();
}
?>

Expected result:
----------------
#0 /home/bjori/tmp/ex.php(7): test()
#1 {main}

Actual result:
--------------
nothin'


------------------------------------------------------------------------



-- 
Edit this bug report at https://bugs.php.net/bug.php?id=51001&edit=1

Reply via email to