summaryrefslogtreecommitdiff
path: root/source3/popt/findme.c
diff options
context:
space:
mode:
authorJames Peach <jpeach@samba.org>2006-05-17 00:04:09 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 11:17:05 -0500
commitdc64af1d2ee478254b57c323795736e85d2aed92 (patch)
treee7e72773994ce1309ff42a6dd32c6670b002bd0b /source3/popt/findme.c
parentf81e4521bf9408754a9873646fd7e911d968b4e1 (diff)
downloadsamba-dc64af1d2ee478254b57c323795736e85d2aed92.tar.gz
samba-dc64af1d2ee478254b57c323795736e85d2aed92.tar.bz2
samba-dc64af1d2ee478254b57c323795736e85d2aed92.zip
r15654: Update our internal copy of popt to that distributed with the RPM 4.2
source code. (This used to be commit 9559886a92b1fdd33d380bf0100dcddb12477ff2)
Diffstat (limited to 'source3/popt/findme.c')
-rw-r--r--source3/popt/findme.c30
1 files changed, 17 insertions, 13 deletions
diff --git a/source3/popt/findme.c b/source3/popt/findme.c
index f2ad05bb3f..a950e50018 100644
--- a/source3/popt/findme.c
+++ b/source3/popt/findme.c
@@ -1,6 +1,10 @@
-/* (C) 1998 Red Hat Software, Inc. -- Licensing details are in the COPYING
+/** \ingroup popt
+ * \file popt/findme.c
+ */
+
+/* (C) 1998-2002 Red Hat, Inc. -- Licensing details are in the COPYING
file accompanying popt source distributions, available from
- ftp://ftp.redhat.com/pub/code/popt */
+ ftp://ftp.rpm.org/pub/rpm/dist. */
#include "system.h"
#include "findme.h"
@@ -9,38 +13,38 @@ const char * findProgramPath(const char * argv0) {
char * path = getenv("PATH");
char * pathbuf;
char * start, * chptr;
- char * buf, *local = NULL;
+ char * buf;
- /* If there is a / in the argv[0], it has to be an absolute
- path */
+ if (argv0 == NULL) return NULL; /* XXX can't happen */
+ /* If there is a / in the argv[0], it has to be an absolute path */
if (strchr(argv0, '/'))
return xstrdup(argv0);
- if (!path) return NULL;
+ if (path == NULL) return NULL;
- local = start = pathbuf = malloc(strlen(path) + 1);
- buf = malloc(strlen(path) + strlen(argv0) + 2);
+ start = pathbuf = alloca(strlen(path) + 1);
+ buf = malloc(strlen(path) + strlen(argv0) + sizeof("/"));
+ if (buf == NULL) return NULL; /* XXX can't happen */
strcpy(pathbuf, path);
chptr = NULL;
+ /*@-branchstate@*/
do {
if ((chptr = strchr(start, ':')))
*chptr = '\0';
sprintf(buf, "%s/%s", start, argv0);
- if (!access(buf, X_OK)) {
- if (local) free(local);
- return buf;
- }
+ if (!access(buf, X_OK))
+ return buf;
if (chptr)
start = chptr + 1;
else
start = NULL;
} while (start && *start);
+ /*@=branchstate@*/
free(buf);
- if (local) free(local);
return NULL;
}