From 2a1fa0f8f9ae1e5df4822c88c9b7ed2faa2cbefc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matou=C5=A1=20Dzivjak?= Date: Tue, 4 Jan 2022 23:07:32 +0100 Subject: [PATCH] Adjust buffer close behavior --- helix-term/src/commands.rs | 8 ++------ helix-view/src/editor.rs | 19 ++++++++----------- helix-view/src/view.rs | 13 ++++++++++--- 3 files changed, 20 insertions(+), 20 deletions(-) diff --git a/helix-term/src/commands.rs b/helix-term/src/commands.rs index 04dd222bbcd37..5738e80d4ff9d 100644 --- a/helix-term/src/commands.rs +++ b/helix-term/src/commands.rs @@ -3839,8 +3839,8 @@ fn goto_last_line(cx: &mut Context) { } fn goto_last_accessed_file(cx: &mut Context) { - let alternate_file = view!(cx.editor).last_accessed_doc; - if let Some(alt) = alternate_file { + let view = view_mut!(cx.editor); + if let Some(alt) = view.docs_access_history.pop() { cx.editor.switch(alt, Action::Replace); } else { cx.editor.set_error("no last accessed buffer".to_owned()) @@ -5478,10 +5478,6 @@ fn jump_backward(cx: &mut Context) { let (view, doc) = current!(cx.editor); if let Some((id, selection)) = view.jumps.backward(view.id, doc, count) { - // manually set the alternate_file as we cannot use the Editor::switch function here. - if view.doc != *id { - view.last_accessed_doc = Some(view.doc) - } view.doc = *id; let selection = selection.clone(); let (view, doc) = current!(cx.editor); // refetch doc diff --git a/helix-view/src/editor.rs b/helix-view/src/editor.rs index 1959c8ba2476f..ea21b9f85e916 100644 --- a/helix-view/src/editor.rs +++ b/helix-view/src/editor.rs @@ -390,7 +390,7 @@ impl Editor { view.jumps.push(jump); // Set last accessed doc if it is a different document if doc.id != id { - view.last_accessed_doc = Some(view.doc); + view.add_to_history(view.doc); // Set last modified doc if modified and last modified doc is different if std::mem::take(&mut doc.modified_since_accessed) && view.last_modified_docs[0] != Some(id) @@ -515,18 +515,15 @@ impl Editor { let actions: Vec = self .tree - .views() + .views_mut() .filter_map(|(view, _focus)| { if view.doc == doc_id { - match view.last_accessed_doc { - Some(doc_id) => { - // something was previously o[en in the view, switch to previous doc - Some(Action::ReplaceDoc(view.id, doc_id)) - } - None => { - // only the document that is being closed was in the view, close it - Some(Action::Close(view.id)) - } + // something was previously open in the view, switch to previous doc + if let Some(prev_doc) = view.docs_access_history.pop() { + Some(Action::ReplaceDoc(view.id, prev_doc)) + } else { + // only the document that is being closed was in the view, close it + Some(Action::Close(view.id)) } } else { None diff --git a/helix-view/src/view.rs b/helix-view/src/view.rs index 94d67acd01e42..9cd49726d70cc 100644 --- a/helix-view/src/view.rs +++ b/helix-view/src/view.rs @@ -73,8 +73,8 @@ pub struct View { pub offset: Position, pub area: Rect, pub jumps: JumpList, - /// the last accessed file before the current one - pub last_accessed_doc: Option, + // documents accessed from this view from the oldest one to last viewed one + pub docs_access_history: Vec, /// the last modified files before the current one /// ordered from most frequent to least frequent // uses two docs because we want to be able to swap between the @@ -90,11 +90,18 @@ impl View { offset: Position::new(0, 0), area: Rect::default(), // will get calculated upon inserting into tree jumps: JumpList::new((doc, Selection::point(0))), // TODO: use actual sel - last_accessed_doc: None, + docs_access_history: Vec::new(), last_modified_docs: [None, None], } } + pub fn add_to_history(&mut self, id: DocumentId) { + if let Some(pos) = self.docs_access_history.iter().position(|&doc| doc == id) { + self.docs_access_history.remove(pos); + } + self.docs_access_history.push(id); + } + pub fn gutters(&self) -> &[(Gutter, usize)] { GUTTERS }