]> granicus.if.org Git - postgresql/commit
Fix detection of the result type of strerror_r().
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 30 Sep 2018 20:24:56 +0000 (16:24 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 30 Sep 2018 20:24:56 +0000 (16:24 -0400)
commit2855421ec728ef5f871c765390ab432ffa6ec8a6
tree0bd1d4dd53222c7b4284185948e5d369a8e922de
parente315bd7db96a8cd41207cec1f036afffb282640e
Fix detection of 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.

Back-patch of commit 751f532b9.  Buildfarm results indicate that only
icc-on-Linux actually has an issue here; perhaps the lack of field
reports indicates that people don't build PG for production that way.

Discussion: https://postgr.es/m/10877.1537993279@sss.pgh.pa.us
config/c-library.m4
configure
src/include/pg_config.h.in
src/include/pg_config.h.win32