2018-06-01 21:29:46 +02:00
|
|
|
#!/usr/bin/env bash
|
2014-11-28 02:09:42 +01:00
|
|
|
|
2014-11-28 02:12:19 +01:00
|
|
|
# Copyright 2014 Oliver Hahm <oliver.hahm@inria.fr>
|
2018-06-01 21:29:46 +02:00
|
|
|
# 2018 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
# 2018 Alexandre Abadie <alexandre.abadie@inria.fr>
|
2014-11-28 02:12:19 +01:00
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
2021-08-31 14:06:49 +02:00
|
|
|
# If we don't find this scripts directory, does it really make sense to exit? So
|
|
|
|
# shellcheck disable=SC2164
|
|
|
|
SCRIPTDIR="$(cd "$(dirname "$0")"; pwd)"
|
2021-08-26 13:39:37 +02:00
|
|
|
RIOTBASE="$(cd "${SCRIPTDIR}"/../../..; pwd)"
|
|
|
|
EXCLUDE_PATTERN_FILE="${SCRIPTDIR}/exclude_patterns"
|
2017-04-25 21:00:21 +02:00
|
|
|
|
2021-08-31 14:06:49 +02:00
|
|
|
. "${RIOTBASE}"/dist/tools/ci/github_annotate.sh
|
2020-12-15 17:14:30 +01:00
|
|
|
|
|
|
|
github_annotate_setup
|
|
|
|
|
2021-08-31 14:06:49 +02:00
|
|
|
if tput colors &> /dev/null && [ "$(tput colors)" -ge 8 ]; then
|
2018-06-01 21:29:46 +02:00
|
|
|
CERROR="\e[1;31m"
|
|
|
|
CWARN="\033[1;33m"
|
|
|
|
CRESET="\e[0m"
|
|
|
|
else
|
|
|
|
CERROR=
|
|
|
|
CWARN=
|
|
|
|
CRESET=
|
|
|
|
fi
|
|
|
|
|
2021-08-26 13:39:37 +02:00
|
|
|
DOXY_OUTPUT=$(make -C "${RIOTBASE}" doc 2>&1 | grep -Evf "${EXCLUDE_PATTERN_FILE}")
|
2018-08-22 15:51:00 +02:00
|
|
|
DOXY_ERRCODE=$?
|
2020-12-15 17:10:22 +01:00
|
|
|
RESULT=0
|
|
|
|
|
2014-11-28 02:09:42 +01:00
|
|
|
|
2018-08-22 15:51:00 +02:00
|
|
|
if [ "${DOXY_ERRCODE}" -ne 0 ] ; then
|
|
|
|
echo "'make doc' exited with non-zero code (${DOXY_ERRCODE})"
|
|
|
|
echo "${DOXY_OUTPUT}"
|
2020-12-15 17:10:22 +01:00
|
|
|
RESULT=2
|
2018-08-22 15:51:00 +02:00
|
|
|
else
|
|
|
|
ERRORS=$(echo "${DOXY_OUTPUT}" | grep '.*warning' | sed "s#${PWD}/\([^:]*\)#\1#g")
|
|
|
|
if [ -n "${ERRORS}" ] ; then
|
2020-12-15 17:14:30 +01:00
|
|
|
if github_annotate_is_on; then
|
2021-08-31 14:06:49 +02:00
|
|
|
# We want to see backslashes here to escape e.g. newlines in
|
|
|
|
# github_annotate_error
|
|
|
|
# shellcheck disable=SC2162
|
2020-12-15 17:14:30 +01:00
|
|
|
echo "${ERRORS}" | grep "^.\+:[0-9]\+: warning:" | while read error_line
|
|
|
|
do
|
|
|
|
FILENAME=$(echo "${error_line}" | cut -d: -f1)
|
|
|
|
LINENR=$(echo "${error_line}" | cut -d: -f2)
|
|
|
|
DETAILS=$(echo "${error_line}" | cut -d: -f4- |
|
|
|
|
sed -e 's/^[ \t]*//' -e 's/[ \t]*$//')
|
|
|
|
github_annotate_error "${FILENAME}" "${LINENR}" "${DETAILS}"
|
|
|
|
done
|
|
|
|
else
|
|
|
|
echo -e "${CERROR}ERROR: Doxygen generates the following warnings:${CRESET}"
|
|
|
|
echo "${ERRORS}"
|
|
|
|
fi
|
2020-12-15 17:10:22 +01:00
|
|
|
RESULT=2
|
2018-08-22 15:51:00 +02:00
|
|
|
fi
|
2018-06-01 21:29:46 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
exclude_filter() {
|
2018-10-11 15:07:33 +02:00
|
|
|
grep -v -e vendor -e examples -e tests -e "\<dist/tools\>"
|
2018-06-01 21:29:46 +02:00
|
|
|
}
|
|
|
|
|
2019-07-06 21:43:22 +02:00
|
|
|
# Check groups are correctly defined (e.g. no undefined groups and no group
|
|
|
|
# defined multiple times)
|
2020-12-15 17:14:30 +01:00
|
|
|
ALL_RAW_DEFGROUP=$(git grep -n @defgroup -- '*.h' '*.c' '*.txt' | exclude_filter)
|
|
|
|
ALL_RAW_INGROUP=$(git grep -n '@ingroup' -- '*.h' '*.c' '*.txt' | exclude_filter)
|
2019-07-06 21:43:22 +02:00
|
|
|
DEFINED_GROUPS=$(echo "${ALL_RAW_DEFGROUP}" | \
|
2018-06-01 21:29:46 +02:00
|
|
|
grep -oE '@defgroup[ ]+[^ ]+' | \
|
2019-07-06 21:43:22 +02:00
|
|
|
grep -oE '[^ ]+$' | \
|
|
|
|
sort)
|
|
|
|
DEFINED_GROUPS_UNIQUE=$(echo "${DEFINED_GROUPS}" | sort -u)
|
2018-06-01 21:29:46 +02:00
|
|
|
|
2019-08-06 20:07:42 +02:00
|
|
|
# Check for undefined groups
|
2018-06-01 21:29:46 +02:00
|
|
|
UNDEFINED_GROUPS=$( \
|
2019-07-06 21:43:22 +02:00
|
|
|
for group in $(echo "${ALL_RAW_INGROUP}" | \
|
2018-06-01 21:29:46 +02:00
|
|
|
grep -oE '[^ ]+$' | sort -u); \
|
|
|
|
do \
|
2019-07-06 21:43:22 +02:00
|
|
|
echo "${DEFINED_GROUPS_UNIQUE}" | grep -xq "${group}" || echo "${group}"; \
|
2018-06-01 21:29:46 +02:00
|
|
|
done \
|
|
|
|
)
|
|
|
|
|
|
|
|
if [ -n "${UNDEFINED_GROUPS}" ]
|
|
|
|
then
|
|
|
|
COUNT=$(echo "${UNDEFINED_GROUPS}" | wc -l)
|
2020-12-15 17:10:22 +01:00
|
|
|
echo -ne "\n\n${CERROR}ERROR${CRESET} "
|
2020-12-15 17:14:30 +01:00
|
|
|
echo -ne "There are ${CWARN}${COUNT}${CRESET} undefined Doxygen groups"
|
|
|
|
if github_annotate_is_on; then
|
|
|
|
echo ""
|
|
|
|
else
|
|
|
|
echo ":"
|
|
|
|
fi
|
2019-08-06 20:07:42 +02:00
|
|
|
for group in ${UNDEFINED_GROUPS};
|
|
|
|
do
|
2020-12-15 17:14:30 +01:00
|
|
|
INGROUPS=$(echo "${ALL_RAW_INGROUP}" | grep "\<${group}\>$" | sort -u)
|
|
|
|
if github_annotate_is_on; then
|
2021-08-31 14:06:49 +02:00
|
|
|
# We want to see backslashes here to escape e.g. newlines in
|
|
|
|
# github_annotate_error
|
|
|
|
# shellcheck disable=SC2162
|
2020-12-15 17:14:30 +01:00
|
|
|
echo "${INGROUPS}" | while read ingroup;
|
|
|
|
do
|
|
|
|
github_annotate_error \
|
2021-08-31 14:06:49 +02:00
|
|
|
"$(echo "${ingroup}" | awk -F: '{ print $1,$2 }')" \
|
2020-12-15 17:14:30 +01:00
|
|
|
"Undefined doxygen group '${group}'"
|
|
|
|
done
|
|
|
|
else
|
|
|
|
echo -e "\n${CWARN}${group}${CRESET} found in:";
|
|
|
|
echo "${INGROUPS}" | awk -F: '{ print "\t" $1 }';
|
|
|
|
fi
|
2019-08-06 20:07:42 +02:00
|
|
|
done
|
2020-12-15 17:10:22 +01:00
|
|
|
RESULT=2
|
2014-11-28 02:09:42 +01:00
|
|
|
fi
|
2019-07-06 21:43:22 +02:00
|
|
|
|
|
|
|
# Check for groups defined multiple times:
|
|
|
|
MULTIPLE_DEFINED_GROUPS=$(echo "${DEFINED_GROUPS}" | uniq -d)
|
|
|
|
|
|
|
|
if [ -n "${MULTIPLE_DEFINED_GROUPS}" ]
|
|
|
|
then
|
|
|
|
COUNT=$(echo "${MULTIPLE_DEFINED_GROUPS}" | wc -l)
|
2020-12-15 17:10:22 +01:00
|
|
|
echo -ne "\n\n${CERROR}ERROR${CRESET} "
|
2020-12-15 17:14:30 +01:00
|
|
|
echo -ne "There are ${CWARN}${COUNT}${CRESET} Doxygen groups defined multiple times"
|
|
|
|
if github_annotate_is_on; then
|
|
|
|
echo ""
|
|
|
|
else
|
|
|
|
echo ":"
|
|
|
|
fi
|
2019-07-06 21:43:22 +02:00
|
|
|
for group in ${MULTIPLE_DEFINED_GROUPS};
|
|
|
|
do
|
2020-12-15 17:14:30 +01:00
|
|
|
DEFGROUPS=$(echo "${ALL_RAW_DEFGROUP}" |
|
2019-07-06 21:43:22 +02:00
|
|
|
awk -F@ '{ split($2, end, " "); printf("%s%s\n",$1,end[2]) }' |
|
2020-12-15 17:14:30 +01:00
|
|
|
grep "\<${group}\>$" | sort -u)
|
|
|
|
DEFGROUPFILES=$(echo "${DEFGROUPS}" | awk -F: '{ print "\t" $1 }')
|
|
|
|
if github_annotate_is_on; then
|
2021-08-31 14:06:49 +02:00
|
|
|
# We want to see backslashes here to escape e.g. newlines in
|
|
|
|
# github_annotate_error
|
|
|
|
# shellcheck disable=SC2162
|
2020-12-15 17:14:30 +01:00
|
|
|
echo "${DEFGROUPS}" | while read defgroup;
|
|
|
|
do
|
2021-08-31 14:06:49 +02:00
|
|
|
github_annotate_error "$(echo "${defgroup}" | awk -F: '{ print $1,$2 }')" \
|
2020-12-15 17:14:30 +01:00
|
|
|
"Multiple doxygen group definitions of '${group}' in\n${DEFGROUPFILES}"
|
|
|
|
done
|
|
|
|
else
|
|
|
|
echo -e "\n${CWARN}${group}${CRESET} defined in:";
|
|
|
|
echo "${DEFGROUPFILES}"
|
|
|
|
fi
|
2019-07-06 21:43:22 +02:00
|
|
|
done
|
2020-12-15 17:10:22 +01:00
|
|
|
RESULT=2
|
2019-07-06 21:43:22 +02:00
|
|
|
fi
|
2020-12-15 17:14:30 +01:00
|
|
|
github_annotate_teardown
|
2020-12-15 17:10:22 +01:00
|
|
|
exit ${RESULT}
|