gmacros: Prioritize the usage of [[noreturn]] in C++11

We defined G_NO_RETURN as [[noreturn]] in the C++ case, but only after
trying the __attribute__ syntax, so it was never used in GNUC compatible
compilers.

Give it priority instead when supporting a C++11 compiler and onwards.

As per this we need to adapt the code in the places where it was not
properly used (leading to compilation warnings).
This commit is contained in:
Marco Trevisan (Treviño) 2022-09-14 01:59:24 +02:00
parent 372ab7a964
commit 641256ea22
4 changed files with 8 additions and 9 deletions

View File

@ -1053,16 +1053,16 @@
* evaluated when a header is included. This results in warnings in third party * evaluated when a header is included. This results in warnings in third party
* code which includes glib.h, even if the third party code doesnt use the new * code which includes glib.h, even if the third party code doesnt use the new
* macro itself. */ * macro itself. */
#if g_macro__has_attribute(__noreturn__) #if G_CXX_STD_CHECK_VERSION (11)
/* Use ISO C++11 syntax when the compiler supports it. */
# define G_NORETURN [[noreturn]]
#elif g_macro__has_attribute(__noreturn__)
/* For compatibility with G_NORETURN_FUNCPTR on clang, use /* For compatibility with G_NORETURN_FUNCPTR on clang, use
__attribute__((__noreturn__)), not _Noreturn. */ __attribute__((__noreturn__)), not _Noreturn. */
# define G_NORETURN __attribute__ ((__noreturn__)) # define G_NORETURN __attribute__ ((__noreturn__))
#elif defined (_MSC_VER) && (1200 <= _MSC_VER) #elif defined (_MSC_VER) && (1200 <= _MSC_VER)
/* Use MSVC specific syntax. */ /* Use MSVC specific syntax. */
# define G_NORETURN __declspec (noreturn) # define G_NORETURN __declspec (noreturn)
/* Use ISO C++11 syntax when the compiler supports it. */
#elif G_CXX_STD_CHECK_VERSION (11)
# define G_NORETURN [[noreturn]]
/* Use ISO C11 syntax when the compiler supports it. */ /* Use ISO C11 syntax when the compiler supports it. */
#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112 #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112
# define G_NORETURN _Noreturn # define G_NORETURN _Noreturn

View File

@ -291,8 +291,8 @@ void g_warn_message (const char *domain,
int line, int line,
const char *func, const char *func,
const char *warnexpr) G_ANALYZER_NORETURN; const char *warnexpr) G_ANALYZER_NORETURN;
GLIB_DEPRECATED
G_NORETURN G_NORETURN
GLIB_DEPRECATED
void g_assert_warning (const char *log_domain, void g_assert_warning (const char *log_domain,
const char *file, const char *file,
const int line, const int line,
@ -409,7 +409,7 @@ void g_log_structured_standard (const gchar *log_domain,
format) format)
#endif #endif
#else /* no varargs macros */ #else /* no varargs macros */
static G_NORETURN void g_error (const gchar *format, ...) G_ANALYZER_NORETURN; G_NORETURN static void g_error (const gchar *format, ...) G_ANALYZER_NORETURN;
static void g_critical (const gchar *format, ...) G_ANALYZER_NORETURN; static void g_critical (const gchar *format, ...) G_ANALYZER_NORETURN;
static inline void static inline void

View File

@ -541,8 +541,8 @@ void g_assertion_message (const char *domain,
int line, int line,
const char *func, const char *func,
const char *message) G_ANALYZER_NORETURN; const char *message) G_ANALYZER_NORETURN;
GLIB_AVAILABLE_IN_ALL
G_NORETURN G_NORETURN
GLIB_AVAILABLE_IN_ALL
void g_assertion_message_expr (const char *domain, void g_assertion_message_expr (const char *domain,
const char *file, const char *file,
int line, int line,

View File

@ -426,8 +426,7 @@ g_bit_storage_impl (gulong number)
# include <stdlib.h> # include <stdlib.h>
# define g_abort() abort () # define g_abort() abort ()
#else #else
GLIB_AVAILABLE_IN_2_50 G_NORETURN GLIB_AVAILABLE_IN_2_50 void g_abort (void) G_ANALYZER_NORETURN;
G_NORETURN void g_abort (void) G_ANALYZER_NORETURN;
#endif #endif
#endif #endif