dist/tools: add check for extern "C" declaration
This commit is contained in:
parent
fc4cf69376
commit
302b9b775c
37
dist/tools/externc/check.sh
vendored
Executable file
37
dist/tools/externc/check.sh
vendored
Executable file
@ -0,0 +1,37 @@
|
||||
#!/bin/sh
|
||||
|
||||
# customizable
|
||||
CHECKROOT=$(dirname "${0}")
|
||||
|
||||
# prepare
|
||||
ROOT=$(git rev-parse --show-toplevel)
|
||||
EXIT_CODE=0
|
||||
BRANCH="${1}"
|
||||
DIFFFILTER="${2}"
|
||||
|
||||
# set default diff-filter
|
||||
if [ -z "${DIFFFILTER}" ]; then
|
||||
DIFFFILTER="ACMR"
|
||||
fi
|
||||
|
||||
# select files to check
|
||||
if [ -z "${BRANCH}" ]; then
|
||||
FILES="$(git ls-tree -r --full-tree --name-only HEAD | grep -E '\.h$')"
|
||||
else
|
||||
FILES="$(git diff --diff-filter=${DIFFFILTER} --name-only ${BRANCH} | grep -E '\.h$')"
|
||||
fi
|
||||
|
||||
# check files
|
||||
for FILE in ${FILES}; do
|
||||
if head -100 "${ROOT}/${FILE}" \
|
||||
| sed -e 's/$/ /' \
|
||||
| tr -d '\r\n' \
|
||||
| sed -e 's/ */ /g' \
|
||||
| grep -v -q '#ifdef __cplusplus extern "C" { #endif'; \
|
||||
then
|
||||
EXIT_CODE=1
|
||||
echo "file does not have a C++ compatible header: '${FILE}'"
|
||||
fi
|
||||
done
|
||||
|
||||
exit ${EXIT_CODE}
|
||||
Loading…
x
Reference in New Issue
Block a user