Various fixes to pre-commit hook

Fix incorrect test in sh. Bash implements the new test with [[ that
accepts the double equal, however, this is not a bash script. On Debian
and derivates, this will be run by dash.

Make the script portable by not using GNU extensions of xargs.

Call `validate-all-*.sh` scripts whenever possible.

Have bashate look for /usr/bin/env style shebang as well.

Remove useless validate-json.sh file.

Change-Id: Id2d697f2e9ddaa66e25f71f410200528c1e0cf6b
This commit is contained in:
Martin André 2015-01-15 11:58:42 +09:00
parent 13799455c2
commit dc3687b18b
2 changed files with 6 additions and 16 deletions

View File

@ -5,7 +5,7 @@ RES=0
cd $TOPLEVEL cd $TOPLEVEL
if [ "$1" == "--install" ]; then if [ "$1" = "--install" ]; then
ln -sf ../../tools/pre-commit-hook .git/hooks/pre-commit ln -sf ../../tools/pre-commit-hook .git/hooks/pre-commit
exit exit
fi fi
@ -26,26 +26,19 @@ find . -type f
echo "=== bashate checks ===" echo "=== bashate checks ==="
find . -type f -print0 | files=$(egrep -rlI '^#!/(bin/|usr/bin/env )(ba)?sh' .)
xargs -0 --no-run-if-empty egrep -lZ '^#!/bin/(ba)?sh' | [ "$files" ] && (bashate $files || RES=1)
xargs -0 bashate || RES=1
echo "=== yaml checks ===" echo "=== yaml checks ==="
find . -name '*.yaml' -print0 | ${TOPLEVEL}/tools/validate-all-yaml.sh || RES=1
xargs -0 --no-run-if-empty ${TOPLEVEL}/tools/validate-yaml.py \
|| RES = 1
echo "=== json checks ===" echo "=== json checks ==="
find . -name '*.json' -print0 | ${TOPLEVEL}/tools/validate-all-json.sh || RES=1
xargs -0 --no-run-if-empty ${TOPLEVEL}/tools/validate-json.py \
|| RES=1
echo "=== maintainer checks ===" echo "=== maintainer checks ==="
find . -name Dockerfile -print0 | ${TOPLEVEL}/tools/validate-all-maintainer.sh || RES=1
xargs -0 --no-run-if-empty ${TOPLEVEL}/tools/validate-maintainer \
|| RES=1
exit $RES exit $RES

View File

@ -1,3 +0,0 @@
#!/bin/sh
true