From e0633768a1a2efe689e5505b3a95aa949d704b06 Mon Sep 17 00:00:00 2001 From: Martin Sebor Date: Sat, 25 Jul 2020 14:21:47 -0600 Subject: [PATCH] Fix PR c++/96310 - Ignoring -Wnonnull via pragma gcc diagnostics still produces an unwanted note. gcc/c-family/ChangeLog: PR c++/96310 * c-common.c (check_nonnull_arg): Print note only when warning was issued. --- gcc/c-family/c-common.c | 4 ++-- gcc/testsuite/g++.dg/warn/Wnonnull8.C | 20 ++++++++++++++++++++ 2 files changed, 22 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/g++.dg/warn/Wnonnull8.C diff --git a/gcc/c-family/c-common.c b/gcc/c-family/c-common.c index 51ecde69f2d..e2569c65827 100644 --- a/gcc/c-family/c-common.c +++ b/gcc/c-family/c-common.c @@ -5538,7 +5538,7 @@ check_nonnull_arg (void *ctx, tree param, unsigned HOST_WIDE_INT param_num) { warned = warning_at (loc, OPT_Wnonnull, "%qs pointer null", "this"); - if (pctx->fndecl) + if (warned && pctx->fndecl) inform (DECL_SOURCE_LOCATION (pctx->fndecl), "in a call to non-static member function %qD", pctx->fndecl); @@ -5548,7 +5548,7 @@ check_nonnull_arg (void *ctx, tree param, unsigned HOST_WIDE_INT param_num) warned = warning_at (loc, OPT_Wnonnull, "argument %u null where non-null expected", (unsigned) param_num); - if (pctx->fndecl) + if (warned && pctx->fndecl) inform (DECL_SOURCE_LOCATION (pctx->fndecl), "in a call to function %qD declared %qs", pctx->fndecl, "nonnull"); diff --git a/gcc/testsuite/g++.dg/warn/Wnonnull8.C b/gcc/testsuite/g++.dg/warn/Wnonnull8.C new file mode 100644 index 00000000000..7820b2e3b79 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wnonnull8.C @@ -0,0 +1,20 @@ +/* PR c++/96310 - Ignoring -Wnonnull via pragma gcc diagnostics still produces + an unwanted note + { dg-do compile } + { dg-options "-Wall" } */ + +struct C { + void f (); // { dg-message "in a call" } + void g (); // { dg-bogus "in a call" } +}; + +void f () +{ + static_cast(0)->f (); // { dg-warning "\\\[-Wnonnull" } +} + +void g () +{ +#pragma GCC diagnostic ignored "-Wnonnull" + static_cast(0)->g (); +} -- 2.30.2