File: eof_rule.c

package info (click to toggle)
re2c 4.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 51,512 kB
  • sloc: cpp: 34,160; ml: 8,494; sh: 5,311; makefile: 1,014; haskell: 611; python: 431; ansic: 234; javascript: 113
file content (124 lines) | stat: -rw-r--r-- 2,140 bytes parent folder | download | duplicates (2)
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
/* Generated by re2c */
// re2c $INPUT -o $OUTPUT --loop-switch -i
#include <assert.h>

// expect a null-terminated string
static int lex(const char *str, unsigned int len)
{
    const char *YYCURSOR = str, *YYLIMIT = str + len, *YYMARKER;
    int count = 0;

loop:
    
{
	char yych;
	unsigned int yystate = 0;
	for (;;) {
		switch (yystate) {
			case 0:
				yych = *YYCURSOR;
				switch (yych) {
					case ' ':
						++YYCURSOR;
						yystate = 3;
						continue;
					case '\'':
						++YYCURSOR;
						yystate = 5;
						continue;
					default:
						if (YYLIMIT <= YYCURSOR) {
							yystate = 10;
							continue;
						}
						++YYCURSOR;
						yystate = 1;
						continue;
				}
			case 1:
				yystate = 2;
				continue;
			case 2: { return -1; }
			case 3:
				yych = *YYCURSOR;
				switch (yych) {
					case ' ':
						++YYCURSOR;
						yystate = 3;
						continue;
					default:
						yystate = 4;
						continue;
				}
			case 4: { goto loop; }
			case 5:
				YYMARKER = YYCURSOR;
				yych = *YYCURSOR;
				if (yych >= 0x01) {
					yystate = 7;
					continue;
				}
				if (YYLIMIT <= YYCURSOR) {
					yystate = 2;
					continue;
				}
				++YYCURSOR;
				yystate = 6;
				continue;
			case 6:
				yych = *YYCURSOR;
				yystate = 7;
				continue;
			case 7:
				switch (yych) {
					case '\'':
						++YYCURSOR;
						yystate = 8;
						continue;
					case '\\':
						++YYCURSOR;
						yystate = 9;
						continue;
					default:
						if (YYLIMIT <= YYCURSOR) {
							yystate = 11;
							continue;
						}
						++YYCURSOR;
						yystate = 6;
						continue;
				}
			case 8: { ++count; goto loop; }
			case 9:
				yych = *YYCURSOR;
				if (yych <= 0x00) {
					if (YYLIMIT <= YYCURSOR) {
						yystate = 11;
						continue;
					}
					++YYCURSOR;
					yystate = 6;
					continue;
				}
				++YYCURSOR;
				yystate = 6;
				continue;
			case 10: { return count; }
			case 11:
				YYCURSOR = YYMARKER;
				yystate = 2;
				continue;
		}
	}
}

}

#define TEST(s, r) assert(lex(s, sizeof(s) - 1) == r)
int main()
{
    TEST("", 0);
    TEST("'qu\0tes' 'are' 'fine: \\'' ", 3);
    TEST("'unterminated\\'", -1);
    return 0;
}