summaryrefslogtreecommitdiff
path: root/helix-view/src
diff options
context:
space:
mode:
authorKirawi2021-08-18 00:59:10 +0000
committerGitHub2021-08-18 00:59:10 +0000
commit16bf8e1e6b52546ba804dc7206317c4e368dcfb5 (patch)
tree247be8e82db3711682392028aa070a3a9e6be77c /helix-view/src
parentb59b2485613089595522377c87a392c859ee31a0 (diff)
Document more of document.rs (#562)
Diffstat (limited to 'helix-view/src')
-rw-r--r--helix-view/src/document.rs27
1 files changed, 27 insertions, 0 deletions
diff --git a/helix-view/src/document.rs b/helix-view/src/document.rs
index 8730bef2..ff0c8bf4 100644
--- a/helix-view/src/document.rs
+++ b/helix-view/src/document.rs
@@ -20,6 +20,7 @@ use helix_lsp::util::LspFormatting;
use crate::{DocumentId, Theme, ViewId};
+/// 8kB of buffer space for encoding and decoding `Rope`s.
const BUF_SIZE: usize = 8192;
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
@@ -437,6 +438,7 @@ impl Document {
theme: Option<&Theme>,
config_loader: Option<&syntax::Loader>,
) -> Result<Self, Error> {
+ // Open the file if it exists, otherwise assume it is a new file (and thus empty).
let (rope, encoding) = if path.exists() {
let mut file =
std::fs::File::open(path).context(format!("unable to open {:?}", path))?;
@@ -564,6 +566,7 @@ impl Document {
}
}
+ /// Detect the programming language based on the file type.
pub fn detect_language(&mut self, theme: Option<&Theme>, config_loader: &syntax::Loader) {
if let Some(path) = &self.path {
let language_config = config_loader.language_config_for_file_name(path);
@@ -571,6 +574,10 @@ impl Document {
}
}
+ /// Detect the indentation used in the file, or otherwise defaults to the language indentation
+ /// configured in `languages.toml`, with a fallback back to 2 space indentation if it isn't
+ /// specified. Line ending is likewise auto-detected, and will fallback to the default OS
+ /// line ending.
pub fn detect_indent_and_line_ending(&mut self) {
self.indent_style = auto_detect_indent_style(&self.text).unwrap_or_else(|| {
IndentStyle::from_str(
@@ -596,6 +603,9 @@ impl Document {
let mut file = std::fs::File::open(path.unwrap())?;
let (rope, ..) = from_reader(&mut file, Some(encoding))?;
+ // Calculate the difference between the buffer and source text, and apply it.
+ // This is not considered a modification of the contents of the file regardless
+ // of the encoding.
let transaction = helix_core::diff::compare_ropes(self.text(), &rope);
self.apply(&transaction, view_id);
self.append_changes_to_history(view_id);
@@ -630,6 +640,8 @@ impl Document {
Ok(())
}
+ /// Set the programming language for the file and load associated data (e.g. highlighting)
+ /// if it exists.
pub fn set_language(
&mut self,
theme: Option<&Theme>,
@@ -650,6 +662,8 @@ impl Document {
};
}
+ /// Set the programming language for the file if you know the name (scope) but don't have the
+ /// [`syntax::LanguageConfiguration`] for it.
pub fn set_language2(
&mut self,
scope: &str,
@@ -661,16 +675,19 @@ impl Document {
self.set_language(theme, language_config);
}
+ /// Set the LSP.
pub fn set_language_server(&mut self, language_server: Option<Arc<helix_lsp::Client>>) {
self.language_server = language_server;
}
+ /// Select text within the [`Document`].
pub fn set_selection(&mut self, view_id: ViewId, selection: Selection) {
// TODO: use a transaction?
self.selections
.insert(view_id, selection.ensure_invariants(self.text().slice(..)));
}
+ /// Apply a [`Transaction`] to the [`Document`] to change its text.
fn apply_impl(&mut self, transaction: &Transaction, view_id: ViewId) -> bool {
let old_doc = self.text().clone();
@@ -733,6 +750,7 @@ impl Document {
success
}
+ /// Apply a [`Transaction`] to the [`Document`] to change its text.
pub fn apply(&mut self, transaction: &Transaction, view_id: ViewId) -> bool {
// store the state just before any changes are made. This allows us to undo to the
// state just before a transaction was applied.
@@ -754,6 +772,7 @@ impl Document {
success
}
+ /// Undo the last modification to the [`Document`].
pub fn undo(&mut self, view_id: ViewId) {
let mut history = self.history.take();
let success = if let Some(transaction) = history.undo() {
@@ -769,6 +788,7 @@ impl Document {
}
}
+ /// Redo the last modification to the [`Document`].
pub fn redo(&mut self, view_id: ViewId) {
let mut history = self.history.take();
let success = if let Some(transaction) = history.redo() {
@@ -784,6 +804,7 @@ impl Document {
}
}
+ /// Undo modifications to the [`Document`] according to `uk`.
pub fn earlier(&mut self, view_id: ViewId, uk: helix_core::history::UndoKind) {
let txns = self.history.get_mut().earlier(uk);
for txn in txns {
@@ -791,6 +812,7 @@ impl Document {
}
}
+ /// Redo modifications to the [`Document`] according to `uk`.
pub fn later(&mut self, view_id: ViewId, uk: helix_core::history::UndoKind) {
let txns = self.history.get_mut().later(uk);
for txn in txns {
@@ -823,6 +845,7 @@ impl Document {
self.id
}
+ /// If there are unsaved modifications.
pub fn is_modified(&self) -> bool {
let history = self.history.take();
let current_revision = history.current_revision();
@@ -830,6 +853,7 @@ impl Document {
current_revision != self.last_saved_revision || !self.changes.is_empty()
}
+ /// Save modifications to history, and so [`Self::is_modified`] will return false.
pub fn reset_modified(&mut self) {
let history = self.history.take();
let current_revision = history.current_revision();
@@ -837,6 +861,7 @@ impl Document {
self.last_saved_revision = current_revision;
}
+ /// Current editing mode for the [`Document`].
pub fn mode(&self) -> Mode {
self.mode
}
@@ -848,6 +873,7 @@ impl Document {
.map(|language| language.scope.as_str())
}
+ /// Corresponding [`LanguageConfiguration`].
pub fn language_config(&self) -> Option<&LanguageConfiguration> {
self.language.as_deref()
}
@@ -890,6 +916,7 @@ impl Document {
self.path.as_ref()
}
+ /// File path as a URL.
pub fn url(&self) -> Option<Url> {
self.path().map(|path| Url::from_file_path(path).unwrap())
}