Remove support for Unix systems without the POSIX signal APIs.
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 31 Aug 2015 16:55:59 +0000 (12:55 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 31 Aug 2015 16:56:10 +0000 (12:56 -0400)
commita65e086453e0dea5cdd7f9fe9dc6c34d8bfc0f2c
tree0d84406b458a305c86098816345d2a48c1d5a9d7
parent8f7d044ba842ab3359a8a3190ff2f3aa1de2a6bb
Remove support for Unix systems without the POSIX signal APIs.

Remove configure's checks for HAVE_POSIX_SIGNALS, HAVE_SIGPROCMASK, and
HAVE_SIGSETJMP.  These APIs are required by the Single Unix Spec v2
(POSIX 1997), which we generally consider to define our minimum required
set of Unix APIs.  Moreover, no buildfarm member has reported not having
them since 2012 or before, which means that even if the code is still live
somewhere, it's untested --- and we've made plenty of signal-handling
changes of late.  So just take these APIs as given and save the cycles for
configure probes for them.

However, we can't remove as much C code as I'd hoped, because the Windows
port evidently still uses the non-POSIX code paths for signal masking.
Since we're largely emulating these BSD-style APIs for Windows anyway, it
might be a good thing to switch over to POSIX-like notation and thereby
remove a few more #ifdefs.  But I'm not in a position to code or test that.
In the meantime, we can at least make things a bit more transparent by
testing for WIN32 explicitly in these places.
config/c-library.m4
configure
configure.in
src/Makefile.global.in
src/backend/libpq/pqsignal.c
src/include/c.h
src/include/libpq/pqsignal.h
src/include/pg_config.h.in
src/include/pg_config.h.win32
src/makefiles/Makefile.hpux
src/port/pqsignal.c