Run Code Sniffer on modified files
If you've got a big project, running
phpcs .
before each commit can be fairly time consuming. Doing a git status and running phpcs on each modified file manually is just as fiddly.
Try this...
#!/bin/bash
files=$(git ls-files -om --exclude-standard)
phpcs $files
Save it as an executable called git-cs in your PATH and typing the following will run phpcs on just the modified files...
git cs
Currently, there's no filtering of file types, but phpcs seems to do a pretty good job of ignoring files it can't sniff.
Written by Steve Halford
Related protips
5 Responses
data:image/s3,"s3://crabby-images/fcb35/fcb35bbbcac338224813e526279f96f12de7ab68" alt=""
Great tip!
I found if no files had changed it would just run phpcs
for the entire project, so use the following:
#!/bin/bash
files=$(git ls-files -om --exclude-standard)
if [ -z "$files" ]; then
echo 'No files to check';
else
phpcs $files
fi
data:image/s3,"s3://crabby-images/bf035/bf0355590584f23c625047701e1888469636a358" alt=""
Thanks @jenkoian !
data:image/s3,"s3://crabby-images/bdcf3/bdcf3e5c68d56512293295bbff720c8c12b197b2" alt=""
Awesome idea! Thanks for sharing :)
data:image/s3,"s3://crabby-images/bdcf3/bdcf3e5c68d56512293295bbff720c8c12b197b2" alt=""
One more improvement. If I want to have pre-commit hook, I need to include files in the commit. git ls-files -om --exclude-standard
exclude those files.
This is the solution (so far):
#!/bin/bash
files=$(git diff --name-only HEAD master);
if [ -z $files ]; then
phpcs $files
fi
data:image/s3,"s3://crabby-images/bdcf3/bdcf3e5c68d56512293295bbff720c8c12b197b2" alt=""
Negation was missing:
#!/bin/bash
FILES=$(git diff --name-only HEAD master);
if [ ! -z "$FILES" ]; then
phpcs $FILES
fi