|
11 | 11 |
|
12 | 12 | namespace Symfony\Component\VarDumper;
|
13 | 13 |
|
| 14 | +use Symfony\Component\HttpFoundation\Request; |
| 15 | +use Symfony\Component\HttpFoundation\RequestStack; |
| 16 | +use Symfony\Component\HttpKernel\Debug\FileLinkFormatter; |
14 | 17 | use Symfony\Component\VarDumper\Caster\ReflectionCaster;
|
15 | 18 | use Symfony\Component\VarDumper\Cloner\VarCloner;
|
16 | 19 | use Symfony\Component\VarDumper\Dumper\CliDumper;
|
| 20 | +use Symfony\Component\VarDumper\Dumper\ContextProvider\CliContextProvider; |
| 21 | +use Symfony\Component\VarDumper\Dumper\ContextProvider\RequestContextProvider; |
17 | 22 | use Symfony\Component\VarDumper\Dumper\ContextProvider\SourceContextProvider;
|
18 | 23 | use Symfony\Component\VarDumper\Dumper\ContextualizedDumper;
|
| 24 | +use Symfony\Component\VarDumper\Dumper\DataDumperInterface; |
19 | 25 | use Symfony\Component\VarDumper\Dumper\HtmlDumper;
|
| 26 | +use Symfony\Component\VarDumper\Dumper\ServerDumper; |
20 | 27 |
|
21 | 28 | // Load the global dump() function
|
22 | 29 | require_once __DIR__.'/Resources/functions/dump.php';
|
|
27 | 34 | class VarDumper
|
28 | 35 | {
|
29 | 36 | private static $handler;
|
| 37 | + private static $locked = false; |
30 | 38 |
|
31 |
| - public static function dump($var) |
| 39 | + /** |
| 40 | + * @final |
| 41 | + * |
| 42 | + * @param bool $lock lock the registered handler so it cannot be replaced |
| 43 | + */ |
| 44 | + public static function register(bool $lock = false): void |
32 | 45 | {
|
33 |
| - if (null === self::$handler) { |
34 |
| - $cloner = new VarCloner(); |
35 |
| - $cloner->addCasters(ReflectionCaster::UNSET_CLOSURE_FILE_INFO); |
| 46 | + self::$locked = $lock; |
| 47 | + $cloner = new VarCloner(); |
| 48 | + $cloner->addCasters(ReflectionCaster::UNSET_CLOSURE_FILE_INFO); |
| 49 | + |
| 50 | + switch ($_SERVER['VAR_DUMPER_FORMAT'] ?? null) { |
| 51 | + case 'html': |
| 52 | + $dumper = new HtmlDumper(); |
| 53 | + break; |
| 54 | + case 'cli': |
| 55 | + $dumper = new CliDumper(); |
| 56 | + break; |
| 57 | + case 'server': |
| 58 | + $host = $_SERVER['VAR_DUMPER_SERVER'] ?? '127.0.0.1:9912'; |
| 59 | + $dumper = new ServerDumper($host, self::getDefaultDumper(), self::getDefaultContextProviders()); |
| 60 | + break; |
| 61 | + default: |
| 62 | + $dumper = self::getDefaultDumper(); |
| 63 | + } |
36 | 64 |
|
37 |
| - if (isset($_SERVER['VAR_DUMPER_FORMAT'])) { |
38 |
| - $dumper = 'html' === $_SERVER['VAR_DUMPER_FORMAT'] ? new HtmlDumper() : new CliDumper(); |
39 |
| - } else { |
40 |
| - $dumper = \in_array(\PHP_SAPI, ['cli', 'phpdbg']) ? new CliDumper() : new HtmlDumper(); |
41 |
| - } |
| 65 | + $dumper = !$dumper instanceof ServerDumper ? new ContextualizedDumper($dumper, [new SourceContextProvider()]) : $dumper; |
42 | 66 |
|
43 |
| - $dumper = new ContextualizedDumper($dumper, [new SourceContextProvider()]); |
| 67 | + self::$handler = function ($var) use ($cloner, $dumper) { |
| 68 | + $dumper->dump($cloner->cloneVar($var)); |
| 69 | + }; |
| 70 | + } |
44 | 71 |
|
45 |
| - self::$handler = function ($var) use ($cloner, $dumper) { |
46 |
| - $dumper->dump($cloner->cloneVar($var)); |
47 |
| - }; |
| 72 | + public static function dump($var) |
| 73 | + { |
| 74 | + if (null === self::$handler) { |
| 75 | + self::register(); |
48 | 76 | }
|
49 | 77 |
|
50 | 78 | return (self::$handler)($var);
|
51 | 79 | }
|
52 | 80 |
|
53 | 81 | public static function setHandler(callable $callable = null)
|
54 | 82 | {
|
| 83 | + $lock = \func_num_args() > 1 ? func_get_arg(1) : false; |
55 | 84 | $prevHandler = self::$handler;
|
| 85 | + |
| 86 | + if (self::$locked) { |
| 87 | + return $prevHandler; |
| 88 | + } |
| 89 | + if ($lock) { |
| 90 | + self::$locked = true; |
| 91 | + } |
| 92 | + |
56 | 93 | self::$handler = $callable;
|
57 | 94 |
|
58 | 95 | return $prevHandler;
|
59 | 96 | }
|
| 97 | + |
| 98 | + private static function getDefaultDumper(): DataDumperInterface |
| 99 | + { |
| 100 | + return \in_array(\PHP_SAPI, ['cli', 'phpdbg'], true) ? new CliDumper() : new HtmlDumper(); |
| 101 | + } |
| 102 | + |
| 103 | + private static function getDefaultContextProviders(): array |
| 104 | + { |
| 105 | + $contextProviders = []; |
| 106 | + |
| 107 | + if ('cli' !== \PHP_SAPI && (class_exists(Request::class))) { |
| 108 | + $requestStack = new RequestStack(); |
| 109 | + $requestStack->push(Request::createFromGlobals()); |
| 110 | + $contextProviders['request'] = new RequestContextProvider($requestStack); |
| 111 | + } |
| 112 | + |
| 113 | + $fileLinkFormatter = class_exists(FileLinkFormatter::class) ? new FileLinkFormatter(null, $requestStack ?? null) : null; |
| 114 | + |
| 115 | + return $contextProviders + [ |
| 116 | + 'cli' => new CliContextProvider(), |
| 117 | + 'source' => new SourceContextProvider(null, null, $fileLinkFormatter), |
| 118 | + ]; |
| 119 | + } |
60 | 120 | }
|
0 commit comments