Fix panic on close last buffer (#2367) (#2658)

* Fix panic on close last buffer (#2367)

In certain circumstances it was possible to cause a panic when closing
buffers due to some mishandling of view document history.

A change has been made to delete removed documents from the history of
accessed documents for each view. The ensures we don't attempt to jump
to a deleted document by mistake.

* Move remove document code into View function 'remove_document'

* Replace 'view.jumps.remove' call with 'view.remove_document' call
This commit is contained in:
gavynriebau 2022-06-05 10:27:41 +08:00 committed by GitHub
parent 5b4e0a304b
commit 026241cf72
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 7 additions and 3 deletions

View File

@ -681,7 +681,7 @@ pub fn switch(&mut self, id: DocumentId, action: Action) {
// Remove the scratch buffer from any jumplists
for (view, _) in self.tree.views_mut() {
view.jumps.remove(&id)
view.remove_document(&id);
}
} else {
let jump = (view.doc, doc.selection(view.id).clone());
@ -814,8 +814,7 @@ enum Action {
.tree
.views_mut()
.filter_map(|(view, _focus)| {
// remove the document from jump list of all views
view.jumps.remove(&doc_id);
view.remove_document(&doc_id);
if view.doc == doc_id {
// something was previously open in the view, switch to previous doc

View File

@ -316,6 +316,11 @@ pub fn gutter_coords_at_screen_coords(&self, row: u16, column: u16) -> Option<Po
))
}
pub fn remove_document(&mut self, doc_id: &DocumentId) {
self.jumps.remove(doc_id);
self.docs_access_history.retain(|doc| doc != doc_id);
}
// pub fn traverse<F>(&self, text: RopeSlice, start: usize, end: usize, fun: F)
// where
// F: Fn(usize, usize),