1 /* Generated by Snowball 2.1.0 - https://snowballstem.org/ */
2 
3 #include "header.h"
4 
5 #ifdef __cplusplus
6 extern "C" {
7 #endif
8 extern int porter_UTF_8_stem(struct SN_env * z);
9 #ifdef __cplusplus
10 }
11 #endif
12 static int r_Step_5b(struct SN_env * z);
13 static int r_Step_5a(struct SN_env * z);
14 static int r_Step_4(struct SN_env * z);
15 static int r_Step_3(struct SN_env * z);
16 static int r_Step_2(struct SN_env * z);
17 static int r_Step_1c(struct SN_env * z);
18 static int r_Step_1b(struct SN_env * z);
19 static int r_Step_1a(struct SN_env * z);
20 static int r_R2(struct SN_env * z);
21 static int r_R1(struct SN_env * z);
22 static int r_shortv(struct SN_env * z);
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
26 
27 
28 extern struct SN_env * porter_UTF_8_create_env(void);
29 extern void porter_UTF_8_close_env(struct SN_env * z);
30 
31 
32 #ifdef __cplusplus
33 }
34 #endif
35 static const symbol s_0_0[1] = { 's' };
36 static const symbol s_0_1[3] = { 'i', 'e', 's' };
37 static const symbol s_0_2[4] = { 's', 's', 'e', 's' };
38 static const symbol s_0_3[2] = { 's', 's' };
39 
40 static const struct among a_0[4] =
41 {
42 { 1, s_0_0, -1, 3, 0},
43 { 3, s_0_1, 0, 2, 0},
44 { 4, s_0_2, 0, 1, 0},
45 { 2, s_0_3, 0, -1, 0}
46 };
47 
48 static const symbol s_1_1[2] = { 'b', 'b' };
49 static const symbol s_1_2[2] = { 'd', 'd' };
50 static const symbol s_1_3[2] = { 'f', 'f' };
51 static const symbol s_1_4[2] = { 'g', 'g' };
52 static const symbol s_1_5[2] = { 'b', 'l' };
53 static const symbol s_1_6[2] = { 'm', 'm' };
54 static const symbol s_1_7[2] = { 'n', 'n' };
55 static const symbol s_1_8[2] = { 'p', 'p' };
56 static const symbol s_1_9[2] = { 'r', 'r' };
57 static const symbol s_1_10[2] = { 'a', 't' };
58 static const symbol s_1_11[2] = { 't', 't' };
59 static const symbol s_1_12[2] = { 'i', 'z' };
60 
61 static const struct among a_1[13] =
62 {
63 { 0, 0, -1, 3, 0},
64 { 2, s_1_1, 0, 2, 0},
65 { 2, s_1_2, 0, 2, 0},
66 { 2, s_1_3, 0, 2, 0},
67 { 2, s_1_4, 0, 2, 0},
68 { 2, s_1_5, 0, 1, 0},
69 { 2, s_1_6, 0, 2, 0},
70 { 2, s_1_7, 0, 2, 0},
71 { 2, s_1_8, 0, 2, 0},
72 { 2, s_1_9, 0, 2, 0},
73 { 2, s_1_10, 0, 1, 0},
74 { 2, s_1_11, 0, 2, 0},
75 { 2, s_1_12, 0, 1, 0}
76 };
77 
78 static const symbol s_2_0[2] = { 'e', 'd' };
79 static const symbol s_2_1[3] = { 'e', 'e', 'd' };
80 static const symbol s_2_2[3] = { 'i', 'n', 'g' };
81 
82 static const struct among a_2[3] =
83 {
84 { 2, s_2_0, -1, 2, 0},
85 { 3, s_2_1, 0, 1, 0},
86 { 3, s_2_2, -1, 2, 0}
87 };
88 
89 static const symbol s_3_0[4] = { 'a', 'n', 'c', 'i' };
90 static const symbol s_3_1[4] = { 'e', 'n', 'c', 'i' };
91 static const symbol s_3_2[4] = { 'a', 'b', 'l', 'i' };
92 static const symbol s_3_3[3] = { 'e', 'l', 'i' };
93 static const symbol s_3_4[4] = { 'a', 'l', 'l', 'i' };
94 static const symbol s_3_5[5] = { 'o', 'u', 's', 'l', 'i' };
95 static const symbol s_3_6[5] = { 'e', 'n', 't', 'l', 'i' };
96 static const symbol s_3_7[5] = { 'a', 'l', 'i', 't', 'i' };
97 static const symbol s_3_8[6] = { 'b', 'i', 'l', 'i', 't', 'i' };
98 static const symbol s_3_9[5] = { 'i', 'v', 'i', 't', 'i' };
99 static const symbol s_3_10[6] = { 't', 'i', 'o', 'n', 'a', 'l' };
100 static const symbol s_3_11[7] = { 'a', 't', 'i', 'o', 'n', 'a', 'l' };
101 static const symbol s_3_12[5] = { 'a', 'l', 'i', 's', 'm' };
102 static const symbol s_3_13[5] = { 'a', 't', 'i', 'o', 'n' };
103 static const symbol s_3_14[7] = { 'i', 'z', 'a', 't', 'i', 'o', 'n' };
104 static const symbol s_3_15[4] = { 'i', 'z', 'e', 'r' };
105 static const symbol s_3_16[4] = { 'a', 't', 'o', 'r' };
106 static const symbol s_3_17[7] = { 'i', 'v', 'e', 'n', 'e', 's', 's' };
107 static const symbol s_3_18[7] = { 'f', 'u', 'l', 'n', 'e', 's', 's' };
108 static const symbol s_3_19[7] = { 'o', 'u', 's', 'n', 'e', 's', 's' };
109 
110 static const struct among a_3[20] =
111 {
112 { 4, s_3_0, -1, 3, 0},
113 { 4, s_3_1, -1, 2, 0},
114 { 4, s_3_2, -1, 4, 0},
115 { 3, s_3_3, -1, 6, 0},
116 { 4, s_3_4, -1, 9, 0},
117 { 5, s_3_5, -1, 11, 0},
118 { 5, s_3_6, -1, 5, 0},
119 { 5, s_3_7, -1, 9, 0},
120 { 6, s_3_8, -1, 13, 0},
121 { 5, s_3_9, -1, 12, 0},
122 { 6, s_3_10, -1, 1, 0},
123 { 7, s_3_11, 10, 8, 0},
124 { 5, s_3_12, -1, 9, 0},
125 { 5, s_3_13, -1, 8, 0},
126 { 7, s_3_14, 13, 7, 0},
127 { 4, s_3_15, -1, 7, 0},
128 { 4, s_3_16, -1, 8, 0},
129 { 7, s_3_17, -1, 12, 0},
130 { 7, s_3_18, -1, 10, 0},
131 { 7, s_3_19, -1, 11, 0}
132 };
133 
134 static const symbol s_4_0[5] = { 'i', 'c', 'a', 't', 'e' };
135 static const symbol s_4_1[5] = { 'a', 't', 'i', 'v', 'e' };
136 static const symbol s_4_2[5] = { 'a', 'l', 'i', 'z', 'e' };
137 static const symbol s_4_3[5] = { 'i', 'c', 'i', 't', 'i' };
138 static const symbol s_4_4[4] = { 'i', 'c', 'a', 'l' };
139 static const symbol s_4_5[3] = { 'f', 'u', 'l' };
140 static const symbol s_4_6[4] = { 'n', 'e', 's', 's' };
141 
142 static const struct among a_4[7] =
143 {
144 { 5, s_4_0, -1, 2, 0},
145 { 5, s_4_1, -1, 3, 0},
146 { 5, s_4_2, -1, 1, 0},
147 { 5, s_4_3, -1, 2, 0},
148 { 4, s_4_4, -1, 2, 0},
149 { 3, s_4_5, -1, 3, 0},
150 { 4, s_4_6, -1, 3, 0}
151 };
152 
153 static const symbol s_5_0[2] = { 'i', 'c' };
154 static const symbol s_5_1[4] = { 'a', 'n', 'c', 'e' };
155 static const symbol s_5_2[4] = { 'e', 'n', 'c', 'e' };
156 static const symbol s_5_3[4] = { 'a', 'b', 'l', 'e' };
157 static const symbol s_5_4[4] = { 'i', 'b', 'l', 'e' };
158 static const symbol s_5_5[3] = { 'a', 't', 'e' };
159 static const symbol s_5_6[3] = { 'i', 'v', 'e' };
160 static const symbol s_5_7[3] = { 'i', 'z', 'e' };
161 static const symbol s_5_8[3] = { 'i', 't', 'i' };
162 static const symbol s_5_9[2] = { 'a', 'l' };
163 static const symbol s_5_10[3] = { 'i', 's', 'm' };
164 static const symbol s_5_11[3] = { 'i', 'o', 'n' };
165 static const symbol s_5_12[2] = { 'e', 'r' };
166 static const symbol s_5_13[3] = { 'o', 'u', 's' };
167 static const symbol s_5_14[3] = { 'a', 'n', 't' };
168 static const symbol s_5_15[3] = { 'e', 'n', 't' };
169 static const symbol s_5_16[4] = { 'm', 'e', 'n', 't' };
170 static const symbol s_5_17[5] = { 'e', 'm', 'e', 'n', 't' };
171 static const symbol s_5_18[2] = { 'o', 'u' };
172 
173 static const struct among a_5[19] =
174 {
175 { 2, s_5_0, -1, 1, 0},
176 { 4, s_5_1, -1, 1, 0},
177 { 4, s_5_2, -1, 1, 0},
178 { 4, s_5_3, -1, 1, 0},
179 { 4, s_5_4, -1, 1, 0},
180 { 3, s_5_5, -1, 1, 0},
181 { 3, s_5_6, -1, 1, 0},
182 { 3, s_5_7, -1, 1, 0},
183 { 3, s_5_8, -1, 1, 0},
184 { 2, s_5_9, -1, 1, 0},
185 { 3, s_5_10, -1, 1, 0},
186 { 3, s_5_11, -1, 2, 0},
187 { 2, s_5_12, -1, 1, 0},
188 { 3, s_5_13, -1, 1, 0},
189 { 3, s_5_14, -1, 1, 0},
190 { 3, s_5_15, -1, 1, 0},
191 { 4, s_5_16, 15, 1, 0},
192 { 5, s_5_17, 16, 1, 0},
193 { 2, s_5_18, -1, 1, 0}
194 };
195 
196 static const unsigned char g_v[] = { 17, 65, 16, 1 };
197 
198 static const unsigned char g_v_WXY[] = { 1, 17, 65, 208, 1 };
199 
200 static const symbol s_0[] = { 's', 's' };
201 static const symbol s_1[] = { 'i' };
202 static const symbol s_2[] = { 'e', 'e' };
203 static const symbol s_3[] = { 'e' };
204 static const symbol s_4[] = { 'e' };
205 static const symbol s_5[] = { 'i' };
206 static const symbol s_6[] = { 't', 'i', 'o', 'n' };
207 static const symbol s_7[] = { 'e', 'n', 'c', 'e' };
208 static const symbol s_8[] = { 'a', 'n', 'c', 'e' };
209 static const symbol s_9[] = { 'a', 'b', 'l', 'e' };
210 static const symbol s_10[] = { 'e', 'n', 't' };
211 static const symbol s_11[] = { 'e' };
212 static const symbol s_12[] = { 'i', 'z', 'e' };
213 static const symbol s_13[] = { 'a', 't', 'e' };
214 static const symbol s_14[] = { 'a', 'l' };
215 static const symbol s_15[] = { 'f', 'u', 'l' };
216 static const symbol s_16[] = { 'o', 'u', 's' };
217 static const symbol s_17[] = { 'i', 'v', 'e' };
218 static const symbol s_18[] = { 'b', 'l', 'e' };
219 static const symbol s_19[] = { 'a', 'l' };
220 static const symbol s_20[] = { 'i', 'c' };
221 static const symbol s_21[] = { 'Y' };
222 static const symbol s_22[] = { 'Y' };
223 static const symbol s_23[] = { 'y' };
224 
r_shortv(struct SN_env * z)225 static int r_shortv(struct SN_env * z) {
226     if (out_grouping_b_U(z, g_v_WXY, 89, 121, 0)) return 0;
227     if (in_grouping_b_U(z, g_v, 97, 121, 0)) return 0;
228     if (out_grouping_b_U(z, g_v, 97, 121, 0)) return 0;
229     return 1;
230 }
231 
r_R1(struct SN_env * z)232 static int r_R1(struct SN_env * z) {
233     if (!(z->I[1] <= z->c)) return 0;
234     return 1;
235 }
236 
r_R2(struct SN_env * z)237 static int r_R2(struct SN_env * z) {
238     if (!(z->I[0] <= z->c)) return 0;
239     return 1;
240 }
241 
r_Step_1a(struct SN_env * z)242 static int r_Step_1a(struct SN_env * z) {
243     int among_var;
244     z->ket = z->c;
245     if (z->c <= z->lb || z->p[z->c - 1] != 115) return 0;
246     among_var = find_among_b(z, a_0, 4);
247     if (!(among_var)) return 0;
248     z->bra = z->c;
249     switch (among_var) {
250         case 1:
251             {   int ret = slice_from_s(z, 2, s_0);
252                 if (ret < 0) return ret;
253             }
254             break;
255         case 2:
256             {   int ret = slice_from_s(z, 1, s_1);
257                 if (ret < 0) return ret;
258             }
259             break;
260         case 3:
261             {   int ret = slice_del(z);
262                 if (ret < 0) return ret;
263             }
264             break;
265     }
266     return 1;
267 }
268 
r_Step_1b(struct SN_env * z)269 static int r_Step_1b(struct SN_env * z) {
270     int among_var;
271     z->ket = z->c;
272     if (z->c - 1 <= z->lb || (z->p[z->c - 1] != 100 && z->p[z->c - 1] != 103)) return 0;
273     among_var = find_among_b(z, a_2, 3);
274     if (!(among_var)) return 0;
275     z->bra = z->c;
276     switch (among_var) {
277         case 1:
278             {   int ret = r_R1(z);
279                 if (ret <= 0) return ret;
280             }
281             {   int ret = slice_from_s(z, 2, s_2);
282                 if (ret < 0) return ret;
283             }
284             break;
285         case 2:
286             {   int m_test1 = z->l - z->c;
287                 {
288                     int ret = out_grouping_b_U(z, g_v, 97, 121, 1);
289                     if (ret < 0) return 0;
290                     z->c -= ret;
291                 }
292                 z->c = z->l - m_test1;
293             }
294             {   int ret = slice_del(z);
295                 if (ret < 0) return ret;
296             }
297             {   int m_test2 = z->l - z->c;
298                 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
299                 among_var = find_among_b(z, a_1, 13);
300                 if (!(among_var)) return 0;
301                 z->c = z->l - m_test2;
302             }
303             switch (among_var) {
304                 case 1:
305                     {   int ret;
306                         {   int saved_c = z->c;
307                             ret = insert_s(z, z->c, z->c, 1, s_3);
308                             z->c = saved_c;
309                         }
310                         if (ret < 0) return ret;
311                     }
312                     break;
313                 case 2:
314                     z->ket = z->c;
315                     {   int ret = skip_b_utf8(z->p, z->c, z->lb, 1);
316                         if (ret < 0) return 0;
317                         z->c = ret;
318                     }
319                     z->bra = z->c;
320                     {   int ret = slice_del(z);
321                         if (ret < 0) return ret;
322                     }
323                     break;
324                 case 3:
325                     if (z->c != z->I[1]) return 0;
326                     {   int m_test3 = z->l - z->c;
327                         {   int ret = r_shortv(z);
328                             if (ret <= 0) return ret;
329                         }
330                         z->c = z->l - m_test3;
331                     }
332                     {   int ret;
333                         {   int saved_c = z->c;
334                             ret = insert_s(z, z->c, z->c, 1, s_4);
335                             z->c = saved_c;
336                         }
337                         if (ret < 0) return ret;
338                     }
339                     break;
340             }
341             break;
342     }
343     return 1;
344 }
345 
r_Step_1c(struct SN_env * z)346 static int r_Step_1c(struct SN_env * z) {
347     z->ket = z->c;
348     {   int m1 = z->l - z->c; (void)m1;
349         if (z->c <= z->lb || z->p[z->c - 1] != 'y') goto lab1;
350         z->c--;
351         goto lab0;
352     lab1:
353         z->c = z->l - m1;
354         if (z->c <= z->lb || z->p[z->c - 1] != 'Y') return 0;
355         z->c--;
356     }
357 lab0:
358     z->bra = z->c;
359     {
360         int ret = out_grouping_b_U(z, g_v, 97, 121, 1);
361         if (ret < 0) return 0;
362         z->c -= ret;
363     }
364     {   int ret = slice_from_s(z, 1, s_5);
365         if (ret < 0) return ret;
366     }
367     return 1;
368 }
369 
r_Step_2(struct SN_env * z)370 static int r_Step_2(struct SN_env * z) {
371     int among_var;
372     z->ket = z->c;
373     if (z->c - 2 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((815616 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
374     among_var = find_among_b(z, a_3, 20);
375     if (!(among_var)) return 0;
376     z->bra = z->c;
377     {   int ret = r_R1(z);
378         if (ret <= 0) return ret;
379     }
380     switch (among_var) {
381         case 1:
382             {   int ret = slice_from_s(z, 4, s_6);
383                 if (ret < 0) return ret;
384             }
385             break;
386         case 2:
387             {   int ret = slice_from_s(z, 4, s_7);
388                 if (ret < 0) return ret;
389             }
390             break;
391         case 3:
392             {   int ret = slice_from_s(z, 4, s_8);
393                 if (ret < 0) return ret;
394             }
395             break;
396         case 4:
397             {   int ret = slice_from_s(z, 4, s_9);
398                 if (ret < 0) return ret;
399             }
400             break;
401         case 5:
402             {   int ret = slice_from_s(z, 3, s_10);
403                 if (ret < 0) return ret;
404             }
405             break;
406         case 6:
407             {   int ret = slice_from_s(z, 1, s_11);
408                 if (ret < 0) return ret;
409             }
410             break;
411         case 7:
412             {   int ret = slice_from_s(z, 3, s_12);
413                 if (ret < 0) return ret;
414             }
415             break;
416         case 8:
417             {   int ret = slice_from_s(z, 3, s_13);
418                 if (ret < 0) return ret;
419             }
420             break;
421         case 9:
422             {   int ret = slice_from_s(z, 2, s_14);
423                 if (ret < 0) return ret;
424             }
425             break;
426         case 10:
427             {   int ret = slice_from_s(z, 3, s_15);
428                 if (ret < 0) return ret;
429             }
430             break;
431         case 11:
432             {   int ret = slice_from_s(z, 3, s_16);
433                 if (ret < 0) return ret;
434             }
435             break;
436         case 12:
437             {   int ret = slice_from_s(z, 3, s_17);
438                 if (ret < 0) return ret;
439             }
440             break;
441         case 13:
442             {   int ret = slice_from_s(z, 3, s_18);
443                 if (ret < 0) return ret;
444             }
445             break;
446     }
447     return 1;
448 }
449 
r_Step_3(struct SN_env * z)450 static int r_Step_3(struct SN_env * z) {
451     int among_var;
452     z->ket = z->c;
453     if (z->c - 2 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((528928 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
454     among_var = find_among_b(z, a_4, 7);
455     if (!(among_var)) return 0;
456     z->bra = z->c;
457     {   int ret = r_R1(z);
458         if (ret <= 0) return ret;
459     }
460     switch (among_var) {
461         case 1:
462             {   int ret = slice_from_s(z, 2, s_19);
463                 if (ret < 0) return ret;
464             }
465             break;
466         case 2:
467             {   int ret = slice_from_s(z, 2, s_20);
468                 if (ret < 0) return ret;
469             }
470             break;
471         case 3:
472             {   int ret = slice_del(z);
473                 if (ret < 0) return ret;
474             }
475             break;
476     }
477     return 1;
478 }
479 
r_Step_4(struct SN_env * z)480 static int r_Step_4(struct SN_env * z) {
481     int among_var;
482     z->ket = z->c;
483     if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((3961384 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
484     among_var = find_among_b(z, a_5, 19);
485     if (!(among_var)) return 0;
486     z->bra = z->c;
487     {   int ret = r_R2(z);
488         if (ret <= 0) return ret;
489     }
490     switch (among_var) {
491         case 1:
492             {   int ret = slice_del(z);
493                 if (ret < 0) return ret;
494             }
495             break;
496         case 2:
497             {   int m1 = z->l - z->c; (void)m1;
498                 if (z->c <= z->lb || z->p[z->c - 1] != 's') goto lab1;
499                 z->c--;
500                 goto lab0;
501             lab1:
502                 z->c = z->l - m1;
503                 if (z->c <= z->lb || z->p[z->c - 1] != 't') return 0;
504                 z->c--;
505             }
506         lab0:
507             {   int ret = slice_del(z);
508                 if (ret < 0) return ret;
509             }
510             break;
511     }
512     return 1;
513 }
514 
r_Step_5a(struct SN_env * z)515 static int r_Step_5a(struct SN_env * z) {
516     z->ket = z->c;
517     if (z->c <= z->lb || z->p[z->c - 1] != 'e') return 0;
518     z->c--;
519     z->bra = z->c;
520     {   int m1 = z->l - z->c; (void)m1;
521         {   int ret = r_R2(z);
522             if (ret == 0) goto lab1;
523             if (ret < 0) return ret;
524         }
525         goto lab0;
526     lab1:
527         z->c = z->l - m1;
528         {   int ret = r_R1(z);
529             if (ret <= 0) return ret;
530         }
531         {   int m2 = z->l - z->c; (void)m2;
532             {   int ret = r_shortv(z);
533                 if (ret == 0) goto lab2;
534                 if (ret < 0) return ret;
535             }
536             return 0;
537         lab2:
538             z->c = z->l - m2;
539         }
540     }
541 lab0:
542     {   int ret = slice_del(z);
543         if (ret < 0) return ret;
544     }
545     return 1;
546 }
547 
r_Step_5b(struct SN_env * z)548 static int r_Step_5b(struct SN_env * z) {
549     z->ket = z->c;
550     if (z->c <= z->lb || z->p[z->c - 1] != 'l') return 0;
551     z->c--;
552     z->bra = z->c;
553     {   int ret = r_R2(z);
554         if (ret <= 0) return ret;
555     }
556     if (z->c <= z->lb || z->p[z->c - 1] != 'l') return 0;
557     z->c--;
558     {   int ret = slice_del(z);
559         if (ret < 0) return ret;
560     }
561     return 1;
562 }
563 
porter_UTF_8_stem(struct SN_env * z)564 extern int porter_UTF_8_stem(struct SN_env * z) {
565     z->I[2] = 0;
566     {   int c1 = z->c;
567         z->bra = z->c;
568         if (z->c == z->l || z->p[z->c] != 'y') goto lab0;
569         z->c++;
570         z->ket = z->c;
571         {   int ret = slice_from_s(z, 1, s_21);
572             if (ret < 0) return ret;
573         }
574         z->I[2] = 1;
575     lab0:
576         z->c = c1;
577     }
578     {   int c2 = z->c;
579         while(1) {
580             int c3 = z->c;
581             while(1) {
582                 int c4 = z->c;
583                 if (in_grouping_U(z, g_v, 97, 121, 0)) goto lab3;
584                 z->bra = z->c;
585                 if (z->c == z->l || z->p[z->c] != 'y') goto lab3;
586                 z->c++;
587                 z->ket = z->c;
588                 z->c = c4;
589                 break;
590             lab3:
591                 z->c = c4;
592                 {   int ret = skip_utf8(z->p, z->c, z->l, 1);
593                     if (ret < 0) goto lab2;
594                     z->c = ret;
595                 }
596             }
597             {   int ret = slice_from_s(z, 1, s_22);
598                 if (ret < 0) return ret;
599             }
600             z->I[2] = 1;
601             continue;
602         lab2:
603             z->c = c3;
604             break;
605         }
606         z->c = c2;
607     }
608     z->I[1] = z->l;
609     z->I[0] = z->l;
610     {   int c5 = z->c;
611         {
612             int ret = out_grouping_U(z, g_v, 97, 121, 1);
613             if (ret < 0) goto lab4;
614             z->c += ret;
615         }
616         {
617             int ret = in_grouping_U(z, g_v, 97, 121, 1);
618             if (ret < 0) goto lab4;
619             z->c += ret;
620         }
621         z->I[1] = z->c;
622         {
623             int ret = out_grouping_U(z, g_v, 97, 121, 1);
624             if (ret < 0) goto lab4;
625             z->c += ret;
626         }
627         {
628             int ret = in_grouping_U(z, g_v, 97, 121, 1);
629             if (ret < 0) goto lab4;
630             z->c += ret;
631         }
632         z->I[0] = z->c;
633     lab4:
634         z->c = c5;
635     }
636     z->lb = z->c; z->c = z->l;
637 
638     {   int m6 = z->l - z->c; (void)m6;
639         {   int ret = r_Step_1a(z);
640             if (ret < 0) return ret;
641         }
642         z->c = z->l - m6;
643     }
644     {   int m7 = z->l - z->c; (void)m7;
645         {   int ret = r_Step_1b(z);
646             if (ret < 0) return ret;
647         }
648         z->c = z->l - m7;
649     }
650     {   int m8 = z->l - z->c; (void)m8;
651         {   int ret = r_Step_1c(z);
652             if (ret < 0) return ret;
653         }
654         z->c = z->l - m8;
655     }
656     {   int m9 = z->l - z->c; (void)m9;
657         {   int ret = r_Step_2(z);
658             if (ret < 0) return ret;
659         }
660         z->c = z->l - m9;
661     }
662     {   int m10 = z->l - z->c; (void)m10;
663         {   int ret = r_Step_3(z);
664             if (ret < 0) return ret;
665         }
666         z->c = z->l - m10;
667     }
668     {   int m11 = z->l - z->c; (void)m11;
669         {   int ret = r_Step_4(z);
670             if (ret < 0) return ret;
671         }
672         z->c = z->l - m11;
673     }
674     {   int m12 = z->l - z->c; (void)m12;
675         {   int ret = r_Step_5a(z);
676             if (ret < 0) return ret;
677         }
678         z->c = z->l - m12;
679     }
680     {   int m13 = z->l - z->c; (void)m13;
681         {   int ret = r_Step_5b(z);
682             if (ret < 0) return ret;
683         }
684         z->c = z->l - m13;
685     }
686     z->c = z->lb;
687     {   int c14 = z->c;
688         if (!(z->I[2])) goto lab5;
689         while(1) {
690             int c15 = z->c;
691             while(1) {
692                 int c16 = z->c;
693                 z->bra = z->c;
694                 if (z->c == z->l || z->p[z->c] != 'Y') goto lab7;
695                 z->c++;
696                 z->ket = z->c;
697                 z->c = c16;
698                 break;
699             lab7:
700                 z->c = c16;
701                 {   int ret = skip_utf8(z->p, z->c, z->l, 1);
702                     if (ret < 0) goto lab6;
703                     z->c = ret;
704                 }
705             }
706             {   int ret = slice_from_s(z, 1, s_23);
707                 if (ret < 0) return ret;
708             }
709             continue;
710         lab6:
711             z->c = c15;
712             break;
713         }
714     lab5:
715         z->c = c14;
716     }
717     return 1;
718 }
719 
porter_UTF_8_create_env(void)720 extern struct SN_env * porter_UTF_8_create_env(void) { return SN_create_env(0, 3); }
721 
porter_UTF_8_close_env(struct SN_env * z)722 extern void porter_UTF_8_close_env(struct SN_env * z) { SN_close_env(z, 0); }
723 
724