cosmopolitan/third_party/python/Include/grammar.h
Justine Tunney fa20edc44d
Reduce header complexity
- Remove most __ASSEMBLER__ __LINKER__ ifdefs
- Rename libc/intrin/bits.h to libc/serialize.h
- Block pthread cancelation in fchmodat() polyfill
- Remove `clang-format off` statements in third_party
2023-11-28 14:39:42 -08:00

77 lines
2 KiB
C

#ifndef Py_GRAMMAR_H
#define Py_GRAMMAR_H
#include "libc/stdio/stdio.h"
#include "third_party/python/Include/bitset.h"
COSMOPOLITAN_C_START_
/* A label of an arc */
typedef struct {
int lb_type;
char *lb_str;
} label;
#define EMPTY 0 /* Label number 0 is by definition the empty label */
/* A list of labels */
typedef struct {
int ll_nlabels;
label *ll_label;
} labellist;
/* An arc from one state to another */
typedef struct {
short a_lbl; /* Label of this arc */
short a_arrow; /* State where this arc goes to */
} arc;
/* A state in a DFA */
typedef struct {
int s_narcs; /* [jart/abi] moving s_accept here saves 4k */
int s_accept; /* [optional] Nonzero for accepting state */
arc *s_arc; /* Array of arcs */
int s_lower; /* [optional] Lowest label index */
int s_upper; /* [optional] Highest label index */
int *s_accel; /* [optional] Accelerator */
} state;
/* A DFA */
typedef struct {
int d_type; /* Non-terminal this represents */
char *d_name; /* For printing */
int d_initial; /* Initial state */
int d_nstates;
state *d_state; /* Array of states */
bitset d_first;
} dfa;
/* A grammar */
typedef struct {
int g_ndfas;
dfa *g_dfa; /* Array of DFAs */
labellist g_ll;
int g_start; /* Start symbol of the grammar */
int g_accel; /* Set if accelerators present */
} grammar;
grammar *newgrammar(int);
void freegrammar(grammar *);
dfa *adddfa(grammar *, int, const char *);
int addstate(dfa *);
void addarc(dfa *, int, int, int);
dfa *PyGrammar_FindDFA(grammar *, int);
int addlabel(labellist *, int, const char *);
int findlabel(labellist *, int, const char *);
const char *PyGrammar_LabelRepr(label *);
void translatelabels(grammar *);
void addfirstsets(grammar *);
void PyGrammar_AddAccelerators(grammar *);
void PyGrammar_RemoveAccelerators(grammar *);
void printgrammar(grammar *, FILE *);
void printnonterminals(grammar *, FILE *);
#ifndef Py_LIMITED_API
extern grammar _PyParser_Grammar;
#endif
COSMOPOLITAN_C_END_
#endif /* !Py_GRAMMAR_H */