cpython/Include/grammar.h

78 lines
1.8 KiB
C
Raw Normal View History

1991-02-19 20:39:46 +08:00
1990-10-14 20:07:46 +08:00
/* Grammar interface */
#ifndef Py_GRAMMAR_H
#define Py_GRAMMAR_H
#ifdef __cplusplus
extern "C" {
#endif
1990-10-14 20:07:46 +08:00
#include "bitset.h" /* Sigh... */
/* A label of an arc */
typedef struct {
int lb_type;
2019-04-23 17:29:57 +08:00
const char *lb_str;
1990-10-14 20:07:46 +08:00
} label;
#define EMPTY 0 /* Label number 0 is by definition the empty label */
1990-10-14 20:07:46 +08:00
/* A list of labels */
typedef struct {
int ll_nlabels;
2019-04-23 17:29:57 +08:00
const label *ll_label;
1990-10-14 20:07:46 +08:00
} 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 */
1990-10-14 20:07:46 +08:00
} arc;
/* A state in a DFA */
typedef struct {
int s_narcs;
2019-04-23 17:29:57 +08:00
const arc *s_arc; /* Array of arcs */
2015-03-21 15:25:53 +08:00
/* Optional accelerators */
int s_lower; /* Lowest label index */
int s_upper; /* Highest label index */
int *s_accel; /* Accelerator */
int s_accept; /* Nonzero for accepting state */
1990-10-14 20:07:46 +08:00
} state;
/* A DFA */
typedef struct {
int d_type; /* Non-terminal this represents */
char *d_name; /* For printing */
int d_nstates;
state *d_state; /* Array of states */
bitset d_first;
1990-10-14 20:07:46 +08:00
} dfa;
/* A grammar */
typedef struct {
int g_ndfas;
2019-04-23 17:29:57 +08:00
const dfa *g_dfa; /* Array of DFAs */
const labellist g_ll;
int g_start; /* Start symbol of the grammar */
int g_accel; /* Set if accelerators present */
1990-10-14 20:07:46 +08:00
} grammar;
/* FUNCTIONS */
const dfa *PyGrammar_FindDFA(grammar *g, int type);
const char *PyGrammar_LabelRepr(label *lb);
void PyGrammar_AddAccelerators(grammar *g);
void PyGrammar_RemoveAccelerators(grammar *);
1990-12-20 23:06:42 +08:00
#ifdef __cplusplus
}
#endif
#endif /* !Py_GRAMMAR_H */