]> granicus.if.org Git - postgresql/commit
Try another way to detect the result type of strerror_r().
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 26 Sep 2018 22:23:13 +0000 (18:23 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 26 Sep 2018 22:23:13 +0000 (18:23 -0400)
commit751f532b9766fb5d3c334758abea95b7bb085c5a
tree5601ac13fba833df9c89eaa46a2026b5177748c0
parent8b91d258844afa58e856ac354f9ba9745ff9ffb2
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/10877.1537993279@sss.pgh.pa.us
config/c-library.m4
configure
src/include/pg_config.h.in
src/include/pg_config.h.win32