LCOV - code coverage report
Current view: top level - src/backend/snowball/libstemmer - stem_ISO_8859_1_english.c (source / functions) Hit Total Coverage
Test: PostgreSQL 13devel Lines: 0 471 0.0 %
Date: 2019-11-13 21:06:57 Functions: 0 18 0.0 %
Legend: Lines: hit not hit

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

Generated by: LCOV version 1.13