summaryrefslogtreecommitdiffstats
path: root/m4
diff options
context:
space:
mode:
authorKarel Zak2012-07-16 17:14:04 +0200
committerKarel Zak2012-07-16 17:14:04 +0200
commit55eec264cc21771b85159a24cfd0c85c2e15ccc0 (patch)
treea31e76a8a0800beaf2002853c1f0d61c2daf89b7 /m4
parentbuild-sys: add UL_PROG_CLANG function, rename warnings.m4 -> compiler.m4 (diff)
downloadkernel-qcow2-util-linux-55eec264cc21771b85159a24cfd0c85c2e15ccc0.tar.gz
kernel-qcow2-util-linux-55eec264cc21771b85159a24cfd0c85c2e15ccc0.tar.xz
kernel-qcow2-util-linux-55eec264cc21771b85159a24cfd0c85c2e15ccc0.zip
build-sys: add exclude list to UL_ADD_WARN
Signed-off-by: Karel Zak <kzak@redhat.com>
Diffstat (limited to 'm4')
-rw-r--r--m4/compiler.m461
1 files changed, 41 insertions, 20 deletions
diff --git a/m4/compiler.m4 b/m4/compiler.m4
index 02e7af22a..cbd406f58 100644
--- a/m4/compiler.m4
+++ b/m4/compiler.m4
@@ -14,32 +14,53 @@ m4_ifdef([AS_VAR_APPEND],
[m4_define([UL_AS_VAR_APPEND],
[AS_VAR_SET([$1], [AS_VAR_GET([$1])$2])])])
-# UL_WARN_ADD(PARAMETER, [VARIABLE = WARN_CFLAGS])
-# ------------------------------------------------
-# Adds parameter to WARN_CFLAGS if the compiler supports it. For example,
-# UL_WARN_ADD([-Wparentheses]).
-AC_DEFUN([UL_WARN_ADD],
-dnl FIXME: ul_Warn must be used unquoted until we can assume
-dnl autoconf 2.64 or newer.
-[AS_VAR_PUSHDEF([ul_Warn], [ul_cv_warn_$1])dnl
-AC_CACHE_CHECK([whether compiler handles $1], m4_defn([ul_Warn]), [
- ul_save_CPPFLAGS="$CPPFLAGS"
- CPPFLAGS="${CPPFLAGS} $1"
- AC_PREPROC_IFELSE([AC_LANG_PROGRAM([])],
- [AS_VAR_SET(ul_Warn, [yes])],
- [AS_VAR_SET(ul_Warn, [no])])
- CPPFLAGS="$ul_save_CPPFLAGS"
+#
+# Adds parameter to WARN_CFLAGS if the compiler supports it.
+#
+AC_DEFUN([UL_ADD_WARN_CFLAG], [
+ AS_VAR_PUSHDEF([ul_Warn], [ul_cv_warn_$1])dnl
+ AC_CACHE_CHECK([whether compiler handles $1], m4_defn([ul_Warn]), [
+ ul_save_CPPFLAGS="$CPPFLAGS"
+ CPPFLAGS="${CPPFLAGS} $1"
+ AC_PREPROC_IFELSE([AC_LANG_PROGRAM([])],
+ [AS_VAR_SET(ul_Warn, [yes])],
+ [AS_VAR_SET(ul_Warn, [no])])
+ CPPFLAGS="$ul_save_CPPFLAGS"
+ ])
+ AS_VAR_IF(ul_Warn, [yes], [UL_AS_VAR_APPEND([WARN_CFLAGS], [" $1"])])
])
-AS_VAR_IF(ul_Warn, [yes],
- [UL_AS_VAR_APPEND(m4_if([$2], [], [[WARN_CFLAGS]], [[$2]]), [" $1"])])
-AS_VAR_POPDEF([ul_Warn])dnl
-m4_ifval([$2], [AS_LITERAL_IF([$2], [AC_SUBST([$2])], [])])dnl
+
+# UL_WARN_ADD(PARAMETER, [EXCLUDE_CC_LIST])
+# -----------------------------------------
+# Adds parameter to WARN_CFLAGS if the compiler supports it. Ignore the
+# parameter if compiler is in exclude list.
+AC_DEFUN([UL_WARN_ADD], [
+m4_ifval([$2], [
+ warn_exclude="$2"
+ case $compiler_clang in
+ yes) warn_cc=clang ;;
+ *) warn_cc=$CC ;;
+ esac
+ case ${warn_exclude} in
+ *${warn_cc}*)
+ AC_MSG_CHECKING([whether compiler handles $1])
+ AC_MSG_RESULT([excluded])
+ ;;
+ *)
+ UL_ADD_WARN_CFLAG([$1])
+ ;;
+ esac],
+ [UL_ADD_WARN_CFLAG([$1])])
])
# UL_PROG_CLANG
# -------------
-# Checks if compiler is clang, defines compiler_clang=yes if yes
+# Checks if compiler is clang, defines compiler_clang=yes if yes.
+#
+# Note that generic CC variable is not modified by this function. It's
+# possible that CC is set to 'cc' and the file /usr/bin/cc is a symlink to
+# /usr/bin/clang, then compiler_clang is also set ot 'yes'.
AC_DEFUN([UL_PROG_CLANG], [
AC_REQUIRE([AC_PROG_CC])
AC_CACHE_CHECK([whether clang is in use], [ul_cv_clang], [