[Spice-devel] [spice-gtk] Use latest warnings.m4 from gnulib

Christophe Fergeau cfergeau at redhat.com
Thu Oct 3 05:24:42 PDT 2013


Ping ?

Christophe

On Fri, Sep 27, 2013 at 09:17:55AM +0200, Christophe Fergeau wrote:
> The one we were using does not work properly with clang, causing
> the build process to try to use -f/-W options that are not
> supported by clang.
> ---
> 
> The same patch has already been ACKed and pushed in libvirt-glib/libosinfo/...
> https://www.redhat.com/archives/libvir-list/2013-September/msg01599.html
> 
> Christophe
> 
> 
>  m4/warnings.m4 | 82 ++++++++++++++++++++++++++++++++++++++++++++--------------
>  1 file changed, 62 insertions(+), 20 deletions(-)
> 
> diff --git a/m4/warnings.m4 b/m4/warnings.m4
> index 69d05a6..e3d239b 100644
> --- a/m4/warnings.m4
> +++ b/m4/warnings.m4
> @@ -1,5 +1,5 @@
> -# warnings.m4 serial 5
> -dnl Copyright (C) 2008-2012 Free Software Foundation, Inc.
> +# warnings.m4 serial 11
> +dnl Copyright (C) 2008-2013 Free Software Foundation, Inc.
>  dnl This file is free software; the Free Software Foundation
>  dnl gives unlimited permission to copy and/or distribute it,
>  dnl with or without modifications, as long as this notice is preserved.
> @@ -14,24 +14,66 @@ m4_ifdef([AS_VAR_APPEND],
>  [m4_define([gl_AS_VAR_APPEND],
>  [AS_VAR_SET([$1], [AS_VAR_GET([$1])$2])])])
>  
> -# gl_WARN_ADD(PARAMETER, [VARIABLE = WARN_CFLAGS])
> -# ------------------------------------------------
> -# Adds parameter to WARN_CFLAGS if the compiler supports it.  For example,
> -# gl_WARN_ADD([-Wparentheses]).
> -AC_DEFUN([gl_WARN_ADD],
> -dnl FIXME: gl_Warn must be used unquoted until we can assume
> -dnl autoconf 2.64 or newer.
> -[AS_VAR_PUSHDEF([gl_Warn], [gl_cv_warn_$1])dnl
> -AC_CACHE_CHECK([whether compiler handles $1], m4_defn([gl_Warn]), [
> -  gl_save_CPPFLAGS="$CPPFLAGS"
> -  CPPFLAGS="${CPPFLAGS} $1"
> -  AC_PREPROC_IFELSE([AC_LANG_PROGRAM([])],
> -                    [AS_VAR_SET(gl_Warn, [yes])],
> -                    [AS_VAR_SET(gl_Warn, [no])])
> -  CPPFLAGS="$gl_save_CPPFLAGS"
> +
> +# gl_COMPILER_OPTION_IF(OPTION, [IF-SUPPORTED], [IF-NOT-SUPPORTED],
> +#                       [PROGRAM = AC_LANG_PROGRAM()])
> +# -----------------------------------------------------------------
> +# Check if the compiler supports OPTION when compiling PROGRAM.
> +#
> +# FIXME: gl_Warn must be used unquoted until we can assume Autoconf
> +# 2.64 or newer.
> +AC_DEFUN([gl_COMPILER_OPTION_IF],
> +[AS_VAR_PUSHDEF([gl_Warn], [gl_cv_warn_[]_AC_LANG_ABBREV[]_$1])dnl
> +AS_VAR_PUSHDEF([gl_Flags], [_AC_LANG_PREFIX[]FLAGS])dnl
> +AS_LITERAL_IF([$1],
> +  [m4_pushdef([gl_Positive], m4_bpatsubst([$1], [^-Wno-], [-W]))],
> +  [gl_positive="$1"
> +case $gl_positive in
> +  -Wno-*) gl_positive=-W`expr "X$gl_positive" : 'X-Wno-\(.*\)'` ;;
> +esac
> +m4_pushdef([gl_Positive], [$gl_positive])])dnl
> +AC_CACHE_CHECK([whether _AC_LANG compiler handles $1], m4_defn([gl_Warn]), [
> +  gl_save_compiler_FLAGS="$gl_Flags"
> +  gl_AS_VAR_APPEND(m4_defn([gl_Flags]),
> +    [" $gl_unknown_warnings_are_errors ]m4_defn([gl_Positive])["])
> +  AC_LINK_IFELSE([m4_default([$4], [AC_LANG_PROGRAM([])])],
> +                 [AS_VAR_SET(gl_Warn, [yes])],
> +                 [AS_VAR_SET(gl_Warn, [no])])
> +  gl_Flags="$gl_save_compiler_FLAGS"
>  ])
> -AS_VAR_IF(gl_Warn, [yes],
> -  [gl_AS_VAR_APPEND(m4_if([$2], [], [[WARN_CFLAGS]], [[$2]]), [" $1"])])
> +AS_VAR_IF(gl_Warn, [yes], [$2], [$3])
> +m4_popdef([gl_Positive])dnl
> +AS_VAR_POPDEF([gl_Flags])dnl
>  AS_VAR_POPDEF([gl_Warn])dnl
> -m4_ifval([$2], [AS_LITERAL_IF([$2], [AC_SUBST([$2])], [])])dnl
>  ])
> +
> +# gl_UNKNOWN_WARNINGS_ARE_ERRORS
> +# ------------------------------
> +# Clang doesn't complain about unknown warning options unless one also
> +# specifies -Wunknown-warning-option -Werror.  Detect this.
> +AC_DEFUN([gl_UNKNOWN_WARNINGS_ARE_ERRORS],
> +[gl_COMPILER_OPTION_IF([-Werror -Wunknown-warning-option],
> +   [gl_unknown_warnings_are_errors='-Wunknown-warning-option -Werror'],
> +   [gl_unknown_warnings_are_errors=])])
> +
> +# gl_WARN_ADD(OPTION, [VARIABLE = WARN_CFLAGS],
> +#             [PROGRAM = AC_LANG_PROGRAM()])
> +# ---------------------------------------------
> +# Adds parameter to WARN_CFLAGS if the compiler supports it when
> +# compiling PROGRAM.  For example, gl_WARN_ADD([-Wparentheses]).
> +#
> +# If VARIABLE is a variable name, AC_SUBST it.
> +AC_DEFUN([gl_WARN_ADD],
> +[AC_REQUIRE([gl_UNKNOWN_WARNINGS_ARE_ERRORS])
> +gl_COMPILER_OPTION_IF([$1],
> +  [gl_AS_VAR_APPEND(m4_if([$2], [], [[WARN_CFLAGS]], [[$2]]), [" $1"])],
> +  [],
> +  [$3])
> +m4_ifval([$2],
> +         [AS_LITERAL_IF([$2], [AC_SUBST([$2])])],
> +         [AC_SUBST([WARN_CFLAGS])])dnl
> +])
> +
> +# Local Variables:
> +# mode: autoconf
> +# End:
> -- 
> 1.8.3.1
> 
> _______________________________________________
> Spice-devel mailing list
> Spice-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/spice-devel
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/spice-devel/attachments/20131003/810c011b/attachment.pgp>


More information about the Spice-devel mailing list