The PHP AST Check Diff Tool is a powerful tool tailored for enhancing and refactoring PHP applications. This tool differentiates itself by analyzing PHP code through its Abstract Syntax Tree (AST), enabling more in-depth and meaningful code comparisons.
- AST-based Diff: Interprets PHP code as an Abstract Syntax Tree (AST) to detect nuanced differences beyond standard code-level diffs.
- Git Integration: Seamlessly works with Git to detect changes in PHP files, focusing on AST differences for a more comprehensive analysis.
- Markdown Output: Generates results in GitHub Flavored Markdown, providing clear and readable reports.
- Automated Reviews: By focusing on AST differences, this tool automates the review process, making it less tedious and more efficient.
- Safe Refactoring: Facilitates safe code modifications. The tool ensures that code changes do not alter the intended behavior, thus supporting secure and reliable refactoring.
Inspiration: The development of this tool was inspired by articles from :
To use the PHP AST Check Diff Tool, follow these steps:
- Installation:
- Run
composer require --dev o0h/ast-check-diff
to install the tool.
- Run
- Execution:
- Execute
vendor/bin/ast-check-diff check
to perform a comparison and output a Markdown document to standard output. - The
--head
and--base
options can be passed via CLI to specify the source and destination of the comparison. Branch names, tags, or commit hashes can be used for this purpose.
- Execute
- Integration with GitHub Actions:
- Integrating this tool with GitHub Actions for deep collaboration with pull requests is highly recommended.
- Example code of workflow: GitHub Workflow
- Example of operation: GitHub Pull Request Example
- Integrating this tool with GitHub Actions for deep collaboration with pull requests is highly recommended.
examples:
vendor/bin/ast-check-diff check ast-diff-check
: If the--head
option is omitted,HEAD
is implicitly specified, and if the--base
option is omitted, themain
branch is implicitly specified.vendor/bin/ast-check-diff check ast-diff-check --base HEAD@{3} --head HEAD~
: These comparisons are made by specifying pointers.vendor/bin/ast-check-diff check ast-diff-check --base cd2f816 --head 1a89b0c
: These comparisons are made by specifying specific commits.
- This tool is intended for use with the latest PHP environments(8.3).
- Includes composer.lock: The project includes a composer.lock file.
Due to the above points, it is recommended to use this tool in isolated environments such as containers or on Continuous Integration (CI) platforms, rather than directly requiring it in your project.