mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-03 16:48:45 +00:00
Fix directory highlighting with custom CDPATH
Reproduce: `set CDPATH . /usr; mkdir foo` Then type "cd foo" and notice that foo is highlighted incorrectly, because there is no /usr/foo.
This commit is contained in:
parent
356b35e446
commit
64a89f882d
1 changed files with 5 additions and 11 deletions
|
@ -212,7 +212,6 @@ bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_l
|
||||||
const bool require_dir = static_cast<bool>(flags & PATH_REQUIRE_DIR);
|
const bool require_dir = static_cast<bool>(flags & PATH_REQUIRE_DIR);
|
||||||
wcstring clean_potential_path_fragment;
|
wcstring clean_potential_path_fragment;
|
||||||
int has_magic = 0;
|
int has_magic = 0;
|
||||||
bool result = false;
|
|
||||||
|
|
||||||
wcstring path_with_magic(potential_path_fragment);
|
wcstring path_with_magic(potential_path_fragment);
|
||||||
if (flags & PATH_EXPAND_TILDE) expand_tilde(path_with_magic, ctx.vars);
|
if (flags & PATH_EXPAND_TILDE) expand_tilde(path_with_magic, ctx.vars);
|
||||||
|
@ -242,7 +241,7 @@ bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_l
|
||||||
}
|
}
|
||||||
|
|
||||||
if (has_magic || clean_potential_path_fragment.empty()) {
|
if (has_magic || clean_potential_path_fragment.empty()) {
|
||||||
return result;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't test the same path multiple times, which can happen if the path is absolute and the
|
// Don't test the same path multiple times, which can happen if the path is absolute and the
|
||||||
|
@ -265,7 +264,7 @@ bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_l
|
||||||
if (must_be_full_dir) {
|
if (must_be_full_dir) {
|
||||||
struct stat buf;
|
struct stat buf;
|
||||||
if (0 == wstat(abs_path, &buf) && S_ISDIR(buf.st_mode)) {
|
if (0 == wstat(abs_path, &buf) && S_ISDIR(buf.st_mode)) {
|
||||||
result = true;
|
return true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// We do not end with a slash; it does not have to be a directory.
|
// We do not end with a slash; it does not have to be a directory.
|
||||||
|
@ -274,7 +273,7 @@ bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_l
|
||||||
const wcstring filename_fragment = wbasename(abs_path);
|
const wcstring filename_fragment = wbasename(abs_path);
|
||||||
if (dir_name == L"/" && filename_fragment == L"/") {
|
if (dir_name == L"/" && filename_fragment == L"/") {
|
||||||
// cd ///.... No autosuggestion.
|
// cd ///.... No autosuggestion.
|
||||||
result = true;
|
return true;;
|
||||||
} else if ((dir = wopendir(dir_name))) {
|
} else if ((dir = wopendir(dir_name))) {
|
||||||
cleanup_t cleanup_dir([&] { closedir(dir); });
|
cleanup_t cleanup_dir([&] { closedir(dir); });
|
||||||
|
|
||||||
|
@ -282,8 +281,6 @@ bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_l
|
||||||
const bool do_case_insensitive =
|
const bool do_case_insensitive =
|
||||||
fs_is_case_insensitive(dir_name, dirfd(dir), case_sensitivity_cache);
|
fs_is_case_insensitive(dir_name, dirfd(dir), case_sensitivity_cache);
|
||||||
|
|
||||||
wcstring matched_file;
|
|
||||||
|
|
||||||
// We opened the dir_name; look for a string where the base name prefixes it Don't
|
// We opened the dir_name; look for a string where the base name prefixes it Don't
|
||||||
// ask for the is_dir value unless we care, because it can cause extra filesystem
|
// ask for the is_dir value unless we care, because it can cause extra filesystem
|
||||||
// access.
|
// access.
|
||||||
|
@ -300,17 +297,14 @@ bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_l
|
||||||
if (string_prefixes_string(filename_fragment, ent) ||
|
if (string_prefixes_string(filename_fragment, ent) ||
|
||||||
(do_case_insensitive &&
|
(do_case_insensitive &&
|
||||||
string_prefixes_string_case_insensitive(filename_fragment, ent))) {
|
string_prefixes_string_case_insensitive(filename_fragment, ent))) {
|
||||||
matched_file = ent; // we matched
|
return true;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
result = !matched_file.empty(); // we succeeded if we found a match
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Given a string, return whether it prefixes a path that we could cd into. Return that path in
|
// Given a string, return whether it prefixes a path that we could cd into. Return that path in
|
||||||
|
|
Loading…
Reference in a new issue