feat: upgrade to tree-sitter@0.19.3
BREAKING CHANGE: require tree-sitter 0.19+
This commit is contained in:
parent
084da152d8
commit
e8801768c1
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -1,2 +1,5 @@
|
||||||
/build
|
/build
|
||||||
/node_modules
|
/node_modules
|
||||||
|
|
||||||
|
/bindings/rust
|
||||||
|
/Cargo.toml
|
||||||
|
|
2
.gitmodules
vendored
2
.gitmodules
vendored
|
@ -1,4 +1,4 @@
|
||||||
[submodule "tree-sitter"]
|
[submodule "tree-sitter"]
|
||||||
path = tree-sitter
|
path = tree-sitter
|
||||||
url = https://github.com/ikatyang/tree-sitter
|
url = https://github.com/ikatyang/tree-sitter
|
||||||
branch = 0.16.7-custom
|
branch = v0.19.3-custom
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
"sources": [
|
"sources": [
|
||||||
"src/parser.c",
|
"src/parser.c",
|
||||||
"src/scanner.c",
|
"src/scanner.c",
|
||||||
"src/binding.cc"
|
"bindings/node/binding.cc"
|
||||||
],
|
],
|
||||||
"cflags_c": [
|
"cflags_c": [
|
||||||
"-std=c99",
|
"-std=c99",
|
||||||
|
|
19
bindings/node/index.js
Normal file
19
bindings/node/index.js
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
try {
|
||||||
|
module.exports = require("../../build/Release/tree_sitter_toml_binding");
|
||||||
|
} catch (error1) {
|
||||||
|
if (error1.code !== 'MODULE_NOT_FOUND') {
|
||||||
|
throw error1;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
module.exports = require("../../build/Debug/tree_sitter_toml_binding");
|
||||||
|
} catch (error2) {
|
||||||
|
if (error2.code !== 'MODULE_NOT_FOUND') {
|
||||||
|
throw error2;
|
||||||
|
}
|
||||||
|
throw error1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
module.exports.nodeTypeInfo = require("../../src/node-types.json");
|
||||||
|
} catch (_) {}
|
13
index.js
generated
13
index.js
generated
|
@ -1,13 +0,0 @@
|
||||||
try {
|
|
||||||
module.exports = require("./build/Release/tree_sitter_toml_binding");
|
|
||||||
} catch (error) {
|
|
||||||
try {
|
|
||||||
module.exports = require("./build/Debug/tree_sitter_toml_binding");
|
|
||||||
} catch (_) {
|
|
||||||
throw error
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
module.exports.nodeTypeInfo = require("./src/node-types.json");
|
|
||||||
} catch (_) {}
|
|
|
@ -6,7 +6,7 @@
|
||||||
"parser",
|
"parser",
|
||||||
"lexer"
|
"lexer"
|
||||||
],
|
],
|
||||||
"main": "index.js",
|
"main": "bindings/node",
|
||||||
"repository": "https://github.com/ikatyang/tree-sitter-toml",
|
"repository": "https://github.com/ikatyang/tree-sitter-toml",
|
||||||
"homepage": "https://github.com/ikatyang/tree-sitter-toml#readme",
|
"homepage": "https://github.com/ikatyang/tree-sitter-toml#readme",
|
||||||
"author": {
|
"author": {
|
||||||
|
@ -37,9 +37,8 @@
|
||||||
"files": [
|
"files": [
|
||||||
"/src/",
|
"/src/",
|
||||||
"/queries/",
|
"/queries/",
|
||||||
"/binding.gyp",
|
"/bindings/node/",
|
||||||
"/grammar.js",
|
"/grammar.js"
|
||||||
"/index.js"
|
|
||||||
],
|
],
|
||||||
"tree-sitter": [
|
"tree-sitter": [
|
||||||
{
|
{
|
||||||
|
|
1
src/grammar.json
generated
1
src/grammar.json
generated
|
@ -809,6 +809,7 @@
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"conflicts": [],
|
"conflicts": [],
|
||||||
|
"precedences": [],
|
||||||
"externals": [
|
"externals": [
|
||||||
{
|
{
|
||||||
"type": "SYMBOL",
|
"type": "SYMBOL",
|
||||||
|
|
4
src/node-types.json
generated
4
src/node-types.json
generated
|
@ -320,6 +320,10 @@
|
||||||
"type": "boolean",
|
"type": "boolean",
|
||||||
"named": true
|
"named": true
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"type": "comment",
|
||||||
|
"named": true
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type": "escape_sequence",
|
"type": "escape_sequence",
|
||||||
"named": true
|
"named": true
|
||||||
|
|
41
src/parser.c
generated
41
src/parser.c
generated
|
@ -5,7 +5,7 @@
|
||||||
#pragma GCC diagnostic ignored "-Wmissing-field-initializers"
|
#pragma GCC diagnostic ignored "-Wmissing-field-initializers"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define LANGUAGE_VERSION 11
|
#define LANGUAGE_VERSION 13
|
||||||
#define STATE_COUNT 152
|
#define STATE_COUNT 152
|
||||||
#define LARGE_STATE_COUNT 2
|
#define LARGE_STATE_COUNT 2
|
||||||
#define SYMBOL_COUNT 66
|
#define SYMBOL_COUNT 66
|
||||||
|
@ -14,6 +14,7 @@
|
||||||
#define EXTERNAL_TOKEN_COUNT 5
|
#define EXTERNAL_TOKEN_COUNT 5
|
||||||
#define FIELD_COUNT 0
|
#define FIELD_COUNT 0
|
||||||
#define MAX_ALIAS_SEQUENCE_LENGTH 8
|
#define MAX_ALIAS_SEQUENCE_LENGTH 8
|
||||||
|
#define PRODUCTION_ID_COUNT 2
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
aux_sym_document_token1 = 1,
|
aux_sym_document_token1 = 1,
|
||||||
|
@ -488,13 +489,20 @@ static const TSSymbolMetadata ts_symbol_metadata[] = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static TSSymbol ts_alias_sequences[2][MAX_ALIAS_SEQUENCE_LENGTH] = {
|
static TSSymbol ts_alias_sequences[PRODUCTION_ID_COUNT][MAX_ALIAS_SEQUENCE_LENGTH] = {
|
||||||
[0] = {0},
|
[0] = {0},
|
||||||
[1] = {
|
[1] = {
|
||||||
[1] = sym_pair,
|
[1] = sym_pair,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static uint16_t ts_non_terminal_alias_map[] = {
|
||||||
|
sym__inline_pair, 2,
|
||||||
|
sym__inline_pair,
|
||||||
|
sym_pair,
|
||||||
|
0,
|
||||||
|
};
|
||||||
|
|
||||||
static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
START_LEXER();
|
START_LEXER();
|
||||||
eof = lexer->eof(lexer);
|
eof = lexer->eof(lexer);
|
||||||
|
@ -542,7 +550,7 @@ static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
if (lookahead == '\t' ||
|
if (lookahead == '\t' ||
|
||||||
lookahead == ' ') ADVANCE(124);
|
lookahead == ' ') ADVANCE(124);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 31 < lookahead) &&
|
lookahead > 31 &&
|
||||||
lookahead != 127) ADVANCE(125);
|
lookahead != 127) ADVANCE(125);
|
||||||
END_STATE();
|
END_STATE();
|
||||||
case 3:
|
case 3:
|
||||||
|
@ -553,7 +561,7 @@ static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
if (lookahead == '\t' ||
|
if (lookahead == '\t' ||
|
||||||
lookahead == ' ') ADVANCE(134);
|
lookahead == ' ') ADVANCE(134);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 31 < lookahead) &&
|
lookahead > 31 &&
|
||||||
lookahead != 127) ADVANCE(135);
|
lookahead != 127) ADVANCE(135);
|
||||||
END_STATE();
|
END_STATE();
|
||||||
case 4:
|
case 4:
|
||||||
|
@ -908,7 +916,7 @@ static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
case 79:
|
case 79:
|
||||||
ACCEPT_TOKEN(sym_comment);
|
ACCEPT_TOKEN(sym_comment);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 8 < lookahead) &&
|
lookahead > 8 &&
|
||||||
(lookahead < '\n' || 31 < lookahead) &&
|
(lookahead < '\n' || 31 < lookahead) &&
|
||||||
lookahead != 127) ADVANCE(79);
|
lookahead != 127) ADVANCE(79);
|
||||||
END_STATE();
|
END_STATE();
|
||||||
|
@ -1269,7 +1277,7 @@ static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
if (lookahead == '\t' ||
|
if (lookahead == '\t' ||
|
||||||
lookahead == ' ') ADVANCE(124);
|
lookahead == ' ') ADVANCE(124);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 31 < lookahead) &&
|
lookahead > 31 &&
|
||||||
lookahead != '"' &&
|
lookahead != '"' &&
|
||||||
lookahead != '\\' &&
|
lookahead != '\\' &&
|
||||||
lookahead != 127) ADVANCE(125);
|
lookahead != 127) ADVANCE(125);
|
||||||
|
@ -1277,7 +1285,7 @@ static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
case 125:
|
case 125:
|
||||||
ACCEPT_TOKEN(aux_sym__basic_string_token1);
|
ACCEPT_TOKEN(aux_sym__basic_string_token1);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 8 < lookahead) &&
|
lookahead > 8 &&
|
||||||
(lookahead < '\n' || 31 < lookahead) &&
|
(lookahead < '\n' || 31 < lookahead) &&
|
||||||
lookahead != '"' &&
|
lookahead != '"' &&
|
||||||
lookahead != '\\' &&
|
lookahead != '\\' &&
|
||||||
|
@ -1315,14 +1323,14 @@ static bool ts_lex(TSLexer *lexer, TSStateId state) {
|
||||||
if (lookahead == '\t' ||
|
if (lookahead == '\t' ||
|
||||||
lookahead == ' ') ADVANCE(134);
|
lookahead == ' ') ADVANCE(134);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 31 < lookahead) &&
|
lookahead > 31 &&
|
||||||
lookahead != '\'' &&
|
lookahead != '\'' &&
|
||||||
lookahead != 127) ADVANCE(135);
|
lookahead != 127) ADVANCE(135);
|
||||||
END_STATE();
|
END_STATE();
|
||||||
case 135:
|
case 135:
|
||||||
ACCEPT_TOKEN(aux_sym__literal_string_token1);
|
ACCEPT_TOKEN(aux_sym__literal_string_token1);
|
||||||
if (lookahead != 0 &&
|
if (lookahead != 0 &&
|
||||||
(lookahead < 0 || 8 < lookahead) &&
|
lookahead > 8 &&
|
||||||
(lookahead < '\n' || 31 < lookahead) &&
|
(lookahead < '\n' || 31 < lookahead) &&
|
||||||
lookahead != '\'' &&
|
lookahead != '\'' &&
|
||||||
lookahead != 127) ADVANCE(135);
|
lookahead != 127) ADVANCE(135);
|
||||||
|
@ -4534,20 +4542,23 @@ extern const TSLanguage *tree_sitter_toml(void) {
|
||||||
.symbol_count = SYMBOL_COUNT,
|
.symbol_count = SYMBOL_COUNT,
|
||||||
.alias_count = ALIAS_COUNT,
|
.alias_count = ALIAS_COUNT,
|
||||||
.token_count = TOKEN_COUNT,
|
.token_count = TOKEN_COUNT,
|
||||||
|
.external_token_count = EXTERNAL_TOKEN_COUNT,
|
||||||
|
.state_count = STATE_COUNT,
|
||||||
.large_state_count = LARGE_STATE_COUNT,
|
.large_state_count = LARGE_STATE_COUNT,
|
||||||
.symbol_metadata = ts_symbol_metadata,
|
.production_id_count = PRODUCTION_ID_COUNT,
|
||||||
.parse_table = (const unsigned short *)ts_parse_table,
|
.field_count = FIELD_COUNT,
|
||||||
|
.max_alias_sequence_length = MAX_ALIAS_SEQUENCE_LENGTH,
|
||||||
|
.parse_table = (const uint16_t *)ts_parse_table,
|
||||||
.small_parse_table = (const uint16_t *)ts_small_parse_table,
|
.small_parse_table = (const uint16_t *)ts_small_parse_table,
|
||||||
.small_parse_table_map = (const uint32_t *)ts_small_parse_table_map,
|
.small_parse_table_map = (const uint32_t *)ts_small_parse_table_map,
|
||||||
.parse_actions = ts_parse_actions,
|
.parse_actions = ts_parse_actions,
|
||||||
.lex_modes = ts_lex_modes,
|
|
||||||
.symbol_names = ts_symbol_names,
|
.symbol_names = ts_symbol_names,
|
||||||
|
.symbol_metadata = ts_symbol_metadata,
|
||||||
.public_symbol_map = ts_symbol_map,
|
.public_symbol_map = ts_symbol_map,
|
||||||
|
.alias_map = ts_non_terminal_alias_map,
|
||||||
.alias_sequences = (const TSSymbol *)ts_alias_sequences,
|
.alias_sequences = (const TSSymbol *)ts_alias_sequences,
|
||||||
.field_count = FIELD_COUNT,
|
.lex_modes = ts_lex_modes,
|
||||||
.max_alias_sequence_length = MAX_ALIAS_SEQUENCE_LENGTH,
|
|
||||||
.lex_fn = ts_lex,
|
.lex_fn = ts_lex,
|
||||||
.external_token_count = EXTERNAL_TOKEN_COUNT,
|
|
||||||
.external_scanner = {
|
.external_scanner = {
|
||||||
(const bool *)ts_external_scanner_states,
|
(const bool *)ts_external_scanner_states,
|
||||||
ts_external_scanner_symbol_map,
|
ts_external_scanner_symbol_map,
|
||||||
|
|
114
src/tree_sitter/parser.h
generated
114
src/tree_sitter/parser.h
generated
|
@ -13,6 +13,8 @@ extern "C" {
|
||||||
#define ts_builtin_sym_end 0
|
#define ts_builtin_sym_end 0
|
||||||
#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
|
#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
|
||||||
|
|
||||||
|
typedef uint16_t TSStateId;
|
||||||
|
|
||||||
#ifndef TREE_SITTER_API_H_
|
#ifndef TREE_SITTER_API_H_
|
||||||
typedef uint16_t TSSymbol;
|
typedef uint16_t TSSymbol;
|
||||||
typedef uint16_t TSFieldId;
|
typedef uint16_t TSFieldId;
|
||||||
|
@ -30,11 +32,10 @@ typedef struct {
|
||||||
uint16_t length;
|
uint16_t length;
|
||||||
} TSFieldMapSlice;
|
} TSFieldMapSlice;
|
||||||
|
|
||||||
typedef uint16_t TSStateId;
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
bool visible : 1;
|
bool visible;
|
||||||
bool named : 1;
|
bool named;
|
||||||
|
bool supertype;
|
||||||
} TSSymbolMetadata;
|
} TSSymbolMetadata;
|
||||||
|
|
||||||
typedef struct TSLexer TSLexer;
|
typedef struct TSLexer TSLexer;
|
||||||
|
@ -56,21 +57,21 @@ typedef enum {
|
||||||
TSParseActionTypeRecover,
|
TSParseActionTypeRecover,
|
||||||
} TSParseActionType;
|
} TSParseActionType;
|
||||||
|
|
||||||
typedef struct {
|
typedef union {
|
||||||
union {
|
|
||||||
struct {
|
struct {
|
||||||
|
uint8_t type;
|
||||||
TSStateId state;
|
TSStateId state;
|
||||||
bool extra : 1;
|
bool extra;
|
||||||
bool repetition : 1;
|
bool repetition;
|
||||||
} shift;
|
} shift;
|
||||||
struct {
|
struct {
|
||||||
|
uint8_t type;
|
||||||
|
uint8_t child_count;
|
||||||
TSSymbol symbol;
|
TSSymbol symbol;
|
||||||
int16_t dynamic_precedence;
|
int16_t dynamic_precedence;
|
||||||
uint8_t child_count;
|
uint16_t production_id;
|
||||||
uint8_t production_id;
|
|
||||||
} reduce;
|
} reduce;
|
||||||
} params;
|
uint8_t type;
|
||||||
TSParseActionType type : 4;
|
|
||||||
} TSParseAction;
|
} TSParseAction;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -82,7 +83,7 @@ typedef union {
|
||||||
TSParseAction action;
|
TSParseAction action;
|
||||||
struct {
|
struct {
|
||||||
uint8_t count;
|
uint8_t count;
|
||||||
bool reusable : 1;
|
bool reusable;
|
||||||
} entry;
|
} entry;
|
||||||
} TSParseActionEntry;
|
} TSParseActionEntry;
|
||||||
|
|
||||||
|
@ -92,13 +93,24 @@ struct TSLanguage {
|
||||||
uint32_t alias_count;
|
uint32_t alias_count;
|
||||||
uint32_t token_count;
|
uint32_t token_count;
|
||||||
uint32_t external_token_count;
|
uint32_t external_token_count;
|
||||||
const char **symbol_names;
|
uint32_t state_count;
|
||||||
const TSSymbolMetadata *symbol_metadata;
|
uint32_t large_state_count;
|
||||||
const uint16_t *parse_table;
|
uint32_t production_id_count;
|
||||||
const TSParseActionEntry *parse_actions;
|
uint32_t field_count;
|
||||||
const TSLexMode *lex_modes;
|
|
||||||
const TSSymbol *alias_sequences;
|
|
||||||
uint16_t max_alias_sequence_length;
|
uint16_t max_alias_sequence_length;
|
||||||
|
const uint16_t *parse_table;
|
||||||
|
const uint16_t *small_parse_table;
|
||||||
|
const uint32_t *small_parse_table_map;
|
||||||
|
const TSParseActionEntry *parse_actions;
|
||||||
|
const char **symbol_names;
|
||||||
|
const char **field_names;
|
||||||
|
const TSFieldMapSlice *field_map_slices;
|
||||||
|
const TSFieldMapEntry *field_map_entries;
|
||||||
|
const TSSymbolMetadata *symbol_metadata;
|
||||||
|
const TSSymbol *public_symbol_map;
|
||||||
|
const uint16_t *alias_map;
|
||||||
|
const TSSymbol *alias_sequences;
|
||||||
|
const TSLexMode *lex_modes;
|
||||||
bool (*lex_fn)(TSLexer *, TSStateId);
|
bool (*lex_fn)(TSLexer *, TSStateId);
|
||||||
bool (*keyword_lex_fn)(TSLexer *, TSStateId);
|
bool (*keyword_lex_fn)(TSLexer *, TSStateId);
|
||||||
TSSymbol keyword_capture_token;
|
TSSymbol keyword_capture_token;
|
||||||
|
@ -111,14 +123,6 @@ struct TSLanguage {
|
||||||
unsigned (*serialize)(void *, char *);
|
unsigned (*serialize)(void *, char *);
|
||||||
void (*deserialize)(void *, const char *, unsigned);
|
void (*deserialize)(void *, const char *, unsigned);
|
||||||
} external_scanner;
|
} external_scanner;
|
||||||
uint32_t field_count;
|
|
||||||
const TSFieldMapSlice *field_map_slices;
|
|
||||||
const TSFieldMapEntry *field_map_entries;
|
|
||||||
const char **field_names;
|
|
||||||
uint32_t large_state_count;
|
|
||||||
const uint16_t *small_parse_table;
|
|
||||||
const uint32_t *small_parse_table_map;
|
|
||||||
const TSSymbol *public_symbol_map;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -168,65 +172,49 @@ struct TSLanguage {
|
||||||
#define ACTIONS(id) id
|
#define ACTIONS(id) id
|
||||||
|
|
||||||
#define SHIFT(state_value) \
|
#define SHIFT(state_value) \
|
||||||
{ \
|
{{ \
|
||||||
{ \
|
|
||||||
.params = { \
|
|
||||||
.shift = { \
|
.shift = { \
|
||||||
|
.type = TSParseActionTypeShift, \
|
||||||
.state = state_value \
|
.state = state_value \
|
||||||
} \
|
} \
|
||||||
}, \
|
}}
|
||||||
.type = TSParseActionTypeShift \
|
|
||||||
} \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SHIFT_REPEAT(state_value) \
|
#define SHIFT_REPEAT(state_value) \
|
||||||
{ \
|
{{ \
|
||||||
{ \
|
|
||||||
.params = { \
|
|
||||||
.shift = { \
|
.shift = { \
|
||||||
|
.type = TSParseActionTypeShift, \
|
||||||
.state = state_value, \
|
.state = state_value, \
|
||||||
.repetition = true \
|
.repetition = true \
|
||||||
} \
|
} \
|
||||||
}, \
|
}}
|
||||||
.type = TSParseActionTypeShift \
|
|
||||||
} \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define RECOVER() \
|
|
||||||
{ \
|
|
||||||
{ .type = TSParseActionTypeRecover } \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SHIFT_EXTRA() \
|
#define SHIFT_EXTRA() \
|
||||||
{ \
|
{{ \
|
||||||
{ \
|
|
||||||
.params = { \
|
|
||||||
.shift = { \
|
.shift = { \
|
||||||
|
.type = TSParseActionTypeShift, \
|
||||||
.extra = true \
|
.extra = true \
|
||||||
} \
|
} \
|
||||||
}, \
|
}}
|
||||||
.type = TSParseActionTypeShift \
|
|
||||||
} \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define REDUCE(symbol_val, child_count_val, ...) \
|
#define REDUCE(symbol_val, child_count_val, ...) \
|
||||||
{ \
|
{{ \
|
||||||
{ \
|
|
||||||
.params = { \
|
|
||||||
.reduce = { \
|
.reduce = { \
|
||||||
|
.type = TSParseActionTypeReduce, \
|
||||||
.symbol = symbol_val, \
|
.symbol = symbol_val, \
|
||||||
.child_count = child_count_val, \
|
.child_count = child_count_val, \
|
||||||
__VA_ARGS__ \
|
__VA_ARGS__ \
|
||||||
}, \
|
}, \
|
||||||
}, \
|
}}
|
||||||
.type = TSParseActionTypeReduce \
|
|
||||||
} \
|
#define RECOVER() \
|
||||||
}
|
{{ \
|
||||||
|
.type = TSParseActionTypeRecover \
|
||||||
|
}}
|
||||||
|
|
||||||
#define ACCEPT_INPUT() \
|
#define ACCEPT_INPUT() \
|
||||||
{ \
|
{{ \
|
||||||
{ .type = TSParseActionTypeAccept } \
|
.type = TSParseActionTypeAccept \
|
||||||
}
|
}}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 1ccb0ac0e840c58f23012dd495bd0180884077e1
|
Subproject commit fc5a692b7d5f144cc531f5823b1c5a3b2f06cf01
|
Loading…
Reference in a new issue