mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 05:28:49 +00:00
Stop passing NULL for realpath()'s second param
macOS 10.5 and earlier do not support the convention of returning a dynamically allocated string, plus this seems like an unnecessary malloc. Always allocate a buffer for realpath() to write into.
This commit is contained in:
parent
639faf1c7f
commit
05c0cb713d
1 changed files with 6 additions and 12 deletions
|
@ -350,7 +350,8 @@ wchar_t *wrealpath(const wcstring &pathname, wchar_t *resolved_path) {
|
||||||
narrow_path.erase(narrow_path.size() - 1, 1);
|
narrow_path.erase(narrow_path.size() - 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *narrow_res = realpath(narrow_path.c_str(), NULL);
|
char tmpbuf[PATH_MAX];
|
||||||
|
char *narrow_res = realpath(narrow_path.c_str(), tmpbuf);
|
||||||
if (narrow_res) {
|
if (narrow_res) {
|
||||||
real_path.append(narrow_res);
|
real_path.append(narrow_res);
|
||||||
} else {
|
} else {
|
||||||
|
@ -360,14 +361,15 @@ wchar_t *wrealpath(const wcstring &pathname, wchar_t *resolved_path) {
|
||||||
// single path component and thus doesn't need conversion.
|
// single path component and thus doesn't need conversion.
|
||||||
real_path = narrow_path;
|
real_path = narrow_path;
|
||||||
} else {
|
} else {
|
||||||
|
char tmpbuff[PATH_MAX];
|
||||||
if (pathsep_idx == cstring::npos) {
|
if (pathsep_idx == cstring::npos) {
|
||||||
// No pathsep means a single path component relative to pwd.
|
// No pathsep means a single path component relative to pwd.
|
||||||
narrow_res = realpath(".", NULL);
|
narrow_res = realpath(".", tmpbuff);
|
||||||
assert(narrow_res != NULL);
|
assert(narrow_res != NULL && "realpath unexpectedly returned null");
|
||||||
pathsep_idx = 0;
|
pathsep_idx = 0;
|
||||||
} else {
|
} else {
|
||||||
// Only call realpath() on the portion up to the last component.
|
// Only call realpath() on the portion up to the last component.
|
||||||
narrow_res = realpath(narrow_path.substr(0, pathsep_idx).c_str(), NULL);
|
narrow_res = realpath(narrow_path.substr(0, pathsep_idx).c_str(), tmpbuff);
|
||||||
if (!narrow_res) return NULL;
|
if (!narrow_res) return NULL;
|
||||||
pathsep_idx++;
|
pathsep_idx++;
|
||||||
}
|
}
|
||||||
|
@ -377,14 +379,6 @@ wchar_t *wrealpath(const wcstring &pathname, wchar_t *resolved_path) {
|
||||||
real_path.append(narrow_path.substr(pathsep_idx, cstring::npos));
|
real_path.append(narrow_path.substr(pathsep_idx, cstring::npos));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if __APPLE__ && __DARWIN_C_LEVEL < 200809L
|
|
||||||
// OS X Snow Leopard is broken with respect to the dynamically allocated buffer returned by
|
|
||||||
// realpath(). It's not dynamically allocated so attempting to free that buffer triggers a
|
|
||||||
// malloc/free error. Thus we don't attempt the free in this case.
|
|
||||||
#else
|
|
||||||
free(narrow_res);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
wcstring wreal_path = str2wcstring(real_path);
|
wcstring wreal_path = str2wcstring(real_path);
|
||||||
if (resolved_path) {
|
if (resolved_path) {
|
||||||
wcslcpy(resolved_path, wreal_path.c_str(), PATH_MAX);
|
wcslcpy(resolved_path, wreal_path.c_str(), PATH_MAX);
|
||||||
|
|
Loading…
Reference in a new issue