1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
/*
* @LANG: c++
*/
#include <iostream>
using namespace std;
struct LangEl
{
int key;
const char *name;
};
struct Fsm
{
int cs;
// Initialize the machine. Invokes any init statement blocks. Returns 0
// if the machine begins in a non-accepting state and 1 if the machine
// begins in an accepting state.
int init( );
// Execute the machine on a block of data. Returns -1 if after processing
// the data, the machine is in the error state and can never accept, 0 if
// the machine is in a non-accepting state and 1 if the machine is in an
// accepting state.
int execute( LangEl *data, int len );
// Indicate that there is no more data. Returns -1 if the machine finishes
// in the error state and does not accept, 0 if the machine finishes
// in any other non-accepting state and 1 if the machine finishes in an
// accepting state.
int finish( );
};
%%{
machine Fsm;
alphtype int;
getkey fpc->key;
variable eof eof_marker;
action a1 {}
action a2 {}
action a3 {}
main := ( 1 2* 3 )
${cout << fpc->name << endl;}
%/{cout << "accept" << endl;};
}%%
%% write data;
int Fsm::init( )
{
%% write init;
return 0;
}
int Fsm::execute( LangEl *data, int len )
{
LangEl *p = data;
LangEl *pe = data + len;
LangEl *eof_marker = pe;
%% write exec;
if ( cs == Fsm_error )
return -1;
if ( cs >= Fsm_first_final )
return 1;
return 0;
}
int Fsm::finish( )
{
if ( cs == Fsm_error )
return -1;
if ( cs >= Fsm_first_final )
return 1;
return 0;
}
int main( )
{
static Fsm fsm;
static LangEl lel[] = {
{1, "one"},
{2, "two-a"},
{2, "two-b"},
{2, "two-c"},
{3, "three"}
};
fsm.init();
fsm.execute( lel, 5 );
fsm.finish();
return 0;
}
#ifdef _____OUTPUT_____
one
two-a
two-b
two-c
three
accept
#endif
|