diff options
author | James Peach <jpeach@samba.org> | 2006-05-17 00:04:09 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 11:17:05 -0500 |
commit | dc64af1d2ee478254b57c323795736e85d2aed92 (patch) | |
tree | e7e72773994ce1309ff42a6dd32c6670b002bd0b /source3/popt/findme.c | |
parent | f81e4521bf9408754a9873646fd7e911d968b4e1 (diff) | |
download | samba-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.c | 30 |
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; } |