Merge pull request #9266 from aabadie/pr/tool/doc_group_check

dist/tools/doccheck: add check for undefined groups
This commit is contained in:
Martine Lenders 2018-06-07 19:43:47 +02:00 committed by GitHub
commit fd1a987bf1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,6 +1,8 @@
#!/bin/sh #!/usr/bin/env bash
# Copyright 2014 Oliver Hahm <oliver.hahm@inria.fr> # Copyright 2014 Oliver Hahm <oliver.hahm@inria.fr>
# 2018 Kaspar Schleiser <kaspar@schleiser.de>
# 2018 Alexandre Abadie <alexandre.abadie@inria.fr>
# #
# This file is subject to the terms and conditions of the GNU Lesser # 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 # General Public License v2.1. See the file LICENSE in the top level
@ -8,15 +10,61 @@
RIOTBASE=$(readlink -f "$(dirname $(realpath $0))/../../..") RIOTBASE=$(readlink -f "$(dirname $(realpath $0))/../../..")
if tput colors &> /dev/null && [ $(tput colors) -ge 8 ]; then
CERROR="\e[1;31m"
CWARN="\033[1;33m"
CRESET="\e[0m"
else
CERROR=
CWARN=
CRESET=
fi
ERRORS=$(make -C "${RIOTBASE}" doc 2>&1 | \ ERRORS=$(make -C "${RIOTBASE}" doc 2>&1 | \
grep '.*warning' | \ grep '.*warning' | \
sed "s#${PWD}/\([^:]*\)#\1#g") sed "s#${PWD}/\([^:]*\)#\1#g")
if [ -n "${ERRORS}" ] if [ -n "${ERRORS}" ]
then then
echo "ERROR: Doxygen generates the following warnings:" echo -e "${CERROR}ERROR: Doxygen generates the following warnings:${CRESET}"
echo "${ERRORS}" echo "${ERRORS}"
exit 2 exit 2
else fi
exit 0
exclude_filter() {
grep -v -e vendor -e examples -e tests
}
# Check all groups are defined
DEFINED_GROUPS=$(git grep @defgroup -- '*.h' '*.c' '*.txt' | \
exclude_filter | \
grep -oE '@defgroup[ ]+[^ ]+' | \
grep -oE '[^ ]+$' | sort -u)
UNDEFINED_GROUPS=$( \
for group in $(git grep '@ingroup' -- '*.h' '*.c' '*.txt' | \
exclude_filter | \
grep -oE '[^ ]+$' | sort -u); \
do \
echo "${DEFINED_GROUPS}" | grep -xq "${group}" || echo "${group}"; \
done \
)
ALL_RAW_INGROUP=$(git grep '@ingroup' -- '*.h' '*.c' '*.txt' | exclude_filter)
UNDEFINED_GROUPS_PRINT=$( \
for group in ${UNDEFINED_GROUPS}; \
do \
echo -e "\n${CWARN}${group}${CRESET} found in:"; \
echo "${ALL_RAW_INGROUP}" | grep "\<${group}\>$" | sort -u | \
awk -F: '{ print "\t" $1 }'; \
done \
)
if [ -n "${UNDEFINED_GROUPS}" ]
then
COUNT=$(echo "${UNDEFINED_GROUPS}" | wc -l)
echo -ne "${CWARN}WARNING${CRESET} "
echo -e "There are ${CWARN}${COUNT}${CRESET} undefined Doxygen groups:"
echo "${UNDEFINED_GROUPS_PRINT}"
fi fi