-
-
Save wesbos/8aec9d2ff7f7cf9dd65ca2c20d5dfc23 to your computer and use it in GitHub Desktop.
#!/bin/bash | |
files=$(git diff --cached --name-only | grep '\.jsx\?$') | |
# Prevent ESLint help message if no files matched | |
if [[ $files = "" ]] ; then | |
exit 0 | |
fi | |
failed=0 | |
for file in ${files}; do | |
git show :$file | eslint $file | |
if [[ $? != 0 ]] ; then | |
failed=1 | |
fi | |
done; | |
if [[ $failed != 0 ]] ; then | |
echo "🚫🚫🚫 ESLint failed, git commit denied!" | |
exit $failed | |
fi |
Super nifty! Thanks for this!
Not sure if this is what you meant for it to do, but I changed this line:
git show :$file | eslint $file
to this:
git show :$file | eslint --stdin
so that it actually lints the staged file, rather than the unstaged copy.
EDIT: This is even better; it shows the proper file name when an error is displayed:
git show :$file | eslint --stdin --stdin-filename "$file"
Neat, thanks a lot! Additionally using --diff-filter=M
in the diff command to skip renamed and deleted files and test modified files only.
Not working for me:
.git/hooks/commit-msg: line 11: eslint: command not found
ESLint failed, git commit denied!
@luclucens you need to have eslint installed globally for that to work
@luclucens you can install eslint locally and user ./node_modules/.bin/eslint
instance of eslint
@zerob4wl this does not work for me:
Any workaround as I really do not want to install eslint globally?
#!/bin/bash
files=$(git diff --cached --name-only | grep '\.jsx\?$')
# Prevent ESLint help message if no files matched
if [[ $files = "" ]] ; then
exit 0
fi
failed=0
for file in ${files}; do
git show :$file | ./node_modules/.bin/eslint $file
if [[ $? != 0 ]] ; then
failed=1
fi
done;
if [[ $failed != 0 ]] ; then
echo "ESLint failed, git commit denied!"
exit $failed
fi
EDIT: made it work now. I will not delete this post and instead post the solution if you might have the same problem as me:
You have to make sure that the hook is exeutable like follows:
chmod +x commit-msg
I've added this to my composer.json so when doing 'composer install', everybody in team would get the script:
"scripts": {
"pre-install-cmd": [
"[[ -f .git/hooks/commit-msg ]] || curl https://gist.githubusercontent.com/wesbos/8aec9d2ff7f7cf9dd65ca2c20d5dfc23/raw/f662c8b15515180c8310e2d20d192dd3d92a7d28/commit-msg --output .git/hooks/commit-msg && chmod +x .git/hooks/commit-msg"
]
}
I had to fix permissions to get this to work:
chmod +x .git/hooks/post-commit