php-parser/grammar
Nikita Popov 3b7d8e8b5d Enable basic error recovery
Adding only a single recovery rule for now.

The API is now:
 * throwOnError parser option must be disabled.
 * List of Errors is available through $parser->getErrors(). This
   method is available either way.
 * If no recovery is possible $parser->parse() will return null.
   (Obviously only if throwOnError is disabled).
2015-04-30 17:41:57 +02:00
..
analyze.php Remove node analysis from analyze.php and fix some other things about it 2011-08-14 15:52:57 +02:00
kmyacc.php.parser Build node attributes inside semantic action methods 2015-04-26 11:55:59 +02:00
README.md Port library to use namespaces, with BC for old names 2014-02-06 20:29:35 +01:00
rebuildParser.php Add support for anonymous classes 2015-04-26 23:04:31 +02:00
zend_language_parser.phpy Enable basic error recovery 2015-04-30 17:41:57 +02:00

What do all those files mean?

  • zend_language_parser.phpy: PHP grammer written in a pseudo language
  • analyze.php: Analyzes the .phpy-grammer and outputs some info about it
  • rebuildParser.php: Preprocesses the .phpy-grammar and builds the parser using kmyacc
  • kmyacc.php.parser: A kmyacc parser prototype file for PHP

.phpy pseudo language

The .phpy file is a normal grammer in kmyacc (yacc) style, with some transformations applied to it:

  • Nodes are created using the syntax Name[..., ...]. This is transformed into new Node\Name(..., ..., $attributes)
  • Name::abc is transformed to Node\Name::abc
  • Some function-like constructs are resolved (see rebuildParser.php for a list)
  • Associative arrays are written as [key: value, ...], which is transformed to array('key' => value, ...)

Building the parser

In order to rebuild the parser, you need moriyoshi's fork of kmyacc. After you compiled/installed it, run the rebuildParser.php script.

By default only the Parser.php is built. If you want to additionally build Parser/Debug.php and y.output run the script with --debug. If you want to retain the preprocessed grammar pass --keep-tmp-grammar.