This reverts commit 5cd07648fd.
The separators construct is useful as an optimization. It turns out that
constructing a node for every chunk of whitespace in a document causes a
significant performance regression.
Conflicts:
src/compiler/build_tables/build_lex_table.cc
src/compiler/grammar.cc
src/runtime/parser.c
30 lines
783 B
C++
30 lines
783 B
C++
#include "tree_sitter/compiler.h"
|
|
#include "helpers.h"
|
|
|
|
namespace tree_sitter_examples {
|
|
|
|
using tree_sitter::Grammar;
|
|
using namespace tree_sitter::rules;
|
|
|
|
extern const Grammar json({
|
|
{ "value", choice({
|
|
sym("object"),
|
|
sym("array"),
|
|
sym("string"),
|
|
sym("number"),
|
|
sym("true"),
|
|
sym("false"),
|
|
sym("null"), }) },
|
|
{ "object", in_braces(comma_sep(err(seq({
|
|
sym("string"),
|
|
str(":"),
|
|
sym("value") })))) },
|
|
{ "array", in_brackets(comma_sep(err(sym("value")))) },
|
|
{ "string", pattern("\"([^\"]|\\\\\")*\"") },
|
|
{ "number", pattern("\\d+(\\.\\d+)?") },
|
|
{ "null", keyword("null") },
|
|
{ "true", keyword("true") },
|
|
{ "false", keyword("false") },
|
|
});
|
|
|
|
} // namespace tree_sitter_examples
|