Skip to content

donquixote/nicetrace

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

nicetrace

PHP library to generate a human-friendly backtrace array.

Inspired from ddebug_backtrace() in the Devel module for Drupal.

The structure of the nicetrace can be seen in nicetrace.php

Development status

This library is quite fresh, and I am still ironing out API details, that is, names of interfaces, method signatures, etc.
You are welcome to participate.

Features

The main design goal is a backtrace array structure that looks nice in recursive array display tools, such as Krumo, or possibly Ladybug.

  • Indices of trace items enhanced with function / method names.
  • Indices for arguments enhanced with parameter names (based on reflection).
  • Indices of trace items reversed, so that the index reflects the depth in the call tree.
  • Arguments inlined, so the array becomes flatter. E.g.
    $backtrace[5]['args'][0] = .. becomes
    $nicetrace[' 8: foo()']['args[0]: $x'] = ...
  • Filename and line number from trace item one level deeper, instead of the "called from".
  • File paths shortened, if known base paths are specified.
  • File basename and line number combined into one array key. E.g.
    $backtrace[5]['file'] = '/../src/MyNamespace/MyFile.php'; $backtrace[5]['line'] = 97; becomes
    $nicetrace[' 8: foo()']['MyClass.php: 97'] = 'src/MyNamespace/MyClass.php';

Basic usage

use Donquixote\Nicetrace\Util\NicetraceUtil;

$backtrace = debug_backtrace();
$nicetrace = NicetraceUtil::backtraceGetNicetrace($backtrace);

// Choose your favourite recursive function/method for recursive printing.
print_r($nicetrace);

Advanced usage

The library allows to create and compose custom BacktraceToNicetrace handlers.

It is recommended to use the fluent interface provided by the Builder class.

use Donquixote\Nicetrace\BacktraceToNicetrace\BacktraceToNicetraceBuilder;

$backtrace = debug_backtrace();
$backtraceToNicetrace = BacktraceToNicetraceBuilder::start()
  ->withClasslessKey()
  ->create();
$nicetrace = NicetraceUtil::backtraceGetNicetrace($backtrace);

// Choose your favourite recursive function/method for recursive printing.
print_r($nicetrace);

The test case gives some examples.

About

PHP library to generate a human-friendly backtrace array.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages