summaryrefslogtreecommitdiff
path: root/config
diff options
context:
space:
mode:
authorTom Lane2018-09-26 22:23:13 +0000
committerTom Lane2018-09-26 22:23:13 +0000
commit751f532b9766fb5d3c334758abea95b7bb085c5a (patch)
tree5601ac13fba833df9c89eaa46a2026b5177748c0 /config
parent8b91d258844afa58e856ac354f9ba9745ff9ffb2 (diff)
Try another way to detect the result type of strerror_r().
The method we've traditionally used, of redeclaring strerror_r() to see if the compiler complains of inconsistent declarations, turns out not to work reliably because some compilers only report a warning, not an error. Amazingly, this has gone undetected for years, even though it certainly breaks our detection of whether strerror_r succeeded. Let's instead test whether the compiler will take the result of strerror_r() as a switch() argument. It's possible this won't work universally either, but it's the best idea I could come up with on the spur of the moment. We should probably back-patch this once the dust settles, but first let's see what the buildfarm thinks of it. Discussion: https://postgr.es/m/[email protected]
Diffstat (limited to 'config')
-rw-r--r--config/c-library.m418
1 files changed, 9 insertions, 9 deletions
diff --git a/config/c-library.m4 b/config/c-library.m4
index d371f1ba6ee..6f2b0fbb4e6 100644
--- a/config/c-library.m4
+++ b/config/c-library.m4
@@ -82,23 +82,23 @@ AH_VERBATIM(GETTIMEOFDAY_1ARG_,
# PGAC_FUNC_STRERROR_R_INT
# ---------------------------
-# Check if strerror_r() returns an int (SUSv3) rather than a char * (GNU libc)
-# If so, define STRERROR_R_INT
+# Check if strerror_r() returns int (POSIX) rather than char * (GNU libc).
+# If so, define STRERROR_R_INT.
+# The result is uncertain if strerror_r() isn't provided,
+# but we don't much care.
AC_DEFUN([PGAC_FUNC_STRERROR_R_INT],
[AC_CACHE_CHECK(whether strerror_r returns int,
pgac_cv_func_strerror_r_int,
[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <string.h>],
-[#ifndef _AIX
-int strerror_r(int, char *, size_t);
-#else
-/* Older AIX has 'int' for the third argument so we don't test the args. */
-int strerror_r();
-#endif])],
+[[char buf[100];
+ switch (strerror_r(1, buf, sizeof(buf)))
+ { case 0: break; default: break; }
+]])],
[pgac_cv_func_strerror_r_int=yes],
[pgac_cv_func_strerror_r_int=no])])
if test x"$pgac_cv_func_strerror_r_int" = xyes ; then
AC_DEFINE(STRERROR_R_INT, 1,
- [Define to 1 if strerror_r() returns a int.])
+ [Define to 1 if strerror_r() returns int.])
fi
])# PGAC_FUNC_STRERROR_R_INT