mirror of
https://github.com/postgres/postgres.git
synced 2025-07-27 12:41:57 +03:00
Select appropriate PG_PRINTF_ATTRIBUTE for recent NetBSD.
NetBSD-current generates a large number of warnings about "%m" not being appropriate to use with *printf functions. While that's true for their native printf, it's surely not true for snprintf.c, so I think they have misunderstood gcc's definition of the "gnu_printf" archetype. Nonetheless, choosing "__syslog__" instead silences the warnings; so teach configure about that. Since this is only a cosmetic warning issue (and anyway it depends on previous hacking to be self-consistent), no back-patch. Discussion: https://postgr.es/m/16785.1539046036@sss.pgh.pa.us
This commit is contained in:
43
configure
vendored
43
configure
vendored
@ -13583,28 +13583,57 @@ $as_echo_n "checking for printf format archetype... " >&6; }
|
||||
if ${pgac_cv_printf_archetype+:} false; then :
|
||||
$as_echo_n "(cached) " >&6
|
||||
else
|
||||
ac_save_c_werror_flag=$ac_c_werror_flag
|
||||
pgac_cv_printf_archetype=gnu_printf
|
||||
ac_save_c_werror_flag=$ac_c_werror_flag
|
||||
ac_c_werror_flag=yes
|
||||
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||
/* end confdefs.h. */
|
||||
extern int
|
||||
pgac_write(int ignore, const char *fmt,...)
|
||||
__attribute__((format(gnu_printf, 2, 3)));
|
||||
extern void pgac_write(int ignore, const char *fmt,...)
|
||||
__attribute__((format($pgac_cv_printf_archetype, 2, 3)));
|
||||
int
|
||||
main ()
|
||||
{
|
||||
|
||||
pgac_write(0, "error %s: %m", "foo");
|
||||
;
|
||||
return 0;
|
||||
}
|
||||
_ACEOF
|
||||
if ac_fn_c_try_compile "$LINENO"; then :
|
||||
pgac_cv_printf_archetype=gnu_printf
|
||||
ac_archetype_ok=yes
|
||||
else
|
||||
pgac_cv_printf_archetype=printf
|
||||
ac_archetype_ok=no
|
||||
fi
|
||||
rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||
ac_c_werror_flag=$ac_save_c_werror_flag
|
||||
|
||||
if [ "$ac_archetype_ok" = no ]; then
|
||||
pgac_cv_printf_archetype=__syslog__
|
||||
ac_save_c_werror_flag=$ac_c_werror_flag
|
||||
ac_c_werror_flag=yes
|
||||
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||
/* end confdefs.h. */
|
||||
extern void pgac_write(int ignore, const char *fmt,...)
|
||||
__attribute__((format($pgac_cv_printf_archetype, 2, 3)));
|
||||
int
|
||||
main ()
|
||||
{
|
||||
pgac_write(0, "error %s: %m", "foo");
|
||||
;
|
||||
return 0;
|
||||
}
|
||||
_ACEOF
|
||||
if ac_fn_c_try_compile "$LINENO"; then :
|
||||
ac_archetype_ok=yes
|
||||
else
|
||||
ac_archetype_ok=no
|
||||
fi
|
||||
rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||
ac_c_werror_flag=$ac_save_c_werror_flag
|
||||
|
||||
if [ "$ac_archetype_ok" = no ]; then
|
||||
pgac_cv_printf_archetype=printf
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $pgac_cv_printf_archetype" >&5
|
||||
$as_echo "$pgac_cv_printf_archetype" >&6; }
|
||||
|
Reference in New Issue
Block a user