|
|
%!s(int64=9) %!d(string=hai) anos | |
|---|---|---|
| .. | ||
| README.md | %!s(int64=9) %!d(string=hai) anos | |
| analyze.php | %!s(int64=9) %!d(string=hai) anos | |
| parser.template | %!s(int64=9) %!d(string=hai) anos | |
| php5.y | %!s(int64=9) %!d(string=hai) anos | |
| php7.y | %!s(int64=9) %!d(string=hai) anos | |
| rebuildParsers.php | %!s(int64=9) %!d(string=hai) anos | |
| tokens.template | %!s(int64=9) %!d(string=hai) anos | |
| tokens.y | %!s(int64=9) %!d(string=hai) anos | |
php5.y: PHP 5 grammar written in a pseudo languagephp7.y: PHP 7 grammar written in a pseudo languagetokens.y: Tokens definition shared between PHP 5 and PHP 7 grammarsparser.template: A kmyacc parser prototype file for PHPtokens.template: A kmyacc prototype file for the Tokens classanalyze.php: Analyzes the grammer and outputs some info about itrebuildParser.php: Preprocesses the grammar and builds the parser using kmyaccThe .y file is a normal grammer in kmyacc (yacc) style, with some transformations
applied to it:
Name[..., ...]. This is transformed into
new Name(..., ..., attributes())rebuildParser.php for a list)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 emit debug symbols and create y.output, run the
script with --debug. If you want to retain the preprocessed grammar pass --keep-tmp-grammar.