postgresql/src/port
Bruce Momjian 1e22e60505 Patch of Win32 Encoding problem for server messages using
FormatMessage() (This should have been in 8.2.0, patched to 8.2.X and
HEAD):

I think this problem to be complex....
http://archives.postgresql.org/pgsql-hackers/2006-11/msg00042.php

FormatMessage of windows cannot consider the encoding of the database.
However, I should try the solution now. It is necessary to clear the
problem.

Multi character-code exists together in message and log. It doesn't
consider
the data base encoding that the user intended....

The user in multi-byte country can try this.
http://inet.winpg.jp/~saito/pg_bug/MessageCheck.c

That is, it is likely to become it in this manner.(Japanese)
http://inet.winpg.jp/~saito/pg_bug/FormatMessage998.png

Hiroshi Saito
2006-12-04 22:23:40 +00:00
..
copydir.c copydir() and rmtree() need to use lstat, not stat, to behave as expected 2006-07-18 22:36:46 +00:00
crypt.c Add CVS tag lines to files that were lacking them. 2006-03-11 04:38:42 +00:00
dirent.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
dirmod.c Patch of Win32 Encoding problem for server messages using 2006-12-04 22:23:40 +00:00
exec.c Move set_pglocale_pgservice() from path.c to exec.c, so that pulling in 2006-09-11 20:10:30 +00:00
fseeko.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
getaddrinfo.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
gethostname.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
getopt_long.c Standard pgindent run for 8.1. 2005-10-15 02:49:52 +00:00
getopt.c Add CVS tag lines to files that were lacking them. 2006-03-11 04:38:42 +00:00
getrusage.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
gettimeofday.c > gettimeofday.c:35: warning: integer constant is too large for "long" 2006-03-04 04:44:07 +00:00
inet_aton.c Prepare code to be built by MSVC: 2006-06-07 22:24:46 +00:00
isinf.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
kill.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
Makefile Add dependency to fix parallel-make race condition. Alexander Dupuy 2006-07-14 16:45:43 +00:00
memcmp.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
noblock.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
open.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
path.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
pgsleep.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
pgstrcasecmp.c Fix thinko in comment. 2006-10-07 21:48:43 +00:00
pipe.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
pthread-win32.h Move pthread-win32.h to /port, modify bcc/msvc makefiles. 2006-07-10 18:53:29 +00:00
qsort_arg.c Use Min() instead of min() in qsort, for consistency and to avoid 2006-10-12 15:04:55 +00:00
qsort.c Rename our substitute qsort to pg_qsort at the link-symbol level (but 2006-10-19 20:56:22 +00:00
rand.c
random.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
README Darin -> Darwin. 2006-04-28 04:39:41 +00:00
rint.c
snprintf.c protect vfprintf from hijacking by Windows gettext just like other members of the *printf family. 2006-11-28 01:12:34 +00:00
sprompt.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
srandom.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
strdup.c Remove separate strdup.h header file; it's redundant with port.h. 2006-09-27 15:41:24 +00:00
strerror.c
strlcpy.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
strtol.c pgindent run for 8.2. 2006-10-04 00:30:14 +00:00
strtoul.c
thread.c Replace strncpy with strlcpy in selected places that seem possibly relevant 2006-09-27 18:40:10 +00:00
unsetenv.c Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00
win32.ico
win32error.c Use Unix line endings instead of DOS ones, per Magnus. 2006-06-26 12:59:44 +00:00
win32ver.rc Update copyright for 2006. Update scripts. 2006-03-05 15:59:11 +00:00

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.