From 5d676de05180434690c91ad05c57870dd6ffe109 Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Thu, 7 Dec 2017 11:40:57 -0800 Subject: [PATCH] Remove unnecessary conditional in parser__accept --- src/runtime/parser.c | 27 +++++++++++---------------- 1 file changed, 11 insertions(+), 16 deletions(-) diff --git a/src/runtime/parser.c b/src/runtime/parser.c index 310df80e..e843cbf0 100644 --- a/src/runtime/parser.c +++ b/src/runtime/parser.c @@ -747,22 +747,17 @@ static void parser__accept(Parser *self, StackVersion version, TreeArray trees = slice.trees; Tree *root = NULL; - if (trees.size == 1) { - root = trees.contents[0]; - array_delete(&trees); - } else { - for (uint32_t j = trees.size - 1; j + 1 > 0; j--) { - Tree *child = trees.contents[j]; - if (!child->extra) { - root = ts_tree_make_copy(child); - root->child_count = 0; - for (uint32_t k = 0; k < child->child_count; k++) - ts_tree_retain(child->children[k]); - array_splice(&trees, j, 1, child->child_count, child->children); - ts_tree_set_children(root, trees.size, trees.contents, self->language); - ts_tree_release(child); - break; - } + for (uint32_t j = trees.size - 1; j + 1 > 0; j--) { + Tree *child = trees.contents[j]; + if (!child->extra) { + root = ts_tree_make_copy(child); + root->child_count = 0; + for (uint32_t k = 0; k < child->child_count; k++) + ts_tree_retain(child->children[k]); + array_splice(&trees, j, 1, child->child_count, child->children); + ts_tree_set_children(root, trees.size, trees.contents, self->language); + ts_tree_release(child); + break; } }