Merge pull request #12232 from aabadie/pr/tools/codespell_check

ci: add codespell check script for tracking typos
This commit is contained in:
Kaspar Schleiser 2019-10-10 16:41:55 +02:00 committed by GitHub
commit bfebb7376e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 56 additions and 1 deletions

View File

@ -39,7 +39,7 @@ function run {
print_result $NEW_RESULT print_result $NEW_RESULT
set_result $NEW_RESULT set_result $NEW_RESULT
# Indent command output so that its easily discernable from the rest # Indent command output so that its easily discernible from the rest
if [ -n "$OUT" ]; then if [ -n "$OUT" ]; then
echo "Command output:" echo "Command output:"
echo "" echo ""
@ -94,6 +94,7 @@ then
run ./dist/tools/flake8/check.sh run ./dist/tools/flake8/check.sh
run ./dist/tools/headerguards/check.sh run ./dist/tools/headerguards/check.sh
run ./dist/tools/buildsystem_sanity_check/check.sh run ./dist/tools/buildsystem_sanity_check/check.sh
run ./dist/tools/codespell/check.sh
exit $RESULT exit $RESULT
fi fi

54
dist/tools/codespell/check.sh vendored Executable file
View File

@ -0,0 +1,54 @@
#!/usr/bin/env bash
# Copyright 2019 Alexandre Abadie <alexandre.abadie@inria.fr>
#
# This file is subject to the terms and conditions of the GNU Lesser
# General Public License v2.1. See the file LICENSE in the top level
# directory for more details.
CODESPELL_CMD="codespell"
if tput colors &> /dev/null && [ "$(tput colors)" -ge 8 ]; then
CERROR=$'\033[1;31m'
CRESET=$'\033[0m'
else
CERROR=
CRESET=
fi
: "${RIOTBASE:=$(cd $(dirname $0)/../../../; pwd)}"
cd $RIOTBASE
: "${RIOTTOOLS:=${RIOTBASE}/dist/tools}"
. "${RIOTTOOLS}"/ci/changed_files.sh
FILEREGEX='\.([CcHh]|[ch]pp|sh|py|md|txt)$'
EXCLUDE='^(.+/vendor/)'
FILES=$(FILEREGEX=${FILEREGEX} EXCLUDE=${EXCLUDE} changed_files)
if [ -z "${FILES}" ]; then
exit 0
fi
${CODESPELL_CMD} --version &> /dev/null || {
printf "%s%s: cannot execute \"%s\"!%s\n" "${CERROR}" "$0" "${CODESPELL_CMD}" "${CRESET}"
exit 1
}
CODESPELL_OPTS="-q 2" # Disable "WARNING: Binary file"
CODESPELL_OPTS+=" --check-hidden"
# Disable false positives "nd => and, 2nd", "WAN => WANT", "od => of"
CODESPELL_OPTS+=" --ignore-words-list=ND,nd,WAN,od"
# Filter-out all false positive raising "disabled due to" messages.
ERRORS=$(${CODESPELL_CMD} ${CODESPELL_OPTS} ${FILES} | grep -ve "disabled due to")
if [ -n "${ERRORS}" ]
then
printf "%sThere are typos in the following files:%s\n\n" "${CERROR}" "${CRESET}"
printf "%s\n" "${ERRORS}"
# TODO: return 1 when all typos are fixed
exit 0
else
exit 0
fi