TLA Line data Source code
1 : /* Generated by Snowball 2.2.0 - https://snowballstem.org/ */
2 :
3 : #include "header.h"
4 :
5 : #ifdef __cplusplus
6 : extern "C" {
7 : #endif
8 : extern int english_UTF_8_stem(struct SN_env * z);
9 : #ifdef __cplusplus
10 : }
11 : #endif
12 : static int r_exception2(struct SN_env * z);
13 : static int r_exception1(struct SN_env * z);
14 : static int r_Step_5(struct SN_env * z);
15 : static int r_Step_4(struct SN_env * z);
16 : static int r_Step_3(struct SN_env * z);
17 : static int r_Step_2(struct SN_env * z);
18 : static int r_Step_1c(struct SN_env * z);
19 : static int r_Step_1b(struct SN_env * z);
20 : static int r_Step_1a(struct SN_env * z);
21 : static int r_R2(struct SN_env * z);
22 : static int r_R1(struct SN_env * z);
23 : static int r_shortv(struct SN_env * z);
24 : static int r_mark_regions(struct SN_env * z);
25 : static int r_postlude(struct SN_env * z);
26 : static int r_prelude(struct SN_env * z);
27 : #ifdef __cplusplus
28 : extern "C" {
29 : #endif
30 :
31 :
32 : extern struct SN_env * english_UTF_8_create_env(void);
33 : extern void english_UTF_8_close_env(struct SN_env * z);
34 :
35 :
36 : #ifdef __cplusplus
37 : }
38 : #endif
39 : static const symbol s_0_0[5] = { 'a', 'r', 's', 'e', 'n' };
40 : static const symbol s_0_1[6] = { 'c', 'o', 'm', 'm', 'u', 'n' };
41 : static const symbol s_0_2[5] = { 'g', 'e', 'n', 'e', 'r' };
42 :
43 : static const struct among a_0[3] =
44 : {
45 : { 5, s_0_0, -1, -1, 0},
46 : { 6, s_0_1, -1, -1, 0},
47 : { 5, s_0_2, -1, -1, 0}
48 : };
49 :
50 : static const symbol s_1_0[1] = { '\'' };
51 : static const symbol s_1_1[3] = { '\'', 's', '\'' };
52 : static const symbol s_1_2[2] = { '\'', 's' };
53 :
54 : static const struct among a_1[3] =
55 : {
56 : { 1, s_1_0, -1, 1, 0},
57 : { 3, s_1_1, 0, 1, 0},
58 : { 2, s_1_2, -1, 1, 0}
59 : };
60 :
61 : static const symbol s_2_0[3] = { 'i', 'e', 'd' };
62 : static const symbol s_2_1[1] = { 's' };
63 : static const symbol s_2_2[3] = { 'i', 'e', 's' };
64 : static const symbol s_2_3[4] = { 's', 's', 'e', 's' };
65 : static const symbol s_2_4[2] = { 's', 's' };
66 : static const symbol s_2_5[2] = { 'u', 's' };
67 :
68 : static const struct among a_2[6] =
69 : {
70 : { 3, s_2_0, -1, 2, 0},
71 : { 1, s_2_1, -1, 3, 0},
72 : { 3, s_2_2, 1, 2, 0},
73 : { 4, s_2_3, 1, 1, 0},
74 : { 2, s_2_4, 1, -1, 0},
75 : { 2, s_2_5, 1, -1, 0}
76 : };
77 :
78 : static const symbol s_3_1[2] = { 'b', 'b' };
79 : static const symbol s_3_2[2] = { 'd', 'd' };
80 : static const symbol s_3_3[2] = { 'f', 'f' };
81 : static const symbol s_3_4[2] = { 'g', 'g' };
82 : static const symbol s_3_5[2] = { 'b', 'l' };
83 : static const symbol s_3_6[2] = { 'm', 'm' };
84 : static const symbol s_3_7[2] = { 'n', 'n' };
85 : static const symbol s_3_8[2] = { 'p', 'p' };
86 : static const symbol s_3_9[2] = { 'r', 'r' };
87 : static const symbol s_3_10[2] = { 'a', 't' };
88 : static const symbol s_3_11[2] = { 't', 't' };
89 : static const symbol s_3_12[2] = { 'i', 'z' };
90 :
91 : static const struct among a_3[13] =
92 : {
93 : { 0, 0, -1, 3, 0},
94 : { 2, s_3_1, 0, 2, 0},
95 : { 2, s_3_2, 0, 2, 0},
96 : { 2, s_3_3, 0, 2, 0},
97 : { 2, s_3_4, 0, 2, 0},
98 : { 2, s_3_5, 0, 1, 0},
99 : { 2, s_3_6, 0, 2, 0},
100 : { 2, s_3_7, 0, 2, 0},
101 : { 2, s_3_8, 0, 2, 0},
102 : { 2, s_3_9, 0, 2, 0},
103 : { 2, s_3_10, 0, 1, 0},
104 : { 2, s_3_11, 0, 2, 0},
105 : { 2, s_3_12, 0, 1, 0}
106 : };
107 :
108 : static const symbol s_4_0[2] = { 'e', 'd' };
109 : static const symbol s_4_1[3] = { 'e', 'e', 'd' };
110 : static const symbol s_4_2[3] = { 'i', 'n', 'g' };
111 : static const symbol s_4_3[4] = { 'e', 'd', 'l', 'y' };
112 : static const symbol s_4_4[5] = { 'e', 'e', 'd', 'l', 'y' };
113 : static const symbol s_4_5[5] = { 'i', 'n', 'g', 'l', 'y' };
114 :
115 : static const struct among a_4[6] =
116 : {
117 : { 2, s_4_0, -1, 2, 0},
118 : { 3, s_4_1, 0, 1, 0},
119 : { 3, s_4_2, -1, 2, 0},
120 : { 4, s_4_3, -1, 2, 0},
121 : { 5, s_4_4, 3, 1, 0},
122 : { 5, s_4_5, -1, 2, 0}
123 : };
124 :
125 : static const symbol s_5_0[4] = { 'a', 'n', 'c', 'i' };
126 : static const symbol s_5_1[4] = { 'e', 'n', 'c', 'i' };
127 : static const symbol s_5_2[3] = { 'o', 'g', 'i' };
128 : static const symbol s_5_3[2] = { 'l', 'i' };
129 : static const symbol s_5_4[3] = { 'b', 'l', 'i' };
130 : static const symbol s_5_5[4] = { 'a', 'b', 'l', 'i' };
131 : static const symbol s_5_6[4] = { 'a', 'l', 'l', 'i' };
132 : static const symbol s_5_7[5] = { 'f', 'u', 'l', 'l', 'i' };
133 : static const symbol s_5_8[6] = { 'l', 'e', 's', 's', 'l', 'i' };
134 : static const symbol s_5_9[5] = { 'o', 'u', 's', 'l', 'i' };
135 : static const symbol s_5_10[5] = { 'e', 'n', 't', 'l', 'i' };
136 : static const symbol s_5_11[5] = { 'a', 'l', 'i', 't', 'i' };
137 : static const symbol s_5_12[6] = { 'b', 'i', 'l', 'i', 't', 'i' };
138 : static const symbol s_5_13[5] = { 'i', 'v', 'i', 't', 'i' };
139 : static const symbol s_5_14[6] = { 't', 'i', 'o', 'n', 'a', 'l' };
140 : static const symbol s_5_15[7] = { 'a', 't', 'i', 'o', 'n', 'a', 'l' };
141 : static const symbol s_5_16[5] = { 'a', 'l', 'i', 's', 'm' };
142 : static const symbol s_5_17[5] = { 'a', 't', 'i', 'o', 'n' };
143 : static const symbol s_5_18[7] = { 'i', 'z', 'a', 't', 'i', 'o', 'n' };
144 : static const symbol s_5_19[4] = { 'i', 'z', 'e', 'r' };
145 : static const symbol s_5_20[4] = { 'a', 't', 'o', 'r' };
146 : static const symbol s_5_21[7] = { 'i', 'v', 'e', 'n', 'e', 's', 's' };
147 : static const symbol s_5_22[7] = { 'f', 'u', 'l', 'n', 'e', 's', 's' };
148 : static const symbol s_5_23[7] = { 'o', 'u', 's', 'n', 'e', 's', 's' };
149 :
150 : static const struct among a_5[24] =
151 : {
152 : { 4, s_5_0, -1, 3, 0},
153 : { 4, s_5_1, -1, 2, 0},
154 : { 3, s_5_2, -1, 13, 0},
155 : { 2, s_5_3, -1, 15, 0},
156 : { 3, s_5_4, 3, 12, 0},
157 : { 4, s_5_5, 4, 4, 0},
158 : { 4, s_5_6, 3, 8, 0},
159 : { 5, s_5_7, 3, 9, 0},
160 : { 6, s_5_8, 3, 14, 0},
161 : { 5, s_5_9, 3, 10, 0},
162 : { 5, s_5_10, 3, 5, 0},
163 : { 5, s_5_11, -1, 8, 0},
164 : { 6, s_5_12, -1, 12, 0},
165 : { 5, s_5_13, -1, 11, 0},
166 : { 6, s_5_14, -1, 1, 0},
167 : { 7, s_5_15, 14, 7, 0},
168 : { 5, s_5_16, -1, 8, 0},
169 : { 5, s_5_17, -1, 7, 0},
170 : { 7, s_5_18, 17, 6, 0},
171 : { 4, s_5_19, -1, 6, 0},
172 : { 4, s_5_20, -1, 7, 0},
173 : { 7, s_5_21, -1, 11, 0},
174 : { 7, s_5_22, -1, 9, 0},
175 : { 7, s_5_23, -1, 10, 0}
176 : };
177 :
178 : static const symbol s_6_0[5] = { 'i', 'c', 'a', 't', 'e' };
179 : static const symbol s_6_1[5] = { 'a', 't', 'i', 'v', 'e' };
180 : static const symbol s_6_2[5] = { 'a', 'l', 'i', 'z', 'e' };
181 : static const symbol s_6_3[5] = { 'i', 'c', 'i', 't', 'i' };
182 : static const symbol s_6_4[4] = { 'i', 'c', 'a', 'l' };
183 : static const symbol s_6_5[6] = { 't', 'i', 'o', 'n', 'a', 'l' };
184 : static const symbol s_6_6[7] = { 'a', 't', 'i', 'o', 'n', 'a', 'l' };
185 : static const symbol s_6_7[3] = { 'f', 'u', 'l' };
186 : static const symbol s_6_8[4] = { 'n', 'e', 's', 's' };
187 :
188 : static const struct among a_6[9] =
189 : {
190 : { 5, s_6_0, -1, 4, 0},
191 : { 5, s_6_1, -1, 6, 0},
192 : { 5, s_6_2, -1, 3, 0},
193 : { 5, s_6_3, -1, 4, 0},
194 : { 4, s_6_4, -1, 4, 0},
195 : { 6, s_6_5, -1, 1, 0},
196 : { 7, s_6_6, 5, 2, 0},
197 : { 3, s_6_7, -1, 5, 0},
198 : { 4, s_6_8, -1, 5, 0}
199 : };
200 :
201 : static const symbol s_7_0[2] = { 'i', 'c' };
202 : static const symbol s_7_1[4] = { 'a', 'n', 'c', 'e' };
203 : static const symbol s_7_2[4] = { 'e', 'n', 'c', 'e' };
204 : static const symbol s_7_3[4] = { 'a', 'b', 'l', 'e' };
205 : static const symbol s_7_4[4] = { 'i', 'b', 'l', 'e' };
206 : static const symbol s_7_5[3] = { 'a', 't', 'e' };
207 : static const symbol s_7_6[3] = { 'i', 'v', 'e' };
208 : static const symbol s_7_7[3] = { 'i', 'z', 'e' };
209 : static const symbol s_7_8[3] = { 'i', 't', 'i' };
210 : static const symbol s_7_9[2] = { 'a', 'l' };
211 : static const symbol s_7_10[3] = { 'i', 's', 'm' };
212 : static const symbol s_7_11[3] = { 'i', 'o', 'n' };
213 : static const symbol s_7_12[2] = { 'e', 'r' };
214 : static const symbol s_7_13[3] = { 'o', 'u', 's' };
215 : static const symbol s_7_14[3] = { 'a', 'n', 't' };
216 : static const symbol s_7_15[3] = { 'e', 'n', 't' };
217 : static const symbol s_7_16[4] = { 'm', 'e', 'n', 't' };
218 : static const symbol s_7_17[5] = { 'e', 'm', 'e', 'n', 't' };
219 :
220 : static const struct among a_7[18] =
221 : {
222 : { 2, s_7_0, -1, 1, 0},
223 : { 4, s_7_1, -1, 1, 0},
224 : { 4, s_7_2, -1, 1, 0},
225 : { 4, s_7_3, -1, 1, 0},
226 : { 4, s_7_4, -1, 1, 0},
227 : { 3, s_7_5, -1, 1, 0},
228 : { 3, s_7_6, -1, 1, 0},
229 : { 3, s_7_7, -1, 1, 0},
230 : { 3, s_7_8, -1, 1, 0},
231 : { 2, s_7_9, -1, 1, 0},
232 : { 3, s_7_10, -1, 1, 0},
233 : { 3, s_7_11, -1, 2, 0},
234 : { 2, s_7_12, -1, 1, 0},
235 : { 3, s_7_13, -1, 1, 0},
236 : { 3, s_7_14, -1, 1, 0},
237 : { 3, s_7_15, -1, 1, 0},
238 : { 4, s_7_16, 15, 1, 0},
239 : { 5, s_7_17, 16, 1, 0}
240 : };
241 :
242 : static const symbol s_8_0[1] = { 'e' };
243 : static const symbol s_8_1[1] = { 'l' };
244 :
245 : static const struct among a_8[2] =
246 : {
247 : { 1, s_8_0, -1, 1, 0},
248 : { 1, s_8_1, -1, 2, 0}
249 : };
250 :
251 : static const symbol s_9_0[7] = { 's', 'u', 'c', 'c', 'e', 'e', 'd' };
252 : static const symbol s_9_1[7] = { 'p', 'r', 'o', 'c', 'e', 'e', 'd' };
253 : static const symbol s_9_2[6] = { 'e', 'x', 'c', 'e', 'e', 'd' };
254 : static const symbol s_9_3[7] = { 'c', 'a', 'n', 'n', 'i', 'n', 'g' };
255 : static const symbol s_9_4[6] = { 'i', 'n', 'n', 'i', 'n', 'g' };
256 : static const symbol s_9_5[7] = { 'e', 'a', 'r', 'r', 'i', 'n', 'g' };
257 : static const symbol s_9_6[7] = { 'h', 'e', 'r', 'r', 'i', 'n', 'g' };
258 : static const symbol s_9_7[6] = { 'o', 'u', 't', 'i', 'n', 'g' };
259 :
260 : static const struct among a_9[8] =
261 : {
262 : { 7, s_9_0, -1, -1, 0},
263 : { 7, s_9_1, -1, -1, 0},
264 : { 6, s_9_2, -1, -1, 0},
265 : { 7, s_9_3, -1, -1, 0},
266 : { 6, s_9_4, -1, -1, 0},
267 : { 7, s_9_5, -1, -1, 0},
268 : { 7, s_9_6, -1, -1, 0},
269 : { 6, s_9_7, -1, -1, 0}
270 : };
271 :
272 : static const symbol s_10_0[5] = { 'a', 'n', 'd', 'e', 's' };
273 : static const symbol s_10_1[5] = { 'a', 't', 'l', 'a', 's' };
274 : static const symbol s_10_2[4] = { 'b', 'i', 'a', 's' };
275 : static const symbol s_10_3[6] = { 'c', 'o', 's', 'm', 'o', 's' };
276 : static const symbol s_10_4[5] = { 'd', 'y', 'i', 'n', 'g' };
277 : static const symbol s_10_5[5] = { 'e', 'a', 'r', 'l', 'y' };
278 : static const symbol s_10_6[6] = { 'g', 'e', 'n', 't', 'l', 'y' };
279 : static const symbol s_10_7[4] = { 'h', 'o', 'w', 'e' };
280 : static const symbol s_10_8[4] = { 'i', 'd', 'l', 'y' };
281 : static const symbol s_10_9[5] = { 'l', 'y', 'i', 'n', 'g' };
282 : static const symbol s_10_10[4] = { 'n', 'e', 'w', 's' };
283 : static const symbol s_10_11[4] = { 'o', 'n', 'l', 'y' };
284 : static const symbol s_10_12[6] = { 's', 'i', 'n', 'g', 'l', 'y' };
285 : static const symbol s_10_13[5] = { 's', 'k', 'i', 'e', 's' };
286 : static const symbol s_10_14[4] = { 's', 'k', 'i', 's' };
287 : static const symbol s_10_15[3] = { 's', 'k', 'y' };
288 : static const symbol s_10_16[5] = { 't', 'y', 'i', 'n', 'g' };
289 : static const symbol s_10_17[4] = { 'u', 'g', 'l', 'y' };
290 :
291 : static const struct among a_10[18] =
292 : {
293 : { 5, s_10_0, -1, -1, 0},
294 : { 5, s_10_1, -1, -1, 0},
295 : { 4, s_10_2, -1, -1, 0},
296 : { 6, s_10_3, -1, -1, 0},
297 : { 5, s_10_4, -1, 3, 0},
298 : { 5, s_10_5, -1, 9, 0},
299 : { 6, s_10_6, -1, 7, 0},
300 : { 4, s_10_7, -1, -1, 0},
301 : { 4, s_10_8, -1, 6, 0},
302 : { 5, s_10_9, -1, 4, 0},
303 : { 4, s_10_10, -1, -1, 0},
304 : { 4, s_10_11, -1, 10, 0},
305 : { 6, s_10_12, -1, 11, 0},
306 : { 5, s_10_13, -1, 2, 0},
307 : { 4, s_10_14, -1, 1, 0},
308 : { 3, s_10_15, -1, -1, 0},
309 : { 5, s_10_16, -1, 5, 0},
310 : { 4, s_10_17, -1, 8, 0}
311 : };
312 :
313 : static const unsigned char g_v[] = { 17, 65, 16, 1 };
314 :
315 : static const unsigned char g_v_WXY[] = { 1, 17, 65, 208, 1 };
316 :
317 : static const unsigned char g_valid_LI[] = { 55, 141, 2 };
318 :
319 : static const symbol s_0[] = { 'Y' };
320 : static const symbol s_1[] = { 'Y' };
321 : static const symbol s_2[] = { 's', 's' };
322 : static const symbol s_3[] = { 'i' };
323 : static const symbol s_4[] = { 'i', 'e' };
324 : static const symbol s_5[] = { 'e', 'e' };
325 : static const symbol s_6[] = { 'e' };
326 : static const symbol s_7[] = { 'e' };
327 : static const symbol s_8[] = { 'i' };
328 : static const symbol s_9[] = { 't', 'i', 'o', 'n' };
329 : static const symbol s_10[] = { 'e', 'n', 'c', 'e' };
330 : static const symbol s_11[] = { 'a', 'n', 'c', 'e' };
331 : static const symbol s_12[] = { 'a', 'b', 'l', 'e' };
332 : static const symbol s_13[] = { 'e', 'n', 't' };
333 : static const symbol s_14[] = { 'i', 'z', 'e' };
334 : static const symbol s_15[] = { 'a', 't', 'e' };
335 : static const symbol s_16[] = { 'a', 'l' };
336 : static const symbol s_17[] = { 'f', 'u', 'l' };
337 : static const symbol s_18[] = { 'o', 'u', 's' };
338 : static const symbol s_19[] = { 'i', 'v', 'e' };
339 : static const symbol s_20[] = { 'b', 'l', 'e' };
340 : static const symbol s_21[] = { 'o', 'g' };
341 : static const symbol s_22[] = { 'l', 'e', 's', 's' };
342 : static const symbol s_23[] = { 't', 'i', 'o', 'n' };
343 : static const symbol s_24[] = { 'a', 't', 'e' };
344 : static const symbol s_25[] = { 'a', 'l' };
345 : static const symbol s_26[] = { 'i', 'c' };
346 : static const symbol s_27[] = { 's', 'k', 'i' };
347 : static const symbol s_28[] = { 's', 'k', 'y' };
348 : static const symbol s_29[] = { 'd', 'i', 'e' };
349 : static const symbol s_30[] = { 'l', 'i', 'e' };
350 : static const symbol s_31[] = { 't', 'i', 'e' };
351 : static const symbol s_32[] = { 'i', 'd', 'l' };
352 : static const symbol s_33[] = { 'g', 'e', 'n', 't', 'l' };
353 : static const symbol s_34[] = { 'u', 'g', 'l', 'i' };
354 : static const symbol s_35[] = { 'e', 'a', 'r', 'l', 'i' };
355 : static const symbol s_36[] = { 'o', 'n', 'l', 'i' };
356 : static const symbol s_37[] = { 's', 'i', 'n', 'g', 'l' };
357 : static const symbol s_38[] = { 'y' };
358 :
359 CBC 3131 : static int r_prelude(struct SN_env * z) {
360 3131 : z->I[2] = 0;
361 3131 : { int c1 = z->c;
362 3131 : z->bra = z->c;
363 3131 : if (z->c == z->l || z->p[z->c] != '\'') goto lab0;
364 UBC 0 : z->c++;
365 0 : z->ket = z->c;
366 0 : { int ret = slice_del(z);
367 0 : if (ret < 0) return ret;
368 : }
369 0 : lab0:
370 CBC 3131 : z->c = c1;
371 : }
372 3131 : { int c2 = z->c;
373 3131 : z->bra = z->c;
374 3131 : if (z->c == z->l || z->p[z->c] != 'y') goto lab1;
375 21 : z->c++;
376 21 : z->ket = z->c;
377 21 : { int ret = slice_from_s(z, 1, s_0);
378 21 : if (ret < 0) return ret;
379 : }
380 21 : z->I[2] = 1;
381 3131 : lab1:
382 3131 : z->c = c2;
383 : }
384 3131 : { int c3 = z->c;
385 243 : while(1) {
386 3374 : int c4 = z->c;
387 14582 : while(1) {
388 17956 : int c5 = z->c;
389 17956 : if (in_grouping_U(z, g_v, 97, 121, 0)) goto lab4;
390 5724 : z->bra = z->c;
391 5724 : if (z->c == z->l || z->p[z->c] != 'y') goto lab4;
392 243 : z->c++;
393 243 : z->ket = z->c;
394 243 : z->c = c5;
395 243 : break;
396 17713 : lab4:
397 17713 : z->c = c5;
398 17713 : { int ret = skip_utf8(z->p, z->c, z->l, 1);
399 17713 : if (ret < 0) goto lab3;
400 14582 : z->c = ret;
401 : }
402 : }
403 243 : { int ret = slice_from_s(z, 1, s_1);
404 243 : if (ret < 0) return ret;
405 : }
406 243 : z->I[2] = 1;
407 243 : continue;
408 3131 : lab3:
409 3131 : z->c = c4;
410 3131 : break;
411 : }
412 3131 : z->c = c3;
413 : }
414 3131 : return 1;
415 : }
416 :
417 3131 : static int r_mark_regions(struct SN_env * z) {
418 3131 : z->I[1] = z->l;
419 3131 : z->I[0] = z->l;
420 3131 : { int c1 = z->c;
421 3131 : { int c2 = z->c;
422 3131 : if (z->c + 4 >= z->l || z->p[z->c + 4] >> 5 != 3 || !((2375680 >> (z->p[z->c + 4] & 0x1f)) & 1)) goto lab2;
423 517 : if (!(find_among(z, a_0, 3))) goto lab2;
424 UBC 0 : goto lab1;
425 CBC 3131 : lab2:
426 3131 : z->c = c2;
427 : {
428 3131 : int ret = out_grouping_U(z, g_v, 97, 121, 1);
429 3131 : if (ret < 0) goto lab0;
430 2795 : z->c += ret;
431 : }
432 : {
433 2795 : int ret = in_grouping_U(z, g_v, 97, 121, 1);
434 2795 : if (ret < 0) goto lab0;
435 2503 : z->c += ret;
436 : }
437 : }
438 2503 : lab1:
439 2503 : z->I[1] = z->c;
440 : {
441 2503 : int ret = out_grouping_U(z, g_v, 97, 121, 1);
442 2503 : if (ret < 0) goto lab0;
443 1369 : z->c += ret;
444 : }
445 : {
446 1369 : int ret = in_grouping_U(z, g_v, 97, 121, 1);
447 1369 : if (ret < 0) goto lab0;
448 1102 : z->c += ret;
449 : }
450 1102 : z->I[0] = z->c;
451 3131 : lab0:
452 3131 : z->c = c1;
453 : }
454 3131 : return 1;
455 : }
456 :
457 218 : static int r_shortv(struct SN_env * z) {
458 218 : { int m1 = z->l - z->c; (void)m1;
459 218 : if (out_grouping_b_U(z, g_v_WXY, 89, 121, 0)) goto lab1;
460 218 : if (in_grouping_b_U(z, g_v, 97, 121, 0)) goto lab1;
461 116 : if (out_grouping_b_U(z, g_v, 97, 121, 0)) goto lab1;
462 33 : goto lab0;
463 185 : lab1:
464 185 : z->c = z->l - m1;
465 185 : if (out_grouping_b_U(z, g_v, 97, 121, 0)) return 0;
466 185 : if (in_grouping_b_U(z, g_v, 97, 121, 0)) return 0;
467 83 : if (z->c > z->lb) return 0;
468 : }
469 54 : lab0:
470 87 : return 1;
471 : }
472 :
473 303 : static int r_R1(struct SN_env * z) {
474 303 : if (!(z->I[1] <= z->c)) return 0;
475 218 : return 1;
476 : }
477 :
478 865 : static int r_R2(struct SN_env * z) {
479 865 : if (!(z->I[0] <= z->c)) return 0;
480 166 : return 1;
481 : }
482 :
483 3131 : static int r_Step_1a(struct SN_env * z) {
484 : int among_var;
485 3131 : { int m1 = z->l - z->c; (void)m1;
486 3131 : z->ket = z->c;
487 3131 : if (z->c <= z->lb || (z->p[z->c - 1] != 39 && z->p[z->c - 1] != 115)) { z->c = z->l - m1; goto lab0; }
488 149 : if (!(find_among_b(z, a_1, 3))) { z->c = z->l - m1; goto lab0; }
489 UBC 0 : z->bra = z->c;
490 0 : { int ret = slice_del(z);
491 0 : if (ret < 0) return ret;
492 : }
493 0 : lab0:
494 : ;
495 : }
496 CBC 3131 : z->ket = z->c;
497 3131 : if (z->c <= z->lb || (z->p[z->c - 1] != 100 && z->p[z->c - 1] != 115)) return 0;
498 395 : among_var = find_among_b(z, a_2, 6);
499 395 : if (!(among_var)) return 0;
500 149 : z->bra = z->c;
501 149 : switch (among_var) {
502 UBC 0 : case 1:
503 0 : { int ret = slice_from_s(z, 2, s_2);
504 0 : if (ret < 0) return ret;
505 : }
506 0 : break;
507 0 : case 2:
508 0 : { int m2 = z->l - z->c; (void)m2;
509 0 : { int ret = skip_b_utf8(z->p, z->c, z->lb, 2);
510 0 : if (ret < 0) goto lab2;
511 0 : z->c = ret;
512 : }
513 0 : { int ret = slice_from_s(z, 1, s_3);
514 0 : if (ret < 0) return ret;
515 : }
516 0 : goto lab1;
517 0 : lab2:
518 0 : z->c = z->l - m2;
519 0 : { int ret = slice_from_s(z, 2, s_4);
520 0 : if (ret < 0) return ret;
521 : }
522 : }
523 0 : lab1:
524 0 : break;
525 CBC 122 : case 3:
526 122 : { int ret = skip_b_utf8(z->p, z->c, z->lb, 1);
527 122 : if (ret < 0) return 0;
528 122 : z->c = ret;
529 : }
530 : {
531 122 : int ret = out_grouping_b_U(z, g_v, 97, 121, 1);
532 122 : if (ret < 0) return 0;
533 119 : z->c -= ret;
534 : }
535 119 : { int ret = slice_del(z);
536 119 : if (ret < 0) return ret;
537 : }
538 119 : break;
539 : }
540 146 : return 1;
541 : }
542 :
543 3131 : static int r_Step_1b(struct SN_env * z) {
544 : int among_var;
545 3131 : z->ket = z->c;
546 3131 : if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((33554576 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
547 571 : among_var = find_among_b(z, a_4, 6);
548 571 : if (!(among_var)) return 0;
549 194 : z->bra = z->c;
550 194 : switch (among_var) {
551 UBC 0 : case 1:
552 0 : { int ret = r_R1(z);
553 0 : if (ret <= 0) return ret;
554 : }
555 0 : { int ret = slice_from_s(z, 2, s_5);
556 0 : if (ret < 0) return ret;
557 : }
558 0 : break;
559 CBC 194 : case 2:
560 194 : { int m_test1 = z->l - z->c;
561 : {
562 194 : int ret = out_grouping_b_U(z, g_v, 97, 121, 1);
563 194 : if (ret < 0) return 0;
564 194 : z->c -= ret;
565 : }
566 194 : z->c = z->l - m_test1;
567 : }
568 194 : { int ret = slice_del(z);
569 194 : if (ret < 0) return ret;
570 : }
571 194 : { int m_test2 = z->l - z->c;
572 194 : if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((68514004 >> (z->p[z->c - 1] & 0x1f)) & 1)) among_var = 3; else
573 162 : among_var = find_among_b(z, a_3, 13);
574 194 : if (!(among_var)) return 0;
575 194 : z->c = z->l - m_test2;
576 : }
577 : switch (among_var) {
578 UBC 0 : case 1:
579 : { int ret;
580 0 : { int saved_c = z->c;
581 0 : ret = insert_s(z, z->c, z->c, 1, s_6);
582 0 : z->c = saved_c;
583 : }
584 0 : if (ret < 0) return ret;
585 : }
586 0 : break;
587 CBC 18 : case 2:
588 18 : z->ket = z->c;
589 18 : { int ret = skip_b_utf8(z->p, z->c, z->lb, 1);
590 18 : if (ret < 0) return 0;
591 18 : z->c = ret;
592 : }
593 18 : z->bra = z->c;
594 18 : { int ret = slice_del(z);
595 18 : if (ret < 0) return ret;
596 : }
597 18 : break;
598 176 : case 3:
599 176 : if (z->c != z->I[1]) return 0;
600 29 : { int m_test3 = z->l - z->c;
601 29 : { int ret = r_shortv(z);
602 29 : if (ret <= 0) return ret;
603 : }
604 3 : z->c = z->l - m_test3;
605 : }
606 : { int ret;
607 3 : { int saved_c = z->c;
608 3 : ret = insert_s(z, z->c, z->c, 1, s_7);
609 3 : z->c = saved_c;
610 : }
611 3 : if (ret < 0) return ret;
612 : }
613 3 : break;
614 : }
615 21 : break;
616 : }
617 21 : return 1;
618 : }
619 :
620 3131 : static int r_Step_1c(struct SN_env * z) {
621 3131 : z->ket = z->c;
622 3131 : { int m1 = z->l - z->c; (void)m1;
623 3131 : if (z->c <= z->lb || z->p[z->c - 1] != 'y') goto lab1;
624 177 : z->c--;
625 177 : goto lab0;
626 2954 : lab1:
627 2954 : z->c = z->l - m1;
628 2954 : if (z->c <= z->lb || z->p[z->c - 1] != 'Y') return 0;
629 243 : z->c--;
630 : }
631 420 : lab0:
632 420 : z->bra = z->c;
633 420 : if (out_grouping_b_U(z, g_v, 97, 121, 0)) return 0;
634 :
635 177 : if (z->c > z->lb) goto lab2;
636 UBC 0 : return 0;
637 CBC 177 : lab2:
638 177 : { int ret = slice_from_s(z, 1, s_8);
639 177 : if (ret < 0) return ret;
640 : }
641 177 : return 1;
642 : }
643 :
644 3131 : static int r_Step_2(struct SN_env * z) {
645 : int among_var;
646 3131 : z->ket = z->c;
647 3131 : if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((815616 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
648 965 : among_var = find_among_b(z, a_5, 24);
649 965 : if (!(among_var)) return 0;
650 29 : z->bra = z->c;
651 29 : { int ret = r_R1(z);
652 29 : if (ret <= 0) return ret;
653 : }
654 29 : switch (among_var) {
655 UBC 0 : case 1:
656 0 : { int ret = slice_from_s(z, 4, s_9);
657 0 : if (ret < 0) return ret;
658 : }
659 0 : break;
660 0 : case 2:
661 0 : { int ret = slice_from_s(z, 4, s_10);
662 0 : if (ret < 0) return ret;
663 : }
664 0 : break;
665 0 : case 3:
666 0 : { int ret = slice_from_s(z, 4, s_11);
667 0 : if (ret < 0) return ret;
668 : }
669 0 : break;
670 0 : case 4:
671 0 : { int ret = slice_from_s(z, 4, s_12);
672 0 : if (ret < 0) return ret;
673 : }
674 0 : break;
675 0 : case 5:
676 0 : { int ret = slice_from_s(z, 3, s_13);
677 0 : if (ret < 0) return ret;
678 : }
679 0 : break;
680 0 : case 6:
681 0 : { int ret = slice_from_s(z, 3, s_14);
682 0 : if (ret < 0) return ret;
683 : }
684 0 : break;
685 CBC 23 : case 7:
686 23 : { int ret = slice_from_s(z, 3, s_15);
687 23 : if (ret < 0) return ret;
688 : }
689 23 : break;
690 6 : case 8:
691 6 : { int ret = slice_from_s(z, 2, s_16);
692 6 : if (ret < 0) return ret;
693 : }
694 6 : break;
695 UBC 0 : case 9:
696 0 : { int ret = slice_from_s(z, 3, s_17);
697 0 : if (ret < 0) return ret;
698 : }
699 0 : break;
700 0 : case 10:
701 0 : { int ret = slice_from_s(z, 3, s_18);
702 0 : if (ret < 0) return ret;
703 : }
704 0 : break;
705 0 : case 11:
706 0 : { int ret = slice_from_s(z, 3, s_19);
707 0 : if (ret < 0) return ret;
708 : }
709 0 : break;
710 0 : case 12:
711 0 : { int ret = slice_from_s(z, 3, s_20);
712 0 : if (ret < 0) return ret;
713 : }
714 0 : break;
715 0 : case 13:
716 0 : if (z->c <= z->lb || z->p[z->c - 1] != 'l') return 0;
717 0 : z->c--;
718 0 : { int ret = slice_from_s(z, 2, s_21);
719 0 : if (ret < 0) return ret;
720 : }
721 0 : break;
722 0 : case 14:
723 0 : { int ret = slice_from_s(z, 4, s_22);
724 0 : if (ret < 0) return ret;
725 : }
726 0 : break;
727 0 : case 15:
728 0 : if (in_grouping_b_U(z, g_valid_LI, 99, 116, 0)) return 0;
729 0 : { int ret = slice_del(z);
730 0 : if (ret < 0) return ret;
731 : }
732 0 : break;
733 : }
734 CBC 29 : return 1;
735 : }
736 :
737 3131 : static int r_Step_3(struct SN_env * z) {
738 : int among_var;
739 3131 : z->ket = z->c;
740 3131 : if (z->c - 2 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((528928 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
741 710 : among_var = find_among_b(z, a_6, 9);
742 710 : if (!(among_var)) return 0;
743 UBC 0 : z->bra = z->c;
744 0 : { int ret = r_R1(z);
745 0 : if (ret <= 0) return ret;
746 : }
747 0 : switch (among_var) {
748 0 : case 1:
749 0 : { int ret = slice_from_s(z, 4, s_23);
750 0 : if (ret < 0) return ret;
751 : }
752 0 : break;
753 0 : case 2:
754 0 : { int ret = slice_from_s(z, 3, s_24);
755 0 : if (ret < 0) return ret;
756 : }
757 0 : break;
758 0 : case 3:
759 0 : { int ret = slice_from_s(z, 2, s_25);
760 0 : if (ret < 0) return ret;
761 : }
762 0 : break;
763 0 : case 4:
764 0 : { int ret = slice_from_s(z, 2, s_26);
765 0 : if (ret < 0) return ret;
766 : }
767 0 : break;
768 0 : case 5:
769 0 : { int ret = slice_del(z);
770 0 : if (ret < 0) return ret;
771 : }
772 0 : break;
773 0 : case 6:
774 0 : { int ret = r_R2(z);
775 0 : if (ret <= 0) return ret;
776 : }
777 0 : { int ret = slice_del(z);
778 0 : if (ret < 0) return ret;
779 : }
780 0 : break;
781 : }
782 0 : return 1;
783 : }
784 :
785 CBC 3131 : static int r_Step_4(struct SN_env * z) {
786 : int among_var;
787 3131 : z->ket = z->c;
788 3131 : if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((1864232 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
789 1711 : among_var = find_among_b(z, a_7, 18);
790 1711 : if (!(among_var)) return 0;
791 424 : z->bra = z->c;
792 424 : { int ret = r_R2(z);
793 424 : if (ret <= 0) return ret;
794 : }
795 44 : switch (among_var) {
796 44 : case 1:
797 44 : { int ret = slice_del(z);
798 44 : if (ret < 0) return ret;
799 : }
800 44 : break;
801 UBC 0 : case 2:
802 0 : { int m1 = z->l - z->c; (void)m1;
803 0 : if (z->c <= z->lb || z->p[z->c - 1] != 's') goto lab1;
804 0 : z->c--;
805 0 : goto lab0;
806 0 : lab1:
807 0 : z->c = z->l - m1;
808 0 : if (z->c <= z->lb || z->p[z->c - 1] != 't') return 0;
809 0 : z->c--;
810 : }
811 0 : lab0:
812 0 : { int ret = slice_del(z);
813 0 : if (ret < 0) return ret;
814 : }
815 0 : break;
816 : }
817 CBC 44 : return 1;
818 : }
819 :
820 3131 : static int r_Step_5(struct SN_env * z) {
821 : int among_var;
822 3131 : z->ket = z->c;
823 3131 : if (z->c <= z->lb || (z->p[z->c - 1] != 101 && z->p[z->c - 1] != 108)) return 0;
824 441 : among_var = find_among_b(z, a_8, 2);
825 441 : if (!(among_var)) return 0;
826 441 : z->bra = z->c;
827 441 : switch (among_var) {
828 393 : case 1:
829 393 : { int m1 = z->l - z->c; (void)m1;
830 393 : { int ret = r_R2(z);
831 393 : if (ret == 0) goto lab1;
832 119 : if (ret < 0) return ret;
833 : }
834 119 : goto lab0;
835 274 : lab1:
836 274 : z->c = z->l - m1;
837 274 : { int ret = r_R1(z);
838 274 : if (ret <= 0) return ret;
839 : }
840 189 : { int m2 = z->l - z->c; (void)m2;
841 189 : { int ret = r_shortv(z);
842 189 : if (ret == 0) goto lab2;
843 84 : if (ret < 0) return ret;
844 : }
845 84 : return 0;
846 105 : lab2:
847 105 : z->c = z->l - m2;
848 : }
849 : }
850 224 : lab0:
851 224 : { int ret = slice_del(z);
852 224 : if (ret < 0) return ret;
853 : }
854 224 : break;
855 48 : case 2:
856 48 : { int ret = r_R2(z);
857 48 : if (ret <= 0) return ret;
858 : }
859 3 : if (z->c <= z->lb || z->p[z->c - 1] != 'l') return 0;
860 UBC 0 : z->c--;
861 0 : { int ret = slice_del(z);
862 0 : if (ret < 0) return ret;
863 : }
864 0 : break;
865 : }
866 CBC 224 : return 1;
867 : }
868 :
869 3131 : static int r_exception2(struct SN_env * z) {
870 3131 : z->ket = z->c;
871 3131 : if (z->c - 5 <= z->lb || (z->p[z->c - 1] != 100 && z->p[z->c - 1] != 103)) return 0;
872 206 : if (!(find_among_b(z, a_9, 8))) return 0;
873 UBC 0 : z->bra = z->c;
874 0 : if (z->c > z->lb) return 0;
875 0 : return 1;
876 : }
877 :
878 CBC 3401 : static int r_exception1(struct SN_env * z) {
879 : int among_var;
880 3401 : z->bra = z->c;
881 3401 : if (z->c + 2 >= z->l || z->p[z->c + 2] >> 5 != 3 || !((42750482 >> (z->p[z->c + 2] & 0x1f)) & 1)) return 0;
882 1491 : among_var = find_among(z, a_10, 18);
883 1491 : if (!(among_var)) return 0;
884 18 : z->ket = z->c;
885 18 : if (z->c < z->l) return 0;
886 18 : switch (among_var) {
887 UBC 0 : case 1:
888 0 : { int ret = slice_from_s(z, 3, s_27);
889 0 : if (ret < 0) return ret;
890 : }
891 0 : break;
892 CBC 18 : case 2:
893 18 : { int ret = slice_from_s(z, 3, s_28);
894 18 : if (ret < 0) return ret;
895 : }
896 18 : break;
897 UBC 0 : case 3:
898 0 : { int ret = slice_from_s(z, 3, s_29);
899 0 : if (ret < 0) return ret;
900 : }
901 0 : break;
902 0 : case 4:
903 0 : { int ret = slice_from_s(z, 3, s_30);
904 0 : if (ret < 0) return ret;
905 : }
906 0 : break;
907 0 : case 5:
908 0 : { int ret = slice_from_s(z, 3, s_31);
909 0 : if (ret < 0) return ret;
910 : }
911 0 : break;
912 0 : case 6:
913 0 : { int ret = slice_from_s(z, 3, s_32);
914 0 : if (ret < 0) return ret;
915 : }
916 0 : break;
917 0 : case 7:
918 0 : { int ret = slice_from_s(z, 5, s_33);
919 0 : if (ret < 0) return ret;
920 : }
921 0 : break;
922 0 : case 8:
923 0 : { int ret = slice_from_s(z, 4, s_34);
924 0 : if (ret < 0) return ret;
925 : }
926 0 : break;
927 0 : case 9:
928 0 : { int ret = slice_from_s(z, 5, s_35);
929 0 : if (ret < 0) return ret;
930 : }
931 0 : break;
932 0 : case 10:
933 0 : { int ret = slice_from_s(z, 4, s_36);
934 0 : if (ret < 0) return ret;
935 : }
936 0 : break;
937 0 : case 11:
938 0 : { int ret = slice_from_s(z, 5, s_37);
939 0 : if (ret < 0) return ret;
940 : }
941 0 : break;
942 : }
943 CBC 18 : return 1;
944 : }
945 :
946 3131 : static int r_postlude(struct SN_env * z) {
947 3131 : if (!(z->I[2])) return 0;
948 264 : while(1) {
949 528 : int c1 = z->c;
950 813 : while(1) {
951 1341 : int c2 = z->c;
952 1341 : z->bra = z->c;
953 1341 : if (z->c == z->l || z->p[z->c] != 'Y') goto lab1;
954 264 : z->c++;
955 264 : z->ket = z->c;
956 264 : z->c = c2;
957 264 : break;
958 1077 : lab1:
959 1077 : z->c = c2;
960 1077 : { int ret = skip_utf8(z->p, z->c, z->l, 1);
961 1077 : if (ret < 0) goto lab0;
962 813 : z->c = ret;
963 : }
964 : }
965 264 : { int ret = slice_from_s(z, 1, s_38);
966 264 : if (ret < 0) return ret;
967 : }
968 264 : continue;
969 264 : lab0:
970 264 : z->c = c1;
971 264 : break;
972 : }
973 264 : return 1;
974 : }
975 :
976 3401 : extern int english_UTF_8_stem(struct SN_env * z) {
977 3401 : { int c1 = z->c;
978 3401 : { int ret = r_exception1(z);
979 3401 : if (ret == 0) goto lab1;
980 18 : if (ret < 0) return ret;
981 : }
982 18 : goto lab0;
983 3383 : lab1:
984 3383 : z->c = c1;
985 3383 : { int c2 = z->c;
986 3383 : { int ret = skip_utf8(z->p, z->c, z->l, 3);
987 3383 : if (ret < 0) goto lab3;
988 3131 : z->c = ret;
989 : }
990 3131 : goto lab2;
991 252 : lab3:
992 252 : z->c = c2;
993 : }
994 252 : goto lab0;
995 3131 : lab2:
996 3131 : z->c = c1;
997 :
998 3131 : { int ret = r_prelude(z);
999 3131 : if (ret < 0) return ret;
1000 : }
1001 :
1002 3131 : { int ret = r_mark_regions(z);
1003 3131 : if (ret < 0) return ret;
1004 : }
1005 3131 : z->lb = z->c; z->c = z->l;
1006 :
1007 3131 : { int m3 = z->l - z->c; (void)m3;
1008 3131 : { int ret = r_Step_1a(z);
1009 3131 : if (ret < 0) return ret;
1010 : }
1011 3131 : z->c = z->l - m3;
1012 : }
1013 3131 : { int m4 = z->l - z->c; (void)m4;
1014 3131 : { int ret = r_exception2(z);
1015 3131 : if (ret == 0) goto lab5;
1016 UBC 0 : if (ret < 0) return ret;
1017 : }
1018 0 : goto lab4;
1019 CBC 3131 : lab5:
1020 3131 : z->c = z->l - m4;
1021 3131 : { int m5 = z->l - z->c; (void)m5;
1022 3131 : { int ret = r_Step_1b(z);
1023 3131 : if (ret < 0) return ret;
1024 : }
1025 3131 : z->c = z->l - m5;
1026 : }
1027 3131 : { int m6 = z->l - z->c; (void)m6;
1028 3131 : { int ret = r_Step_1c(z);
1029 3131 : if (ret < 0) return ret;
1030 : }
1031 3131 : z->c = z->l - m6;
1032 : }
1033 3131 : { int m7 = z->l - z->c; (void)m7;
1034 3131 : { int ret = r_Step_2(z);
1035 3131 : if (ret < 0) return ret;
1036 : }
1037 3131 : z->c = z->l - m7;
1038 : }
1039 3131 : { int m8 = z->l - z->c; (void)m8;
1040 3131 : { int ret = r_Step_3(z);
1041 3131 : if (ret < 0) return ret;
1042 : }
1043 3131 : z->c = z->l - m8;
1044 : }
1045 3131 : { int m9 = z->l - z->c; (void)m9;
1046 3131 : { int ret = r_Step_4(z);
1047 3131 : if (ret < 0) return ret;
1048 : }
1049 3131 : z->c = z->l - m9;
1050 : }
1051 3131 : { int m10 = z->l - z->c; (void)m10;
1052 3131 : { int ret = r_Step_5(z);
1053 3131 : if (ret < 0) return ret;
1054 : }
1055 3131 : z->c = z->l - m10;
1056 : }
1057 : }
1058 3131 : lab4:
1059 3131 : z->c = z->lb;
1060 3131 : { int c11 = z->c;
1061 3131 : { int ret = r_postlude(z);
1062 3131 : if (ret < 0) return ret;
1063 : }
1064 3131 : z->c = c11;
1065 : }
1066 : }
1067 3401 : lab0:
1068 3401 : return 1;
1069 : }
1070 :
1071 19 : extern struct SN_env * english_UTF_8_create_env(void) { return SN_create_env(0, 3); }
1072 :
1073 UBC 0 : extern void english_UTF_8_close_env(struct SN_env * z) { SN_close_env(z, 0); }
1074 :
|