vim: fix dtx when x is immediately to the right

This commit is contained in:
Brian Strauch 2024-01-26 16:58:48 -08:00
parent 5db7e8f89e
commit f369e9a48b
2 changed files with 18 additions and 8 deletions

View file

@ -434,10 +434,13 @@ impl Motion {
SelectionGoal::None, SelectionGoal::None,
), ),
Matching => (matching(map, point), SelectionGoal::None), Matching => (matching(map, point), SelectionGoal::None),
FindForward { before, char } => ( FindForward { before, char } => {
find_forward(map, point, *before, *char, times), if let Some(new_point) = find_forward(map, point, *before, *char, times) {
SelectionGoal::None, return Some((new_point, SelectionGoal::None));
), } else {
return None;
}
}
FindBackward { after, char } => ( FindBackward { after, char } => (
find_backward(map, point, *after, *char, times), find_backward(map, point, *after, *char, times),
SelectionGoal::None, SelectionGoal::None,
@ -882,7 +885,7 @@ fn find_forward(
before: bool, before: bool,
target: char, target: char,
times: usize, times: usize,
) -> DisplayPoint { ) -> Option<DisplayPoint> {
let mut to = from; let mut to = from;
let mut found = false; let mut found = false;
@ -897,12 +900,12 @@ fn find_forward(
if found { if found {
if before && to.column() > 0 { if before && to.column() > 0 {
*to.column_mut() -= 1; *to.column_mut() -= 1;
map.clip_point(to, Bias::Left) Some(map.clip_point(to, Bias::Left))
} else { } else {
to Some(to)
} }
} else { } else {
from None
} }
} }

View file

@ -472,4 +472,11 @@ mod test {
the ˇlazy dog"}) the ˇlazy dog"})
.await; .await;
} }
#[gpui::test]
async fn test_delete_to_adjacent_character(cx: &mut gpui::TestAppContext) {
let mut cx = NeovimBackedTestContext::new(cx).await;
cx.assert_neovim_compatible("ˇax", ["d", "t", "x"]).await;
cx.assert_neovim_compatible("aˇx", ["d", "t", "x"]).await;
}
} }