LCOV - code coverage report
Current view: top level - src/backend/snowball/libstemmer - stem_UTF_8_english.c (source / functions) Hit Total Coverage
Test: PostgreSQL 19devel Lines: 346 549 63.0 %
Date: 2026-02-02 14:17:46 Functions: 16 17 94.1 %
Legend: Lines: hit not hit

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

Generated by: LCOV version 1.16