diff --git a/crates/vim/src/test.rs b/crates/vim/src/test.rs index 40bda6ca2d809..dc447708c6d81 100644 --- a/crates/vim/src/test.rs +++ b/crates/vim/src/test.rs @@ -1448,3 +1448,15 @@ async fn test_visual_indent_count(cx: &mut gpui::TestAppContext) { cx.simulate_keystrokes("shift-v 2 <"); cx.assert_state(" ˇhi", Mode::Normal); } + +#[gpui::test] +async fn test_record_replay_recursion(cx: &mut gpui::TestAppContext) { + let mut cx = NeovimBackedTestContext::new(cx).await; + + cx.set_shared_state("ˇhello world").await; + cx.simulate_shared_keystrokes(">").await; + cx.simulate_shared_keystrokes(".").await; + cx.simulate_shared_keystrokes(".").await; + cx.simulate_shared_keystrokes(".").await; + cx.shared_state().await.assert_eq("ˇhello world"); // takes a _long_ time +} diff --git a/crates/vim/src/vim.rs b/crates/vim/src/vim.rs index 5f5dff6062b8f..cac66dde0fc23 100644 --- a/crates/vim/src/vim.rs +++ b/crates/vim/src/vim.rs @@ -189,25 +189,13 @@ fn observe_keystrokes(keystroke_event: &KeystrokeEvent, cx: &mut WindowContext) return; } - Vim::update(cx, |vim, cx| match vim.active_operator() { - Some( - Operator::FindForward { .. } - | Operator::FindBackward { .. } - | Operator::Replace - | Operator::Digraph { .. } - | Operator::AddSurrounds { .. } - | Operator::ChangeSurrounds { .. } - | Operator::DeleteSurrounds - | Operator::Mark - | Operator::Jump { .. } - | Operator::Register - | Operator::RecordRegister - | Operator::ReplayRegister, - ) => {} - Some(_) => { - vim.clear_operator(cx); + Vim::update(cx, |vim, cx| { + if let Some(operator) = vim.active_operator() { + if !operator.is_waiting(vim.state().mode) { + vim.clear_operator(cx); + vim.stop_recording_immediately(Box::new(ClearOperators)) + } } - _ => {} }); } diff --git a/crates/vim/test_data/test_record_replay_recursion.json b/crates/vim/test_data/test_record_replay_recursion.json new file mode 100644 index 0000000000000..d02817db57059 --- /dev/null +++ b/crates/vim/test_data/test_record_replay_recursion.json @@ -0,0 +1,6 @@ +{"Put":{"state":"ˇhello world"}} +{"Key":">"} +{"Key":"."} +{"Key":"."} +{"Key":"."} +{"Get":{"state":"ˇhello world","mode":"Normal"}}