Change summary
crates/editor/src/editor_tests.rs | 15 +++++++++++++++
crates/multi_buffer/src/multi_buffer.rs | 2 +-
2 files changed, 16 insertions(+), 1 deletion(-)
Detailed changes
@@ -5362,6 +5362,21 @@ async fn test_select_previous_with_single_caret(cx: &mut gpui::TestAppContext) {
cx.assert_editor_state("«abcˇ»\n«abcˇ» «abcˇ»\ndef«abcˇ»\n«abcˇ»");
}
+#[gpui::test]
+async fn test_select_previous_empty_buffer(cx: &mut gpui::TestAppContext) {
+ init_test(cx, |_| {});
+
+ let mut cx = EditorTestContext::new(cx).await;
+ cx.set_state("aˇ");
+
+ cx.update_editor(|e, window, cx| e.select_previous(&SelectPrevious::default(), window, cx))
+ .unwrap();
+ cx.assert_editor_state("«aˇ»");
+ cx.update_editor(|e, window, cx| e.select_previous(&SelectPrevious::default(), window, cx))
+ .unwrap();
+ cx.assert_editor_state("«aˇ»");
+}
+
#[gpui::test]
async fn test_select_previous_with_multiple_carets(cx: &mut gpui::TestAppContext) {
init_test(cx, |_| {});
@@ -7121,7 +7121,7 @@ impl<'a> Iterator for ReversedMultiBufferChunks<'a> {
self.offset -= 1;
Some("\n")
} else {
- let chunk = self.current_chunks.as_mut().unwrap().next().unwrap();
+ let chunk = self.current_chunks.as_mut().unwrap().next()?;
self.offset -= chunk.len();
Some(chunk)
}