[network-manager-pptp/th/vpn-editor-split-bgo766623: 1/21] build: update m4/compiler_warnings.m4 to support clang
- From: Thomas Haller <thaller src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [network-manager-pptp/th/vpn-editor-split-bgo766623: 1/21] build: update m4/compiler_warnings.m4 to support clang
- Date: Wed, 18 May 2016 19:04:13 +0000 (UTC)
commit 5142dcab8201f133f5ca6d1b6e0bf465f44597f0
Author: Thomas Haller <thaller redhat com>
Date: Wed May 18 12:33:18 2016 +0200
build: update m4/compiler_warnings.m4 to support clang
NetworkManager's compiler_warnings.m4 file properly handles clang.
Import the entire file and use it.
m4/compiler_warnings.m4 | 99 ++++++++++++++++++++++++++++++++++++++++------
1 files changed, 86 insertions(+), 13 deletions(-)
---
diff --git a/m4/compiler_warnings.m4 b/m4/compiler_warnings.m4
index 95ad3fb..77dcc7a 100644
--- a/m4/compiler_warnings.m4
+++ b/m4/compiler_warnings.m4
@@ -1,33 +1,106 @@
+dnl Check whether a particular compiler flag works with code provided,
+dnl disable it in CFLAGS if the check fails.
+AC_DEFUN([NM_COMPILER_WARNING], [
+ CFLAGS_SAVED="$CFLAGS"
+ CFLAGS="$CFLAGS -Werror -W$1"
+ AC_MSG_CHECKING(whether -W$1 works)
+
+ AC_COMPILE_IFELSE([AC_LANG_SOURCE([[]])], [
+ AC_COMPILE_IFELSE([AC_LANG_SOURCE([[$2]])], [
+ AC_MSG_RESULT(yes)
+ CFLAGS="$CFLAGS_SAVED -W$1"
+ ],[
+ AC_MSG_RESULT(no)
+ CFLAGS="$CFLAGS_SAVED -Wno-$1"
+ ])
+ ],[
+ AC_MSG_RESULT(not supported)
+ CFLAGS="$CFLAGS_SAVED"
+ ])
+])
+
AC_DEFUN([NM_COMPILER_WARNINGS],
[AC_ARG_ENABLE(more-warnings,
AS_HELP_STRING([--enable-more-warnings], [Possible values: no/yes/error]),
- set_more_warnings="$enableval",set_more_warnings=error)
+ set_more_warnings="$enableval",set_more_warnings=yes)
AC_MSG_CHECKING(for more warnings)
if test "$GCC" = "yes" -a "$set_more_warnings" != "no"; then
AC_MSG_RESULT(yes)
- CFLAGS="-Wall -std=gnu89 $CFLAGS"
+
+ dnl This is enabled in clang by default, makes little sense,
+ dnl and causes the build to abort with -Werror.
+ CFLAGS_SAVED="$CFLAGS"
+ CFLAGS="$CFLAGS -Qunused-arguments"
+ AC_COMPILE_IFELSE([AC_LANG_SOURCE([])], [], CFLAGS="$CFLAGS_SAVED")
+ unset CFLAGS_SAVED
+
+ dnl clang only warns about unknown warnings, unless
+ dnl called with "-Werror=unknown-warning-option"
+ dnl Test if the compiler supports that, and if it does
+ dnl attach it to the CFLAGS.
+ NM_COMPILER_WARNING([unknown-warning-option], [])
+
+ CFLAGS_SAVED="$CFLAGS"
+ CFLAGS_MORE_WARNINGS="-Wall -std=gnu89"
+
+ if test "x$set_more_warnings" = xerror; then
+ CFLAGS_MORE_WARNINGS="$CFLAGS_MORE_WARNINGS -Werror"
+ fi
for option in -Wshadow -Wmissing-declarations -Wmissing-prototypes \
- -Wdeclaration-after-statement -Wstrict-prototypes \
+ -Wdeclaration-after-statement -Wformat-security \
-Wfloat-equal -Wno-unused-parameter -Wno-sign-compare \
- -fno-strict-aliasing -Wno-unused-but-set-variable; do
- SAVE_CFLAGS="$CFLAGS"
- CFLAGS="$CFLAGS $option"
- AC_MSG_CHECKING([whether gcc understands $option])
+ -Wno-duplicate-decl-specifier \
+ -Wstrict-prototypes \
+ -fno-strict-aliasing -Wno-unused-but-set-variable \
+ -Wundef -Wimplicit-function-declaration \
+ -Wpointer-arith -Winit-self \
+ -Wmissing-include-dirs -Wno-pragmas; do
+ dnl GCC 4.4 does not warn when checking for -Wno-* flags
(https://gcc.gnu.org/wiki/FAQ#wnowarning)
+ CFLAGS="-Werror $CFLAGS_MORE_WARNINGS $(printf '%s' "$option" | sed 's/^-Wno-/-W/')
$CFLAGS_SAVED"
+ AC_MSG_CHECKING([whether compiler understands $option])
AC_TRY_COMPILE([], [],
has_option=yes,
has_option=no,)
- if test $has_option = no; then
- CFLAGS="$SAVE_CFLAGS"
+ if test $has_option != no; then
+ CFLAGS_MORE_WARNINGS="$CFLAGS_MORE_WARNINGS $option"
fi
AC_MSG_RESULT($has_option)
unset has_option
- unset SAVE_CFLAGS
done
unset option
- if test "x$set_more_warnings" = xerror; then
- CFLAGS="$CFLAGS -Werror"
- fi
+
+ CFLAGS="$CFLAGS_SAVED"
+ unset CFLAGS_SAVED
+
+ dnl Disable warnings triggered by known compiler problems
+
+ dnl https://bugzilla.gnome.org/show_bug.cgi?id=745821
+ NM_COMPILER_WARNING([unknown-attributes], [#include <glib.h>])
+
+ dnl https://bugzilla.gnome.org/show_bug.cgi?id=744473
+ NM_COMPILER_WARNING([typedef-redefinition], [#include <gio/gio.h>])
+
+ dnl https://llvm.org/bugs/show_bug.cgi?id=21614
+ NM_COMPILER_WARNING([array-bounds],
+ [#include <string.h>]
+ [void f () { strcmp ("something", "0"); }]
+ )
+
+ dnl https://llvm.org/bugs/show_bug.cgi?id=22949
+ NM_COMPILER_WARNING([parentheses-equality],
+ [#include <sys/wait.h>]
+ [void f () { if (WIFCONTINUED(0)) return; }]
+ )
+
+ dnl systemd-dhcp's log_internal macro and our handle_warn are sometimes
+ dnl used in void context,u sometimes in int. Makes clang unhappy.
+ NM_COMPILER_WARNING([unused-value],
+ [#define yolo ({ (666 + 666); })]
+ [int f () { int i = yolo; yolo; return i; }]
+ )
+
+ CFLAGS="$CFLAGS_MORE_WARNINGS $CFLAGS"
else
AC_MSG_RESULT(no)
fi
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]