bitcoin/contrib/devtools/lint-whitespace.sh
Evan Klitzke dd365612fd Add a lint check for trailing whitespace.
This adds a new CHECK_DOC check that looks for newly introduced trailing
whitespace. Existing trailing whitespace (of which there is plenty!)
will not trigger an error.

This is written in a generic way so that new lint-*.sh scripts can be
added to contrib/devtools/, as I'd like to contribute additional lint
checks in the future.
2017-09-14 10:49:48 +12:00

47 lines
1.1 KiB
Bash
Executable file

#!/bin/bash
#
# Copyright (c) 2017 The Bitcoin Core developers
# Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
#
# Check for new lines in diff that introduce trailing whitespace.
# We can't run this check unless we know the commit range for the PR.
if [ -z "${TRAVIS_COMMIT_RANGE}" ]; then
exit 0
fi
showdiff() {
if ! git diff -U0 "${TRAVIS_COMMIT_RANGE}" --; then
echo "Failed to get a diff"
exit 1
fi
}
# Do a first pass, and if no trailing whitespace was found then exit early.
if ! showdiff | grep -E -q '^\+.*\s+$'; then
exit
fi
echo "This diff appears to have added new lines with trailing whitespace."
echo "The following changes were suspected:"
FILENAME=""
SEEN=0
while read -r line; do
if [[ "$line" =~ ^diff ]]; then
FILENAME="$line"
SEEN=0
else
if [ "$SEEN" -eq 0 ]; then
# The first time a file is seen with trailing whitespace, we print the
# filename (preceded by a newline).
echo
echo "$FILENAME"
SEEN=1
fi
echo "$line"
fi
done < <(showdiff | grep -E '^(diff --git |\+.*\s+$)')
exit 1