aboutsummaryrefslogtreecommitdiff
path: root/helix-view/src/document.rs
diff options
context:
space:
mode:
authorBlaž Hrastnik2020-10-30 08:00:30 +0000
committerBlaž Hrastnik2020-12-03 04:12:05 +0000
commit3f707c19f46284d745568c632a57103eb1be4dd4 (patch)
tree41047ba33a48eae0ca625be822e83048363c4a69 /helix-view/src/document.rs
parent8f0bcfe286d97dfff67bd924e11ca2b6ae1a63dc (diff)
Save command
Diffstat (limited to 'helix-view/src/document.rs')
-rw-r--r--helix-view/src/document.rs25
1 files changed, 25 insertions, 0 deletions
diff --git a/helix-view/src/document.rs b/helix-view/src/document.rs
index 710ea4f8..1587de8b 100644
--- a/helix-view/src/document.rs
+++ b/helix-view/src/document.rs
@@ -1,4 +1,5 @@
use anyhow::Error;
+use std::future::Future;
use std::path::PathBuf;
use helix_core::{
@@ -97,6 +98,30 @@ impl Document {
Ok(doc)
}
+ pub fn save(&self) -> impl Future<Output = Result<(), anyhow::Error>> {
+ // we clone and move text + path into the future so that we asynchronously save the current
+ // state without blocking any further edits.
+
+ let text = self.text().clone();
+ let path = self.path.clone().expect("Can't save with no path set!"); // TODO: handle no path
+
+ // TODO: mark changes up to now as saved
+ // TODO: mark dirty false
+
+ async move {
+ use smol::{fs::File, prelude::*};
+ let mut file = File::create(path).await?;
+
+ // write all the rope chunks to file
+ for chunk in text.chunks() {
+ file.write_all(chunk.as_bytes()).await?;
+ }
+ // TODO: flush?
+
+ Ok(())
+ } // and_then(// lsp.send_text_saved_notification())
+ }
+
pub fn set_language(&mut self, scope: &str, scopes: &[String]) {
if let Some(language_config) = LOADER.language_config_for_scope(scope) {
let highlight_config = language_config.highlight_config(scopes).unwrap().unwrap();