Fix "quiet inline" configure test for newer clang compilers.
This test used to just define an unused static inline function and check whether that causes a warning. But newer clang versions warn about unused static inline functions when defined inside a .c file, but not when defined in an included header, which is the case we care about. Change the test to cope. Andres Freund
This commit is contained in:
parent
3f8c8e3c61
commit
4c8aa8b5ae
@ -19,7 +19,18 @@ fi])# PGAC_C_SIGNED
|
|||||||
|
|
||||||
# PGAC_C_INLINE
|
# PGAC_C_INLINE
|
||||||
# -------------
|
# -------------
|
||||||
# Check if the C compiler understands inline functions.
|
# Check if the C compiler understands inline functions without being
|
||||||
|
# noisy about unused static inline functions. Some older compilers
|
||||||
|
# understand inline functions (as tested by AC_C_INLINE) but warn about
|
||||||
|
# them if they aren't used in a translation unit.
|
||||||
|
#
|
||||||
|
# This test used to just define an inline function, but some compilers
|
||||||
|
# (notably clang) got too smart and now warn about unused static
|
||||||
|
# inline functions when defined inside a .c file, but not when defined
|
||||||
|
# in an included header. Since the latter is what we want to use, test
|
||||||
|
# to see if the warning appears when the function is in a header file.
|
||||||
|
# Not pretty, but it works.
|
||||||
|
#
|
||||||
# Defines: inline, PG_USE_INLINE
|
# Defines: inline, PG_USE_INLINE
|
||||||
AC_DEFUN([PGAC_C_INLINE],
|
AC_DEFUN([PGAC_C_INLINE],
|
||||||
[AC_C_INLINE
|
[AC_C_INLINE
|
||||||
@ -28,7 +39,7 @@ AC_CACHE_CHECK([for quiet inline (no complaint if unreferenced)], pgac_cv_c_inli
|
|||||||
if test "$ac_cv_c_inline" != no; then
|
if test "$ac_cv_c_inline" != no; then
|
||||||
pgac_c_inline_save_werror=$ac_c_werror_flag
|
pgac_c_inline_save_werror=$ac_c_werror_flag
|
||||||
ac_c_werror_flag=yes
|
ac_c_werror_flag=yes
|
||||||
AC_LINK_IFELSE([AC_LANG_PROGRAM([static inline int fun () {return 0;}],[])],
|
AC_LINK_IFELSE([AC_LANG_PROGRAM([#include "$srcdir/config/test_quiet_include.h"],[])],
|
||||||
[pgac_cv_c_inline_quietly=yes])
|
[pgac_cv_c_inline_quietly=yes])
|
||||||
ac_c_werror_flag=$pgac_c_inline_save_werror
|
ac_c_werror_flag=$pgac_c_inline_save_werror
|
||||||
fi])
|
fi])
|
||||||
|
5
config/test_quiet_include.h
Normal file
5
config/test_quiet_include.h
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
/*
|
||||||
|
* For the raison d'etre of this file, check the comment above the definition
|
||||||
|
* of the PGAC_C_INLINE macro in config/c-compiler.m4.
|
||||||
|
*/
|
||||||
|
static inline int fun () { return 0; }
|
2
configure
vendored
2
configure
vendored
@ -9725,7 +9725,7 @@ else
|
|||||||
ac_c_werror_flag=yes
|
ac_c_werror_flag=yes
|
||||||
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||||
/* end confdefs.h. */
|
/* end confdefs.h. */
|
||||||
static inline int fun () {return 0;}
|
#include "$srcdir/config/test_quiet_include.h"
|
||||||
int
|
int
|
||||||
main ()
|
main ()
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user