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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
const _curs1_actions = Int8[0, 1, 0, 1, 1, 1, 2, 1, 3, 0 , ]
const _curs1_trans_keys = UInt8[1, 0, 0, 3, 10, 10, 6, 6, 10, 10, 8, 8, 5, 5, 4, 4, 7, 7, 6, 6, 5, 5, 9, 9, 11, 11, 7, 7, 1, 0, 1, 0, 1, 0, 1, 0, 0 , ]
const _curs1_char_class = Int8[0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 5, 1, 1, 1, 1, 1, 1, 1, 1, 6, 7, 1, 1, 1, 8, 9, 10, 1, 11, 0 , ]
const _curs1_index_offsets = Int8[0, 0, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 16, 16, 16, 0 , ]
const _curs1_indicies = Int8[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 0 , ]
const _curs1_index_defaults = Int8[0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0 , ]
const _curs1_trans_cond_spaces = Int8[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0 , ]
const _curs1_cond_targs = Int8[14, 0, 14, 14, 3, 4, 5, 6, 7, 15, 9, 10, 16, 12, 13, 17, 0 , ]
const _curs1_cond_actions = Int8[0, 0, 5, 7, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 3, 0 , ]
const _curs1_nfa_targs = Int8[0, 0 , ]
const _curs1_nfa_offsets = Int8[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 , ]
const _curs1_nfa_push_actions = Int8[0, 0 , ]
const _curs1_nfa_pop_trans = Int8[0, 0 , ]
const curs1_start = 1
const curs1_first_final = 14
const curs1_error = 0
const curs1_en_unused = 2
const curs1_en_one = 8
const curs1_en_two = 11
const curs1_en_main = 1
function m( data::AbstractString )
p = 0
pe = length(data)
eof = length(data)
cs = 0
buffer = ""
return_to = 0;
cs = convert(Int, curs1_start )
_ps= 0
;
_trans = 0;
_have = 0;
_cont = 1;
_acts = 0;
_nacts= 0
;
_keys = 0;
_inds = 0;
while _cont == 1
if cs == 0
_cont = 0
end
_have = 0
if p == pe
if _have == 0
_cont = 0
end
end
if _cont == 1
if _have == 0
_keys = (cs<<1)
_inds = _curs1_index_offsets[1+(cs)]
if (data[1+(p )])<= 119 && (data[1+(p )])>= 10
_ic = convert(Int, _curs1_char_class[1+(convert(Int, (data[1+(p )]) )- 10)] );
if _ic <= convert(Int, _curs1_trans_keys[1+(_keys+1 )] )&& _ic >= convert(Int, _curs1_trans_keys[1+(_keys )] )
_trans = convert(UInt, _curs1_indicies[1+(_inds + convert(Int, (_ic - convert(Int, _curs1_trans_keys[1+(_keys )] )) ))] )
else
_trans = convert(UInt, _curs1_index_defaults[1+(cs)] )
end
else
_trans = convert(UInt, _curs1_index_defaults[1+(cs)] )
end
end
if _cont == 1
_ps = cs
cs = convert(Int, _curs1_cond_targs[1+(_trans)] )
if _curs1_cond_actions[1+(_trans)]!= 0
_acts = _curs1_cond_actions[1+(_trans)]
_nacts = convert(UInt, _curs1_actions[1+(_acts )] )
_acts += 1
while _nacts > 0
if _curs1_actions[1+(_acts )] == 0
print( "one\n" );
{
cs = (return_to)
}
elseif _curs1_actions[1+(_acts )] == 1
print( "two\n" );
{
cs = (return_to)
}
elseif _curs1_actions[1+(_acts )] == 2
return_to = (_ps);
{
cs = 8
}
elseif _curs1_actions[1+(_acts )] == 3
return_to = (_ps);
{
cs = 11
}
end
_nacts -= 1
_acts += 1
end
end
if cs == 0
_cont = 0
end
if _cont == 1
p += 1
end
end
end
end
if ( cs >= curs1_first_final )
println( "ACCEPT" );
else
println( "FAIL" );
end
end
m( "1one2two1one\n" );
|