mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-28 04:35:09 +00:00
Fix caret position of invalid expansion in command position
Fixes #5812
This commit is contained in:
parent
e2952f230b
commit
f91c725ff0
4 changed files with 20 additions and 2 deletions
|
@ -753,12 +753,18 @@ parse_execution_result_t parse_execution_context_t::expand_command(
|
||||||
|
|
||||||
// Get the unexpanded command string. We expect to always get it here.
|
// Get the unexpanded command string. We expect to always get it here.
|
||||||
wcstring unexp_cmd = *command_for_plain_statement(statement, pstree->src);
|
wcstring unexp_cmd = *command_for_plain_statement(statement, pstree->src);
|
||||||
|
size_t pos_of_command_token = statement.child<0>().source_range()->start;
|
||||||
|
|
||||||
// Expand the string to produce completions, and report errors.
|
// Expand the string to produce completions, and report errors.
|
||||||
expand_result_t expand_err =
|
expand_result_t expand_err =
|
||||||
expand_to_command_and_args(unexp_cmd, parser->vars(), out_cmd, out_args, &errors);
|
expand_to_command_and_args(unexp_cmd, parser->vars(), out_cmd, out_args, &errors);
|
||||||
if (expand_err == expand_result_t::error) {
|
if (expand_err == expand_result_t::error) {
|
||||||
parser->set_last_statuses(statuses_t::just(STATUS_ILLEGAL_CMD));
|
parser->set_last_statuses(statuses_t::just(STATUS_ILLEGAL_CMD));
|
||||||
|
// Issue #5812 - the expansions were done on the command token,
|
||||||
|
// excluding prefixes such as " " or "if ".
|
||||||
|
// This means that the error positions are relative to the beginning
|
||||||
|
// of the token; we need to make them relative to the original source.
|
||||||
|
for (auto &error : errors) error.source_start += pos_of_command_token;
|
||||||
return report_errors(errors);
|
return report_errors(errors);
|
||||||
} else if (expand_err == expand_result_t::wildcard_no_match) {
|
} else if (expand_err == expand_result_t::wildcard_no_match) {
|
||||||
return report_unmatched_wildcard_error(statement);
|
return report_unmatched_wildcard_error(statement);
|
||||||
|
|
13
tests/checks/expansion.fish
Normal file
13
tests/checks/expansion.fish
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
# RUN: %fish -C 'set -g fish %fish' %s
|
||||||
|
|
||||||
|
# caret position (#5812)
|
||||||
|
printf '<%s>\n' ($fish -c ' $f[a]' 2>&1)
|
||||||
|
|
||||||
|
# CHECK: <fish: Invalid index value>
|
||||||
|
# CHECK: < $f[a]>
|
||||||
|
# CHECK: < ^>
|
||||||
|
|
||||||
|
printf '<%s>\n' ($fish -c 'if $f[a]; end' 2>&1)
|
||||||
|
# CHECK: <fish: Invalid index value>
|
||||||
|
# CHECK: <if $f[a]; end>
|
||||||
|
# CHECK: < ^>
|
|
@ -41,4 +41,4 @@ echo {}}
|
||||||
|
|
||||||
fish: Command substitutions not allowed
|
fish: Command substitutions not allowed
|
||||||
command (asd)
|
command (asd)
|
||||||
^
|
^
|
||||||
|
|
|
@ -153,6 +153,5 @@ logmsg Test fatal syntax errors
|
||||||
../test/root/bin/fish -c 'echo $,foo'
|
../test/root/bin/fish -c 'echo $,foo'
|
||||||
../test/root/bin/fish -c 'echo {'
|
../test/root/bin/fish -c 'echo {'
|
||||||
../test/root/bin/fish -c 'echo {}}'
|
../test/root/bin/fish -c 'echo {}}'
|
||||||
# The output for this is wrong in non-interactive mode and will need fixing when #5812 is fixed
|
|
||||||
../test/root/bin/fish -c 'command (asd)'
|
../test/root/bin/fish -c 'command (asd)'
|
||||||
true
|
true
|
||||||
|
|
Loading…
Reference in a new issue