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
|
using System;
// Disables lots of warnings that appear in the test suite
#pragma warning disable 0168, 0169, 0219, 0162, 0414
namespace Test {
class Test
{
static readonly char []_rangei_trans_keys = { '\u0001', '\u0000', '\u0001', '\u0002', '\u0001', '\u0002', '\u0000', '\u0003', '\u0001', '\u0005', '\u0001', '\u0004', '\u0000', '\u0005', '\u0001', '\u0000', '\u0000', };
static readonly sbyte []_rangei_char_class = { 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 3, 3, 3, 4, 4, 4, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 5, 5, 5, 0, };
static readonly sbyte []_rangei_index_offsets = { 0, 0, 2, 4, 8, 13, 17, 23, 0, };
static readonly sbyte []_rangei_indicies = { 0, 0, 2, 2, 3, 3, 3, 3, 4, 4, 1, 4, 4, 5, 1, 5, 5, 6, 6, 6, 6, 6, 6, 0, };
static readonly sbyte []_rangei_index_defaults = { 0, 1, 1, 1, 1, 1, 1, 1, 0, };
static readonly sbyte []_rangei_trans_cond_spaces = { -1, -1, -1, -1, -1, -1, -1, 0, };
static readonly sbyte []_rangei_cond_targs = { 2, 0, 3, 4, 5, 6, 7, 0, };
static readonly sbyte []_rangei_cond_actions = { 0, 0, 0, 0, 0, 0, 0, 0, };
static readonly sbyte []_rangei_nfa_targs = { 0, 0, };
static readonly sbyte []_rangei_nfa_offsets = { 0, 0, 0, 0, 0, 0, 0, 0, 0, };
static readonly sbyte []_rangei_nfa_push_actions = { 0, 0, };
static readonly sbyte []_rangei_nfa_pop_trans = { 0, 0, };
static readonly int rangei_start = 1;
static readonly int rangei_first_final = 7;
static readonly int rangei_error = 0;
static readonly int rangei_en_main = 1;
int cs;
void init()
{
{
cs = (int)rangei_start;
}
}
void exec( char[] data, int len )
{
int p = 0;
int pe = len;
int eof = len;
string _s;
char [] buffer = new char [1024];
int blen = 0;
{
int _trans = 0;
int _keys;
int _inds;
if ( p == pe )
goto _test_eof;
if ( cs == 0 )
goto _out;
_resume :
_keys = (cs<<1) ;
_inds = _rangei_index_offsets[cs] ;
if ( ( data[p ]) <= 125&& ( data[p ]) >= 60 )
{
int _ic = (int)_rangei_char_class[(int)( data[p ]) - 60];
if ( _ic <= (int)_rangei_trans_keys[_keys+1]&& _ic >= (int)_rangei_trans_keys[_keys ] )
_trans = (int)_rangei_indicies[_inds + (int)( _ic - (int)_rangei_trans_keys[_keys ]) ];
else
_trans = (int)_rangei_index_defaults[cs];
}
else
{
_trans = (int)_rangei_index_defaults[cs];
}
goto _match_cond;
_match_cond :
cs = (int)_rangei_cond_targs[_trans];
if ( cs == 0 )
goto _out;
p += 1;
if ( p != pe )
goto _resume;
_test_eof :
{}
_out :
{}
}
}
void finish( )
{
if ( cs >= rangei_first_final )
Console.WriteLine( "ACCEPT" );
else
Console.WriteLine( "FAIL" );
}
static readonly string[] inp = {
"AaBbAa",
"Aa`bAa",
"AaB@Aa",
"AaBbMa",
"AaBbma",
};
static readonly int inplen = 5;
public static void Main (string[] args)
{
Test machine = new Test();
for ( int i = 0; i < inplen; i++ ) {
machine.init();
machine.exec( inp[i].ToCharArray(), inp[i].Length );
machine.finish();
}
}
}
}
|