vim: Fix r enter
indentation (#29838)
Release Notes:
- `r enter` now maintains indentation, matching vim
Useful info for this implementation can be found here:
c3f48e3a76/src/normal.c (L4865)
This commit is contained in:
parent
4b9b908233
commit
c56a1cf2b1
2 changed files with 24 additions and 3 deletions
|
@ -697,6 +697,7 @@ impl Vim {
|
|||
window: &mut Window,
|
||||
cx: &mut Context<Self>,
|
||||
) {
|
||||
let is_return_char = text == "\n".into() || text == "\r".into();
|
||||
let count = Vim::take_count(cx).unwrap_or(1);
|
||||
Vim::take_forced_motion(cx);
|
||||
self.stop_recording(cx);
|
||||
|
@ -706,7 +707,7 @@ impl Vim {
|
|||
let (map, display_selections) = editor.selections.all_display(cx);
|
||||
|
||||
let mut edits = Vec::new();
|
||||
for selection in display_selections {
|
||||
for selection in &display_selections {
|
||||
let mut range = selection.range();
|
||||
for _ in 0..count {
|
||||
let new_point = movement::saturating_right(&map, range.end);
|
||||
|
@ -719,11 +720,14 @@ impl Vim {
|
|||
edits.push((
|
||||
range.start.to_offset(&map, Bias::Left)
|
||||
..range.end.to_offset(&map, Bias::Left),
|
||||
text.repeat(count),
|
||||
))
|
||||
text.repeat(if is_return_char { 0 } else { count }),
|
||||
));
|
||||
}
|
||||
|
||||
editor.edit(edits, cx);
|
||||
if is_return_char {
|
||||
editor.newline(&editor::actions::Newline, window, cx);
|
||||
}
|
||||
editor.set_clip_at_line_ends(true, cx);
|
||||
editor.change_selections(None, window, cx, |s| {
|
||||
s.move_with(|map, selection| {
|
||||
|
@ -1710,6 +1714,14 @@ mod test {
|
|||
cx.set_shared_state("ˇhello world\n").await;
|
||||
cx.simulate_shared_keystrokes("2 0 r - ").await;
|
||||
cx.shared_state().await.assert_eq("ˇhello world\n");
|
||||
|
||||
cx.set_shared_state(" helloˇ world\n").await;
|
||||
cx.simulate_shared_keystrokes("r enter").await;
|
||||
cx.shared_state().await.assert_eq(" hello\n ˇ world\n");
|
||||
|
||||
cx.set_shared_state(" helloˇ world\n").await;
|
||||
cx.simulate_shared_keystrokes("2 r enter").await;
|
||||
cx.shared_state().await.assert_eq(" hello\n ˇ orld\n");
|
||||
}
|
||||
|
||||
#[gpui::test]
|
||||
|
|
|
@ -29,3 +29,12 @@
|
|||
{"Key":"-"}
|
||||
{"Key":""}
|
||||
{"Get":{"state":"ˇhello world\n","mode":"Normal"}}
|
||||
{"Put":{"state":" helloˇ world\n"}}
|
||||
{"Key":"r"}
|
||||
{"Key":"enter"}
|
||||
{"Get":{"state":" hello\n ˇ world\n","mode":"Normal"}}
|
||||
{"Put":{"state":" helloˇ world\n"}}
|
||||
{"Key":"2"}
|
||||
{"Key":"r"}
|
||||
{"Key":"enter"}
|
||||
{"Get":{"state":" hello\n ˇ orld\n","mode":"Normal"}}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue