2021-01-23 05:44:05 +13:00
|
|
|
#!/usr/bin/env bash
|
2020-11-28 18:16:38 +01:00
|
|
|
|
|
|
|
set -eo pipefail
|
|
|
|
|
|
|
|
script_path=$(cd -P -- "$(dirname -- "$0")" && pwd -P)
|
|
|
|
cd "${script_path}/.."
|
|
|
|
|
|
|
|
MISSING_FLAGS=n
|
|
|
|
|
|
|
|
while IFS= read -r FLAG; do
|
2021-04-16 21:53:43 +02:00
|
|
|
# Ignore ELF_DEBUG because it's not a debug flag.
|
|
|
|
if [ "$FLAG" = "ELF_DEBUG" ]; then
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
|
2020-11-28 18:16:38 +01:00
|
|
|
# We simply search whether the CMakeLists.txt *ever* sets the flag.
|
|
|
|
# There are (basically) no false positives, but there might be false negatives,
|
|
|
|
# for example we intentionally don't check for commented-out lines here.
|
2021-10-26 13:08:39 -05:00
|
|
|
if ! grep -qF "set(${FLAG}" Meta/CMake/all_the_debug_macros.cmake ; then
|
2021-02-13 12:46:22 +01:00
|
|
|
echo "'all_the_debug_macros.cmake' is missing ${FLAG}"
|
2020-11-28 18:16:38 +01:00
|
|
|
MISSING_FLAGS=y
|
|
|
|
fi
|
|
|
|
done < <(
|
|
|
|
git ls-files -- \
|
|
|
|
'*.cpp' \
|
|
|
|
'*.h' \
|
2021-01-24 15:07:40 +01:00
|
|
|
'*.in' \
|
2020-11-28 18:16:38 +01:00
|
|
|
':!:Kernel/FileSystem/ext2_fs.h' \
|
2021-10-26 13:08:39 -05:00
|
|
|
| xargs grep -E '(_DEBUG|DEBUG_)' \
|
2020-11-28 18:16:38 +01:00
|
|
|
| sed -re 's,^.*[^a-zA-Z0-9_]([a-zA-Z0-9_]*DEBUG[a-zA-Z0-9_]*).*$,\1,' \
|
|
|
|
| sort \
|
|
|
|
| uniq
|
|
|
|
)
|
|
|
|
|
|
|
|
if [ "n" != "${MISSING_FLAGS}" ] ; then
|
2021-02-13 12:46:22 +01:00
|
|
|
echo "Some flags are missing for the ALL_THE_DEBUG_MACROS feature."
|
2020-11-28 18:16:38 +01:00
|
|
|
echo "If you just added a new SOMETHING_DEBUG flag, that's great!"
|
|
|
|
echo "We want to enable all of these in automated builds, so that the code doesn't rot."
|
2021-02-13 12:46:22 +01:00
|
|
|
echo "Please add it to Meta/CMake/all_the_debug_macros.cmake"
|
2020-11-28 18:16:38 +01:00
|
|
|
exit 1
|
|
|
|
fi
|