From 31999d6528b247e223774d1a4edec7966dda3d9e Mon Sep 17 00:00:00 2001 From: Blaž Hrastnik Date: Mon, 14 Sep 2020 19:50:46 +0900 Subject: Make state fields read-only from outside the crate. --- helix-core/src/state.rs | 32 ++++++++++++++++++++++++++++---- 1 file changed, 28 insertions(+), 4 deletions(-) (limited to 'helix-core/src') diff --git a/helix-core/src/state.rs b/helix-core/src/state.rs index be2b3317..e41ee565 100644 --- a/helix-core/src/state.rs +++ b/helix-core/src/state.rs @@ -4,6 +4,7 @@ use anyhow::Error; use std::path::PathBuf; +#[derive(Copy, Clone)] pub enum Mode { Normal, Insert, @@ -12,10 +13,10 @@ pub enum Mode { /// A state represents the current editor state of a single buffer. pub struct State { /// Path to file on disk. - pub path: Option, - pub doc: Rope, - pub selection: Selection, - pub mode: Mode, + pub(crate) path: Option, + pub(crate) doc: Rope, + pub(crate) selection: Selection, + pub(crate) mode: Mode, } #[derive(Copy, Clone, PartialEq, Eq)] @@ -58,6 +59,29 @@ impl State { // TODO: doc/selection accessors + // TODO: be able to take either Rope or RopeSlice + #[inline] + pub fn doc(&self) -> &Rope { + &self.doc + } + + #[inline] + pub fn selection(&self) -> &Selection { + &self.selection + } + + #[inline] + pub fn mode(&self) -> Mode { + self.mode + } + + // pub fn doc(&self, range: R) -> RopeSlice + // where + // R: std::ops::RangeBounds, + // { + // self.doc.slice(range) + // } + // update/transact: // update(desc) => transaction ? transaction.doc() for applied doc // transaction.apply(doc) -- cgit v1.2.3-70-g09d2