mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-04 11:27:46 +03:00
Expose doc.syntax() via accessor.
This commit is contained in:
parent
2b64f49f2c
commit
8ba1e15d29
5 changed files with 19 additions and 23 deletions
|
@ -770,12 +770,8 @@ pub fn open_below(cx: &mut Context) {
|
|||
let changes: Vec<Change> = positions
|
||||
.map(|index| {
|
||||
// TODO: share logic with insert_newline for indentation
|
||||
let indent_level = helix_core::indent::suggested_indent_for_pos(
|
||||
doc.syntax.as_ref(),
|
||||
text,
|
||||
index,
|
||||
true,
|
||||
);
|
||||
let indent_level =
|
||||
helix_core::indent::suggested_indent_for_pos(doc.syntax(), text, index, true);
|
||||
let indent = " ".repeat(TAB_WIDTH).repeat(indent_level);
|
||||
let mut text = String::with_capacity(1 + indent.len());
|
||||
text.push('\n');
|
||||
|
@ -970,12 +966,8 @@ pub mod insert {
|
|||
let doc = cx.doc();
|
||||
let text = doc.text().slice(..);
|
||||
let transaction = Transaction::change_by_selection(doc.text(), doc.selection(), |range| {
|
||||
let indent_level = helix_core::indent::suggested_indent_for_pos(
|
||||
doc.syntax.as_ref(),
|
||||
text,
|
||||
range.head,
|
||||
true,
|
||||
);
|
||||
let indent_level =
|
||||
helix_core::indent::suggested_indent_for_pos(doc.syntax(), text, range.head, true);
|
||||
let indent = " ".repeat(TAB_WIDTH).repeat(indent_level);
|
||||
let mut text = String::with_capacity(1 + indent.len());
|
||||
text.push('\n');
|
||||
|
@ -1434,7 +1426,7 @@ pub fn toggle_comments(cx: &mut Context) {
|
|||
pub fn expand_selection(cx: &mut Context) {
|
||||
let doc = cx.doc();
|
||||
|
||||
if let Some(syntax) = &doc.syntax {
|
||||
if let Some(syntax) = doc.syntax() {
|
||||
let text = doc.text().slice(..);
|
||||
let selection = object::expand_selection(syntax, text, doc.selection());
|
||||
doc.set_selection(selection);
|
||||
|
|
|
@ -90,7 +90,7 @@ impl EditorView {
|
|||
// TODO: range doesn't actually restrict source, just highlight range
|
||||
// TODO: cache highlight results
|
||||
// TODO: only recalculate when state.doc is actually modified
|
||||
let highlights: Vec<_> = match &view.doc.syntax {
|
||||
let highlights: Vec<_> = match view.doc.syntax() {
|
||||
Some(syntax) => {
|
||||
syntax
|
||||
.highlight_iter(text.slice(..), Some(range), None, |_| None)
|
||||
|
|
|
@ -7,11 +7,11 @@ use std::borrow::Cow;
|
|||
use std::string::String;
|
||||
|
||||
pub struct Prompt {
|
||||
pub prompt: String,
|
||||
prompt: String,
|
||||
pub line: String,
|
||||
pub cursor: usize,
|
||||
pub completion: Vec<Cow<'static, str>>,
|
||||
pub completion_selection_index: Option<usize>,
|
||||
cursor: usize,
|
||||
completion: Vec<Cow<'static, str>>,
|
||||
completion_selection_index: Option<usize>,
|
||||
completion_fn: Box<dyn FnMut(&str) -> Vec<Cow<'static, str>>>,
|
||||
callback_fn: Box<dyn FnMut(&mut Editor, &str, PromptEvent)>,
|
||||
}
|
||||
|
|
|
@ -18,15 +18,13 @@ pub enum Mode {
|
|||
|
||||
pub struct Document {
|
||||
pub state: State, // rope + selection
|
||||
/// File path on disk.
|
||||
path: Option<PathBuf>,
|
||||
|
||||
/// Current editing mode.
|
||||
pub mode: Mode,
|
||||
pub restore_cursor: bool,
|
||||
|
||||
/// Tree-sitter AST tree
|
||||
pub syntax: Option<Syntax>,
|
||||
syntax: Option<Syntax>,
|
||||
// /// Corresponding language scope name. Usually `source.<lang>`.
|
||||
pub(crate) language: Option<Arc<LanguageConfiguration>>,
|
||||
|
||||
|
@ -36,7 +34,6 @@ pub struct Document {
|
|||
old_state: Option<State>,
|
||||
/// Undo tree.
|
||||
history: History,
|
||||
/// Current document version, incremented at each change.
|
||||
version: i32, // should be usize?
|
||||
|
||||
pub diagnostics: Vec<Diagnostic>,
|
||||
|
@ -284,6 +281,7 @@ impl Document {
|
|||
}
|
||||
|
||||
#[inline]
|
||||
/// Current document version, incremented at each change.
|
||||
pub fn version(&self) -> i32 {
|
||||
self.version
|
||||
}
|
||||
|
@ -292,7 +290,13 @@ impl Document {
|
|||
self.language_server.as_deref()
|
||||
}
|
||||
|
||||
/// Tree-sitter AST tree
|
||||
pub fn syntax(&self) -> Option<&Syntax> {
|
||||
self.syntax.as_ref()
|
||||
}
|
||||
|
||||
#[inline]
|
||||
/// File path on disk.
|
||||
pub fn path(&self) -> Option<&PathBuf> {
|
||||
self.path.as_ref()
|
||||
}
|
||||
|
|
|
@ -95,7 +95,7 @@ impl Editor {
|
|||
self.tree.remove(id)
|
||||
}
|
||||
|
||||
pub fn should_close(&mut self) -> bool {
|
||||
pub fn should_close(&self) -> bool {
|
||||
self.tree.is_empty()
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue