cdwv / php-static-analysis-hook
A script that enables
Installs: 536
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 4
Forks: 0
Open Issues: 2
Language:Shell
Requires
- php: >=5.3.0
- phpmd/phpmd: *
- squizlabs/php_codesniffer: 2.0.*@dev
This package is not auto-updated.
Last update: 2025-01-08 08:56:07 UTC
README
PHP Static Analysis Hook configures a GIT pre-commit hook to run a few static analysis tools and block the commit if any of the tools detects code issues. Static analysis tools included in the current version of the hook:
- internal PHP linter (
php -l
) - PHP_CodeSniffer
- PHP Mess Detector
Additionally, the tool symlinks hook to Composer's bin-dir
, so that it's code can be versioned in the repository.
Credits
The tool is an extended version of this gist by cjsaylor. Git hook versioning is inspired by this StackOverflow answer: http://stackoverflow.com/a/3464399
Requirements
- an initialized git repository in the project's directory
- the repository needs to have at least one commit for the script to work correctly. Yes, it is a bug - I didn't have time to cover that yet (but please go ahead and fix it).
Usage
- Add the package to require-dev section of your composer.json file and run
composer update
. Example:
{
"require-dev": {
"cdwv/php-static-analysis-hook": "dev-master"
}
}
- In your CLI, run
bin/symlink-git-hooks-to-hub
command. It will automatically back up your existing git hooks and will redirect all the hooks to a git-hook-hub, which in turn redirects the hooks' calls to the hooks in Composer'sbin-dir
(currently only pre-commit hook is in use).
The script doesn't need any additional action - it runs whenever you run a git commit
command.
Ignore-errors mode
Sometimes it might be useful to commit the code even though it contains some issues. You can do that by setting an environment variable STATIC_ANALYSIS_IGNORE_ERRORS
prior to running git commit
command.
Please note that you should remember to unset the variable after the commit. Otherwise, all your future commits will not be blocked in case there are errors in your code. The following command sets the variable before the commit and unsets it afterwards, feel free to use it or adjust it to your own needs:
export STATIC_ANALYSIS_IGNORE_ERRORS="t" && git commit -a; unset STATIC_ANALYSIS_IGNORE_ERRORS
Disclaimer
The script in it's current version is only a proof of concept and should be used with extreme care. Use it at your own risk.