python-2.7.6/include/grammar.h Source File

grammar.h
Go to the documentation of this file.
1 
2 /* Grammar interface */
3 
4 #ifndef Py_GRAMMAR_H
5 #define Py_GRAMMAR_H
6 #ifdef __cplusplus
7 extern "C" {
8 #endif
9 
10 #include "bitset.h" /* Sigh... */
11 
12 /* A label of an arc */
13 
14 typedef struct {
15  int lb_type;
16  char *lb_str;
17 } label;
18 
19 #define EMPTY 0 /* Label number 0 is by definition the empty label */
20 
21 /* A list of labels */
22 
23 typedef struct {
26 } labellist;
27 
28 /* An arc from one state to another */
29 
30 typedef struct {
31  short a_lbl; /* Label of this arc */
32  short a_arrow; /* State where this arc goes to */
33 } arc;
34 
35 /* A state in a DFA */
36 
37 typedef struct {
38  int s_narcs;
39  arc *s_arc; /* Array of arcs */
40 
41  /* Optional accelerators */
42  int s_lower; /* Lowest label index */
43  int s_upper; /* Highest label index */
44  int *s_accel; /* Accelerator */
45  int s_accept; /* Nonzero for accepting state */
46 } state;
47 
48 /* A DFA */
49 
50 typedef struct {
51  int d_type; /* Non-terminal this represents */
52  char *d_name; /* For printing */
53  int d_initial; /* Initial state */
54  int d_nstates;
55  state *d_state; /* Array of states */
57 } dfa;
58 
59 /* A grammar */
60 
61 typedef struct {
62  int g_ndfas;
63  dfa *g_dfa; /* Array of DFAs */
65  int g_start; /* Start symbol of the grammar */
66  int g_accel; /* Set if accelerators present */
67 } grammar;
68 
69 /* FUNCTIONS */
70 
72 dfa *adddfa(grammar *g, int type, char *name);
73 int addstate(dfa *d);
74 void addarc(dfa *d, int from, int to, int lbl);
76 
77 int addlabel(labellist *ll, int type, char *str);
78 int findlabel(labellist *ll, int type, char *str);
79 char *PyGrammar_LabelRepr(label *lb);
80 void translatelabels(grammar *g);
81 
82 void addfirstsets(grammar *g);
83 
86 
87 void printgrammar(grammar *g, FILE *fp);
88 void printnonterminals(grammar *g, FILE *fp);
89 
90 #ifdef __cplusplus
91 }
92 #endif
93 #endif /* !Py_GRAMMAR_H */
int addstate(dfa *d)
Definition: grammar.h:14
char * bitset
Definition: bitset.h:12
char * d_name
Definition: grammar.h:52
int g_start
Definition: grammar.h:65
void translatelabels(grammar *g)
dfa * PyGrammar_FindDFA(grammar *g, int type)
Definition: grammar.h:30
int s_upper
Definition: grammar.h:43
void addarc(dfa *d, int from, int to, int lbl)
char * PyGrammar_LabelRepr(label *lb)
int ll_nlabels
Definition: grammar.h:24
short a_arrow
Definition: grammar.h:32
arc * s_arc
Definition: grammar.h:39
dfa * g_dfa
Definition: grammar.h:63
size_t const char double d
Definition: pystrtod.h:13
Definition: grammar.h:50
int type
Definition: node.h:20
int * s_accel
Definition: grammar.h:44
void PyGrammar_AddAccelerators(grammar *g)
void addfirstsets(grammar *g)
void PyGrammar_RemoveAccelerators(grammar *)
short a_lbl
Definition: grammar.h:31
void printgrammar(grammar *g, FILE *fp)
int d_nstates
Definition: grammar.h:54
int addlabel(labellist *ll, int type, char *str)
char * lb_str
Definition: grammar.h:16
int d_initial
Definition: grammar.h:53
int s_lower
Definition: grammar.h:42
bitset d_first
Definition: grammar.h:56
char char char char char * name
Definition: abstract.h:355
int lb_type
Definition: grammar.h:15
label * ll_label
Definition: grammar.h:25
void printnonterminals(grammar *g, FILE *fp)
char char int FILE
Definition: fileobject.h:45
Py_ssize_t Py_ssize_t * start
Definition: sliceobject.h:35
Definition: grammar.h:37
int char * str
Definition: node.h:20
int g_accel
Definition: grammar.h:66
int findlabel(labellist *ll, int type, char *str)
state * d_state
Definition: grammar.h:55
dfa * adddfa(grammar *g, int type, char *name)
int s_narcs
Definition: grammar.h:38
grammar * newgrammar(int start)
int s_accept
Definition: grammar.h:45
labellist g_ll
Definition: grammar.h:64
int g_ndfas
Definition: grammar.h:62
int d_type
Definition: grammar.h:51