我想在提交到Mercurial或Git代码库之前运行JSLint。
我希望这是一个自动设置的步骤,而不是依赖于开发人员(主要是我)记住事先运行JSLint。我通常在开发时运行JSLint,但是我想在JS文件上指定一个契约,这些JS文件在提交到代码库之前传递给JSLint。
对于Mercurial,this page详细说明了预提交语法,但唯一可用的变量似乎是提交中涉及的parent1和parent2变更集in。我真正想要的是提交所涉及的文件名列表,这样我就可以选择.js文件并对它们运行jslint。
Similar issue for GIT,作为预提交脚本的一部分可用的默认信息似乎有限。
可能的工作是调用hg status/git status作为预提交脚本的一部分,解析输出以找到JS文件,然后以这种方式完成工作。不过,我希望更简单一些,而且我不确定调用状态作为预提交钩子的一部分是否反映了正确的信息。例如,在Git中,如果更改文件尚未添加,但git提交使用了-a,那么这些文件是否会显示在git状态输出的正确部分中,作为提交集的一部分?
更新:我得到了一些工作,它在这里可见:http://github.com/jrburke/dvcs_jslint/
发布于 2009-12-03 18:26:25
对于git,.git/hooks目录中有一些示例。如果只需要JSLint的文件名,可以使用git diff --name-only
,在我的示例中,它将列出与当前HEAD
不同的文件名。
发布于 2011-09-12 17:45:23
以下是@Bitbieger的Git解决方案的一个变体,它可以与Node.js和node-jslint的本地副本一起使用(即,您需要在根存储库目录中使用npm install jslint
)。
此外,脚本:
--indent 4 --white true
jslint选项来确保源代码一致性要使其正常工作,请将以下内容复制到.git/hooks/pre-commit
,并不要忘记使用chmod +x .git/hooks/pre-commit
# Pre-commit hook passing files through jslint
#
# This ensures that all js, html and json files are valid and conform
# to expectations.
ROOT_DIR=$(git rev-parse --show-toplevel)
JSLINT="${ROOT_DIR}/node_modules/.bin/jslint --indent 4 --white true"
for file in $(git diff-index --name-only --diff-filter=ACM --cached HEAD -- | grep -P '\.((js)|(html)|(json))$'); do
if node $JSLINT $file 2>&1 | grep 'No errors found' ; then
echo "jslint passed ${file}"
exit 0
else
node $JSLINT $file
exit 1
fi
done
发布于 2009-12-06 19:15:21
for js in $(git diff-index --name-only --cached HEAD -- | grep '\.js$'); do
if jslint.sh $js 2>&1 | grep 'Lint at line' ; then
echo $js
exit 1
else
echo "js files validated"
exit 0
fi
done
https://stackoverflow.com/questions/1837681
复制相似问题