|
Packit |
712bc5 |
# ============================================================================
|
|
Packit |
712bc5 |
# http://www.gnu.org/software/autoconf-archive/ax_compiler_flags_cflags.html
|
|
Packit |
712bc5 |
# ============================================================================
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# SYNOPSIS
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# AX_COMPILER_FLAGS_CFLAGS([VARIABLE], [IS-RELEASE], [EXTRA-BASE-FLAGS], [EXTRA-YES-FLAGS])
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# DESCRIPTION
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# Add warning flags for the C compiler to VARIABLE, which defaults to
|
|
Packit |
712bc5 |
# WARN_CFLAGS. VARIABLE is AC_SUBST-ed by this macro, but must be
|
|
Packit |
712bc5 |
# manually added to the CFLAGS variable for each target in the code base.
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# This macro depends on the environment set up by AX_COMPILER_FLAGS.
|
|
Packit |
712bc5 |
# Specifically, it uses the value of $ax_enable_compile_warnings to decide
|
|
Packit |
712bc5 |
# which flags to enable.
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# LICENSE
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# Copyright (c) 2014, 2015 Philip Withnall <philip@tecnocode.co.uk>
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# Copying and distribution of this file, with or without modification, are
|
|
Packit |
712bc5 |
# permitted in any medium without royalty provided the copyright notice
|
|
Packit |
712bc5 |
# and this notice are preserved. This file is offered as-is, without any
|
|
Packit |
712bc5 |
# warranty.
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
#serial 11
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
AC_DEFUN([AX_COMPILER_FLAGS_CFLAGS],[
|
|
Packit |
712bc5 |
AC_REQUIRE([AC_PROG_SED])
|
|
Packit |
712bc5 |
AX_REQUIRE_DEFINED([AX_APPEND_COMPILE_FLAGS])
|
|
Packit |
712bc5 |
AX_REQUIRE_DEFINED([AX_APPEND_FLAG])
|
|
Packit |
712bc5 |
AX_REQUIRE_DEFINED([AX_CHECK_COMPILE_FLAG])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
# Variable names
|
|
Packit |
712bc5 |
m4_define(ax_warn_cflags_variable,
|
|
Packit |
712bc5 |
[m4_normalize(ifelse([$1],,[WARN_CFLAGS],[$1]))])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
AC_LANG_PUSH([C])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
# Always pass -Werror=unknown-warning-option to get Clang to fail on bad
|
|
Packit |
712bc5 |
# flags, otherwise they are always appended to the warn_cflags variable, and
|
|
Packit |
712bc5 |
# Clang warns on them for every compilation unit.
|
|
Packit |
712bc5 |
# If this is passed to GCC, it will explode, so the flag must be enabled
|
|
Packit |
712bc5 |
# conditionally.
|
|
Packit |
712bc5 |
AX_CHECK_COMPILE_FLAG([-Werror=unknown-warning-option],[
|
|
Packit |
712bc5 |
ax_compiler_flags_test="-Werror=unknown-warning-option"
|
|
Packit |
712bc5 |
],[
|
|
Packit |
712bc5 |
ax_compiler_flags_test=""
|
|
Packit |
712bc5 |
])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
# Base flags
|
|
Packit |
712bc5 |
AX_APPEND_COMPILE_FLAGS([ dnl
|
|
Packit |
712bc5 |
-fno-strict-aliasing dnl
|
|
Packit |
712bc5 |
$3 dnl
|
|
Packit |
712bc5 |
],ax_warn_cflags_variable,[$ax_compiler_flags_test])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
AS_IF([test "$ax_enable_compile_warnings" != "no"],[
|
|
Packit |
712bc5 |
# "yes" flags
|
|
Packit |
712bc5 |
AX_APPEND_COMPILE_FLAGS([ dnl
|
|
Packit |
712bc5 |
-Wall dnl
|
|
Packit |
712bc5 |
-Wextra dnl
|
|
Packit |
712bc5 |
-Wundef dnl
|
|
Packit |
712bc5 |
-Wnested-externs dnl
|
|
Packit |
712bc5 |
-Wwrite-strings dnl
|
|
Packit |
712bc5 |
-Wpointer-arith dnl
|
|
Packit |
712bc5 |
-Wmissing-declarations dnl
|
|
Packit |
712bc5 |
-Wmissing-prototypes dnl
|
|
Packit |
712bc5 |
-Wstrict-prototypes dnl
|
|
Packit |
712bc5 |
-Wredundant-decls dnl
|
|
Packit |
712bc5 |
-Wno-unused-parameter dnl
|
|
Packit |
712bc5 |
-Wno-missing-field-initializers dnl
|
|
Packit |
712bc5 |
-Wdeclaration-after-statement dnl
|
|
Packit |
712bc5 |
-Wformat=2 dnl
|
|
Packit |
712bc5 |
-Wold-style-definition dnl
|
|
Packit |
712bc5 |
-Wcast-align dnl
|
|
Packit |
712bc5 |
-Wformat-nonliteral dnl
|
|
Packit |
712bc5 |
-Wformat-security dnl
|
|
Packit |
712bc5 |
-Wsign-compare dnl
|
|
Packit |
712bc5 |
-Wstrict-aliasing dnl
|
|
Packit |
712bc5 |
-Wshadow dnl
|
|
Packit |
712bc5 |
-Winline dnl
|
|
Packit |
712bc5 |
-Wpacked dnl
|
|
Packit |
712bc5 |
-Wmissing-format-attribute dnl
|
|
Packit |
712bc5 |
-Wmissing-noreturn dnl
|
|
Packit |
712bc5 |
-Winit-self dnl
|
|
Packit |
712bc5 |
-Wredundant-decls dnl
|
|
Packit |
712bc5 |
-Wmissing-include-dirs dnl
|
|
Packit |
712bc5 |
-Wunused-but-set-variable dnl
|
|
Packit |
712bc5 |
-Warray-bounds dnl
|
|
Packit |
712bc5 |
-Wimplicit-function-declaration dnl
|
|
Packit |
712bc5 |
-Wreturn-type dnl
|
|
Packit |
712bc5 |
-Wswitch-enum dnl
|
|
Packit |
712bc5 |
-Wswitch-default dnl
|
|
Packit |
712bc5 |
$4 dnl
|
|
Packit |
712bc5 |
$5 dnl
|
|
Packit |
712bc5 |
$6 dnl
|
|
Packit |
712bc5 |
$7 dnl
|
|
Packit |
712bc5 |
],ax_warn_cflags_variable,[$ax_compiler_flags_test])
|
|
Packit |
712bc5 |
])
|
|
Packit |
712bc5 |
AS_IF([test "$ax_enable_compile_warnings" = "error"],[
|
|
Packit |
712bc5 |
# "error" flags; -Werror has to be appended unconditionally because
|
|
Packit |
712bc5 |
# it's not possible to test for
|
|
Packit |
712bc5 |
#
|
|
Packit |
712bc5 |
# suggest-attribute=format is disabled because it gives too many false
|
|
Packit |
712bc5 |
# positives
|
|
Packit |
712bc5 |
AX_APPEND_FLAG([-Werror],ax_warn_cflags_variable)
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
AX_APPEND_COMPILE_FLAGS([ dnl
|
|
Packit |
712bc5 |
-Wno-suggest-attribute=format dnl
|
|
Packit |
712bc5 |
],ax_warn_cflags_variable,[$ax_compiler_flags_test])
|
|
Packit |
712bc5 |
])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
# In the flags below, when disabling specific flags, always add *both*
|
|
Packit |
712bc5 |
# -Wno-foo and -Wno-error=foo. This fixes the situation where (for example)
|
|
Packit |
712bc5 |
# we enable -Werror, disable a flag, and a build bot passes CFLAGS=-Wall,
|
|
Packit |
712bc5 |
# which effectively turns that flag back on again as an error.
|
|
Packit |
712bc5 |
for flag in $ax_warn_cflags_variable; do
|
|
Packit |
712bc5 |
AS_CASE([$flag],
|
|
Packit |
712bc5 |
[-Wno-*=*],[],
|
|
Packit |
712bc5 |
[-Wno-*],[
|
|
Packit |
712bc5 |
AX_APPEND_COMPILE_FLAGS([-Wno-error=$(AS_ECHO([$flag]) | $SED 's/^-Wno-//')],
|
|
Packit |
712bc5 |
ax_warn_cflags_variable,
|
|
Packit |
712bc5 |
[$ax_compiler_flags_test])
|
|
Packit |
712bc5 |
])
|
|
Packit |
712bc5 |
done
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
AC_LANG_POP([C])
|
|
Packit |
712bc5 |
|
|
Packit |
712bc5 |
# Substitute the variables
|
|
Packit |
712bc5 |
AC_SUBST(ax_warn_cflags_variable)
|
|
Packit |
712bc5 |
])dnl AX_COMPILER_FLAGS
|