Comment and format
This commit is contained in:
parent
85d8c9df5c
commit
25a254a732
3 changed files with 38 additions and 25 deletions
|
|
@ -3,20 +3,21 @@
|
|||
#include "runtime/tree.h"
|
||||
|
||||
static int advance(TSLexer *lexer) {
|
||||
static const char empty_chunk[2] = { '\0', '\0' };
|
||||
if (lexer->position_in_chunk + 1 < lexer->chunk_size) {
|
||||
lexer->position_in_chunk++;
|
||||
} else {
|
||||
if (lexer->chunk == empty_chunk)
|
||||
return 0;
|
||||
|
||||
lexer->chunk_start += lexer->chunk_size;
|
||||
lexer->chunk = lexer->input.read_fn(lexer->input.data, &lexer->chunk_size);
|
||||
lexer->position_in_chunk = 0;
|
||||
if (lexer->chunk_size == 0) {
|
||||
lexer->chunk = empty_chunk;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
static const char *empty_chunk = "";
|
||||
if (lexer->chunk == empty_chunk)
|
||||
return 0;
|
||||
|
||||
lexer->chunk_start += lexer->chunk_size;
|
||||
lexer->chunk = lexer->input.read_fn(lexer->input.data, &lexer->chunk_size);
|
||||
lexer->position_in_chunk = 0;
|
||||
if (lexer->chunk_size == 0)
|
||||
lexer->chunk = empty_chunk;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
|
@ -28,6 +29,11 @@ static TSTree *accept(TSLexer *lexer, TSSymbol symbol, int is_hidden) {
|
|||
return ts_tree_make_leaf(symbol, size, padding, is_hidden);
|
||||
}
|
||||
|
||||
/*
|
||||
* The `advance` and `accept` methods are stored as fields on the Lexer so
|
||||
* that generated parsers can call them without needing to be linked against
|
||||
* this library.
|
||||
*/
|
||||
TSLexer ts_lexer_make() {
|
||||
return (TSLexer) { .chunk = NULL,
|
||||
.debug = 0,
|
||||
|
|
|
|||
|
|
@ -2,15 +2,13 @@
|
|||
#include "runtime/tree.h"
|
||||
#include "runtime/stack.h"
|
||||
|
||||
static size_t INITIAL_STACK_SIZE = 100;
|
||||
static size_t INITIAL_SIZE = 100;
|
||||
static TSStateId INITIAL_STATE = 0;
|
||||
|
||||
TSStack ts_stack_make() {
|
||||
TSStack result = { .size = 0,
|
||||
.capacity = INITIAL_STACK_SIZE,
|
||||
.entries =
|
||||
calloc(INITIAL_STACK_SIZE, sizeof(*result.entries)), };
|
||||
return result;
|
||||
return (TSStack) { .size = 0,
|
||||
.capacity = INITIAL_SIZE,
|
||||
.entries = malloc(INITIAL_SIZE * sizeof(TSStackEntry)) };
|
||||
}
|
||||
|
||||
void ts_stack_delete(TSStack *stack) {
|
||||
|
|
|
|||
|
|
@ -34,8 +34,10 @@ TSTree *ts_tree_make_leaf(TSSymbol symbol, size_t size, size_t padding,
|
|||
|
||||
TSTree *ts_tree_make_node(TSSymbol symbol, size_t child_count,
|
||||
TSTree **children, int is_hidden) {
|
||||
|
||||
/*
|
||||
* Determine size, padding and visible child count based on child nodes.
|
||||
* Determine the new node's size, padding and visible child count based on
|
||||
* the given child nodes.
|
||||
*/
|
||||
size_t size = 0, padding = 0, visible_child_count = 0;
|
||||
for (size_t i = 0; i < child_count; i++) {
|
||||
|
|
@ -55,7 +57,7 @@ TSTree *ts_tree_make_node(TSSymbol symbol, size_t child_count,
|
|||
}
|
||||
|
||||
/*
|
||||
* Mark tree as hidden if it wraps a single child node.
|
||||
* Mark the tree as hidden if it wraps a single child node.
|
||||
*/
|
||||
TSTreeOptions options = 0;
|
||||
if (is_hidden)
|
||||
|
|
@ -64,6 +66,10 @@ TSTree *ts_tree_make_node(TSSymbol symbol, size_t child_count,
|
|||
(ts_tree_is_visible(children[0]) || ts_tree_is_wrapper(children[0])))
|
||||
options |= (TSTreeOptionsWrapper | TSTreeOptionsHidden);
|
||||
|
||||
/*
|
||||
* Store the visible child array adjacent to the tree itself. This avoids
|
||||
* performing a second allocation and storing an additional pointer.
|
||||
*/
|
||||
TSTree *result =
|
||||
malloc(sizeof(TSTree) + (visible_child_count * sizeof(TSTreeChild)));
|
||||
*result = (TSTree) { .ref_count = 1,
|
||||
|
|
@ -77,9 +83,8 @@ TSTree *ts_tree_make_node(TSSymbol symbol, size_t child_count,
|
|||
result->visible_child_count = visible_child_count;
|
||||
|
||||
/*
|
||||
* Associate a relative offset with each of the visible child nodes, so
|
||||
* that their positions can be queried without dealing with the hidden child
|
||||
* nodes.
|
||||
* Associate a relative offset with each of the visible child nodes, so that
|
||||
* their positions can be queried without using the hidden child nodes.
|
||||
*/
|
||||
TSTreeChild *visible_children = ts_tree_visible_children(result, NULL);
|
||||
for (size_t i = 0, vis_i = 0, offset = 0; i < child_count; i++) {
|
||||
|
|
@ -193,9 +198,13 @@ static size_t tree_write_to_string(const TSTree *tree,
|
|||
}
|
||||
|
||||
char *ts_tree_string(const TSTree *tree, const char **symbol_names) {
|
||||
static char SCRATCH_STRING[1];
|
||||
size_t size =
|
||||
tree_write_to_string(tree, symbol_names, SCRATCH_STRING, 0, 1) + 1;
|
||||
|
||||
/*
|
||||
* Determine how long the string will need to be up front so that
|
||||
* the right amount of memory can be allocated.
|
||||
*/
|
||||
static char SCRATCH[1];
|
||||
size_t size = tree_write_to_string(tree, symbol_names, SCRATCH, 0, 1) + 1;
|
||||
char *result = malloc(size * sizeof(char));
|
||||
tree_write_to_string(tree, symbol_names, result, size, 1);
|
||||
return result;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue