]> git.r.bdr.sh - rbdr/tree-sitter-api-notation/blame - src/tree_sitter/parser.h
Add vimscript
[rbdr/tree-sitter-api-notation] / src / tree_sitter / parser.h
CommitLineData
dc87cd89
RBR
1#ifndef TREE_SITTER_PARSER_H_
2#define TREE_SITTER_PARSER_H_
3
4#ifdef __cplusplus
5extern "C" {
6#endif
7
8#include <stdbool.h>
9#include <stdint.h>
10#include <stdlib.h>
11
12#define ts_builtin_sym_error ((TSSymbol)-1)
13#define ts_builtin_sym_end 0
14#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
15
16typedef uint16_t TSStateId;
17
18#ifndef TREE_SITTER_API_H_
19typedef uint16_t TSSymbol;
20typedef uint16_t TSFieldId;
21typedef struct TSLanguage TSLanguage;
22#endif
23
24typedef struct {
25 TSFieldId field_id;
26 uint8_t child_index;
27 bool inherited;
28} TSFieldMapEntry;
29
30typedef struct {
31 uint16_t index;
32 uint16_t length;
33} TSFieldMapSlice;
34
35typedef struct {
36 bool visible;
37 bool named;
38 bool supertype;
39} TSSymbolMetadata;
40
41typedef struct TSLexer TSLexer;
42
43struct TSLexer {
44 int32_t lookahead;
45 TSSymbol result_symbol;
46 void (*advance)(TSLexer *, bool);
47 void (*mark_end)(TSLexer *);
48 uint32_t (*get_column)(TSLexer *);
49 bool (*is_at_included_range_start)(const TSLexer *);
50 bool (*eof)(const TSLexer *);
51};
52
53typedef enum {
54 TSParseActionTypeShift,
55 TSParseActionTypeReduce,
56 TSParseActionTypeAccept,
57 TSParseActionTypeRecover,
58} TSParseActionType;
59
60typedef union {
61 struct {
62 uint8_t type;
63 TSStateId state;
64 bool extra;
65 bool repetition;
66 } shift;
67 struct {
68 uint8_t type;
69 uint8_t child_count;
70 TSSymbol symbol;
71 int16_t dynamic_precedence;
72 uint16_t production_id;
73 } reduce;
74 uint8_t type;
75} TSParseAction;
76
77typedef struct {
78 uint16_t lex_state;
79 uint16_t external_lex_state;
80} TSLexMode;
81
82typedef union {
83 TSParseAction action;
84 struct {
85 uint8_t count;
86 bool reusable;
87 } entry;
88} TSParseActionEntry;
89
90struct TSLanguage {
91 uint32_t version;
92 uint32_t symbol_count;
93 uint32_t alias_count;
94 uint32_t token_count;
95 uint32_t external_token_count;
96 uint32_t state_count;
97 uint32_t large_state_count;
98 uint32_t production_id_count;
99 uint32_t field_count;
100 uint16_t max_alias_sequence_length;
101 const uint16_t *parse_table;
102 const uint16_t *small_parse_table;
103 const uint32_t *small_parse_table_map;
104 const TSParseActionEntry *parse_actions;
105 const char * const *symbol_names;
106 const char * const *field_names;
107 const TSFieldMapSlice *field_map_slices;
108 const TSFieldMapEntry *field_map_entries;
109 const TSSymbolMetadata *symbol_metadata;
110 const TSSymbol *public_symbol_map;
111 const uint16_t *alias_map;
112 const TSSymbol *alias_sequences;
113 const TSLexMode *lex_modes;
114 bool (*lex_fn)(TSLexer *, TSStateId);
115 bool (*keyword_lex_fn)(TSLexer *, TSStateId);
116 TSSymbol keyword_capture_token;
117 struct {
118 const bool *states;
119 const TSSymbol *symbol_map;
120 void *(*create)(void);
121 void (*destroy)(void *);
122 bool (*scan)(void *, TSLexer *, const bool *symbol_whitelist);
123 unsigned (*serialize)(void *, char *);
124 void (*deserialize)(void *, const char *, unsigned);
125 } external_scanner;
126 const TSStateId *primary_state_ids;
127};
128
129/*
130 * Lexer Macros
131 */
132
133#define START_LEXER() \
134 bool result = false; \
135 bool skip = false; \
136 bool eof = false; \
137 int32_t lookahead; \
138 goto start; \
139 next_state: \
140 lexer->advance(lexer, skip); \
141 start: \
142 skip = false; \
143 lookahead = lexer->lookahead;
144
145#define ADVANCE(state_value) \
146 { \
147 state = state_value; \
148 goto next_state; \
149 }
150
151#define SKIP(state_value) \
152 { \
153 skip = true; \
154 state = state_value; \
155 goto next_state; \
156 }
157
158#define ACCEPT_TOKEN(symbol_value) \
159 result = true; \
160 lexer->result_symbol = symbol_value; \
161 lexer->mark_end(lexer);
162
163#define END_STATE() return result;
164
165/*
166 * Parse Table Macros
167 */
168
169#define SMALL_STATE(id) id - LARGE_STATE_COUNT
170
171#define STATE(id) id
172
173#define ACTIONS(id) id
174
175#define SHIFT(state_value) \
176 {{ \
177 .shift = { \
178 .type = TSParseActionTypeShift, \
179 .state = state_value \
180 } \
181 }}
182
183#define SHIFT_REPEAT(state_value) \
184 {{ \
185 .shift = { \
186 .type = TSParseActionTypeShift, \
187 .state = state_value, \
188 .repetition = true \
189 } \
190 }}
191
192#define SHIFT_EXTRA() \
193 {{ \
194 .shift = { \
195 .type = TSParseActionTypeShift, \
196 .extra = true \
197 } \
198 }}
199
200#define REDUCE(symbol_val, child_count_val, ...) \
201 {{ \
202 .reduce = { \
203 .type = TSParseActionTypeReduce, \
204 .symbol = symbol_val, \
205 .child_count = child_count_val, \
206 __VA_ARGS__ \
207 }, \
208 }}
209
210#define RECOVER() \
211 {{ \
212 .type = TSParseActionTypeRecover \
213 }}
214
215#define ACCEPT_INPUT() \
216 {{ \
217 .type = TSParseActionTypeAccept \
218 }}
219
220#ifdef __cplusplus
221}
222#endif
223
224#endif // TREE_SITTER_PARSER_H_