jcnventura / pharborist
Pharborist builds a syntax tree for PHP that can be traversed and manipulated.
dev-master
2023-05-04 07:21 UTC
Requires
- php: >=5.4
- phpdocumentor/reflection-docblock: ^2.0|^3.0.2|^4.0|^5.0
Requires (Dev)
- apigen/apigen: 2.8.*
- phpunit/phpunit: 4.2.*
This package is not auto-updated.
Last update: 2025-01-23 15:05:57 UTC
README
A PHP library to query and transform PHP source code via tree operations.
Roadmap
- Tests with 100% code coverage
- Integration with a third party library for PHPDoc comments
- API to ease querying and transforming of the syntax tree
- Build a PHP source code formatter using the library (Partially completed).
- Build a PHP code check using the library
Below is an example of how the API might look once its more developed:
// Add use declaration if it does not already exist. Use UtilityString alias if conflict $alias = $tree->ensureUseDeclaration('Drupal\Component\Utility\String', 'UtilityString'); // Find all calls to check_plain and rename them to use String::checkPlain $function_calls = $tree->find(Filter::functionCall('check_plain')); foreach ($function_calls as $call) { $class_method_call = ClassMethodCallNode::create($alias, 'check_plain', $call->getArgumentList()); $call->replaceWith($class_method_call); }
Usage
require_once 'vendor/autoload.php'; use Pharborist\Parser; use Pharborist\Namespaces\NamespaceNode; use Pharborist\Filter; $filename = $argv[1]; $tree = Parser::parseFile($filename); // check there only one namespace declaration $namespaces = $tree->children(Filter::isInstanceOf('\Pharborist\Namespaces\NamespaceNode')); if ($namespaces->count() > 1) { die('More then one namespace at line ' . $namespaces[1]->getLineNumber() . PHP_EOL); }