2015-09-23 08:52:44 -07:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
readonly BASEDIR=$(readlink -f $(dirname $0))/..
|
|
|
|
cd $BASEDIR
|
|
|
|
|
|
|
|
# exit on errors
|
|
|
|
set -e
|
|
|
|
|
2018-10-30 16:58:42 +01:00
|
|
|
if ! hash nproc 2>/dev/null; then
|
|
|
|
|
|
|
|
function nproc() {
|
|
|
|
echo 8
|
|
|
|
}
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
2016-10-18 09:56:25 -07:00
|
|
|
rc=0
|
|
|
|
|
2018-10-01 11:47:23 -07:00
|
|
|
echo -n "Checking file permissions..."
|
|
|
|
|
|
|
|
while read -r perm _res0 _res1 path; do
|
|
|
|
if [ ! -f "$path" ]; then
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
|
|
|
|
fname=$(basename -- "$path")
|
|
|
|
|
|
|
|
case ${fname##*.} in
|
|
|
|
c|h|cpp|cc|cxx|hh|hpp|md|html|js|json|svg|Doxyfile|yml|LICENSE|README|conf|in|Makefile|mk|gitignore|go|txt)
|
|
|
|
# These file types should never be executable
|
|
|
|
if [ "$perm" -eq 100755 ]; then
|
|
|
|
echo "ERROR: $path is marked executable but is a code file."
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
shebang=$(head -n 1 $path | cut -c1-3)
|
|
|
|
|
|
|
|
# git only tracks the execute bit, so will only ever return 755 or 644 as the permission.
|
|
|
|
if [ "$perm" -eq 100755 ]; then
|
|
|
|
# If the file has execute permission, it should start with a shebang.
|
|
|
|
if [ "$shebang" != "#!/" ]; then
|
|
|
|
echo "ERROR: $path is marked executable but does not start with a shebang."
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# If the file doesnot have execute permissions, it should not start with a shebang.
|
|
|
|
if [ "$shebang" = "#!/" ]; then
|
|
|
|
echo "ERROR: $path is not marked executable but starts with a shebang."
|
|
|
|
rc=1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2018-10-08 16:58:32 +08:00
|
|
|
done <<< "$(git grep -I --name-only --untracked -e . | git ls-files -s)"
|
2018-10-01 11:47:23 -07:00
|
|
|
|
|
|
|
if [ $rc -eq 0 ]; then
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
|
2015-09-23 08:52:44 -07:00
|
|
|
if hash astyle; then
|
|
|
|
echo -n "Checking coding style..."
|
2018-07-20 13:11:52 +02:00
|
|
|
if [ "$(astyle -V)" \< "Artistic Style Version 3" ]
|
|
|
|
then
|
2018-12-03 13:51:56 -07:00
|
|
|
echo -n " Your astyle version is too old so skipping coding style checks. Please update astyle to at least 3.0.1 version..."
|
2016-10-18 09:56:25 -07:00
|
|
|
else
|
2018-12-03 13:51:56 -07:00
|
|
|
rm -f astyle.log
|
|
|
|
touch astyle.log
|
|
|
|
# Exclude rte_vhost code imported from DPDK - we want to keep the original code
|
|
|
|
# as-is to enable ongoing work to synch with a generic upstream DPDK vhost library,
|
|
|
|
# rather than making diffs more complicated by a lot of changes to follow SPDK
|
|
|
|
# coding standards.
|
|
|
|
git ls-files '*.[ch]' '*.cpp' '*.cc' '*.cxx' '*.hh' '*.hpp' | \
|
|
|
|
grep -v rte_vhost | grep -v cpp_headers | \
|
|
|
|
xargs -P$(nproc) -n10 astyle --options=.astylerc >> astyle.log
|
|
|
|
if grep -q "^Formatted" astyle.log; then
|
|
|
|
echo " errors detected"
|
|
|
|
git diff
|
|
|
|
sed -i -e 's/ / /g' astyle.log
|
|
|
|
grep --color=auto "^Formatted.*" astyle.log
|
|
|
|
echo "Incorrect code style detected in one or more files."
|
|
|
|
echo "The files have been automatically formatted."
|
|
|
|
echo "Remember to add the files to your commit."
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f astyle.log
|
2015-09-23 08:52:44 -07:00
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "You do not have astyle installed so your code style is not being checked!"
|
|
|
|
fi
|
|
|
|
|
2017-04-24 11:14:41 -07:00
|
|
|
echo -n "Checking comment style..."
|
|
|
|
|
2017-04-25 10:35:22 -07:00
|
|
|
git grep --line-number -e '/[*][^ *-]' -- '*.[ch]' > comment.log || true
|
2017-10-18 10:06:51 -07:00
|
|
|
git grep --line-number -e '[^ ][*]/' -- '*.[ch]' ':!lib/vhost/rte_vhost*/*' >> comment.log || true
|
2017-04-25 10:35:22 -07:00
|
|
|
git grep --line-number -e '^[*]' -- '*.[ch]' >> comment.log || true
|
2018-10-30 09:07:09 +09:00
|
|
|
git grep --line-number -e '\s//' -- '*.[ch]' >> comment.log || true
|
|
|
|
git grep --line-number -e '^//' -- '*.[ch]' >> comment.log || true
|
2017-04-24 11:14:41 -07:00
|
|
|
|
|
|
|
if [ -s comment.log ]; then
|
|
|
|
echo " Incorrect comment formatting detected"
|
|
|
|
cat comment.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f comment.log
|
|
|
|
|
2018-03-02 12:49:36 -07:00
|
|
|
echo -n "Checking for spaces before tabs..."
|
|
|
|
git grep --line-number $' \t' -- > whitespace.log || true
|
|
|
|
if [ -s whitespace.log ]; then
|
|
|
|
echo " Spaces before tabs detected"
|
|
|
|
cat whitespace.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f whitespace.log
|
|
|
|
|
2018-01-29 16:43:37 -07:00
|
|
|
echo -n "Checking trailing whitespace in output strings..."
|
|
|
|
|
|
|
|
git grep --line-number -e ' \\n"' -- '*.[ch]' > whitespace.log || true
|
|
|
|
|
|
|
|
if [ -s whitespace.log ]; then
|
|
|
|
echo " Incorrect trailing whitespace detected"
|
|
|
|
cat whitespace.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f whitespace.log
|
|
|
|
|
2017-12-07 17:18:21 -07:00
|
|
|
echo -n "Checking for use of forbidden library functions..."
|
|
|
|
|
2018-05-08 14:53:32 -07:00
|
|
|
git grep --line-number -w '\(strncpy\|strcpy\|strcat\|sprintf\|vsprintf\)' -- './*.c' ':!lib/vhost/rte_vhost*/**' > badfunc.log || true
|
2017-12-07 17:18:21 -07:00
|
|
|
if [ -s badfunc.log ]; then
|
|
|
|
echo " Forbidden library functions detected"
|
|
|
|
cat badfunc.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f badfunc.log
|
|
|
|
|
2018-07-05 05:52:19 -07:00
|
|
|
echo -n "Checking for use of forbidden CUnit macros..."
|
|
|
|
|
|
|
|
git grep --line-number -w 'CU_ASSERT_FATAL' -- 'test/*' ':!test/spdk_cunit.h' > badcunit.log || true
|
|
|
|
if [ -s badcunit.log ]; then
|
|
|
|
echo " Forbidden CU_ASSERT_FATAL usage detected - use SPDK_CU_ASSERT_FATAL instead"
|
|
|
|
cat badcunit.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f badcunit.log
|
|
|
|
|
2016-10-18 09:56:25 -07:00
|
|
|
echo -n "Checking blank lines at end of file..."
|
|
|
|
|
|
|
|
if ! git grep -I -l -e . -z | \
|
2018-10-30 16:58:42 +01:00
|
|
|
xargs -0 -P$(nproc) -n1 scripts/eofnl > eofnl.log; then
|
2016-10-18 09:56:25 -07:00
|
|
|
echo " Incorrect end-of-file formatting detected"
|
|
|
|
cat eofnl.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f eofnl.log
|
|
|
|
|
2017-05-08 12:46:11 -07:00
|
|
|
echo -n "Checking for POSIX includes..."
|
2017-11-20 16:31:58 +01:00
|
|
|
git grep -I -i -f scripts/posix.txt -- './*' ':!include/spdk/stdinc.h' ':!include/linux/**' ':!lib/vhost/rte_vhost*/**' ':!scripts/posix.txt' > scripts/posix.log || true
|
2017-05-08 12:46:11 -07:00
|
|
|
if [ -s scripts/posix.log ]; then
|
|
|
|
echo "POSIX includes detected. Please include spdk/stdinc.h instead."
|
|
|
|
cat scripts/posix.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f scripts/posix.log
|
|
|
|
|
2018-06-21 19:29:12 +00:00
|
|
|
if hash pycodestyle 2>/dev/null; then
|
|
|
|
PEP8=pycodestyle
|
2018-06-25 11:12:16 -07:00
|
|
|
elif hash pep8 2>/dev/null; then
|
|
|
|
PEP8=pep8
|
2018-06-21 19:29:12 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -z ${PEP8} ]; then
|
2016-10-18 09:56:25 -07:00
|
|
|
echo -n "Checking Python style..."
|
|
|
|
|
|
|
|
PEP8_ARGS+=" --max-line-length=140"
|
|
|
|
|
|
|
|
error=0
|
2018-10-30 16:58:42 +01:00
|
|
|
git ls-files '*.py' | xargs -P$(nproc) -n1 $PEP8 $PEP8_ARGS > pep8.log || error=1
|
2016-10-18 09:56:25 -07:00
|
|
|
if [ $error -ne 0 ]; then
|
|
|
|
echo " Python formatting errors detected"
|
|
|
|
cat pep8.log
|
|
|
|
rc=1
|
|
|
|
else
|
|
|
|
echo " OK"
|
|
|
|
fi
|
|
|
|
rm -f pep8.log
|
2018-06-25 11:14:00 -07:00
|
|
|
else
|
|
|
|
echo "You do not have pycodestyle or pep8 installed so your Python style is not being checked!"
|
2016-10-18 09:56:25 -07:00
|
|
|
fi
|
2016-03-16 15:00:28 -07:00
|
|
|
|
2017-08-03 11:27:53 -07:00
|
|
|
# Check if any of the public interfaces were modified by this patch.
|
|
|
|
# Warn the user to consider updating the changelog any changes
|
|
|
|
# are detected.
|
|
|
|
echo -n "Checking whether CHANGELOG.md should be updated..."
|
|
|
|
staged=$(git diff --name-only --cached .)
|
|
|
|
working=$(git status -s --porcelain | grep -iv "??" | awk '{print $2}')
|
|
|
|
files="$staged $working"
|
|
|
|
if [[ "$files" = " " ]]; then
|
|
|
|
files=$(git diff-tree --no-commit-id --name-only -r HEAD)
|
|
|
|
fi
|
|
|
|
|
|
|
|
has_changelog=0
|
|
|
|
for f in $files; do
|
|
|
|
if [[ $f == CHANGELOG.md ]]; then
|
|
|
|
# The user has a changelog entry, so exit.
|
|
|
|
has_changelog=1
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
needs_changelog=0
|
|
|
|
if [ $has_changelog -eq 0 ]; then
|
|
|
|
for f in $files; do
|
|
|
|
if [[ $f == include/spdk/* ]] || [[ $f == scripts/rpc.py ]] || [[ $f == etc/* ]]; then
|
|
|
|
echo ""
|
|
|
|
echo -n "$f was modified. Consider updating CHANGELOG.md."
|
|
|
|
needs_changelog=1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $needs_changelog -eq 0 ]; then
|
|
|
|
echo " OK"
|
|
|
|
else
|
|
|
|
echo ""
|
|
|
|
fi
|
|
|
|
|
2016-10-18 09:56:25 -07:00
|
|
|
exit $rc
|