mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-28 12:45:13 +00:00
realpath: Use physical PWD
This was an inadvertent change from
cc632d6ae9
.
Because we used wgetcwd directly before, we always got the "physical"
resolved $PWD.
There's an argument to be made to use the logical $PWD here as well
but I prefer not to make changes lik that in a random commit without
good reason.
This commit is contained in:
parent
5dfb64b547
commit
407a455cfd
2 changed files with 20 additions and 1 deletions
|
@ -101,7 +101,13 @@ maybe_t<int> builtin_realpath(parser_t &parser, io_streams_t &streams, const wch
|
||||||
return STATUS_CMD_ERROR;
|
return STATUS_CMD_ERROR;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
wcstring absolute_arg = string_prefixes_string(L"/", arg) ? arg : path_apply_working_directory(arg, parser.vars().get_pwd_slash());
|
// We need to get the *physical* pwd here.
|
||||||
|
auto realpwd = wrealpath(parser.vars().get_pwd_slash());
|
||||||
|
if (!realpwd) {
|
||||||
|
streams.err.append_format(L"builtin %ls: realpath failed: %s\n", cmd, std::strerror(errno));
|
||||||
|
return STATUS_CMD_ERROR;
|
||||||
|
}
|
||||||
|
wcstring absolute_arg = string_prefixes_string(L"/", arg) ? arg : path_apply_working_directory(arg, *realpwd);
|
||||||
streams.out.append(normalize_path(absolute_arg, /* allow leading double slashes */ false));
|
streams.out.append(normalize_path(absolute_arg, /* allow leading double slashes */ false));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -72,6 +72,19 @@ else
|
||||||
echo "fish-symlink not handled correctly: $real_path != $expected_real_path" >&2
|
echo "fish-symlink not handled correctly: $real_path != $expected_real_path" >&2
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# But the $PWD is still resolved
|
||||||
|
set -l oldpwd $PWD
|
||||||
|
cd $XDG_DATA_HOME/fish-symlink
|
||||||
|
set -l real_path (builtin realpath -s $data_home_realpath/fish-symlink)
|
||||||
|
set -l expected_real_path "$data_home_realpath/fish-symlink"
|
||||||
|
if test "$real_path" = "$expected_real_path"
|
||||||
|
echo "fish-symlink handled correctly"
|
||||||
|
# CHECK: fish-symlink handled correctly
|
||||||
|
else
|
||||||
|
echo "fish-symlink not handled correctly: $real_path != $expected_real_path" >&2
|
||||||
|
end
|
||||||
|
cd $oldpwd
|
||||||
|
|
||||||
set -l real_path (builtin realpath -s .)
|
set -l real_path (builtin realpath -s .)
|
||||||
set -l expected_real_path (pwd -P) # Physical working directory.
|
set -l expected_real_path (pwd -P) # Physical working directory.
|
||||||
if test "$real_path" = "$expected_real_path"
|
if test "$real_path" = "$expected_real_path"
|
||||||
|
|
Loading…
Reference in a new issue