vim: Fix VisualYankLine (#22416)
Closes #22388 Release Notes: - Fixed Visual Mode Use `Y` Yank Line --------- Co-authored-by: Conrad Irwin <conrad.irwin@gmail.com>
This commit is contained in:
parent
7d0c571a8f
commit
e7ca39dfe9
3 changed files with 32 additions and 5 deletions
|
@ -259,7 +259,7 @@
|
||||||
"shift-d": "vim::VisualDeleteLine",
|
"shift-d": "vim::VisualDeleteLine",
|
||||||
"shift-x": "vim::VisualDeleteLine",
|
"shift-x": "vim::VisualDeleteLine",
|
||||||
"y": "vim::VisualYank",
|
"y": "vim::VisualYank",
|
||||||
"shift-y": "vim::VisualYank",
|
"shift-y": "vim::VisualYankLine",
|
||||||
"p": "vim::Paste",
|
"p": "vim::Paste",
|
||||||
"shift-p": ["vim::Paste", { "preserveClipboard": true }],
|
"shift-p": ["vim::Paste", { "preserveClipboard": true }],
|
||||||
"s": "vim::Substitute",
|
"s": "vim::Substitute",
|
||||||
|
|
|
@ -65,7 +65,12 @@ pub fn register(editor: &mut Editor, cx: &mut ViewContext<Vim>) {
|
||||||
vim.record_current_action(cx);
|
vim.record_current_action(cx);
|
||||||
vim.visual_delete(true, cx);
|
vim.visual_delete(true, cx);
|
||||||
});
|
});
|
||||||
Vim::action(editor, cx, |vim, _: &VisualYank, cx| vim.visual_yank(cx));
|
Vim::action(editor, cx, |vim, _: &VisualYank, cx| {
|
||||||
|
vim.visual_yank(false, cx)
|
||||||
|
});
|
||||||
|
Vim::action(editor, cx, |vim, _: &VisualYankLine, cx| {
|
||||||
|
vim.visual_yank(true, cx)
|
||||||
|
});
|
||||||
|
|
||||||
Vim::action(editor, cx, Vim::select_next);
|
Vim::action(editor, cx, Vim::select_next);
|
||||||
Vim::action(editor, cx, Vim::select_previous);
|
Vim::action(editor, cx, Vim::select_previous);
|
||||||
|
@ -506,10 +511,11 @@ impl Vim {
|
||||||
self.switch_mode(Mode::Normal, true, cx);
|
self.switch_mode(Mode::Normal, true, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn visual_yank(&mut self, cx: &mut ViewContext<Self>) {
|
pub fn visual_yank(&mut self, line_mode: bool, cx: &mut ViewContext<Self>) {
|
||||||
self.store_visual_marks(cx);
|
self.store_visual_marks(cx);
|
||||||
self.update_editor(cx, |vim, editor, cx| {
|
self.update_editor(cx, |vim, editor, cx| {
|
||||||
let line_mode = editor.selections.line_mode;
|
let line_mode = line_mode || editor.selections.line_mode;
|
||||||
|
editor.selections.line_mode = line_mode;
|
||||||
vim.yank_selections_content(editor, line_mode, cx);
|
vim.yank_selections_content(editor, line_mode, cx);
|
||||||
editor.change_selections(None, cx, |s| {
|
editor.change_selections(None, cx, |s| {
|
||||||
s.move_with(|map, selection| {
|
s.move_with(|map, selection| {
|
||||||
|
@ -670,7 +676,7 @@ impl Vim {
|
||||||
self.stop_recording(cx);
|
self.stop_recording(cx);
|
||||||
self.visual_delete(false, cx)
|
self.visual_delete(false, cx)
|
||||||
}
|
}
|
||||||
Some(Operator::Yank) => self.visual_yank(cx),
|
Some(Operator::Yank) => self.visual_yank(false, cx),
|
||||||
_ => {} // Ignoring other operators
|
_ => {} // Ignoring other operators
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1386,6 +1392,20 @@ mod test {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[gpui::test]
|
||||||
|
async fn test_shift_y(cx: &mut gpui::TestAppContext) {
|
||||||
|
let mut cx = NeovimBackedTestContext::new(cx).await;
|
||||||
|
|
||||||
|
cx.set_shared_state(indoc! {
|
||||||
|
"The ˇquick brown\n"
|
||||||
|
})
|
||||||
|
.await;
|
||||||
|
cx.simulate_shared_keystrokes("v i w shift-y").await;
|
||||||
|
cx.shared_clipboard().await.assert_eq(indoc! {
|
||||||
|
"The quick brown\n"
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
#[gpui::test]
|
#[gpui::test]
|
||||||
async fn test_gv(cx: &mut gpui::TestAppContext) {
|
async fn test_gv(cx: &mut gpui::TestAppContext) {
|
||||||
let mut cx = NeovimBackedTestContext::new(cx).await;
|
let mut cx = NeovimBackedTestContext::new(cx).await;
|
||||||
|
|
7
crates/vim/test_data/test_shift_y.json
Normal file
7
crates/vim/test_data/test_shift_y.json
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{"Put":{"state":"The ˇquick brown\n"}}
|
||||||
|
{"Key":"v"}
|
||||||
|
{"Key":"i"}
|
||||||
|
{"Key":"w"}
|
||||||
|
{"Key":"shift-y"}
|
||||||
|
{"Get":{"state":"ˇThe quick brown\n","mode":"Normal"}}
|
||||||
|
{"ReadRegister":{"name":"\"","value":"The quick brown\n"}}
|
Loading…
Add table
Add a link
Reference in a new issue