2016-02-06 09:36:57 +00:00
|
|
|
|
|
|
|
/* Grammar interface */
|
|
|
|
|
|
|
|
#ifndef Py_GRAMMAR_H
|
|
|
|
#define Py_GRAMMAR_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "bitset.h" /* Sigh... */
|
|
|
|
|
|
|
|
/* A label of an arc */
|
|
|
|
|
|
|
|
typedef struct {
|
2018-12-31 23:25:26 +00:00
|
|
|
int lb_type;
|
|
|
|
char *lb_str;
|
2016-02-06 09:36:57 +00:00
|
|
|
} label;
|
|
|
|
|
2018-12-31 23:25:26 +00:00
|
|
|
#define EMPTY 0 /* Label number 0 is by definition the empty label */
|
2016-02-06 09:36:57 +00:00
|
|
|
|
|
|
|
/* A list of labels */
|
|
|
|
|
|
|
|
typedef struct {
|
2018-12-31 23:25:26 +00:00
|
|
|
int ll_nlabels;
|
|
|
|
label *ll_label;
|
2016-02-06 09:36:57 +00:00
|
|
|
} labellist;
|
|
|
|
|
|
|
|
/* An arc from one state to another */
|
|
|
|
|
|
|
|
typedef struct {
|
2018-12-31 23:25:26 +00:00
|
|
|
short a_lbl; /* Label of this arc */
|
|
|
|
short a_arrow; /* State where this arc goes to */
|
2016-02-06 09:36:57 +00:00
|
|
|
} arc;
|
|
|
|
|
|
|
|
/* A state in a DFA */
|
|
|
|
|
|
|
|
typedef struct {
|
2018-12-31 23:25:26 +00:00
|
|
|
int s_narcs;
|
|
|
|
arc *s_arc; /* Array of arcs */
|
2016-02-06 09:36:57 +00:00
|
|
|
|
|
|
|
/* Optional accelerators */
|
2018-12-31 23:25:26 +00:00
|
|
|
int s_lower; /* Lowest label index */
|
|
|
|
int s_upper; /* Highest label index */
|
|
|
|
int *s_accel; /* Accelerator */
|
|
|
|
int s_accept; /* Nonzero for accepting state */
|
2016-02-06 09:36:57 +00:00
|
|
|
} state;
|
|
|
|
|
|
|
|
/* A DFA */
|
|
|
|
|
|
|
|
typedef struct {
|
2018-12-31 23:25:26 +00:00
|
|
|
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;
|
2016-02-06 09:36:57 +00:00
|
|
|
} dfa;
|
|
|
|
|
|
|
|
/* A grammar */
|
|
|
|
|
|
|
|
typedef struct {
|
2018-12-31 23:25:26 +00:00
|
|
|
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 */
|
2016-02-06 09:36:57 +00:00
|
|
|
} grammar;
|
|
|
|
|
|
|
|
/* FUNCTIONS */
|
|
|
|
|
|
|
|
grammar *newgrammar(int start);
|
2018-12-31 23:25:26 +00:00
|
|
|
void freegrammar(grammar *g);
|
2016-02-06 09:36:57 +00:00
|
|
|
dfa *adddfa(grammar *g, int type, const char *name);
|
|
|
|
int addstate(dfa *d);
|
|
|
|
void addarc(dfa *d, int from, int to, int lbl);
|
|
|
|
dfa *PyGrammar_FindDFA(grammar *g, int type);
|
|
|
|
|
|
|
|
int addlabel(labellist *ll, int type, const char *str);
|
|
|
|
int findlabel(labellist *ll, int type, const char *str);
|
|
|
|
const char *PyGrammar_LabelRepr(label *lb);
|
|
|
|
void translatelabels(grammar *g);
|
|
|
|
|
|
|
|
void addfirstsets(grammar *g);
|
|
|
|
|
|
|
|
void PyGrammar_AddAccelerators(grammar *g);
|
|
|
|
void PyGrammar_RemoveAccelerators(grammar *);
|
|
|
|
|
|
|
|
void printgrammar(grammar *g, FILE *fp);
|
|
|
|
void printnonterminals(grammar *g, FILE *fp);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* !Py_GRAMMAR_H */
|