123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- <?php
- require __DIR__ . '/../lib/bootstrap.php';
- ini_set('xdebug.max_nesting_level', 2000);
- // Disable XDebug var_dump() output truncation
- ini_set('xdebug.var_display_max_children', -1);
- ini_set('xdebug.var_display_max_data', -1);
- ini_set('xdebug.var_display_max_depth', -1);
- list($operations, $files) = parseArgs($argv);
- /* Dump nodes by default */
- if (empty($operations)) {
- $operations[] = 'dump';
- }
- if (empty($files)) {
- showHelp("Must specify at least one file.");
- }
- $parser = new PhpParser\Parser(new PhpParser\Lexer\Emulative);
- $dumper = new PhpParser\NodeDumper;
- $prettyPrinter = new PhpParser\PrettyPrinter\Standard;
- $serializer = new PhpParser\Serializer\XML;
- $traverser = new PhpParser\NodeTraverser();
- $traverser->addVisitor(new PhpParser\NodeVisitor\NameResolver);
- foreach ($files as $file) {
- if (strpos($file, '<?php') === 0) {
- $code = $file;
- echo "====> Code $code\n";
- } else {
- if (!file_exists($file)) {
- die("File $file does not exist.\n");
- }
- $code = file_get_contents($file);
- echo "====> File $file:\n";
- }
- try {
- $stmts = $parser->parse($code);
- } catch (PhpParser\Error $e) {
- die("==> Parse Error: {$e->getMessage()}\n");
- }
- foreach ($operations as $operation) {
- if ('dump' === $operation) {
- echo "==> Node dump:\n";
- echo $dumper->dump($stmts), "\n";
- } elseif ('pretty-print' === $operation) {
- echo "==> Pretty print:\n";
- echo $prettyPrinter->prettyPrintFile($stmts), "\n";
- } elseif ('serialize-xml' === $operation) {
- echo "==> Serialized XML:\n";
- echo $serializer->serialize($stmts), "\n";
- } elseif ('var-dump' === $operation) {
- echo "==> var_dump():\n";
- var_dump($stmts);
- } elseif ('resolve-names' === $operation) {
- echo "==> Resolved names.\n";
- $stmts = $traverser->traverse($stmts);
- }
- }
- }
- function showHelp($error) {
- die($error . "\n\n" .
- <<<OUTPUT
- Usage:
- php php-parse.php [operations] file1.php [file2.php ...]
- The file arguments can also be replaced with a code string:
- php php-parse.php [operations] "<?php code"
- Operations is a list of the following options (--dump by default):
- --dump -d Dump nodes using NodeDumper
- --pretty-print -p Pretty print file using PrettyPrinter\Standard
- --serialize-xml Serialize nodes using Serializer\XML
- --var-dump var_dump() nodes (for exact structure)
- --resolve-names -N Resolve names using NodeVisitor\NameResolver
- Example:
- php php-parse.php -d -p -N -d file.php
- Dumps nodes, pretty prints them, then resolves names and dumps them again.
- OUTPUT
- );
- }
- function parseArgs($args) {
- $operations = array();
- $files = array();
- array_shift($args);
- $parseOptions = true;
- foreach ($args as $arg) {
- if (!$parseOptions) {
- $files[] = $arg;
- continue;
- }
- switch ($arg) {
- case '--dump':
- case '-d':
- $operations[] = 'dump';
- break;
- case '--pretty-print':
- case '-p':
- $operations[] = 'pretty-print';
- break;
- case '--serialize-xml':
- $operations[] = 'serialize-xml';
- break;
- case '--var-dump':
- $operations[] = 'var-dump';
- break;
- case '--resolve-names':
- case '-N';
- $operations[] = 'resolve-names';
- break;
- case '--':
- $parseOptions = false;
- break;
- default:
- if ($arg[0] === '-') {
- showHelp("Invalid operation $arg.");
- } else {
- $files[] = $arg;
- }
- }
- }
- return array($operations, $files);
- }
|