diff options
author | Blaž Hrastnik | 2021-05-03 08:23:11 +0000 |
---|---|---|
committer | Blaž Hrastnik | 2021-05-03 08:23:11 +0000 |
commit | 28c167d71d910d113d5217349830a42fa52e9a9d (patch) | |
tree | 8cd2790b625761c2da16cce4ba2acf238f1729a4 | |
parent | 594575ba3f1cd1775f104c95ce604f952ccd5caf (diff) |
doc: Be smarter about calculating modified status.
This way edit -> undo will properly show up as unmodified.
-rw-r--r-- | helix-core/src/history.rs | 5 | ||||
-rw-r--r-- | helix-term/src/ui/editor.rs | 2 | ||||
-rw-r--r-- | helix-view/src/document.rs | 16 |
3 files changed, 13 insertions, 10 deletions
diff --git a/helix-core/src/history.rs b/helix-core/src/history.rs index df4b9fc4..5a9ec8de 100644 --- a/helix-core/src/history.rs +++ b/helix-core/src/history.rs @@ -56,6 +56,11 @@ impl History { } #[inline] + pub fn current_revision(&self) -> usize { + self.cursor + } + + #[inline] pub const fn at_root(&self) -> bool { self.cursor == 0 } diff --git a/helix-term/src/ui/editor.rs b/helix-term/src/ui/editor.rs index 227ccdaa..13ac88fd 100644 --- a/helix-term/src/ui/editor.rs +++ b/helix-term/src/ui/editor.rs @@ -440,7 +440,7 @@ impl EditorView { if let Some(path) = doc.relative_path() { let path = path.to_string_lossy(); - let title = format!("{}{}", path, if doc.modified() { "[+]" } else { "" }); + let title = format!("{}{}", path, if doc.is_modified() { "[+]" } else { "" }); surface.set_stringn( viewport.x + 6, viewport.y, 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.<lang>`. pub(crate) language: Option<Arc<LanguageConfiguration>>, - modified: bool, /// Pending changes since last history commit. changes: ChangeSet, /// State at last commit. Used for calculating reverts. old_state: Option<State>, /// Undo tree. history: History, + last_saved_revision: usize, version: i32, // should be usize? pub diagnostics: Vec<Diagnostic>, @@ -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] |