From: lostd Date: Wed, 22 Oct 2014 14:02:15 +0000 (+0300) Subject: Add xdirname() again and give dirname(3) another chance X-Git-Tag: v1.0~92^2~173 X-Git-Url: http://www.git.stargrave.org/?a=commitdiff_plain;h=36cf4136b5ec5ddc1e84b426e1992b599efbe6ae;p=nnn.git Add xdirname() again and give dirname(3) another chance --- diff --git a/noice.c b/noice.c index 7a6d6751..e804e686 100644 --- a/noice.c +++ b/noice.c @@ -118,6 +118,25 @@ xrealpath(const char *path) return p; } +char * +xdirname(const char *path) +{ + char *p, *tmp; + + /* Some implementations of dirname(3) may modify `path' and some + * return a pointer inside `path` and we cannot free(3) the + * original string if we lose track of it. */ + tmp = xstrdup(path); + p = dirname(tmp); + free(tmp); + if (p == NULL) + printerr(1, "dirname"); + + /* Make sure this is a malloc(3)-ed string */ + p = xstrdup(p); + return p; +} + void spawn(const char *file, const char *arg) { @@ -532,7 +551,7 @@ nochange: if (strcmp(path, "/") == 0) { goto nochange; } else { - dir = dirname(path); + dir = xdirname(path); tmp = xmalloc(strlen(dir) + 1); strlcpy(tmp, dir, strlen(dir) + 1); free(path);