2017-08-25 13:37:13 -07:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
set -e
|
|
|
|
rc=0
|
|
|
|
verbose=0
|
2022-10-11 11:16:00 +02:00
|
|
|
# NOTE: there is a bug in GNU indent command line parse where it says, that
|
|
|
|
# -il6 require numeric parameter. This is because it treat it like "-i"
|
|
|
|
# param. Here we pass -i8 which is default for linux code style and
|
|
|
|
# we use long parameter name for indent label.
|
|
|
|
indent_args='-i8 -linux -l95 -cp1 -lps -ncs --indent-label6'
|
|
|
|
function iver { printf "%03d%03d%03d%03d" $(echo "$@" | sed 's/^.* indent//; y/./ /'); }
|
2017-08-25 13:37:13 -07:00
|
|
|
|
|
|
|
while [ -n "$*" ]; do
|
|
|
|
case "$1" in
|
|
|
|
-v )
|
|
|
|
verbose=1
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
-h )
|
|
|
|
echo check_format.sh [-h -v]
|
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "Checking format of files in the git index at $PWD"
|
|
|
|
if ! git rev-parse --is-inside-work-tree >& /dev/null; then
|
|
|
|
echo "Not in a git repo: Fail"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2022-10-11 11:16:00 +02:00
|
|
|
# On FreeBSD we need to use gindent
|
|
|
|
for indent_tool in indent gindent ''; do
|
|
|
|
if hash $indent_tool && [ $(iver $($indent_tool --version)) -ge $(iver 2.2.12) ]; then
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ -n "$indent_tool" ]; then
|
2017-08-25 13:37:13 -07:00
|
|
|
echo "Checking C files for coding style..."
|
|
|
|
for f in `git ls-files '*.c'`; do
|
2018-10-05 13:17:23 -07:00
|
|
|
[ "$verbose" -gt 0 ] && echo "checking style on $f"
|
2022-10-11 11:16:00 +02:00
|
|
|
if ! $indent_tool $indent_args -st $f | diff -q $f - >& /dev/null; then
|
2017-08-25 13:37:13 -07:00
|
|
|
echo " File found with formatting issues: $f"
|
2022-10-11 11:16:00 +02:00
|
|
|
[ "$verbose" -gt 0 ] 2> /dev/null && $indent_tool $indent_args -st $f | diff -u $f -
|
2017-08-25 13:37:13 -07:00
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
[ "$rc" -gt 0 ] && echo " Run ./tools/iindent on files"
|
|
|
|
else
|
2019-07-03 14:56:32 -07:00
|
|
|
echo "You do not have a recent indent installed so your code style is not being checked!"
|
2017-08-25 13:37:13 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
if hash grep; then
|
|
|
|
echo "Checking for dos and whitespace violations..."
|
2018-10-05 13:17:23 -07:00
|
|
|
for f in $(git ls-files); do
|
|
|
|
[ "$verbose" -gt 0 ] && echo "checking whitespace on $f"
|
2017-08-25 13:37:13 -07:00
|
|
|
if grep -q '[[:space:]]$' $f ; then
|
|
|
|
echo " File found with trailing whitespace: $f"
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
if grep -q $'\r' $f ; then
|
|
|
|
echo " File found with dos formatting: $f"
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
2018-10-05 13:17:23 -07:00
|
|
|
echo "Checking source files for permissions..."
|
|
|
|
while read -r perm _res0 _res1 f; do
|
|
|
|
[ -z "$f" ] && continue
|
|
|
|
[ "$verbose" -gt 0 ] && echo "checking permissions on $f"
|
|
|
|
if [ "$perm" -ne 100644 ]; then
|
|
|
|
echo " File found with permissions issue ($perm): $f"
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
done <<< $(git ls-files -s -- ':(exclude)*.sh' ':(exclude)*iindent')
|
|
|
|
|
|
|
|
echo "Checking script files for permissions..."
|
|
|
|
while read -r perm _res0 _res1 f; do
|
|
|
|
[ -z "$f" ] && continue
|
|
|
|
[ "$verbose" -gt 0 ] && echo "checking permissions on $f"
|
|
|
|
if [ "$perm" -ne 100755 ]; then
|
|
|
|
echo " Script found with permissions issue ($perm): $f"
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
done <<< $(git ls-files -s '*.sh')
|
|
|
|
|
|
|
|
|
2018-06-15 16:45:02 -07:00
|
|
|
echo "Checking for signoff in commit message..."
|
2018-12-20 16:18:19 -07:00
|
|
|
if ! git log -n 1 --format=%B --no-merges | grep -q "^Signed-off-by:" ; then
|
2018-06-15 16:45:02 -07:00
|
|
|
echo " Commit not signed off. Please read src/CONTRIBUTING.md"
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
|
2017-08-25 13:37:13 -07:00
|
|
|
[ "$rc" -gt 0 ] && echo Format Fail || echo Format Pass
|
|
|
|
|
|
|
|
exit $rc
|