Skip to content

Instantly share code, notes, and snippets.

@mllavez
Created April 25, 2017 18:29
Show Gist options
  • Save mllavez/60675d202c23cb6f17230ef8a9ed8ff5 to your computer and use it in GitHub Desktop.
Save mllavez/60675d202c23cb6f17230ef8a9ed8ff5 to your computer and use it in GitHub Desktop.
PHP Error Handling - @jurchiks101's generateCallTrace()
<?php
/**
* jurchiks101_at_gmail_dot_com
* Can be found at http://php.net/manual/en/function.debug-backtrace.php#112238
*/
function generateCallTrace()
{
$e = new Exception();
$trace = explode("\n", $e->getTraceAsString());
// reverse array to make steps line up chronologically
$trace = array_reverse($trace);
array_shift($trace); // remove {main}
array_pop($trace); // remove call to this method
$length = count($trace);
$result = array();
for ($i = 0; $i < $length; $i++)
{
$result[] = ($i + 1) . ')' . substr($trace[$i], strpos($trace[$i], ' ')); // replace '#someNum' with '$i)', set the right ordering
}
return "\t" . implode("\n\t", $result);
}
?>
Example output:
1) /var/www/test/test.php(15): SomeClass->__construct()
2) /var/www/test/SomeClass.class.php(36): SomeClass->callSomething()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment