|  | 4 年之前 | |
|---|---|---|
| .. | ||
| tests | 4 年之前 | |
| README.md | 4 年之前 | |
| config.m4 | 4 年之前 | |
| config.w32 | 4 年之前 | |
| php_symfony_debug.h | 4 年之前 | |
| symfony_debug.c | 4 年之前 | |
This extension publishes several functions to help building powerful debugging tools. It is compatible with PHP 5.3, 5.4, 5.5 and 5.6; with ZTS and non-ZTS modes. It is not required thus not provided for PHP 7.
Its behavior is about the same as:
<?php
function symfony_zval_info($key, $array, $options = 0)
{
    // $options is currently not used, but could be in future version.
    if (!array_key_exists($key, $array)) {
        return null;
    }
    $info = array(
        'type' => gettype($array[$key]),
        'zval_hash' => /* hashed memory address of $array[$key] */,
        'zval_refcount' => /* internal zval refcount of $array[$key] */,
        'zval_isref' => /* is_ref status of $array[$key] */,
    );
    switch ($info['type']) {
        case 'object':
            $info += array(
                'object_class' => get_class($array[$key]),
                'object_refcount' => /* internal object refcount of $array[$key] */,
                'object_hash' => spl_object_hash($array[$key]),
                'object_handle' => /* internal object handle $array[$key] */,
            );
            break;
        case 'resource':
            $info += array(
                'resource_handle' => (int) $array[$key],
                'resource_type' => get_resource_type($array[$key]),
                'resource_refcount' => /* internal resource refcount of $array[$key] */,
            );
            break;
        case 'array':
            $info += array(
                'array_count' => count($array[$key]),
            );
            break;
        case 'string':
            $info += array(
                'strlen' => strlen($array[$key]),
            );
            break;
    }
    return $info;
}
This function works like debug_backtrace(), except that it can fetch the full backtrace in case of fatal errors:
function foo() { fatal(); }
function bar() { foo(); }
function sd() { var_dump(symfony_debug_backtrace()); }
register_shutdown_function('sd');
bar();
/* Will output
Fatal error: Call to undefined function fatal() in foo.php on line 42
array(3) {
  [0]=>
  array(2) {
    ["function"]=>
    string(2) "sd"
    ["args"]=>
    array(0) {
    }
  }
  [1]=>
  array(4) {
    ["file"]=>
    string(7) "foo.php"
    ["line"]=>
    int(1)
    ["function"]=>
    string(3) "foo"
    ["args"]=>
    array(0) {
    }
  }
  [2]=>
  array(4) {
    ["file"]=>
    string(102) "foo.php"
    ["line"]=>
    int(2)
    ["function"]=>
    string(3) "bar"
    ["args"]=>
    array(0) {
    }
  }
}
*/
To enable the extension from source, run:
    phpize
    ./configure
    make
    sudo make install