mirror of
https://github.com/jarun/nnn.git
synced 2024-11-24 11:51:27 +00:00
Add xdirname() again and give dirname(3) another chance
This commit is contained in:
parent
577e0284a1
commit
36cf4136b5
21
noice.c
21
noice.c
|
@ -118,6 +118,25 @@ xrealpath(const char *path)
|
||||||
return p;
|
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
|
void
|
||||||
spawn(const char *file, const char *arg)
|
spawn(const char *file, const char *arg)
|
||||||
{
|
{
|
||||||
|
@ -532,7 +551,7 @@ nochange:
|
||||||
if (strcmp(path, "/") == 0) {
|
if (strcmp(path, "/") == 0) {
|
||||||
goto nochange;
|
goto nochange;
|
||||||
} else {
|
} else {
|
||||||
dir = dirname(path);
|
dir = xdirname(path);
|
||||||
tmp = xmalloc(strlen(dir) + 1);
|
tmp = xmalloc(strlen(dir) + 1);
|
||||||
strlcpy(tmp, dir, strlen(dir) + 1);
|
strlcpy(tmp, dir, strlen(dir) + 1);
|
||||||
free(path);
|
free(path);
|
||||||
|
|
Loading…
Reference in a new issue