2020-10-30 13:12:35 +01:00
|
|
|
#!/usr/bin/env bash
|
2018-02-05 14:26:15 +01:00
|
|
|
RIOTBASE=$(git rev-parse --show-toplevel)
|
|
|
|
CURDIR=$(cd "$(dirname "$0")" && pwd)
|
|
|
|
UNCRUSTIFY_CFG="$RIOTBASE"/uncrustify-riot.cfg
|
|
|
|
|
|
|
|
WHITELIST=$CURDIR/whitelist.txt
|
|
|
|
BLACKLIST=$CURDIR/blacklist.txt
|
|
|
|
|
|
|
|
. "$RIOTBASE"/dist/tools/ci/changed_files.sh
|
2021-01-12 14:19:32 +01:00
|
|
|
. "$RIOTBASE"/dist/tools/ci/github_annotate.sh
|
2018-02-05 14:26:15 +01:00
|
|
|
|
|
|
|
# only consider whitelisted stuff, then filter out blacklist
|
|
|
|
# note: this also applies changed_files' default filter
|
|
|
|
FILES=$(changed_files | grep -xf "$WHITELIST" | grep -xvf "$BLACKLIST")
|
|
|
|
|
|
|
|
check () {
|
|
|
|
for F in $FILES
|
|
|
|
do
|
2020-04-29 09:48:14 +02:00
|
|
|
uncrustify -c "$UNCRUSTIFY_CFG" -f "$RIOTBASE/$F" \
|
|
|
|
--check > /dev/null 2>&1 || {
|
|
|
|
echo "file $F needs to be uncrustified."
|
2018-02-05 14:26:15 +01:00
|
|
|
echo "Please run 'dist/tools/uncrustify/uncrustify.sh'"
|
2020-05-07 13:57:09 +02:00
|
|
|
|
|
|
|
# Disable error until versioning issue is sorted out.
|
|
|
|
#exit 1
|
|
|
|
exit 0
|
2020-04-29 09:48:14 +02:00
|
|
|
}
|
2018-02-05 14:26:15 +01:00
|
|
|
done
|
|
|
|
echo "All files are uncrustified!"
|
|
|
|
}
|
|
|
|
|
2021-01-12 14:19:32 +01:00
|
|
|
_annotate_diff() {
|
|
|
|
if [ -n "$1" -a -n "$2" -a -n "$3" ]; then
|
|
|
|
MSG="Uncrustify proposes the following patch:\n\n$3"
|
|
|
|
github_annotate_error "$1" "$2" "${MSG}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2018-02-05 14:26:15 +01:00
|
|
|
exec_uncrustify () {
|
|
|
|
if [ "$(git diff HEAD)" ] ; then
|
|
|
|
echo "Please commit all changes before running uncrustify.sh"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
for F in $FILES
|
|
|
|
do
|
|
|
|
uncrustify -c "$UNCRUSTIFY_CFG" --no-backup "$RIOTBASE/$F"
|
|
|
|
done
|
2021-01-12 14:19:32 +01:00
|
|
|
if github_annotate_is_on; then
|
|
|
|
DIFF=""
|
|
|
|
DIFFFILE=""
|
|
|
|
DIFFLINE=""
|
|
|
|
git diff HEAD | {
|
|
|
|
# see https://stackoverflow.com/a/30064493/11921757 for why we
|
|
|
|
# use a sub shell here
|
|
|
|
while read line; do
|
|
|
|
# parse beginning of new diff
|
|
|
|
if echo "$line" | grep -q '^--- .\+$'; then
|
|
|
|
_annotate_diff "$DIFFFILE" "$DIFFLINE" "$DIFF"
|
|
|
|
DIFF="$line"
|
2021-01-14 12:12:50 +01:00
|
|
|
DIFFFILE=$(echo "$line" |
|
|
|
|
sed 's#^--- \([ab]/\)\?\(.\+\)$#\2#g')
|
2021-01-12 14:19:32 +01:00
|
|
|
DIFFLINE=""
|
|
|
|
# we are in a diff currently
|
|
|
|
elif [ -n "$DIFF" ]; then
|
|
|
|
# grep first line number of diff including offset to
|
|
|
|
# comment _under_ diff
|
|
|
|
if echo "$line" | \
|
|
|
|
grep -q "@@ -[0-9]\+\(,[0-9]\+\)\? +[0-9]\+\(,[0-9]\+\)\? @@"
|
|
|
|
then
|
|
|
|
# treat hunk as new diff so it is at the corresponding line
|
|
|
|
if [ -n "${DIFFLINE}" ]; then
|
|
|
|
_annotate_diff "$DIFFFILE" "$DIFFLINE" "$DIFF"
|
|
|
|
DIFF="--- $DIFFFILE\n+++ $DIFFFILE"
|
|
|
|
fi
|
|
|
|
DIFFLINE="$(echo "$line" | sed 's/@@ -\([0-9]\+\).*$/\1/')"
|
|
|
|
fi
|
|
|
|
DIFF="$DIFF\n$line"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
_annotate_diff "$DIFFFILE" "$DIFFLINE" "$DIFF"
|
|
|
|
}
|
|
|
|
else
|
|
|
|
echo "$OUT"
|
|
|
|
fi
|
2018-02-05 14:26:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if [ "$1" == "--check" ] ; then
|
|
|
|
check
|
|
|
|
else
|
2021-01-12 14:19:32 +01:00
|
|
|
github_annotate_setup
|
2018-02-05 14:26:15 +01:00
|
|
|
exec_uncrustify
|
2021-01-12 14:19:32 +01:00
|
|
|
github_annotate_teardown
|
2018-02-05 14:26:15 +01:00
|
|
|
fi
|