postgresql/src/port
Tom Lane 8525419947 Don't try to trim "../" in join_path_components().
join_path_components() tried to remove leading ".." components from its
tail argument, but it was not nearly bright enough to do so correctly
unless the head argument was (a) absolute and (b) canonicalized.
Rather than try to fix that logic, let's just get rid of it: there is no
correctness reason to remove "..", and cosmetic concerns can be taken
care of by a subsequent canonicalize_path() call.  Per bug #6715 from
Greg Davidson.

Back-patch to all supported branches.  It appears that pre-9.2, this
function is only used with absolute paths as head arguments, which is why
we'd not noticed the breakage before.  However, third-party code might be
expecting this function to work in more general cases, so it seems wise
to back-patch.

In HEAD and 9.2, also make some minor cosmetic improvements to callers.
2012-07-05 17:16:11 -04:00
..
.gitignore Convert cvsignore to gitignore, and add .gitignore for build targets. 2010-09-22 12:57:04 +02:00
Makefile Fix dependency tracking for src/port/%_srv.o files 2012-05-08 20:10:50 +03:00
README Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
chklocale.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
crypt.c pgindent run before PG 9.1 beta 1. 2011-04-10 11:42:00 -04:00
dirent.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
dirmod.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05: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 Remove now redundant pgpipe code. 2012-03-28 23:24:07 -04:00
fls.c Run pgindent on 9.2 source tree in preparation for first 9.3 2012-06-10 15:20:04 -04:00
fseeko.c Remove BSD/OS (BSDi) port. There are no known users upgrading to 2012-05-03 10:58:44 -04:00
getaddrinfo.c Run pgindent on 9.2 source tree in preparation for first 9.3 2012-06-10 15:20:04 -04:00
gethostname.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -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 copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
getrusage.c Kill some remaining references to SVR4 and univel. 2012-05-02 00:29:17 -04: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 copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
kill.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
memcmp.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
noblock.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
open.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
path.c Don't try to trim "../" in join_path_components(). 2012-07-05 17:16:11 -04:00
pg_crc.c Move CRC tables to libpgport, and provide them in a separate include file. 2012-02-28 19:53:39 -05:00
pgcheckdir.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
pgmkdirp.c pgindent run before PG 9.1 beta 1. 2011-04-10 11:42:00 -04:00
pgsleep.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
pgstrcasecmp.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
pthread-win32.h Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
qsort.c Speed up in-memory tuplesorting. 2012-02-15 12:13:32 -05:00
qsort_arg.c Speed up in-memory tuplesorting. 2012-02-15 12:13:32 -05:00
random.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05: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 Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
srandom.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -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 copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
thread.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
unsetenv.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
win32.ico Revert binary change in copyright year adjustment. 2012-01-01 19:40:13 -05:00
win32env.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
win32error.c Update copyright notices for year 2012. 2012-01-01 18:01:58 -05:00
win32setlocale.c Run pgindent on 9.2 source tree in preparation for first 9.3 2012-06-10 15:20:04 -04:00
win32ver.rc Stamp HEAD as 9.3devel. 2012-06-13 20:03:02 -04: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 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.