Fix special readline functions after and/or

Here we needed to handle self-insert immediately, but we ended up
returning it.

Fixes #9051
This commit is contained in:
Fabian Boehm 2022-07-02 09:23:11 +02:00
parent 98ba66ed8e
commit d920610f96
2 changed files with 14 additions and 4 deletions

View File

@ -752,12 +752,12 @@ char_event_t inputter_t::read_char(const command_handler_t &command_handler) {
}
case readline_cmd_t::func_and:
case readline_cmd_t::func_or: {
// If previous function has right status, we keep reading tokens
// If previous function has correct status, we keep reading tokens
if (evt.get_readline() == readline_cmd_t::func_and) {
if (function_status_) return readch();
// Don't return immediately, we might need to handle it here - like self-insert.
if (function_status_) continue;
} else {
assert(evt.get_readline() == readline_cmd_t::func_or);
if (!function_status_) return readch();
if (!function_status_) continue;
}
// Else we flush remaining tokens
do {

View File

@ -292,6 +292,16 @@ send("echo git@github.com:fish-shell/fish-shell")
send("\x17\x17\x17\r")
expect_prompt("git@", unmatched="ctrl-w does not stop at @")
sendline("abbr --add foo 'echo foonanana'")
expect_prompt()
sendline("bind ' ' expand-abbr or self-insert")
expect_prompt()
send("foo ")
expect_str("echo foonanana")
send(" banana\r")
expect_str(" banana\r")
expect_prompt("foonanana banana")
# Ensure that nul can be bound properly (#3189).
send("bind -k nul 'echo nul seen'\r")
expect_prompt()