From a3410621bdb09e07728faaaf4ebe09f27953c5be Mon Sep 17 00:00:00 2001 From: albert-github Date: Wed, 19 Aug 2020 15:58:52 +0200 Subject: issue #7970 Doxygen doesn't stop on errors Routines doing their own formatting should also stop when `WARN_AS_ERROR` is set. --- src/message.cpp | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/message.cpp b/src/message.cpp index 37204f5..984a00f 100644 --- a/src/message.cpp +++ b/src/message.cpp @@ -161,6 +161,18 @@ static void format_warn(const char *file,int line,const char *text) } } +static void handle_warn_as_error(void) +{ + static bool warnAsError = Config_getBool(WARN_AS_ERROR); + if (warnAsError) + { + std::unique_lock lock(g_mutex); + QCString msgText = " (warning treated as error, aborting now)\n"; + fwrite(msgText.data(),1,msgText.length(),warnFile); + exit(1); + } +} + static void do_warn(bool enabled, const char *file, int line, const char *prefix, const char *fmt, va_list args) { if (!enabled) return; // warning type disabled @@ -230,6 +242,7 @@ void warn_uncond(const char *fmt, ...) va_start(args, fmt); vfprintf(warnFile, (QCString(warning_str) + fmt).data(), args); va_end(args); + handle_warn_as_error(); } void err(const char *fmt, ...) @@ -238,6 +251,7 @@ void err(const char *fmt, ...) va_start(args, fmt); vfprintf(warnFile, (QCString(error_str) + fmt).data(), args); va_end(args); + handle_warn_as_error(); } extern void err_full(const char *file,int line,const char *fmt, ...) -- cgit v0.12