mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-05 11:57:43 +03:00
automatically disable TS when parsing takes longer than 500ms
This commit is contained in:
parent
2f2306475c
commit
b0705337be
5 changed files with 23 additions and 18 deletions
|
@ -768,7 +768,11 @@ fn byte_range_to_str(range: std::ops::Range<usize>, source: RopeSlice) -> Cow<st
|
|||
}
|
||||
|
||||
impl Syntax {
|
||||
pub fn new(source: &Rope, config: Arc<HighlightConfiguration>, loader: Arc<Loader>) -> Self {
|
||||
pub fn new(
|
||||
source: &Rope,
|
||||
config: Arc<HighlightConfiguration>,
|
||||
loader: Arc<Loader>,
|
||||
) -> Option<Self> {
|
||||
let root_layer = LanguageLayer {
|
||||
tree: None,
|
||||
config,
|
||||
|
@ -793,11 +797,13 @@ impl Syntax {
|
|||
loader,
|
||||
};
|
||||
|
||||
syntax
|
||||
.update(source, source, &ChangeSet::new(source))
|
||||
.unwrap();
|
||||
let res = syntax.update(source, source, &ChangeSet::new(source));
|
||||
|
||||
syntax
|
||||
if res.is_err() {
|
||||
log::error!("TS parser failed, disabeling TS for the current buffer: {res:?}");
|
||||
return None;
|
||||
}
|
||||
Some(syntax)
|
||||
}
|
||||
|
||||
pub fn update(
|
||||
|
@ -925,6 +931,7 @@ impl Syntax {
|
|||
|
||||
PARSER.with(|ts_parser| {
|
||||
let ts_parser = &mut ts_parser.borrow_mut();
|
||||
ts_parser.parser.set_timeout_micros(1000 * 500); // half a second is pretty generours
|
||||
let mut cursor = ts_parser.cursors.pop().unwrap_or_else(QueryCursor::new);
|
||||
// TODO: might need to set cursor range
|
||||
cursor.set_byte_range(0..usize::MAX);
|
||||
|
@ -2371,7 +2378,7 @@ mod test {
|
|||
let mut cursor = QueryCursor::new();
|
||||
|
||||
let config = HighlightConfiguration::new(language, "", "", "").unwrap();
|
||||
let syntax = Syntax::new(&source, Arc::new(config), Arc::new(loader));
|
||||
let syntax = Syntax::new(&source, Arc::new(config), Arc::new(loader)).unwrap();
|
||||
|
||||
let root = syntax.tree().root_node();
|
||||
let mut test = |capture, range| {
|
||||
|
@ -2442,7 +2449,7 @@ mod test {
|
|||
fn main() {}
|
||||
",
|
||||
);
|
||||
let syntax = Syntax::new(&source, Arc::new(config), Arc::new(loader));
|
||||
let syntax = Syntax::new(&source, Arc::new(config), Arc::new(loader)).unwrap();
|
||||
let tree = syntax.tree();
|
||||
let root = tree.root_node();
|
||||
assert_eq!(root.kind(), "source_file");
|
||||
|
@ -2529,7 +2536,7 @@ mod test {
|
|||
let language = get_language(language_name).unwrap();
|
||||
|
||||
let config = HighlightConfiguration::new(language, "", "", "").unwrap();
|
||||
let syntax = Syntax::new(&source, Arc::new(config), Arc::new(loader));
|
||||
let syntax = Syntax::new(&source, Arc::new(config), Arc::new(loader)).unwrap();
|
||||
|
||||
let root = syntax
|
||||
.tree()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue