From 28c167d71d910d113d5217349830a42fa52e9a9d Mon Sep 17 00:00:00 2001 From: Blaž Hrastnik Date: Mon, 3 May 2021 17:23:11 +0900 Subject: doc: Be smarter about calculating modified status. This way edit -> undo will properly show up as unmodified. --- helix-view/src/document.rs | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) (limited to 'helix-view/src') diff --git a/helix-view/src/document.rs b/helix-view/src/document.rs index a04600b6..16a7a88a 100644 --- a/helix-view/src/document.rs +++ b/helix-view/src/document.rs @@ -35,13 +35,13 @@ pub struct Document { // /// Corresponding language scope name. Usually `source.`. pub(crate) language: Option>, - modified: bool, /// Pending changes since last history commit. changes: ChangeSet, /// State at last commit. Used for calculating reverts. old_state: Option, /// Undo tree. history: History, + last_saved_revision: usize, version: i32, // should be usize? pub diagnostics: Vec, @@ -81,12 +81,12 @@ impl Document { restore_cursor: false, syntax: None, language: None, - modified: false, changes, old_state, diagnostics: Vec::new(), version: 0, history: History::default(), + last_saved_revision: 0, language_server: None, } } @@ -131,7 +131,7 @@ impl Document { let language_server = self.language_server.clone(); // reset the modified flag - self.modified = false; + self.last_saved_revision = self.history.current_revision(); async move { use smol::{fs::File, prelude::*}; @@ -246,10 +246,6 @@ impl Document { let success = self._apply(transaction, view_id); - self.modified = true; - // TODO: be smarter about modified by keeping track of saved version instead. That way if - // current version == version then it's not modified. - if !transaction.changes().is_empty() { // Compose this transaction with the previous one take_with(&mut self.changes, |changes| { @@ -307,8 +303,10 @@ impl Document { } #[inline] - pub fn modified(&self) -> bool { - self.modified + pub fn is_modified(&self) -> bool { + self.path.is_some() + && (self.history.current_revision() != self.last_saved_revision + || !self.changes.is_empty()) } #[inline] -- cgit v1.2.3-70-g09d2