- [enableval=no])
-if test "${enableval}" = yes; then
- gl_WARNING_CFLAGS([-Werror])
- AC_SUBST([WERROR_CFLAGS], [$WARNING_CFLAGS])
- WARNING_CFLAGS=
- gl_WARNING_CFLAGS([-W])
- gl_WARNING_CFLAGS([-Wall])
- gl_WARNING_CFLAGS([-Wcast-align])
- gl_WARNING_CFLAGS([-Wcast-qual])
- gl_WARNING_CFLAGS([-Wformat])
- gl_WARNING_CFLAGS([-Wwrite-strings])
- AC_SUBST([WARNING_CXXFLAGS], [$WARNING_CFLAGS])
- # The following warnings are not suitable for C++.
- gl_WARNING_CFLAGS([-Wbad-function-cast])
- gl_WARNING_CFLAGS([-Wmissing-declarations])
- gl_WARNING_CFLAGS([-Wmissing-prototypes])
- gl_WARNING_CFLAGS([-Wshadow])
- gl_WARNING_CFLAGS([-Wstrict-prototypes])
- AC_DEFINE([lint], 1, [Define to 1 if the compiler is checking for lint.])
+ [enable_gcc_warnings=no])
+if test "$enable_gcc_warnings" = yes; then
+ warn_common='-Wall -Wextra -Wno-sign-compare -Wcast-align
+ -Wcast-qual -Wformat -Wpointer-arith -Wwrite-strings'
+ warn_c='-Wbad-function-cast -Wmissing-declarations -Wmissing-prototypes
+ -Wshadow -Wstrict-prototypes'
+ warn_cxx='-Wnoexcept'
+ AC_LANG_PUSH([C])
+ for i in $warn_common $warn_c;
+ do
+ gl_WARN_ADD([$i], [WARN_CFLAGS])
+ done
+ gl_WARN_ADD([-Werror], [WERROR_CFLAGS])
+ # Warnings for the test suite only.
+ gl_WARN_ADD([-Wundef], [WARN_CFLAGS_TEST])
+ gl_WARN_ADD([-pedantic], [WARN_CFLAGS_TEST])
+ AC_LANG_POP([C])
+
+ AC_LANG_PUSH([C++])
+ for i in $warn_common $warn_cxx;
+ do
+ gl_WARN_ADD([$i], [WARN_CXXFLAGS])
+ done
+ gl_WARN_ADD([ -Wzero-as-null-pointer-constant], [WARN_CXXFLAGS],
+ [AC_LANG_PROGRAM([], [nullptr])])
+ gl_WARN_ADD([-Werror], [WERROR_CXXFLAGS])
+ # Warnings for the test suite only.
+ gl_WARN_ADD([-Wundef], [WARN_CXXFLAGS_TEST])
+ gl_WARN_ADD([-pedantic], [WARN_CXXFLAGS_TEST])
+ AC_LANG_POP([C++])