mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-05 11:57:43 +03:00
Make state fields read-only from outside the crate.
This commit is contained in:
parent
96db02742e
commit
31999d6528
2 changed files with 36 additions and 12 deletions
|
@ -4,6 +4,7 @@ use anyhow::Error;
|
||||||
|
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
|
||||||
|
#[derive(Copy, Clone)]
|
||||||
pub enum Mode {
|
pub enum Mode {
|
||||||
Normal,
|
Normal,
|
||||||
Insert,
|
Insert,
|
||||||
|
@ -12,10 +13,10 @@ pub enum Mode {
|
||||||
/// A state represents the current editor state of a single buffer.
|
/// A state represents the current editor state of a single buffer.
|
||||||
pub struct State {
|
pub struct State {
|
||||||
/// Path to file on disk.
|
/// Path to file on disk.
|
||||||
pub path: Option<PathBuf>,
|
pub(crate) path: Option<PathBuf>,
|
||||||
pub doc: Rope,
|
pub(crate) doc: Rope,
|
||||||
pub selection: Selection,
|
pub(crate) selection: Selection,
|
||||||
pub mode: Mode,
|
pub(crate) mode: Mode,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Copy, Clone, PartialEq, Eq)]
|
#[derive(Copy, Clone, PartialEq, Eq)]
|
||||||
|
@ -58,6 +59,29 @@ impl State {
|
||||||
|
|
||||||
// TODO: doc/selection accessors
|
// 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<R>(&self, range: R) -> RopeSlice
|
||||||
|
// where
|
||||||
|
// R: std::ops::RangeBounds<usize>,
|
||||||
|
// {
|
||||||
|
// self.doc.slice(range)
|
||||||
|
// }
|
||||||
|
|
||||||
// update/transact:
|
// update/transact:
|
||||||
// update(desc) => transaction ? transaction.doc() for applied doc
|
// update(desc) => transaction ? transaction.doc() for applied doc
|
||||||
// transaction.apply(doc)
|
// transaction.apply(doc)
|
||||||
|
|
|
@ -108,7 +108,7 @@ impl Editor {
|
||||||
let mut stdout = stdout();
|
let mut stdout = stdout();
|
||||||
|
|
||||||
// TODO: inefficient, should feed chunks.iter() to tree_sitter.parse_with(|offset, pos|)
|
// TODO: inefficient, should feed chunks.iter() to tree_sitter.parse_with(|offset, pos|)
|
||||||
let source_code = state.doc.to_string();
|
let source_code = state.doc().to_string();
|
||||||
|
|
||||||
// TODO: cache highlight results
|
// TODO: cache highlight results
|
||||||
// TODO: only recalculate when state.doc is actually modified
|
// TODO: only recalculate when state.doc is actually modified
|
||||||
|
@ -137,10 +137,10 @@ impl Editor {
|
||||||
HighlightEvent::Source { start, end } => {
|
HighlightEvent::Source { start, end } => {
|
||||||
// TODO: filter out spans out of viewport for now..
|
// TODO: filter out spans out of viewport for now..
|
||||||
|
|
||||||
let start = state.doc.byte_to_char(start);
|
let start = state.doc().byte_to_char(start);
|
||||||
let end = state.doc.byte_to_char(end);
|
let end = state.doc().byte_to_char(end);
|
||||||
|
|
||||||
let text = state.doc.slice(start..end);
|
let text = state.doc().slice(start..end);
|
||||||
|
|
||||||
use helix_core::graphemes::{grapheme_width, RopeGraphemes};
|
use helix_core::graphemes::{grapheme_width, RopeGraphemes};
|
||||||
|
|
||||||
|
@ -225,14 +225,14 @@ impl Editor {
|
||||||
self.surface = surface;
|
self.surface = surface;
|
||||||
|
|
||||||
// set cursor shape
|
// set cursor shape
|
||||||
match state.mode {
|
match state.mode() {
|
||||||
Mode::Insert => write!(stdout, "\x1B[6 q"),
|
Mode::Insert => write!(stdout, "\x1B[6 q"),
|
||||||
Mode::Normal => write!(stdout, "\x1B[2 q"),
|
Mode::Normal => write!(stdout, "\x1B[2 q"),
|
||||||
};
|
};
|
||||||
|
|
||||||
// render the cursor
|
// render the cursor
|
||||||
let pos = state.selection.cursor();
|
let pos = state.selection().cursor();
|
||||||
let coords = coords_at_pos(&state.doc.slice(..), pos);
|
let coords = coords_at_pos(&state.doc().slice(..), pos);
|
||||||
execute!(
|
execute!(
|
||||||
stdout,
|
stdout,
|
||||||
cursor::MoveTo((coords.1 + 2) as u16, coords.0 as u16)
|
cursor::MoveTo((coords.1 + 2) as u16, coords.0 as u16)
|
||||||
|
@ -261,7 +261,7 @@ impl Editor {
|
||||||
}
|
}
|
||||||
Some(Ok(Event::Key(event))) => {
|
Some(Ok(Event::Key(event))) => {
|
||||||
if let Some(state) = &mut self.state {
|
if let Some(state) = &mut self.state {
|
||||||
match state.mode {
|
match state.mode() {
|
||||||
Mode::Insert => {
|
Mode::Insert => {
|
||||||
match event {
|
match event {
|
||||||
KeyEvent {
|
KeyEvent {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue