mirror of
https://github.com/jarun/nnn.git
synced 2024-11-28 05:41:31 +00:00
Avoid unneeded memory allocation in xdirname()
This commit is contained in:
parent
e27af6f1db
commit
fa6b45a96d
12
noice.c
12
noice.c
|
@ -158,21 +158,17 @@ xstrdup(const char *s)
|
|||
char *
|
||||
xdirname(const char *path)
|
||||
{
|
||||
char *p, *tmp;
|
||||
char tmp[PATH_MAX], *p;
|
||||
|
||||
/* 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);
|
||||
strlcpy(tmp, path, sizeof(tmp));
|
||||
p = dirname(tmp);
|
||||
if (p == NULL) {
|
||||
free(tmp);
|
||||
if (p == NULL)
|
||||
printerr(1, "dirname");
|
||||
}
|
||||
/* Make sure this is a malloc(3)-ed string */
|
||||
p = xstrdup(p);
|
||||
free(tmp);
|
||||
return p;
|
||||
return xstrdup(p);
|
||||
}
|
||||
|
||||
void
|
||||
|
|
Loading…
Reference in a new issue