Restored to old state that doesn't leak
This commit is contained in:
parent
1a74bb38d3
commit
7329c95ba0
11 changed files with 1028 additions and 328 deletions
|
|
@ -30,6 +30,10 @@ void ts_tree_delete(TSTree *self)
|
|||
{
|
||||
if (!self)
|
||||
return;
|
||||
|
||||
SubtreePool pool = ts_subtree_pool_new(0);
|
||||
ts_subtree_release(&pool, self->root);
|
||||
ts_subtree_pool_delete(&pool);
|
||||
ts_language_delete(self->language);
|
||||
mem_free(self->included_ranges);
|
||||
mem_free(self);
|
||||
|
|
@ -50,3 +54,56 @@ const TSLanguage *ts_tree_language(const TSTree *self)
|
|||
{
|
||||
return self->language;
|
||||
}
|
||||
|
||||
void ts_tree_edit(TSTree *self, const TSInputEdit *edit)
|
||||
{
|
||||
for (t_u32 i = 0; i < self->included_range_count; i++)
|
||||
{
|
||||
TSRange *range = &self->included_ranges[i];
|
||||
if (range->end_byte >= edit->old_end_byte)
|
||||
{
|
||||
if (range->end_byte != UINT32_MAX)
|
||||
{
|
||||
range->end_byte = edit->new_end_byte + (range->end_byte - edit->old_end_byte);
|
||||
range->end_point = point_add(edit->new_end_point, point_sub(range->end_point, edit->old_end_point));
|
||||
if (range->end_byte < edit->new_end_byte)
|
||||
{
|
||||
range->end_byte = UINT32_MAX;
|
||||
range->end_point = POINT_MAX;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (range->end_byte > edit->start_byte)
|
||||
{
|
||||
range->end_byte = edit->start_byte;
|
||||
range->end_point = edit->start_point;
|
||||
}
|
||||
if (range->start_byte >= edit->old_end_byte)
|
||||
{
|
||||
range->start_byte = edit->new_end_byte + (range->start_byte - edit->old_end_byte);
|
||||
range->start_point = point_add(edit->new_end_point, point_sub(range->start_point, edit->old_end_point));
|
||||
if (range->start_byte < edit->new_end_byte)
|
||||
{
|
||||
range->start_byte = UINT32_MAX;
|
||||
range->start_point = POINT_MAX;
|
||||
}
|
||||
}
|
||||
else if (range->start_byte > edit->start_byte)
|
||||
{
|
||||
range->start_byte = edit->start_byte;
|
||||
range->start_point = edit->start_point;
|
||||
}
|
||||
}
|
||||
|
||||
SubtreePool pool = ts_subtree_pool_new(0);
|
||||
self->root = ts_subtree_edit(self->root, edit, &pool);
|
||||
ts_subtree_pool_delete(&pool);
|
||||
}
|
||||
|
||||
TSRange *ts_tree_included_ranges(const TSTree *self, t_u32 *length)
|
||||
{
|
||||
*length = self->included_range_count;
|
||||
TSRange *ranges = mem_alloc_array(self->included_range_count, sizeof(TSRange));
|
||||
memcpy(ranges, self->included_ranges, self->included_range_count * sizeof(TSRange));
|
||||
return ranges;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue