aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2001-10-21 03:43:54 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2001-10-21 03:43:54 +0000
commit6ec5eaad3b6f69f28a529b2911c97c38dc32225a (patch)
treedca0a91b2e002cc02833c9713f129b7c573e878b
parentb2e92a712ea7316563c5115639c1e39ad6c5a09b (diff)
downloadpostgresql-6ec5eaad3b6f69f28a529b2911c97c38dc32225a.tar.gz
postgresql-6ec5eaad3b6f69f28a529b2911c97c38dc32225a.zip
Fix FindExec() for case where executable is found via a relative path
in .:/home/postgres/testversion/bin:/opt/perl5.6.1/bin:/home/postgres/bin:/usr/local/bin:/usr/bin:/opt/ansic/bin:/usr/ccs/bin:/usr/contrib/bin:/opt/nettladm/bin:/opt/pd/bin:/usr/bin/X11:/usr/contrib/bin/X11:/opt/upgrade/bin:/opt/CC/bin:/opt/langtools/bin:/opt/graphics/phigs/bin:/opt/java/bin:/bin:/opt/imake/bin:/opt/hparray/bin:/opt/aCC/bin:/opt/lrom/bin:/usr/local/nmh/bin:. (I suppose the only common case for this is '.').
-rw-r--r--src/backend/utils/init/findbe.c30
1 files changed, 10 insertions, 20 deletions
diff --git a/src/backend/utils/init/findbe.c b/src/backend/utils/init/findbe.c
index 085784d11de..01770c7e66b 100644
--- a/src/backend/utils/init/findbe.c
+++ b/src/backend/utils/init/findbe.c
@@ -7,17 +7,18 @@
*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/backend/utils/init/Attic/findbe.c,v 1.22 2001/05/09 19:28:31 momjian Exp $
+ * $Header: /cvsroot/pgsql/src/backend/utils/init/Attic/findbe.c,v 1.23 2001/10/21 03:43:54 tgl Exp $
*
*-------------------------------------------------------------------------
*/
+#include "postgres.h"
+
#include <grp.h>
#include <pwd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
-#include "postgres.h"
#include "miscadmin.h"
#ifndef S_IRUSR /* XXX [TRH] should be in a header */
@@ -32,7 +33,6 @@
#define S_IXOTH ((S_IXUSR)>>6)
#endif
-static int ValidateBinary(char *path);
/*
* ValidateBinary -- validate "path" as a POSTMASTER/POSTGRES executable file
@@ -59,14 +59,6 @@ ValidateBinary(char *path)
* XXX if you have a broken system where stat() looks at the symlink
* instead of the underlying file, you lose.
*/
- if (strlen(path) >= MAXPGPATH)
- {
- if (DebugLvl > 1)
- fprintf(stderr, "ValidateBinary: pathname \"%s\" is too long\n",
- path);
- return -1;
- }
-
if (stat(path, &buf) < 0)
{
if (DebugLvl > 1)
@@ -75,7 +67,6 @@ ValidateBinary(char *path)
return -1;
}
-
if ((buf.st_mode & S_IFMT) != S_IFREG)
{
if (DebugLvl > 1)
@@ -145,9 +136,9 @@ ValidateBinary(char *path)
* FindExec -- find an absolute path to a valid backend executable
*
* The reason we have to work so hard to find an absolute path is that
- * we need to feed the binary the location of its actual executable file,
- * otherwise, we can't do dynamic loading. It needs a full pathname because
- * we change directories to the /data directory.
+ * on some platforms we can't do dynamic loading unless we know the
+ * executable's location. Also, we need a full path not a relative
+ * path because we will later change working directory.
*/
int
FindExec(char *full_path, const char *argv0, const char *binary_name)
@@ -157,7 +148,6 @@ FindExec(char *full_path, const char *argv0, const char *binary_name)
char *path,
*startp,
*endp;
- int pathlen;
/*
* for the postmaster: First try: use the binary that's located in the
@@ -183,7 +173,7 @@ FindExec(char *full_path, const char *argv0, const char *binary_name)
strcat(buf, argv0);
p = strrchr(buf, '/');
strcpy(++p, binary_name);
- if (!ValidateBinary(buf))
+ if (ValidateBinary(buf) == 0)
{
strncpy(full_path, buf, MAXPGPATH);
if (DebugLvl)
@@ -204,9 +194,7 @@ FindExec(char *full_path, const char *argv0, const char *binary_name)
{
if (DebugLvl)
fprintf(stderr, "FindExec: searching PATH ...\n");
- pathlen = strlen(p);
- path = malloc(pathlen + 1);
- strcpy(path, p);
+ path = strdup(p); /* make a modifiable copy */
for (startp = path, endp = strchr(path, ':');
startp && *startp;
startp = endp + 1, endp = strchr(startp, ':'))
@@ -217,6 +205,8 @@ FindExec(char *full_path, const char *argv0, const char *binary_name)
*endp = '\0';
if (*startp == '/' || !getcwd(buf, MAXPGPATH))
buf[0] = '\0';
+ else
+ strcat(buf, "/");
strcat(buf, startp);
strcat(buf, "/");
strcat(buf, binary_name);