tysonandre / php-parser-to-php-ast
A pure PHP substitute for nikic/php-ast, using nikic/php-parser. Can also be used to generate php-ast trees, even for files with some types of syntax errors.
Requires
- php: >=7.1
- nikic/php-parser: ~3.1.1
Requires (Dev)
- phan/phan: ^2.6.0
- phpunit/phpunit: ^5.7
Suggests
- ext-ast: ~0.1.5
This package is auto-updated.
Last update: 2025-01-12 11:21:19 UTC
README
This converts ASTs(Abstract Syntax Trees) from PHP-Parser to php-ast. It can be used as a PHP-only implementation of php-ast. It can alternatively be used as a best-effort parser for syntactically valid PHP code.
Also see https://github.com/TysonAndre/tolerant-php-parser-to-php-ast (in progress, may have better results)
Supported php-ast AST versions: 40, 45, 50
Current Status
No tests are failing
- Need to normalize namespaces (Mostly done)
- The test suite this is based off of covers common cases for Phan, but edge cases still remain. See #4
- See nikic/php-ast#78
Remaining work:
- Translate PhpParser exception to a
\ParseError
instance
Usage
Using it as a slow substitute for php-ast
Using it as an error-tolerant substitute for php-ast: (e.g. for use in IDEs)
- There are currently two modes: omitting errors and adding placeholders (e.g.
__INCOMPLETE_VARIABLE__
). - Omitting errors only handles some common cases that come up while editing a file.
- Placeholders may change in the future.
- tests/ASTConverter/ErrorTolerantConversionTest.php
- If performance is an issue, cache previous results for a file's contents (in combination with the version used to generate the file
ASTConversion::ASTCONVERTER_VERSION
)
Running unit tests
To run unit tests, you must install nikic/php-ast. A version supporting AST versions 40 and/or 50 should be installed (~0.1.5
is preferred)
- Then run
vendor/bin/phpunit
Possible Future Enhancements
- microsoft/tolerant-php-parser#113 See https://github.com/tysonandre/tolerant-php-parser-to-php-ast (The library to convert between AST formats is broken(not finished implementing) and inefficient, waiting for stable API for tolerant-php-parser)