2015-11-20 12:00:49 -08:00
|
|
|
#ifndef RUNTIME_LANGUAGE_H_
|
|
|
|
|
#define RUNTIME_LANGUAGE_H_
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#include "tree_sitter/parser.h"
|
2016-05-09 14:31:44 -07:00
|
|
|
#include "runtime/tree.h"
|
2015-11-20 12:00:49 -08:00
|
|
|
|
2016-06-21 07:28:04 -07:00
|
|
|
typedef struct {
|
|
|
|
|
const TSParseAction *actions;
|
2016-11-14 12:15:24 -08:00
|
|
|
uint32_t action_count;
|
2016-06-21 07:28:04 -07:00
|
|
|
bool is_reusable;
|
|
|
|
|
bool depends_on_lookahead;
|
|
|
|
|
} TableEntry;
|
|
|
|
|
|
2016-11-14 10:35:33 -08:00
|
|
|
void ts_language_table_entry(const TSLanguage *, TSStateId, TSSymbol, TableEntry *);
|
2016-06-21 07:28:04 -07:00
|
|
|
|
2016-11-14 10:35:33 -08:00
|
|
|
TSSymbolMetadata ts_language_symbol_metadata(const TSLanguage *, TSSymbol);
|
2016-02-25 17:36:09 -08:00
|
|
|
|
2016-12-20 17:06:20 -08:00
|
|
|
static inline bool ts_language_is_symbol_external(const TSLanguage *self, TSSymbol symbol) {
|
|
|
|
|
return 0 < symbol && symbol < self->external_token_count + 1;
|
|
|
|
|
}
|
|
|
|
|
|
2016-06-21 07:28:04 -07:00
|
|
|
static inline const TSParseAction *ts_language_actions(const TSLanguage *self,
|
|
|
|
|
TSStateId state,
|
|
|
|
|
TSSymbol symbol,
|
2016-11-14 12:15:24 -08:00
|
|
|
uint32_t *count) {
|
2016-06-21 07:28:04 -07:00
|
|
|
TableEntry entry;
|
|
|
|
|
ts_language_table_entry(self, state, symbol, &entry);
|
|
|
|
|
*count = entry.action_count;
|
|
|
|
|
return entry.actions;
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-14 08:36:06 -08:00
|
|
|
static inline TSStateId ts_language_next_state(const TSLanguage *self,
|
|
|
|
|
TSStateId state,
|
|
|
|
|
TSSymbol symbol) {
|
|
|
|
|
if (symbol == ts_builtin_sym_error) {
|
|
|
|
|
return 0;
|
|
|
|
|
} else if (symbol < self->token_count) {
|
2016-11-14 12:15:24 -08:00
|
|
|
uint32_t count;
|
2016-11-14 10:35:33 -08:00
|
|
|
const TSParseAction *actions = ts_language_actions(self, state, symbol, &count);
|
|
|
|
|
if (count > 0) {
|
|
|
|
|
TSParseAction action = actions[count - 1];
|
|
|
|
|
if (action.type == TSParseActionTypeShift || action.type == TSParseActionTypeRecover) {
|
2017-07-13 17:17:22 -07:00
|
|
|
return action.to_state;
|
2016-11-14 10:35:33 -08:00
|
|
|
}
|
2016-11-14 08:36:06 -08:00
|
|
|
}
|
2016-11-14 10:35:33 -08:00
|
|
|
return 0;
|
2016-11-14 08:36:06 -08:00
|
|
|
} else {
|
|
|
|
|
return self->parse_table[state * self->symbol_count + symbol];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-12-02 22:03:48 -08:00
|
|
|
static inline const bool *
|
|
|
|
|
ts_language_enabled_external_tokens(const TSLanguage *self,
|
|
|
|
|
unsigned external_scanner_state) {
|
2016-12-20 17:06:20 -08:00
|
|
|
if (external_scanner_state == 0) {
|
|
|
|
|
return NULL;
|
|
|
|
|
} else {
|
2016-12-21 11:24:41 -08:00
|
|
|
return self->external_scanner.states + self->external_token_count * external_scanner_state;
|
2016-12-20 17:06:20 -08:00
|
|
|
}
|
2016-12-02 22:03:48 -08:00
|
|
|
}
|
|
|
|
|
|
2017-07-14 10:19:58 -07:00
|
|
|
static inline const TSSymbol *
|
|
|
|
|
ts_language_rename_sequence(const TSLanguage *self, unsigned id) {
|
|
|
|
|
return id > 0 ?
|
|
|
|
|
self->rename_sequences + id * self->max_rename_sequence_length :
|
|
|
|
|
NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-20 12:00:49 -08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif // RUNTIME_LANGUAGE_H_
|