postgresql/src/port
Andres Freund 76e38b37a5 windows: Only consider us to be running as service if stderr is invalid.
Previously pgwin32_is_service() would falsely return true when postgres is
started from somewhere within a service, but not as a service. That is
e.g. always the case with windows docker containers, which some CI services
use to run windows tests in.

When postgres falsely thinks its running as a service, no messages are
writting to stdout / stderr. That can be very confusing and causes a few tests
to fail.

To fix additionally check if stderr is invalid in pgwin32_is_service(). For
that to work in backend processes, pg_ctl is changed to pass down handles so
that postgres can do the same check (otherwise "default" handles are created).

While this problem exists in all branches, there have been no reports by
users, the prospective CI usage currently is only for master, and I am not a
windows expert. So doing the change in only master for now seems the sanest
approach.

Author: Andres Freund <andres@anarazel.de>
Reviewed-By: Magnus Hagander <magnus@hagander.net>
Discussion: https://postgr.es/m/20210305185752.3up5eq2eanb7ofmb@alap3.anarazel.de
2021-09-07 11:56:13 -07:00
..
.gitignore Build src/port files as a library with -fPIC, and use that in libpq. 2018-09-27 11:23:43 -04:00
Makefile Move bsearch_arg to src/port 2021-03-23 00:11:22 +01:00
README AIX: Fix missing libpq symbols by respecting SHLIB_EXPORTS. 2021-09-06 11:27:59 -07:00
bsearch_arg.c Fix typos and grammar in comments and docs 2021-04-19 11:32:30 +09:00
chklocale.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
dirent.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
dirmod.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
dlopen.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
erand48.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
explicit_bzero.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
fls.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
getaddrinfo.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
getopt.c Use our own getopt() on OpenBSD. 2019-01-18 15:06:26 -05:00
getopt_long.c Fix our getopt_long's behavior for a command line argument of just "-". 2020-03-23 11:58:00 -04:00
getpeereid.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
getrusage.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
gettimeofday.c Clean up newlines following left parentheses 2020-01-30 13:42:14 -03:00
inet_aton.c Correct include file name in inet_aton fallback. 2017-10-01 17:41:00 -07:00
inet_net_ntop.c Avoid conflicts with library versions of inet_net_ntop() and friends. 2019-08-18 19:27:23 -04:00
kill.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
link.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
mkdtemp.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
noblock.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
open.c Revert "Fix issues with Windows' stat() for files pending on deletion" 2021-07-12 14:46:08 +09:00
path.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pg_bitutils.c Use direct function calls for pg_popcount{32,64} on non-x86 platforms 2021-08-16 11:51:15 -04:00
pg_crc32c_armv8.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pg_crc32c_armv8_choose.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pg_crc32c_sb8.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pg_crc32c_sse42.c pg_attribute_no_sanitize_alignment() macro 2021-02-12 17:23:35 +03:00
pg_crc32c_sse42_choose.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pg_strong_random.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pgcheckdir.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pgmkdirp.c Fix various typos and grammar errors in comments. 2015-04-26 18:42:31 +02:00
pgsleep.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pgstrcasecmp.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pgstrsignal.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pqsignal.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
pread.c Move our p{read,write}v replacements into their own files. 2021-01-14 11:16:59 +13:00
preadv.c Initial pgindent and pgperltidy run for v14. 2021-05-12 13:14:10 -04:00
pthread-win32.h Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
pthread_barrier_wait.c Fix error handling in replacement pthread_barrier_init(). 2021-06-01 11:31:06 +12:00
pwrite.c Move our p{read,write}v replacements into their own files. 2021-01-14 11:16:59 +13:00
pwritev.c Move our p{read,write}v replacements into their own files. 2021-01-14 11:16:59 +13:00
qsort.c Use sort_template.h for qsort() and qsort_arg(). 2021-03-03 17:02:32 +13:00
qsort_arg.c Use sort_template.h for qsort() and qsort_arg(). 2021-03-03 17:02:32 +13:00
quotes.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
random.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
setenv.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
snprintf.c Make printf("%s", NULL) print "(null)" instead of crashing. 2021-07-24 13:41:17 -04:00
srandom.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
strerror.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
strlcat.c pgindent run for 9.4 2014-05-06 12:12:18 -04:00
strlcpy.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
strnlen.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
strtof.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
system.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
tar.c Make the order of the header file includes consistent in non-backend modules. 2019-10-25 07:41:52 +05:30
thread.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
unsetenv.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
win32.ico Revert binary change in copyright year adjustment. 2012-01-01 19:40:13 -05:00
win32env.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
win32error.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
win32security.c windows: Only consider us to be running as service if stderr is invalid. 2021-09-07 11:56:13 -07:00
win32setlocale.c Update copyright for 2021 2021-01-02 13:06:25 -05:00
win32stat.c Revert "Fix issues with Windows' stat() for files pending on deletion" 2021-07-12 14:46:08 +09:00
win32ver.rc Update copyright for 2021 2021-01-02 13:06:25 -05:00

README

src/port/README

libpgport
=========

libpgport must have special behavior.  It supplies functions to both
libraries and applications.  However, there are two complexities:

1)  Libraries need to use object files that are compiled with exactly
the same flags as the library.  libpgport might not use the same flags,
so it is necessary to recompile the object files for individual
libraries.  This is done by removing -lpgport from the link line:

        # Need to recompile any libpgport object files
        LIBS := $(filter-out -lpgport, $(LIBS))

and adding infrastructure to recompile the object files:

        OBJS= execute.o typename.o descriptor.o data.o error.o prepare.o memory.o \
                connect.o misc.o path.o exec.o \
                $(filter strlcat.o, $(LIBOBJS))

The problem is that there is no testing of which object files need to be
added, but missing functions usually show up when linking user
applications.

2) For applications, we use -lpgport before -lpq, so the static files
from libpgport are linked first.  This avoids having applications
dependent on symbols that are _used_ by libpq, but not intended to be
exported by libpq.  libpq's libpgport usage changes over time, so such a
dependency is a problem.  Windows, Linux, AIX, and macOS use an export
list to control the symbols exported by libpq.