mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-04 19:37:54 +03:00
progress
This commit is contained in:
parent
1bd36f528a
commit
29ffc20290
4 changed files with 89 additions and 2 deletions
|
@ -4,9 +4,9 @@ use std::sync::Arc;
|
||||||
|
|
||||||
use hashbrown::HashMap;
|
use hashbrown::HashMap;
|
||||||
use slotmap::{new_key_type, SlotMap};
|
use slotmap::{new_key_type, SlotMap};
|
||||||
use tree_sitter::Tree;
|
|
||||||
|
|
||||||
use crate::parse::LayerUpdateFlags;
|
use crate::parse::LayerUpdateFlags;
|
||||||
|
use crate::tree_sitter::SyntaxTree;
|
||||||
use crate::{HighlightConfiguration, RopeProvider};
|
use crate::{HighlightConfiguration, RopeProvider};
|
||||||
|
|
||||||
// TODO(perf): replace std::ops::Range with helix_core::Range once added
|
// TODO(perf): replace std::ops::Range with helix_core::Range once added
|
||||||
|
@ -20,7 +20,7 @@ new_key_type! {
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct LanguageLayer {
|
pub struct LanguageLayer {
|
||||||
pub config: Arc<HighlightConfiguration>,
|
pub config: Arc<HighlightConfiguration>,
|
||||||
pub(crate) parse_tree: Option<Tree>,
|
pub(crate) parse_tree: Option<SyntaxTree>,
|
||||||
/// internal flags used during parsing to track incremental invalidation
|
/// internal flags used during parsing to track incremental invalidation
|
||||||
pub(crate) flags: LayerUpdateFlags,
|
pub(crate) flags: LayerUpdateFlags,
|
||||||
pub(crate) parent: Option<LayerId>,
|
pub(crate) parent: Option<LayerId>,
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
mod grammar;
|
mod grammar;
|
||||||
mod parser;
|
mod parser;
|
||||||
mod query;
|
mod query;
|
||||||
|
mod query_captures;
|
||||||
mod ropey;
|
mod ropey;
|
||||||
mod syntax_tree;
|
mod syntax_tree;
|
||||||
mod syntax_tree_node;
|
mod syntax_tree_node;
|
||||||
|
|
|
@ -4,6 +4,8 @@ use std::path::{Path, PathBuf};
|
||||||
use std::ptr::NonNull;
|
use std::ptr::NonNull;
|
||||||
use std::{slice, str};
|
use std::{slice, str};
|
||||||
|
|
||||||
|
use regex_cursor::Cursor;
|
||||||
|
|
||||||
use crate::tree_sitter::query::predicate::{InvalidPredicateError, Predicate, TextPredicate};
|
use crate::tree_sitter::query::predicate::{InvalidPredicateError, Predicate, TextPredicate};
|
||||||
use crate::tree_sitter::query::property::QueryProperty;
|
use crate::tree_sitter::query::property::QueryProperty;
|
||||||
use crate::tree_sitter::Grammar;
|
use crate::tree_sitter::Grammar;
|
||||||
|
@ -155,6 +157,24 @@ impl Query {
|
||||||
Ok(query)
|
Ok(query)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn satsifies_text_predicate<C: Cursor>(
|
||||||
|
&self,
|
||||||
|
cursor: &mut regex_cursor::Input<C>,
|
||||||
|
pattern: u32,
|
||||||
|
) {
|
||||||
|
let text_predicates = self.patterns[pattern as usize].text_predicates;
|
||||||
|
let text_predicates =
|
||||||
|
&self.text_predicates[text_predicates.start as usize..text_predicates.end as usize];
|
||||||
|
for predicate in text_predicates {
|
||||||
|
match predicate.kind {
|
||||||
|
predicate::TextPredicateKind::EqString(_) => todo!(),
|
||||||
|
predicate::TextPredicateKind::EqCapture(_) => todo!(),
|
||||||
|
predicate::TextPredicateKind::MatchString(_) => todo!(),
|
||||||
|
predicate::TextPredicateKind::AnyString(_) => todo!(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// fn parse_predicates(&mut self) {
|
// fn parse_predicates(&mut self) {
|
||||||
// let pattern_count = unsafe { ts_query_pattern_count(self.raw) };
|
// let pattern_count = unsafe { ts_query_pattern_count(self.raw) };
|
||||||
|
|
||||||
|
|
66
helix-syntax/src/tree_sitter/query_captures.rs
Normal file
66
helix-syntax/src/tree_sitter/query_captures.rs
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
use std::ptr::{self, NonNull};
|
||||||
|
|
||||||
|
use regex_cursor::Cursor;
|
||||||
|
|
||||||
|
use crate::tree_sitter::query::Query;
|
||||||
|
use crate::tree_sitter::syntax_tree_node::SyntaxTreeNodeRaw;
|
||||||
|
|
||||||
|
enum QueryCursorData {}
|
||||||
|
|
||||||
|
pub struct QueryCaptures<'a> {
|
||||||
|
query: &'a Query,
|
||||||
|
query_cursor: &'a mut QueryCursorData,
|
||||||
|
text_cursor: regex_cursor::RopeyCursor<'a>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<C: Cursor> QueryCaptures<'_, C> {
|
||||||
|
fn next(&mut self) {
|
||||||
|
let mut query_match = TSQueryMatch {
|
||||||
|
id: 0,
|
||||||
|
pattern_index: 0,
|
||||||
|
capture_count: 0,
|
||||||
|
captures: ptr::null(),
|
||||||
|
};
|
||||||
|
let mut capture_idx = 0;
|
||||||
|
loop {
|
||||||
|
let success = unsafe {
|
||||||
|
ts_query_cursor_next_capture(
|
||||||
|
&mut self.query_cursor,
|
||||||
|
&mut query_match,
|
||||||
|
&mut capture_idx,
|
||||||
|
)
|
||||||
|
};
|
||||||
|
if !success {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let mut input = regex_cursor::Input::new(self.text_cursor.clone());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[repr(C)]
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct TSQueryCapture {
|
||||||
|
node: SyntaxTreeNodeRaw,
|
||||||
|
index: u32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[repr(C)]
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct TSQueryMatch {
|
||||||
|
id: u32,
|
||||||
|
pattern_index: u16,
|
||||||
|
capture_count: u16,
|
||||||
|
captures: *const TSQueryCapture,
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
/// Advance to the next capture of the currently running query.
|
||||||
|
/// If there is a capture, write its match to `*match` and its index within
|
||||||
|
/// the matche's capture list to `*capture_index`. Otherwise, return `false`.
|
||||||
|
fn ts_query_cursor_next_capture(
|
||||||
|
self_: &mut QueryCursorData,
|
||||||
|
match_: &mut TSQueryMatch,
|
||||||
|
capture_index: &mut u32,
|
||||||
|
) -> bool;
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue