fix: relax tree-sitter full reparse time limit to avoid incremental parsing
This commit is contained in:
parent
9b6e01f358
commit
66dfcd4a91
1 changed files with 5 additions and 5 deletions
|
@ -36,7 +36,7 @@ const scroll_step_small = 3;
|
||||||
const scroll_cursor_min_border_distance = 5;
|
const scroll_cursor_min_border_distance = 5;
|
||||||
|
|
||||||
const double_click_time_ms = 350;
|
const double_click_time_ms = 350;
|
||||||
const syntax_refresh_update_time = 10; // ms
|
const syntax_full_reparse_time_limit = 30; // ms
|
||||||
|
|
||||||
pub const max_matches = if (builtin.mode == std.builtin.OptimizeMode.Debug) 10_000 else 100_000;
|
pub const max_matches = if (builtin.mode == std.builtin.OptimizeMode.Debug) 10_000 else 100_000;
|
||||||
pub const max_match_lines = 15;
|
pub const max_match_lines = 15;
|
||||||
|
@ -251,7 +251,7 @@ pub const Editor = struct {
|
||||||
syntax_no_render: bool = false,
|
syntax_no_render: bool = false,
|
||||||
syntax_refresh_full: bool = false,
|
syntax_refresh_full: bool = false,
|
||||||
syntax_token: usize = 0,
|
syntax_token: usize = 0,
|
||||||
syntax_refresh_update: bool = false,
|
syntax_incremental_reparse: bool = false,
|
||||||
|
|
||||||
style_cache: ?StyleCache = null,
|
style_cache: ?StyleCache = null,
|
||||||
style_cache_theme: []const u8 = "",
|
style_cache_theme: []const u8 = "",
|
||||||
|
@ -3080,7 +3080,7 @@ pub const Editor = struct {
|
||||||
self.syntax_token = 0;
|
self.syntax_token = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!self.syntax_refresh_update)
|
if (!self.syntax_incremental_reparse)
|
||||||
self.syntax_refresh_full = true;
|
self.syntax_refresh_full = true;
|
||||||
if (self.syntax_refresh_full) {
|
if (self.syntax_refresh_full) {
|
||||||
const start_time = std.time.milliTimestamp();
|
const start_time = std.time.milliTimestamp();
|
||||||
|
@ -3090,8 +3090,8 @@ pub const Editor = struct {
|
||||||
try syn.refresh_full(content.items);
|
try syn.refresh_full(content.items);
|
||||||
self.syntax_refresh_full = false;
|
self.syntax_refresh_full = false;
|
||||||
const end_time = std.time.milliTimestamp();
|
const end_time = std.time.milliTimestamp();
|
||||||
if (end_time - start_time > syntax_refresh_update_time)
|
if (end_time - start_time > syntax_full_reparse_time_limit)
|
||||||
self.syntax_refresh_update = true;
|
self.syntax_incremental_reparse = true;
|
||||||
} else {
|
} else {
|
||||||
try syn.refresh_from_buffer(root, self.metrics);
|
try syn.refresh_from_buffer(root, self.metrics);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue