Fix regression causing alt-right to stop at autosuggestion

Fixes #10839
This commit is contained in:
Johannes Altmanninger 2024-11-14 12:20:47 +01:00
parent ca21872d14
commit 913860bd1c

View file

@ -2859,7 +2859,7 @@ impl<'a> Reader<'a> {
self.update_buff_pos(elt, Some(new_position));
}
rl::KillToken => {
let Some(new_position) = self.forward_token() else {
let Some(new_position) = self.forward_token(false) else {
return;
};
@ -2877,12 +2877,22 @@ impl<'a> Reader<'a> {
);
}
rl::ForwardToken => {
let Some(new_position) = self.forward_token() else {
let (_elt, el) = self.active_edit_line();
if self.is_at_end(el) {
let Some(new_position) = self.forward_token(true) else {
return;
};
self.accept_autosuggestion(AutosuggestionPortion::Count(
new_position - el.len(),
));
} else {
let Some(new_position) = self.forward_token(false) else {
return;
};
let (elt, _el) = self.active_edit_line();
self.update_buff_pos(elt, Some(new_position));
}
}
rl::BackwardWord | rl::BackwardBigword | rl::PrevdOrBackwardWord => {
if c == rl::PrevdOrBackwardWord && self.command_line.is_empty() {
self.eval_bind_cmd(L!("prevd"));
@ -3449,22 +3459,30 @@ impl<'a> Reader<'a> {
Some(new_position)
}
fn forward_token(&self) -> Option<usize> {
fn forward_token(&self, autosuggest: bool) -> Option<usize> {
let (_elt, el) = self.active_edit_line();
let pos = el.position();
if pos == el.len() {
let buffer = if autosuggest {
if pos > self.autosuggestion.text.len() {
return None;
}
&self.autosuggestion.text
} else {
el.text()
};
if pos == buffer.len() {
return None;
}
// If we are not in a token, look for one ahead
let buff_pos = pos
+ el.text()[pos..]
+ buffer[pos..]
.chars()
.take_while(|c| c.is_ascii_whitespace())
.count();
let mut tok = 0..0;
parse_util_token_extent(el.text(), buff_pos, &mut tok, None);
parse_util_token_extent(buffer, buff_pos, &mut tok, None);
let new_position = if tok.end == pos { pos + 1 } else { tok.end };