postgresql/src/port
Noah Misch 5f538ad004 Renovate display of non-ASCII messages on Windows.
GNU gettext selects a default encoding for the messages it emits in a
platform-specific manner; it uses the Windows ANSI code page on Windows
and follows LC_CTYPE on other platforms.  This is inconvenient for
PostgreSQL server processes, so realize consistent cross-platform
behavior by calling bind_textdomain_codeset() on Windows each time we
permanently change LC_CTYPE.  This primarily affects SQL_ASCII databases
and processes like the postmaster that do not attach to a database,
making their behavior consistent with PostgreSQL on non-Windows
platforms.  Messages from SQL_ASCII databases use the encoding implied
by the database LC_CTYPE, and messages from non-database processes use
LC_CTYPE from the postmaster system environment.  PlatformEncoding
becomes unused, so remove it.

Make write_console() prefer WriteConsoleW() to write() regardless of the
encodings in use.  In this situation, write() will invariably mishandle
non-ASCII characters.

elog.c has assumed that messages conform to the database encoding.
While usually true, this does not hold for SQL_ASCII and MULE_INTERNAL.
Introduce MessageEncoding to track the actual encoding of message text.
The present consumers are Windows-specific code for converting messages
to UTF16 for use in system interfaces.  This fixes the appearance in
Windows event logs and consoles of translated messages from SQL_ASCII
processes like the postmaster.  Note that SQL_ASCII inherently disclaims
a strong notion of encoding, so non-ASCII byte sequences interpolated
into messages by %s may yet yield a nonsensical message.  MULE_INTERNAL
has similar problems at present, albeit for a different reason: its lack
of libiconv support or a conversion to UTF8.

Consequently, one need no longer restart Windows with a different
Windows ANSI code page to broadly test backend logging under a given
language.  Changing the user's locale ("Format") is enough.  Several
accounts can simultaneously run postmasters under different locales, all
correctly logging localized messages to Windows event logs and consoles.

Alexander Law and Noah Misch
2013-06-26 11:17:33 -04:00
..
.gitignore Convert cvsignore to gitignore, and add .gitignore for build targets. 2010-09-22 12:57:04 +02:00
chklocale.c Renovate display of non-ASCII messages on Windows. 2013-06-26 11:17:33 -04:00
crypt.c pgindent run before PG 9.1 beta 1. 2011-04-10 11:42:00 -04:00
dirent.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
dirmod.c Create libpgcommon, and move pg_malloc et al to it 2013-02-12 11:21:05 -03:00
erand48.c Run pgindent on 9.2 source tree in preparation for first 9.3 2012-06-10 15:20:04 -04:00
exec.c Add support for piping COPY to/from an external program. 2013-02-27 18:22:31 +02:00
fls.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
fseeko.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
getaddrinfo.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
gethostname.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
getopt.c Pgindent run before 9.1 beta2. 2011-06-09 14:32:50 -04:00
getopt_long.c Remove optreset from src/port/ implementations of getopt and getopt_long. 2010-12-16 16:23:05 -05:00
getpeereid.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
getrusage.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
gettimeofday.c Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
inet_aton.c Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
inet_net_ntop.c Pgindent run before 9.1 beta2. 2011-06-09 14:32:50 -04:00
isinf.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
kill.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
Makefile Move pqsignal() to libpgport. 2013-03-17 12:06:42 -04:00
memcmp.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
noblock.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
open.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
path.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pg_crc.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pgcheckdir.c pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pgmkdirp.c pgindent run before PG 9.1 beta 1. 2011-04-10 11:42:00 -04:00
pgsleep.c Add a comment warning against use of pg_usleep() for long sleeps. 2013-06-23 14:43:10 -04:00
pgstrcasecmp.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pqsignal.c Use SA_RESTART for all signals, including SIGALRM. 2013-06-15 15:39:51 -04:00
pthread-win32.h Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
qsort.c Make new event trigger facility actually do something. 2012-07-20 11:39:01 -04:00
qsort_arg.c Speed up in-memory tuplesorting. 2012-02-15 12:13:32 -05:00
quotes.c Add standard file header comment to quotes.c. 2013-02-27 18:42:40 +02:00
random.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
README Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
rint.c Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
snprintf.c pgindent run before PG 9.1 beta 1. 2011-04-10 11:42:00 -04:00
sprompt.c pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
srandom.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
strerror.c Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
strlcat.c Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
strlcpy.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
tar.c Move tar function headers to pgtar.h 2013-01-02 20:34:08 +01:00
thread.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
unsetenv.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
wait_error.c pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
win32.ico Revert binary change in copyright year adjustment. 2012-01-01 19:40:13 -05:00
win32env.c Enable building with Microsoft Visual Studio 2012. 2013-02-06 14:52:29 -05:00
win32error.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
win32setlocale.c Update copyrights for 2013 2013-01-01 17:15:01 -05:00
win32ver.rc Stamp HEAD as 9.4devel. 2013-06-14 14:41:28 -04:00

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 snprintf.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.  Win32, Linux, and Darwin use an export list to
control the symbols exported by libpq.