summaryrefslogtreecommitdiffstats
path: root/configure.ac
diff options
context:
space:
mode:
authorDavid Lamparter <equinox@opensourcerouting.org>2024-04-30 13:51:38 +0200
committerDavid Lamparter <equinox@opensourcerouting.org>2024-05-03 10:53:13 +0200
commitb4eb7a037414e453cf7377a08dbc38b3e616cb75 (patch)
tree55a93e1366d4b097a7bfd732b7a5a3f439e60dfd /configure.ac
parentMerge pull request #15837 from acooks-at-bda/dev/fix-deprecated-cares-api (diff)
downloadfrr-b4eb7a037414e453cf7377a08dbc38b3e616cb75.tar.xz
frr-b4eb7a037414e453cf7377a08dbc38b3e616cb75.zip
build: get rid of "unrecognized … anon-tag"
GCC only errors out on unrecognized _positive_ `-Wsomething` flags, negative ones it ignores... but then prints a "note" about whenever an unrelated(!) warning/error occurs. This is both annoying and confusing, since we now get a lot of: ``` cc1: note: unrecognized command-line option ‘-Wno-microsoft-anon-tag’ may have been intended to silence earlier diagnostics ``` Fix by checking for the positive flag in `AC_C_FLAG` instead, which will error out, and therefore `-Wno-microsoft-anon-tag` won't be added for GCC. (It only exists on clang.) Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
Diffstat (limited to 'configure.ac')
-rw-r--r--configure.ac11
1 files changed, 10 insertions, 1 deletions
diff --git a/configure.ac b/configure.ac
index f11b345cf..6d8e70bb8 100644
--- a/configure.ac
+++ b/configure.ac
@@ -275,7 +275,16 @@ AC_DEFUN([AC_C_FLAG], [{
AC_CACHE_CHECK([[whether $CC supports $1]], cachename, [
AC_LANG_PUSH([C])
ac_c_flag_save="$CFLAGS"
- CFLAGS="$CFLAGS $1"
+ dnl GCC ignores unknown -Wno-whatever flags, but errors on -Wwhatever
+ dnl except when it ignores them it prints:
+ dnl cc1: note: unrecognized command-line option ‘-Wno-whatever’ may have been intended to silence earlier diagnostics
+ dnl which is annoying as hell. So check for the positive flag instead.
+ flag_add="$1"
+ if test "$flag_add" != "${flag_add#-Wno-}"; then
+ CFLAGS="$CFLAGS -W${flag_add#-Wno-}"
+ else
+ CFLAGS="$CFLAGS $flag_add"
+ fi
AC_COMPILE_IFELSE(
[AC_LANG_PROGRAM([[$4]])],
[