#!/usr/bin/env python | |
import os, sys | |
""" | |
Checks your git commit with JSHint. Only checks staged files | |
""" | |
def jshint(): | |
errors = [] | |
# get all staged files | |
f = os.popen('git diff-index --name-only --cached HEAD') | |
for file in f.readlines(): | |
# you may have to change path to jshint! | |
# global options stored in ~/.jshintrc | |
g = os.popen('/usr/local/bin/jshint ' + file) | |
# add all errors from all files together | |
for error in g.readlines(): | |
errors.append(error) | |
# got errors? | |
if errors: | |
for i, error in enumerate(errors): | |
print error, | |
# Abort the commit | |
sys.exit(1) | |
# All good | |
sys.exit(0) | |
if __name__ == '__main__': | |
jshint() |
This comment has been minimized.
This comment has been minimized.
This guy actually made 99% of the codes I'm using: |
This comment has been minimized.
This comment has been minimized.
Hey Matt, is the argument of os.popen() the path to the file staged to commit or the path to jshint? It seems to be like it is for the staged commit js files, but when I try to run it it gives me an error: my/path/myModifiedJS.js: Permission denied I did chmod +x .git/hooks/pre-commit as mentioned in the article above but still gives me this error. Any ideas? |
This comment has been minimized.
This comment has been minimized.
no...afraid not. I only get 1% of that code :) |
This comment has been minimized.
This comment has been minimized.
and this hook works for you? git-rev-parse gives me a syntax error but this passes that specific line: if git rev-parse --verify HEAD >/dev/null 2>&1 but now i get: fatal: --name-only, --name-status, --check and -s are mutually exclusive |
This comment has been minimized.
This comment has been minimized.
(I'm on a Mac and know nothing about PC setup for this—and so far my use has been pretty limited, haven't done very complicated git stuff with it) Yea, it works for me. If its silently failing your path to jshint is maybe off this one uses: but npm installs in /usr/bin/jshint I think. If you do |