LCOV - code coverage report
Current view: top level - src/backend/snowball/libstemmer - stem_UTF_8_french.c (source / functions) Hit Total Coverage
Test: PostgreSQL 14devel Lines: 0 632 0.0 %
Date: 2020-09-25 17:06:10 Functions: 0 15 0.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /* Generated by Snowball 2.0.0 - https://snowballstem.org/ */
       2             : 
       3             : #include "header.h"
       4             : 
       5             : #ifdef __cplusplus
       6             : extern "C" {
       7             : #endif
       8             : extern int french_UTF_8_stem(struct SN_env * z);
       9             : #ifdef __cplusplus
      10             : }
      11             : #endif
      12             : static int r_un_accent(struct SN_env * z);
      13             : static int r_un_double(struct SN_env * z);
      14             : static int r_residual_suffix(struct SN_env * z);
      15             : static int r_verb_suffix(struct SN_env * z);
      16             : static int r_i_verb_suffix(struct SN_env * z);
      17             : static int r_standard_suffix(struct SN_env * z);
      18             : static int r_R2(struct SN_env * z);
      19             : static int r_R1(struct SN_env * z);
      20             : static int r_RV(struct SN_env * z);
      21             : static int r_mark_regions(struct SN_env * z);
      22             : static int r_postlude(struct SN_env * z);
      23             : static int r_prelude(struct SN_env * z);
      24             : #ifdef __cplusplus
      25             : extern "C" {
      26             : #endif
      27             : 
      28             : 
      29             : extern struct SN_env * french_UTF_8_create_env(void);
      30             : extern void french_UTF_8_close_env(struct SN_env * z);
      31             : 
      32             : 
      33             : #ifdef __cplusplus
      34             : }
      35             : #endif
      36             : static const symbol s_0_0[3] = { 'c', 'o', 'l' };
      37             : static const symbol s_0_1[3] = { 'p', 'a', 'r' };
      38             : static const symbol s_0_2[3] = { 't', 'a', 'p' };
      39             : 
      40             : static const struct among a_0[3] =
      41             : {
      42             : /*  0 */ { 3, s_0_0, -1, -1, 0},
      43             : /*  1 */ { 3, s_0_1, -1, -1, 0},
      44             : /*  2 */ { 3, s_0_2, -1, -1, 0}
      45             : };
      46             : 
      47             : static const symbol s_1_1[1] = { 'H' };
      48             : static const symbol s_1_2[2] = { 'H', 'e' };
      49             : static const symbol s_1_3[2] = { 'H', 'i' };
      50             : static const symbol s_1_4[1] = { 'I' };
      51             : static const symbol s_1_5[1] = { 'U' };
      52             : static const symbol s_1_6[1] = { 'Y' };
      53             : 
      54             : static const struct among a_1[7] =
      55             : {
      56             : /*  0 */ { 0, 0, -1, 7, 0},
      57             : /*  1 */ { 1, s_1_1, 0, 6, 0},
      58             : /*  2 */ { 2, s_1_2, 1, 4, 0},
      59             : /*  3 */ { 2, s_1_3, 1, 5, 0},
      60             : /*  4 */ { 1, s_1_4, 0, 1, 0},
      61             : /*  5 */ { 1, s_1_5, 0, 2, 0},
      62             : /*  6 */ { 1, s_1_6, 0, 3, 0}
      63             : };
      64             : 
      65             : static const symbol s_2_0[3] = { 'i', 'q', 'U' };
      66             : static const symbol s_2_1[3] = { 'a', 'b', 'l' };
      67             : static const symbol s_2_2[4] = { 'I', 0xC3, 0xA8, 'r' };
      68             : static const symbol s_2_3[4] = { 'i', 0xC3, 0xA8, 'r' };
      69             : static const symbol s_2_4[3] = { 'e', 'u', 's' };
      70             : static const symbol s_2_5[2] = { 'i', 'v' };
      71             : 
      72             : static const struct among a_2[6] =
      73             : {
      74             : /*  0 */ { 3, s_2_0, -1, 3, 0},
      75             : /*  1 */ { 3, s_2_1, -1, 3, 0},
      76             : /*  2 */ { 4, s_2_2, -1, 4, 0},
      77             : /*  3 */ { 4, s_2_3, -1, 4, 0},
      78             : /*  4 */ { 3, s_2_4, -1, 2, 0},
      79             : /*  5 */ { 2, s_2_5, -1, 1, 0}
      80             : };
      81             : 
      82             : static const symbol s_3_0[2] = { 'i', 'c' };
      83             : static const symbol s_3_1[4] = { 'a', 'b', 'i', 'l' };
      84             : static const symbol s_3_2[2] = { 'i', 'v' };
      85             : 
      86             : static const struct among a_3[3] =
      87             : {
      88             : /*  0 */ { 2, s_3_0, -1, 2, 0},
      89             : /*  1 */ { 4, s_3_1, -1, 1, 0},
      90             : /*  2 */ { 2, s_3_2, -1, 3, 0}
      91             : };
      92             : 
      93             : static const symbol s_4_0[4] = { 'i', 'q', 'U', 'e' };
      94             : static const symbol s_4_1[6] = { 'a', 't', 'r', 'i', 'c', 'e' };
      95             : static const symbol s_4_2[4] = { 'a', 'n', 'c', 'e' };
      96             : static const symbol s_4_3[4] = { 'e', 'n', 'c', 'e' };
      97             : static const symbol s_4_4[5] = { 'l', 'o', 'g', 'i', 'e' };
      98             : static const symbol s_4_5[4] = { 'a', 'b', 'l', 'e' };
      99             : static const symbol s_4_6[4] = { 'i', 's', 'm', 'e' };
     100             : static const symbol s_4_7[4] = { 'e', 'u', 's', 'e' };
     101             : static const symbol s_4_8[4] = { 'i', 's', 't', 'e' };
     102             : static const symbol s_4_9[3] = { 'i', 'v', 'e' };
     103             : static const symbol s_4_10[2] = { 'i', 'f' };
     104             : static const symbol s_4_11[5] = { 'u', 's', 'i', 'o', 'n' };
     105             : static const symbol s_4_12[5] = { 'a', 't', 'i', 'o', 'n' };
     106             : static const symbol s_4_13[5] = { 'u', 't', 'i', 'o', 'n' };
     107             : static const symbol s_4_14[5] = { 'a', 't', 'e', 'u', 'r' };
     108             : static const symbol s_4_15[5] = { 'i', 'q', 'U', 'e', 's' };
     109             : static const symbol s_4_16[7] = { 'a', 't', 'r', 'i', 'c', 'e', 's' };
     110             : static const symbol s_4_17[5] = { 'a', 'n', 'c', 'e', 's' };
     111             : static const symbol s_4_18[5] = { 'e', 'n', 'c', 'e', 's' };
     112             : static const symbol s_4_19[6] = { 'l', 'o', 'g', 'i', 'e', 's' };
     113             : static const symbol s_4_20[5] = { 'a', 'b', 'l', 'e', 's' };
     114             : static const symbol s_4_21[5] = { 'i', 's', 'm', 'e', 's' };
     115             : static const symbol s_4_22[5] = { 'e', 'u', 's', 'e', 's' };
     116             : static const symbol s_4_23[5] = { 'i', 's', 't', 'e', 's' };
     117             : static const symbol s_4_24[4] = { 'i', 'v', 'e', 's' };
     118             : static const symbol s_4_25[3] = { 'i', 'f', 's' };
     119             : static const symbol s_4_26[6] = { 'u', 's', 'i', 'o', 'n', 's' };
     120             : static const symbol s_4_27[6] = { 'a', 't', 'i', 'o', 'n', 's' };
     121             : static const symbol s_4_28[6] = { 'u', 't', 'i', 'o', 'n', 's' };
     122             : static const symbol s_4_29[6] = { 'a', 't', 'e', 'u', 'r', 's' };
     123             : static const symbol s_4_30[5] = { 'm', 'e', 'n', 't', 's' };
     124             : static const symbol s_4_31[6] = { 'e', 'm', 'e', 'n', 't', 's' };
     125             : static const symbol s_4_32[9] = { 'i', 's', 's', 'e', 'm', 'e', 'n', 't', 's' };
     126             : static const symbol s_4_33[5] = { 'i', 't', 0xC3, 0xA9, 's' };
     127             : static const symbol s_4_34[4] = { 'm', 'e', 'n', 't' };
     128             : static const symbol s_4_35[5] = { 'e', 'm', 'e', 'n', 't' };
     129             : static const symbol s_4_36[8] = { 'i', 's', 's', 'e', 'm', 'e', 'n', 't' };
     130             : static const symbol s_4_37[6] = { 'a', 'm', 'm', 'e', 'n', 't' };
     131             : static const symbol s_4_38[6] = { 'e', 'm', 'm', 'e', 'n', 't' };
     132             : static const symbol s_4_39[3] = { 'a', 'u', 'x' };
     133             : static const symbol s_4_40[4] = { 'e', 'a', 'u', 'x' };
     134             : static const symbol s_4_41[3] = { 'e', 'u', 'x' };
     135             : static const symbol s_4_42[4] = { 'i', 't', 0xC3, 0xA9 };
     136             : 
     137             : static const struct among a_4[43] =
     138             : {
     139             : /*  0 */ { 4, s_4_0, -1, 1, 0},
     140             : /*  1 */ { 6, s_4_1, -1, 2, 0},
     141             : /*  2 */ { 4, s_4_2, -1, 1, 0},
     142             : /*  3 */ { 4, s_4_3, -1, 5, 0},
     143             : /*  4 */ { 5, s_4_4, -1, 3, 0},
     144             : /*  5 */ { 4, s_4_5, -1, 1, 0},
     145             : /*  6 */ { 4, s_4_6, -1, 1, 0},
     146             : /*  7 */ { 4, s_4_7, -1, 11, 0},
     147             : /*  8 */ { 4, s_4_8, -1, 1, 0},
     148             : /*  9 */ { 3, s_4_9, -1, 8, 0},
     149             : /* 10 */ { 2, s_4_10, -1, 8, 0},
     150             : /* 11 */ { 5, s_4_11, -1, 4, 0},
     151             : /* 12 */ { 5, s_4_12, -1, 2, 0},
     152             : /* 13 */ { 5, s_4_13, -1, 4, 0},
     153             : /* 14 */ { 5, s_4_14, -1, 2, 0},
     154             : /* 15 */ { 5, s_4_15, -1, 1, 0},
     155             : /* 16 */ { 7, s_4_16, -1, 2, 0},
     156             : /* 17 */ { 5, s_4_17, -1, 1, 0},
     157             : /* 18 */ { 5, s_4_18, -1, 5, 0},
     158             : /* 19 */ { 6, s_4_19, -1, 3, 0},
     159             : /* 20 */ { 5, s_4_20, -1, 1, 0},
     160             : /* 21 */ { 5, s_4_21, -1, 1, 0},
     161             : /* 22 */ { 5, s_4_22, -1, 11, 0},
     162             : /* 23 */ { 5, s_4_23, -1, 1, 0},
     163             : /* 24 */ { 4, s_4_24, -1, 8, 0},
     164             : /* 25 */ { 3, s_4_25, -1, 8, 0},
     165             : /* 26 */ { 6, s_4_26, -1, 4, 0},
     166             : /* 27 */ { 6, s_4_27, -1, 2, 0},
     167             : /* 28 */ { 6, s_4_28, -1, 4, 0},
     168             : /* 29 */ { 6, s_4_29, -1, 2, 0},
     169             : /* 30 */ { 5, s_4_30, -1, 15, 0},
     170             : /* 31 */ { 6, s_4_31, 30, 6, 0},
     171             : /* 32 */ { 9, s_4_32, 31, 12, 0},
     172             : /* 33 */ { 5, s_4_33, -1, 7, 0},
     173             : /* 34 */ { 4, s_4_34, -1, 15, 0},
     174             : /* 35 */ { 5, s_4_35, 34, 6, 0},
     175             : /* 36 */ { 8, s_4_36, 35, 12, 0},
     176             : /* 37 */ { 6, s_4_37, 34, 13, 0},
     177             : /* 38 */ { 6, s_4_38, 34, 14, 0},
     178             : /* 39 */ { 3, s_4_39, -1, 10, 0},
     179             : /* 40 */ { 4, s_4_40, 39, 9, 0},
     180             : /* 41 */ { 3, s_4_41, -1, 1, 0},
     181             : /* 42 */ { 4, s_4_42, -1, 7, 0}
     182             : };
     183             : 
     184             : static const symbol s_5_0[3] = { 'i', 'r', 'a' };
     185             : static const symbol s_5_1[2] = { 'i', 'e' };
     186             : static const symbol s_5_2[4] = { 'i', 's', 's', 'e' };
     187             : static const symbol s_5_3[7] = { 'i', 's', 's', 'a', 'n', 't', 'e' };
     188             : static const symbol s_5_4[1] = { 'i' };
     189             : static const symbol s_5_5[4] = { 'i', 'r', 'a', 'i' };
     190             : static const symbol s_5_6[2] = { 'i', 'r' };
     191             : static const symbol s_5_7[4] = { 'i', 'r', 'a', 's' };
     192             : static const symbol s_5_8[3] = { 'i', 'e', 's' };
     193             : static const symbol s_5_9[5] = { 0xC3, 0xAE, 'm', 'e', 's' };
     194             : static const symbol s_5_10[5] = { 'i', 's', 's', 'e', 's' };
     195             : static const symbol s_5_11[8] = { 'i', 's', 's', 'a', 'n', 't', 'e', 's' };
     196             : static const symbol s_5_12[5] = { 0xC3, 0xAE, 't', 'e', 's' };
     197             : static const symbol s_5_13[2] = { 'i', 's' };
     198             : static const symbol s_5_14[5] = { 'i', 'r', 'a', 'i', 's' };
     199             : static const symbol s_5_15[6] = { 'i', 's', 's', 'a', 'i', 's' };
     200             : static const symbol s_5_16[6] = { 'i', 'r', 'i', 'o', 'n', 's' };
     201             : static const symbol s_5_17[7] = { 'i', 's', 's', 'i', 'o', 'n', 's' };
     202             : static const symbol s_5_18[5] = { 'i', 'r', 'o', 'n', 's' };
     203             : static const symbol s_5_19[6] = { 'i', 's', 's', 'o', 'n', 's' };
     204             : static const symbol s_5_20[7] = { 'i', 's', 's', 'a', 'n', 't', 's' };
     205             : static const symbol s_5_21[2] = { 'i', 't' };
     206             : static const symbol s_5_22[5] = { 'i', 'r', 'a', 'i', 't' };
     207             : static const symbol s_5_23[6] = { 'i', 's', 's', 'a', 'i', 't' };
     208             : static const symbol s_5_24[6] = { 'i', 's', 's', 'a', 'n', 't' };
     209             : static const symbol s_5_25[7] = { 'i', 'r', 'a', 'I', 'e', 'n', 't' };
     210             : static const symbol s_5_26[8] = { 'i', 's', 's', 'a', 'I', 'e', 'n', 't' };
     211             : static const symbol s_5_27[5] = { 'i', 'r', 'e', 'n', 't' };
     212             : static const symbol s_5_28[6] = { 'i', 's', 's', 'e', 'n', 't' };
     213             : static const symbol s_5_29[5] = { 'i', 'r', 'o', 'n', 't' };
     214             : static const symbol s_5_30[3] = { 0xC3, 0xAE, 't' };
     215             : static const symbol s_5_31[5] = { 'i', 'r', 'i', 'e', 'z' };
     216             : static const symbol s_5_32[6] = { 'i', 's', 's', 'i', 'e', 'z' };
     217             : static const symbol s_5_33[4] = { 'i', 'r', 'e', 'z' };
     218             : static const symbol s_5_34[5] = { 'i', 's', 's', 'e', 'z' };
     219             : 
     220             : static const struct among a_5[35] =
     221             : {
     222             : /*  0 */ { 3, s_5_0, -1, 1, 0},
     223             : /*  1 */ { 2, s_5_1, -1, 1, 0},
     224             : /*  2 */ { 4, s_5_2, -1, 1, 0},
     225             : /*  3 */ { 7, s_5_3, -1, 1, 0},
     226             : /*  4 */ { 1, s_5_4, -1, 1, 0},
     227             : /*  5 */ { 4, s_5_5, 4, 1, 0},
     228             : /*  6 */ { 2, s_5_6, -1, 1, 0},
     229             : /*  7 */ { 4, s_5_7, -1, 1, 0},
     230             : /*  8 */ { 3, s_5_8, -1, 1, 0},
     231             : /*  9 */ { 5, s_5_9, -1, 1, 0},
     232             : /* 10 */ { 5, s_5_10, -1, 1, 0},
     233             : /* 11 */ { 8, s_5_11, -1, 1, 0},
     234             : /* 12 */ { 5, s_5_12, -1, 1, 0},
     235             : /* 13 */ { 2, s_5_13, -1, 1, 0},
     236             : /* 14 */ { 5, s_5_14, 13, 1, 0},
     237             : /* 15 */ { 6, s_5_15, 13, 1, 0},
     238             : /* 16 */ { 6, s_5_16, -1, 1, 0},
     239             : /* 17 */ { 7, s_5_17, -1, 1, 0},
     240             : /* 18 */ { 5, s_5_18, -1, 1, 0},
     241             : /* 19 */ { 6, s_5_19, -1, 1, 0},
     242             : /* 20 */ { 7, s_5_20, -1, 1, 0},
     243             : /* 21 */ { 2, s_5_21, -1, 1, 0},
     244             : /* 22 */ { 5, s_5_22, 21, 1, 0},
     245             : /* 23 */ { 6, s_5_23, 21, 1, 0},
     246             : /* 24 */ { 6, s_5_24, -1, 1, 0},
     247             : /* 25 */ { 7, s_5_25, -1, 1, 0},
     248             : /* 26 */ { 8, s_5_26, -1, 1, 0},
     249             : /* 27 */ { 5, s_5_27, -1, 1, 0},
     250             : /* 28 */ { 6, s_5_28, -1, 1, 0},
     251             : /* 29 */ { 5, s_5_29, -1, 1, 0},
     252             : /* 30 */ { 3, s_5_30, -1, 1, 0},
     253             : /* 31 */ { 5, s_5_31, -1, 1, 0},
     254             : /* 32 */ { 6, s_5_32, -1, 1, 0},
     255             : /* 33 */ { 4, s_5_33, -1, 1, 0},
     256             : /* 34 */ { 5, s_5_34, -1, 1, 0}
     257             : };
     258             : 
     259             : static const symbol s_6_0[1] = { 'a' };
     260             : static const symbol s_6_1[3] = { 'e', 'r', 'a' };
     261             : static const symbol s_6_2[4] = { 'a', 's', 's', 'e' };
     262             : static const symbol s_6_3[4] = { 'a', 'n', 't', 'e' };
     263             : static const symbol s_6_4[3] = { 0xC3, 0xA9, 'e' };
     264             : static const symbol s_6_5[2] = { 'a', 'i' };
     265             : static const symbol s_6_6[4] = { 'e', 'r', 'a', 'i' };
     266             : static const symbol s_6_7[2] = { 'e', 'r' };
     267             : static const symbol s_6_8[2] = { 'a', 's' };
     268             : static const symbol s_6_9[4] = { 'e', 'r', 'a', 's' };
     269             : static const symbol s_6_10[5] = { 0xC3, 0xA2, 'm', 'e', 's' };
     270             : static const symbol s_6_11[5] = { 'a', 's', 's', 'e', 's' };
     271             : static const symbol s_6_12[5] = { 'a', 'n', 't', 'e', 's' };
     272             : static const symbol s_6_13[5] = { 0xC3, 0xA2, 't', 'e', 's' };
     273             : static const symbol s_6_14[4] = { 0xC3, 0xA9, 'e', 's' };
     274             : static const symbol s_6_15[3] = { 'a', 'i', 's' };
     275             : static const symbol s_6_16[5] = { 'e', 'r', 'a', 'i', 's' };
     276             : static const symbol s_6_17[4] = { 'i', 'o', 'n', 's' };
     277             : static const symbol s_6_18[6] = { 'e', 'r', 'i', 'o', 'n', 's' };
     278             : static const symbol s_6_19[7] = { 'a', 's', 's', 'i', 'o', 'n', 's' };
     279             : static const symbol s_6_20[5] = { 'e', 'r', 'o', 'n', 's' };
     280             : static const symbol s_6_21[4] = { 'a', 'n', 't', 's' };
     281             : static const symbol s_6_22[3] = { 0xC3, 0xA9, 's' };
     282             : static const symbol s_6_23[3] = { 'a', 'i', 't' };
     283             : static const symbol s_6_24[5] = { 'e', 'r', 'a', 'i', 't' };
     284             : static const symbol s_6_25[3] = { 'a', 'n', 't' };
     285             : static const symbol s_6_26[5] = { 'a', 'I', 'e', 'n', 't' };
     286             : static const symbol s_6_27[7] = { 'e', 'r', 'a', 'I', 'e', 'n', 't' };
     287             : static const symbol s_6_28[6] = { 0xC3, 0xA8, 'r', 'e', 'n', 't' };
     288             : static const symbol s_6_29[6] = { 'a', 's', 's', 'e', 'n', 't' };
     289             : static const symbol s_6_30[5] = { 'e', 'r', 'o', 'n', 't' };
     290             : static const symbol s_6_31[3] = { 0xC3, 0xA2, 't' };
     291             : static const symbol s_6_32[2] = { 'e', 'z' };
     292             : static const symbol s_6_33[3] = { 'i', 'e', 'z' };
     293             : static const symbol s_6_34[5] = { 'e', 'r', 'i', 'e', 'z' };
     294             : static const symbol s_6_35[6] = { 'a', 's', 's', 'i', 'e', 'z' };
     295             : static const symbol s_6_36[4] = { 'e', 'r', 'e', 'z' };
     296             : static const symbol s_6_37[2] = { 0xC3, 0xA9 };
     297             : 
     298             : static const struct among a_6[38] =
     299             : {
     300             : /*  0 */ { 1, s_6_0, -1, 3, 0},
     301             : /*  1 */ { 3, s_6_1, 0, 2, 0},
     302             : /*  2 */ { 4, s_6_2, -1, 3, 0},
     303             : /*  3 */ { 4, s_6_3, -1, 3, 0},
     304             : /*  4 */ { 3, s_6_4, -1, 2, 0},
     305             : /*  5 */ { 2, s_6_5, -1, 3, 0},
     306             : /*  6 */ { 4, s_6_6, 5, 2, 0},
     307             : /*  7 */ { 2, s_6_7, -1, 2, 0},
     308             : /*  8 */ { 2, s_6_8, -1, 3, 0},
     309             : /*  9 */ { 4, s_6_9, 8, 2, 0},
     310             : /* 10 */ { 5, s_6_10, -1, 3, 0},
     311             : /* 11 */ { 5, s_6_11, -1, 3, 0},
     312             : /* 12 */ { 5, s_6_12, -1, 3, 0},
     313             : /* 13 */ { 5, s_6_13, -1, 3, 0},
     314             : /* 14 */ { 4, s_6_14, -1, 2, 0},
     315             : /* 15 */ { 3, s_6_15, -1, 3, 0},
     316             : /* 16 */ { 5, s_6_16, 15, 2, 0},
     317             : /* 17 */ { 4, s_6_17, -1, 1, 0},
     318             : /* 18 */ { 6, s_6_18, 17, 2, 0},
     319             : /* 19 */ { 7, s_6_19, 17, 3, 0},
     320             : /* 20 */ { 5, s_6_20, -1, 2, 0},
     321             : /* 21 */ { 4, s_6_21, -1, 3, 0},
     322             : /* 22 */ { 3, s_6_22, -1, 2, 0},
     323             : /* 23 */ { 3, s_6_23, -1, 3, 0},
     324             : /* 24 */ { 5, s_6_24, 23, 2, 0},
     325             : /* 25 */ { 3, s_6_25, -1, 3, 0},
     326             : /* 26 */ { 5, s_6_26, -1, 3, 0},
     327             : /* 27 */ { 7, s_6_27, 26, 2, 0},
     328             : /* 28 */ { 6, s_6_28, -1, 2, 0},
     329             : /* 29 */ { 6, s_6_29, -1, 3, 0},
     330             : /* 30 */ { 5, s_6_30, -1, 2, 0},
     331             : /* 31 */ { 3, s_6_31, -1, 3, 0},
     332             : /* 32 */ { 2, s_6_32, -1, 2, 0},
     333             : /* 33 */ { 3, s_6_33, 32, 2, 0},
     334             : /* 34 */ { 5, s_6_34, 33, 2, 0},
     335             : /* 35 */ { 6, s_6_35, 33, 3, 0},
     336             : /* 36 */ { 4, s_6_36, 32, 2, 0},
     337             : /* 37 */ { 2, s_6_37, -1, 2, 0}
     338             : };
     339             : 
     340             : static const symbol s_7_0[1] = { 'e' };
     341             : static const symbol s_7_1[5] = { 'I', 0xC3, 0xA8, 'r', 'e' };
     342             : static const symbol s_7_2[5] = { 'i', 0xC3, 0xA8, 'r', 'e' };
     343             : static const symbol s_7_3[3] = { 'i', 'o', 'n' };
     344             : static const symbol s_7_4[3] = { 'I', 'e', 'r' };
     345             : static const symbol s_7_5[3] = { 'i', 'e', 'r' };
     346             : 
     347             : static const struct among a_7[6] =
     348             : {
     349             : /*  0 */ { 1, s_7_0, -1, 3, 0},
     350             : /*  1 */ { 5, s_7_1, 0, 2, 0},
     351             : /*  2 */ { 5, s_7_2, 0, 2, 0},
     352             : /*  3 */ { 3, s_7_3, -1, 1, 0},
     353             : /*  4 */ { 3, s_7_4, -1, 2, 0},
     354             : /*  5 */ { 3, s_7_5, -1, 2, 0}
     355             : };
     356             : 
     357             : static const symbol s_8_0[3] = { 'e', 'l', 'l' };
     358             : static const symbol s_8_1[4] = { 'e', 'i', 'l', 'l' };
     359             : static const symbol s_8_2[3] = { 'e', 'n', 'n' };
     360             : static const symbol s_8_3[3] = { 'o', 'n', 'n' };
     361             : static const symbol s_8_4[3] = { 'e', 't', 't' };
     362             : 
     363             : static const struct among a_8[5] =
     364             : {
     365             : /*  0 */ { 3, s_8_0, -1, -1, 0},
     366             : /*  1 */ { 4, s_8_1, -1, -1, 0},
     367             : /*  2 */ { 3, s_8_2, -1, -1, 0},
     368             : /*  3 */ { 3, s_8_3, -1, -1, 0},
     369             : /*  4 */ { 3, s_8_4, -1, -1, 0}
     370             : };
     371             : 
     372             : static const unsigned char g_v[] = { 17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 128, 130, 103, 8, 5 };
     373             : 
     374             : static const unsigned char g_keep_with_s[] = { 1, 65, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 128 };
     375             : 
     376             : static const symbol s_0[] = { 'U' };
     377             : static const symbol s_1[] = { 'I' };
     378             : static const symbol s_2[] = { 'Y' };
     379             : static const symbol s_3[] = { 0xC3, 0xAB };
     380             : static const symbol s_4[] = { 'H', 'e' };
     381             : static const symbol s_5[] = { 0xC3, 0xAF };
     382             : static const symbol s_6[] = { 'H', 'i' };
     383             : static const symbol s_7[] = { 'Y' };
     384             : static const symbol s_8[] = { 'U' };
     385             : static const symbol s_9[] = { 'i' };
     386             : static const symbol s_10[] = { 'u' };
     387             : static const symbol s_11[] = { 'y' };
     388             : static const symbol s_12[] = { 0xC3, 0xAB };
     389             : static const symbol s_13[] = { 0xC3, 0xAF };
     390             : static const symbol s_14[] = { 'i', 'c' };
     391             : static const symbol s_15[] = { 'i', 'q', 'U' };
     392             : static const symbol s_16[] = { 'l', 'o', 'g' };
     393             : static const symbol s_17[] = { 'u' };
     394             : static const symbol s_18[] = { 'e', 'n', 't' };
     395             : static const symbol s_19[] = { 'a', 't' };
     396             : static const symbol s_20[] = { 'e', 'u', 'x' };
     397             : static const symbol s_21[] = { 'i' };
     398             : static const symbol s_22[] = { 'a', 'b', 'l' };
     399             : static const symbol s_23[] = { 'i', 'q', 'U' };
     400             : static const symbol s_24[] = { 'a', 't' };
     401             : static const symbol s_25[] = { 'i', 'c' };
     402             : static const symbol s_26[] = { 'i', 'q', 'U' };
     403             : static const symbol s_27[] = { 'e', 'a', 'u' };
     404             : static const symbol s_28[] = { 'a', 'l' };
     405             : static const symbol s_29[] = { 'e', 'u', 'x' };
     406             : static const symbol s_30[] = { 'a', 'n', 't' };
     407             : static const symbol s_31[] = { 'e', 'n', 't' };
     408             : static const symbol s_32[] = { 'H', 'i' };
     409             : static const symbol s_33[] = { 'i' };
     410             : static const symbol s_34[] = { 0xC3, 0xA9 };
     411             : static const symbol s_35[] = { 0xC3, 0xA8 };
     412             : static const symbol s_36[] = { 'e' };
     413             : static const symbol s_37[] = { 'i' };
     414             : static const symbol s_38[] = { 0xC3, 0xA7 };
     415             : static const symbol s_39[] = { 'c' };
     416             : 
     417           0 : static int r_prelude(struct SN_env * z) { /* forwardmode */
     418             : /* repeat, line 38 */
     419             : 
     420           0 :     while(1) {        int c1 = z->c;
     421           0 :         while(1) { /* goto, line 38 */
     422           0 :             int c2 = z->c;
     423           0 :             {   int c3 = z->c; /* or, line 44 */
     424           0 :                 if (in_grouping_U(z, g_v, 97, 251, 0)) goto lab3; /* grouping v, line 40 */
     425           0 :                 z->bra = z->c; /* [, line 40 */
     426           0 :                 {   int c4 = z->c; /* or, line 40 */
     427           0 :                     if (z->c == z->l || z->p[z->c] != 'u') goto lab5; /* literal, line 40 */
     428           0 :                     z->c++;
     429           0 :                     z->ket = z->c; /* ], line 40 */
     430           0 :                     if (in_grouping_U(z, g_v, 97, 251, 0)) goto lab5; /* grouping v, line 40 */
     431           0 :                     {   int ret = slice_from_s(z, 1, s_0); /* <-, line 40 */
     432           0 :                         if (ret < 0) return ret;
     433             :                     }
     434           0 :                     goto lab4;
     435           0 :                 lab5:
     436           0 :                     z->c = c4;
     437           0 :                     if (z->c == z->l || z->p[z->c] != 'i') goto lab6; /* literal, line 41 */
     438           0 :                     z->c++;
     439           0 :                     z->ket = z->c; /* ], line 41 */
     440           0 :                     if (in_grouping_U(z, g_v, 97, 251, 0)) goto lab6; /* grouping v, line 41 */
     441           0 :                     {   int ret = slice_from_s(z, 1, s_1); /* <-, line 41 */
     442           0 :                         if (ret < 0) return ret;
     443             :                     }
     444           0 :                     goto lab4;
     445           0 :                 lab6:
     446           0 :                     z->c = c4;
     447           0 :                     if (z->c == z->l || z->p[z->c] != 'y') goto lab3; /* literal, line 42 */
     448           0 :                     z->c++;
     449           0 :                     z->ket = z->c; /* ], line 42 */
     450           0 :                     {   int ret = slice_from_s(z, 1, s_2); /* <-, line 42 */
     451           0 :                         if (ret < 0) return ret;
     452             :                     }
     453             :                 }
     454           0 :             lab4:
     455           0 :                 goto lab2;
     456           0 :             lab3:
     457           0 :                 z->c = c3;
     458           0 :                 z->bra = z->c; /* [, line 45 */
     459           0 :                 if (!(eq_s(z, 2, s_3))) goto lab7; /* literal, line 45 */
     460           0 :                 z->ket = z->c; /* ], line 45 */
     461           0 :                 {   int ret = slice_from_s(z, 2, s_4); /* <-, line 45 */
     462           0 :                     if (ret < 0) return ret;
     463             :                 }
     464           0 :                 goto lab2;
     465           0 :             lab7:
     466           0 :                 z->c = c3;
     467           0 :                 z->bra = z->c; /* [, line 47 */
     468           0 :                 if (!(eq_s(z, 2, s_5))) goto lab8; /* literal, line 47 */
     469           0 :                 z->ket = z->c; /* ], line 47 */
     470           0 :                 {   int ret = slice_from_s(z, 2, s_6); /* <-, line 47 */
     471           0 :                     if (ret < 0) return ret;
     472             :                 }
     473           0 :                 goto lab2;
     474           0 :             lab8:
     475           0 :                 z->c = c3;
     476           0 :                 z->bra = z->c; /* [, line 49 */
     477           0 :                 if (z->c == z->l || z->p[z->c] != 'y') goto lab9; /* literal, line 49 */
     478           0 :                 z->c++;
     479           0 :                 z->ket = z->c; /* ], line 49 */
     480           0 :                 if (in_grouping_U(z, g_v, 97, 251, 0)) goto lab9; /* grouping v, line 49 */
     481           0 :                 {   int ret = slice_from_s(z, 1, s_7); /* <-, line 49 */
     482           0 :                     if (ret < 0) return ret;
     483             :                 }
     484           0 :                 goto lab2;
     485           0 :             lab9:
     486           0 :                 z->c = c3;
     487           0 :                 if (z->c == z->l || z->p[z->c] != 'q') goto lab1; /* literal, line 51 */
     488           0 :                 z->c++;
     489           0 :                 z->bra = z->c; /* [, line 51 */
     490           0 :                 if (z->c == z->l || z->p[z->c] != 'u') goto lab1; /* literal, line 51 */
     491           0 :                 z->c++;
     492           0 :                 z->ket = z->c; /* ], line 51 */
     493           0 :                 {   int ret = slice_from_s(z, 1, s_8); /* <-, line 51 */
     494           0 :                     if (ret < 0) return ret;
     495             :                 }
     496             :             }
     497           0 :         lab2:
     498           0 :             z->c = c2;
     499           0 :             break;
     500           0 :         lab1:
     501           0 :             z->c = c2;
     502           0 :             {   int ret = skip_utf8(z->p, z->c, 0, z->l, 1);
     503           0 :                 if (ret < 0) goto lab0;
     504           0 :                 z->c = ret; /* goto, line 38 */
     505             :             }
     506             :         }
     507           0 :         continue;
     508           0 :     lab0:
     509           0 :         z->c = c1;
     510           0 :         break;
     511             :     }
     512           0 :     return 1;
     513             : }
     514             : 
     515           0 : static int r_mark_regions(struct SN_env * z) { /* forwardmode */
     516           0 :     z->I[0] = z->l; /* $pV = <integer expression>, line 56 */
     517           0 :     z->I[1] = z->l; /* $p1 = <integer expression>, line 57 */
     518           0 :     z->I[2] = z->l; /* $p2 = <integer expression>, line 58 */
     519           0 :     {   int c1 = z->c; /* do, line 60 */
     520           0 :         {   int c2 = z->c; /* or, line 62 */
     521           0 :             if (in_grouping_U(z, g_v, 97, 251, 0)) goto lab2; /* grouping v, line 61 */
     522           0 :             if (in_grouping_U(z, g_v, 97, 251, 0)) goto lab2; /* grouping v, line 61 */
     523           0 :             {   int ret = skip_utf8(z->p, z->c, 0, z->l, 1);
     524           0 :                 if (ret < 0) goto lab2;
     525           0 :                 z->c = ret; /* next, line 61 */
     526             :             }
     527           0 :             goto lab1;
     528           0 :         lab2:
     529           0 :             z->c = c2;
     530           0 :             if (z->c + 2 >= z->l || z->p[z->c + 2] >> 5 != 3 || !((331776 >> (z->p[z->c + 2] & 0x1f)) & 1)) goto lab3; /* among, line 63 */
     531           0 :             if (!(find_among(z, a_0, 3))) goto lab3;
     532           0 :             goto lab1;
     533           0 :         lab3:
     534           0 :             z->c = c2;
     535           0 :             {   int ret = skip_utf8(z->p, z->c, 0, z->l, 1);
     536           0 :                 if (ret < 0) goto lab0;
     537           0 :                 z->c = ret; /* next, line 70 */
     538             :             }
     539             :             {    /* gopast */ /* grouping v, line 70 */
     540           0 :                 int ret = out_grouping_U(z, g_v, 97, 251, 1);
     541           0 :                 if (ret < 0) goto lab0;
     542           0 :                 z->c += ret;
     543             :             }
     544             :         }
     545           0 :     lab1:
     546           0 :         z->I[0] = z->c; /* setmark pV, line 71 */
     547           0 :     lab0:
     548           0 :         z->c = c1;
     549             :     }
     550           0 :     {   int c3 = z->c; /* do, line 73 */
     551             :         {    /* gopast */ /* grouping v, line 74 */
     552           0 :             int ret = out_grouping_U(z, g_v, 97, 251, 1);
     553           0 :             if (ret < 0) goto lab4;
     554           0 :             z->c += ret;
     555             :         }
     556             :         {    /* gopast */ /* non v, line 74 */
     557           0 :             int ret = in_grouping_U(z, g_v, 97, 251, 1);
     558           0 :             if (ret < 0) goto lab4;
     559           0 :             z->c += ret;
     560             :         }
     561           0 :         z->I[1] = z->c; /* setmark p1, line 74 */
     562             :         {    /* gopast */ /* grouping v, line 75 */
     563           0 :             int ret = out_grouping_U(z, g_v, 97, 251, 1);
     564           0 :             if (ret < 0) goto lab4;
     565           0 :             z->c += ret;
     566             :         }
     567             :         {    /* gopast */ /* non v, line 75 */
     568           0 :             int ret = in_grouping_U(z, g_v, 97, 251, 1);
     569           0 :             if (ret < 0) goto lab4;
     570           0 :             z->c += ret;
     571             :         }
     572           0 :         z->I[2] = z->c; /* setmark p2, line 75 */
     573           0 :     lab4:
     574           0 :         z->c = c3;
     575             :     }
     576           0 :     return 1;
     577             : }
     578             : 
     579           0 : static int r_postlude(struct SN_env * z) { /* forwardmode */
     580             :     int among_var;
     581             : /* repeat, line 79 */
     582             : 
     583           0 :     while(1) {        int c1 = z->c;
     584           0 :         z->bra = z->c; /* [, line 81 */
     585           0 :         if (z->c >= z->l || z->p[z->c + 0] >> 5 != 2 || !((35652352 >> (z->p[z->c + 0] & 0x1f)) & 1)) among_var = 7; else /* substring, line 81 */
     586           0 :         among_var = find_among(z, a_1, 7);
     587           0 :         if (!(among_var)) goto lab0;
     588           0 :         z->ket = z->c; /* ], line 81 */
     589           0 :         switch (among_var) { /* among, line 81 */
     590           0 :             case 1:
     591           0 :                 {   int ret = slice_from_s(z, 1, s_9); /* <-, line 82 */
     592           0 :                     if (ret < 0) return ret;
     593             :                 }
     594           0 :                 break;
     595           0 :             case 2:
     596           0 :                 {   int ret = slice_from_s(z, 1, s_10); /* <-, line 83 */
     597           0 :                     if (ret < 0) return ret;
     598             :                 }
     599           0 :                 break;
     600           0 :             case 3:
     601           0 :                 {   int ret = slice_from_s(z, 1, s_11); /* <-, line 84 */
     602           0 :                     if (ret < 0) return ret;
     603             :                 }
     604           0 :                 break;
     605           0 :             case 4:
     606           0 :                 {   int ret = slice_from_s(z, 2, s_12); /* <-, line 85 */
     607           0 :                     if (ret < 0) return ret;
     608             :                 }
     609           0 :                 break;
     610           0 :             case 5:
     611           0 :                 {   int ret = slice_from_s(z, 2, s_13); /* <-, line 86 */
     612           0 :                     if (ret < 0) return ret;
     613             :                 }
     614           0 :                 break;
     615           0 :             case 6:
     616           0 :                 {   int ret = slice_del(z); /* delete, line 87 */
     617           0 :                     if (ret < 0) return ret;
     618             :                 }
     619           0 :                 break;
     620           0 :             case 7:
     621           0 :                 {   int ret = skip_utf8(z->p, z->c, 0, z->l, 1);
     622           0 :                     if (ret < 0) goto lab0;
     623           0 :                     z->c = ret; /* next, line 88 */
     624             :                 }
     625           0 :                 break;
     626             :         }
     627           0 :         continue;
     628           0 :     lab0:
     629           0 :         z->c = c1;
     630           0 :         break;
     631             :     }
     632           0 :     return 1;
     633             : }
     634             : 
     635           0 : static int r_RV(struct SN_env * z) { /* backwardmode */
     636           0 :     if (!(z->I[0] <= z->c)) return 0; /* $(<integer expression> <= <integer expression>), line 94 */
     637           0 :     return 1;
     638             : }
     639             : 
     640           0 : static int r_R1(struct SN_env * z) { /* backwardmode */
     641           0 :     if (!(z->I[1] <= z->c)) return 0; /* $(<integer expression> <= <integer expression>), line 95 */
     642           0 :     return 1;
     643             : }
     644             : 
     645           0 : static int r_R2(struct SN_env * z) { /* backwardmode */
     646           0 :     if (!(z->I[2] <= z->c)) return 0; /* $(<integer expression> <= <integer expression>), line 96 */
     647           0 :     return 1;
     648             : }
     649             : 
     650           0 : static int r_standard_suffix(struct SN_env * z) { /* backwardmode */
     651             :     int among_var;
     652           0 :     z->ket = z->c; /* [, line 99 */
     653           0 :     among_var = find_among_b(z, a_4, 43); /* substring, line 99 */
     654           0 :     if (!(among_var)) return 0;
     655           0 :     z->bra = z->c; /* ], line 99 */
     656           0 :     switch (among_var) { /* among, line 99 */
     657           0 :         case 1:
     658           0 :             {   int ret = r_R2(z); /* call R2, line 103 */
     659           0 :                 if (ret <= 0) return ret;
     660             :             }
     661           0 :             {   int ret = slice_del(z); /* delete, line 103 */
     662           0 :                 if (ret < 0) return ret;
     663             :             }
     664           0 :             break;
     665           0 :         case 2:
     666           0 :             {   int ret = r_R2(z); /* call R2, line 106 */
     667           0 :                 if (ret <= 0) return ret;
     668             :             }
     669           0 :             {   int ret = slice_del(z); /* delete, line 106 */
     670           0 :                 if (ret < 0) return ret;
     671             :             }
     672           0 :             {   int m1 = z->l - z->c; (void)m1; /* try, line 107 */
     673           0 :                 z->ket = z->c; /* [, line 107 */
     674           0 :                 if (!(eq_s_b(z, 2, s_14))) { z->c = z->l - m1; goto lab0; } /* literal, line 107 */
     675           0 :                 z->bra = z->c; /* ], line 107 */
     676           0 :                 {   int m2 = z->l - z->c; (void)m2; /* or, line 107 */
     677           0 :                     {   int ret = r_R2(z); /* call R2, line 107 */
     678           0 :                         if (ret == 0) goto lab2;
     679           0 :                         if (ret < 0) return ret;
     680             :                     }
     681           0 :                     {   int ret = slice_del(z); /* delete, line 107 */
     682           0 :                         if (ret < 0) return ret;
     683             :                     }
     684           0 :                     goto lab1;
     685           0 :                 lab2:
     686           0 :                     z->c = z->l - m2;
     687           0 :                     {   int ret = slice_from_s(z, 3, s_15); /* <-, line 107 */
     688           0 :                         if (ret < 0) return ret;
     689             :                     }
     690             :                 }
     691           0 :             lab1:
     692           0 :             lab0:
     693             :                 ;
     694             :             }
     695           0 :             break;
     696           0 :         case 3:
     697           0 :             {   int ret = r_R2(z); /* call R2, line 111 */
     698           0 :                 if (ret <= 0) return ret;
     699             :             }
     700           0 :             {   int ret = slice_from_s(z, 3, s_16); /* <-, line 111 */
     701           0 :                 if (ret < 0) return ret;
     702             :             }
     703           0 :             break;
     704           0 :         case 4:
     705           0 :             {   int ret = r_R2(z); /* call R2, line 114 */
     706           0 :                 if (ret <= 0) return ret;
     707             :             }
     708           0 :             {   int ret = slice_from_s(z, 1, s_17); /* <-, line 114 */
     709           0 :                 if (ret < 0) return ret;
     710             :             }
     711           0 :             break;
     712           0 :         case 5:
     713           0 :             {   int ret = r_R2(z); /* call R2, line 117 */
     714           0 :                 if (ret <= 0) return ret;
     715             :             }
     716           0 :             {   int ret = slice_from_s(z, 3, s_18); /* <-, line 117 */
     717           0 :                 if (ret < 0) return ret;
     718             :             }
     719           0 :             break;
     720           0 :         case 6:
     721           0 :             {   int ret = r_RV(z); /* call RV, line 121 */
     722           0 :                 if (ret <= 0) return ret;
     723             :             }
     724           0 :             {   int ret = slice_del(z); /* delete, line 121 */
     725           0 :                 if (ret < 0) return ret;
     726             :             }
     727           0 :             {   int m3 = z->l - z->c; (void)m3; /* try, line 122 */
     728           0 :                 z->ket = z->c; /* [, line 123 */
     729           0 :                 among_var = find_among_b(z, a_2, 6); /* substring, line 123 */
     730           0 :                 if (!(among_var)) { z->c = z->l - m3; goto lab3; }
     731           0 :                 z->bra = z->c; /* ], line 123 */
     732             :                 switch (among_var) { /* among, line 123 */
     733           0 :                     case 1:
     734           0 :                         {   int ret = r_R2(z); /* call R2, line 124 */
     735           0 :                             if (ret == 0) { z->c = z->l - m3; goto lab3; }
     736           0 :                             if (ret < 0) return ret;
     737             :                         }
     738           0 :                         {   int ret = slice_del(z); /* delete, line 124 */
     739           0 :                             if (ret < 0) return ret;
     740             :                         }
     741           0 :                         z->ket = z->c; /* [, line 124 */
     742           0 :                         if (!(eq_s_b(z, 2, s_19))) { z->c = z->l - m3; goto lab3; } /* literal, line 124 */
     743           0 :                         z->bra = z->c; /* ], line 124 */
     744           0 :                         {   int ret = r_R2(z); /* call R2, line 124 */
     745           0 :                             if (ret == 0) { z->c = z->l - m3; goto lab3; }
     746           0 :                             if (ret < 0) return ret;
     747             :                         }
     748           0 :                         {   int ret = slice_del(z); /* delete, line 124 */
     749           0 :                             if (ret < 0) return ret;
     750             :                         }
     751           0 :                         break;
     752           0 :                     case 2:
     753           0 :                         {   int m4 = z->l - z->c; (void)m4; /* or, line 125 */
     754           0 :                             {   int ret = r_R2(z); /* call R2, line 125 */
     755           0 :                                 if (ret == 0) goto lab5;
     756           0 :                                 if (ret < 0) return ret;
     757             :                             }
     758           0 :                             {   int ret = slice_del(z); /* delete, line 125 */
     759           0 :                                 if (ret < 0) return ret;
     760             :                             }
     761           0 :                             goto lab4;
     762           0 :                         lab5:
     763           0 :                             z->c = z->l - m4;
     764           0 :                             {   int ret = r_R1(z); /* call R1, line 125 */
     765           0 :                                 if (ret == 0) { z->c = z->l - m3; goto lab3; }
     766           0 :                                 if (ret < 0) return ret;
     767             :                             }
     768           0 :                             {   int ret = slice_from_s(z, 3, s_20); /* <-, line 125 */
     769           0 :                                 if (ret < 0) return ret;
     770             :                             }
     771             :                         }
     772           0 :                     lab4:
     773           0 :                         break;
     774           0 :                     case 3:
     775           0 :                         {   int ret = r_R2(z); /* call R2, line 127 */
     776           0 :                             if (ret == 0) { z->c = z->l - m3; goto lab3; }
     777           0 :                             if (ret < 0) return ret;
     778             :                         }
     779           0 :                         {   int ret = slice_del(z); /* delete, line 127 */
     780           0 :                             if (ret < 0) return ret;
     781             :                         }
     782           0 :                         break;
     783           0 :                     case 4:
     784           0 :                         {   int ret = r_RV(z); /* call RV, line 129 */
     785           0 :                             if (ret == 0) { z->c = z->l - m3; goto lab3; }
     786           0 :                             if (ret < 0) return ret;
     787             :                         }
     788           0 :                         {   int ret = slice_from_s(z, 1, s_21); /* <-, line 129 */
     789           0 :                             if (ret < 0) return ret;
     790             :                         }
     791           0 :                         break;
     792             :                 }
     793           0 :             lab3:
     794             :                 ;
     795             :             }
     796           0 :             break;
     797           0 :         case 7:
     798           0 :             {   int ret = r_R2(z); /* call R2, line 136 */
     799           0 :                 if (ret <= 0) return ret;
     800             :             }
     801           0 :             {   int ret = slice_del(z); /* delete, line 136 */
     802           0 :                 if (ret < 0) return ret;
     803             :             }
     804           0 :             {   int m5 = z->l - z->c; (void)m5; /* try, line 137 */
     805           0 :                 z->ket = z->c; /* [, line 138 */
     806           0 :                 if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((4198408 >> (z->p[z->c - 1] & 0x1f)) & 1)) { z->c = z->l - m5; goto lab6; } /* substring, line 138 */
     807           0 :                 among_var = find_among_b(z, a_3, 3);
     808           0 :                 if (!(among_var)) { z->c = z->l - m5; goto lab6; }
     809           0 :                 z->bra = z->c; /* ], line 138 */
     810             :                 switch (among_var) { /* among, line 138 */
     811           0 :                     case 1:
     812           0 :                         {   int m6 = z->l - z->c; (void)m6; /* or, line 139 */
     813           0 :                             {   int ret = r_R2(z); /* call R2, line 139 */
     814           0 :                                 if (ret == 0) goto lab8;
     815           0 :                                 if (ret < 0) return ret;
     816             :                             }
     817           0 :                             {   int ret = slice_del(z); /* delete, line 139 */
     818           0 :                                 if (ret < 0) return ret;
     819             :                             }
     820           0 :                             goto lab7;
     821           0 :                         lab8:
     822           0 :                             z->c = z->l - m6;
     823           0 :                             {   int ret = slice_from_s(z, 3, s_22); /* <-, line 139 */
     824           0 :                                 if (ret < 0) return ret;
     825             :                             }
     826             :                         }
     827           0 :                     lab7:
     828           0 :                         break;
     829           0 :                     case 2:
     830           0 :                         {   int m7 = z->l - z->c; (void)m7; /* or, line 140 */
     831           0 :                             {   int ret = r_R2(z); /* call R2, line 140 */
     832           0 :                                 if (ret == 0) goto lab10;
     833           0 :                                 if (ret < 0) return ret;
     834             :                             }
     835           0 :                             {   int ret = slice_del(z); /* delete, line 140 */
     836           0 :                                 if (ret < 0) return ret;
     837             :                             }
     838           0 :                             goto lab9;
     839           0 :                         lab10:
     840           0 :                             z->c = z->l - m7;
     841           0 :                             {   int ret = slice_from_s(z, 3, s_23); /* <-, line 140 */
     842           0 :                                 if (ret < 0) return ret;
     843             :                             }
     844             :                         }
     845           0 :                     lab9:
     846           0 :                         break;
     847           0 :                     case 3:
     848           0 :                         {   int ret = r_R2(z); /* call R2, line 141 */
     849           0 :                             if (ret == 0) { z->c = z->l - m5; goto lab6; }
     850           0 :                             if (ret < 0) return ret;
     851             :                         }
     852           0 :                         {   int ret = slice_del(z); /* delete, line 141 */
     853           0 :                             if (ret < 0) return ret;
     854             :                         }
     855           0 :                         break;
     856             :                 }
     857           0 :             lab6:
     858             :                 ;
     859             :             }
     860           0 :             break;
     861           0 :         case 8:
     862           0 :             {   int ret = r_R2(z); /* call R2, line 148 */
     863           0 :                 if (ret <= 0) return ret;
     864             :             }
     865           0 :             {   int ret = slice_del(z); /* delete, line 148 */
     866           0 :                 if (ret < 0) return ret;
     867             :             }
     868           0 :             {   int m8 = z->l - z->c; (void)m8; /* try, line 149 */
     869           0 :                 z->ket = z->c; /* [, line 149 */
     870           0 :                 if (!(eq_s_b(z, 2, s_24))) { z->c = z->l - m8; goto lab11; } /* literal, line 149 */
     871           0 :                 z->bra = z->c; /* ], line 149 */
     872           0 :                 {   int ret = r_R2(z); /* call R2, line 149 */
     873           0 :                     if (ret == 0) { z->c = z->l - m8; goto lab11; }
     874           0 :                     if (ret < 0) return ret;
     875             :                 }
     876           0 :                 {   int ret = slice_del(z); /* delete, line 149 */
     877           0 :                     if (ret < 0) return ret;
     878             :                 }
     879           0 :                 z->ket = z->c; /* [, line 149 */
     880           0 :                 if (!(eq_s_b(z, 2, s_25))) { z->c = z->l - m8; goto lab11; } /* literal, line 149 */
     881           0 :                 z->bra = z->c; /* ], line 149 */
     882           0 :                 {   int m9 = z->l - z->c; (void)m9; /* or, line 149 */
     883           0 :                     {   int ret = r_R2(z); /* call R2, line 149 */
     884           0 :                         if (ret == 0) goto lab13;
     885           0 :                         if (ret < 0) return ret;
     886             :                     }
     887           0 :                     {   int ret = slice_del(z); /* delete, line 149 */
     888           0 :                         if (ret < 0) return ret;
     889             :                     }
     890           0 :                     goto lab12;
     891           0 :                 lab13:
     892           0 :                     z->c = z->l - m9;
     893           0 :                     {   int ret = slice_from_s(z, 3, s_26); /* <-, line 149 */
     894           0 :                         if (ret < 0) return ret;
     895             :                     }
     896             :                 }
     897           0 :             lab12:
     898           0 :             lab11:
     899             :                 ;
     900             :             }
     901           0 :             break;
     902           0 :         case 9:
     903           0 :             {   int ret = slice_from_s(z, 3, s_27); /* <-, line 151 */
     904           0 :                 if (ret < 0) return ret;
     905             :             }
     906           0 :             break;
     907           0 :         case 10:
     908           0 :             {   int ret = r_R1(z); /* call R1, line 152 */
     909           0 :                 if (ret <= 0) return ret;
     910             :             }
     911           0 :             {   int ret = slice_from_s(z, 2, s_28); /* <-, line 152 */
     912           0 :                 if (ret < 0) return ret;
     913             :             }
     914           0 :             break;
     915           0 :         case 11:
     916           0 :             {   int m10 = z->l - z->c; (void)m10; /* or, line 154 */
     917           0 :                 {   int ret = r_R2(z); /* call R2, line 154 */
     918           0 :                     if (ret == 0) goto lab15;
     919           0 :                     if (ret < 0) return ret;
     920             :                 }
     921           0 :                 {   int ret = slice_del(z); /* delete, line 154 */
     922           0 :                     if (ret < 0) return ret;
     923             :                 }
     924           0 :                 goto lab14;
     925           0 :             lab15:
     926           0 :                 z->c = z->l - m10;
     927           0 :                 {   int ret = r_R1(z); /* call R1, line 154 */
     928           0 :                     if (ret <= 0) return ret;
     929             :                 }
     930           0 :                 {   int ret = slice_from_s(z, 3, s_29); /* <-, line 154 */
     931           0 :                     if (ret < 0) return ret;
     932             :                 }
     933             :             }
     934           0 :         lab14:
     935           0 :             break;
     936           0 :         case 12:
     937           0 :             {   int ret = r_R1(z); /* call R1, line 157 */
     938           0 :                 if (ret <= 0) return ret;
     939             :             }
     940           0 :             if (out_grouping_b_U(z, g_v, 97, 251, 0)) return 0; /* non v, line 157 */
     941           0 :             {   int ret = slice_del(z); /* delete, line 157 */
     942           0 :                 if (ret < 0) return ret;
     943             :             }
     944           0 :             break;
     945           0 :         case 13:
     946           0 :             {   int ret = r_RV(z); /* call RV, line 162 */
     947           0 :                 if (ret <= 0) return ret;
     948             :             }
     949           0 :             {   int ret = slice_from_s(z, 3, s_30); /* <-, line 162 */
     950           0 :                 if (ret < 0) return ret;
     951             :             }
     952           0 :             return 0; /* fail, line 162 */
     953             :             break;
     954           0 :         case 14:
     955           0 :             {   int ret = r_RV(z); /* call RV, line 163 */
     956           0 :                 if (ret <= 0) return ret;
     957             :             }
     958           0 :             {   int ret = slice_from_s(z, 3, s_31); /* <-, line 163 */
     959           0 :                 if (ret < 0) return ret;
     960             :             }
     961           0 :             return 0; /* fail, line 163 */
     962             :             break;
     963           0 :         case 15:
     964           0 :             {   int m_test11 = z->l - z->c; /* test, line 165 */
     965           0 :                 if (in_grouping_b_U(z, g_v, 97, 251, 0)) return 0; /* grouping v, line 165 */
     966           0 :                 {   int ret = r_RV(z); /* call RV, line 165 */
     967           0 :                     if (ret <= 0) return ret;
     968             :                 }
     969           0 :                 z->c = z->l - m_test11;
     970             :             }
     971           0 :             {   int ret = slice_del(z); /* delete, line 165 */
     972           0 :                 if (ret < 0) return ret;
     973             :             }
     974           0 :             return 0; /* fail, line 165 */
     975             :             break;
     976             :     }
     977           0 :     return 1;
     978             : }
     979             : 
     980           0 : static int r_i_verb_suffix(struct SN_env * z) { /* backwardmode */
     981             : 
     982             :     {   int mlimit1; /* setlimit, line 170 */
     983           0 :         if (z->c < z->I[0]) return 0;
     984           0 :         mlimit1 = z->lb; z->lb = z->I[0];
     985           0 :         z->ket = z->c; /* [, line 171 */
     986           0 :         if (z->c <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((68944418 >> (z->p[z->c - 1] & 0x1f)) & 1)) { z->lb = mlimit1; return 0; } /* substring, line 171 */
     987           0 :         if (!(find_among_b(z, a_5, 35))) { z->lb = mlimit1; return 0; }
     988           0 :         z->bra = z->c; /* ], line 171 */
     989           0 :         {   int m2 = z->l - z->c; (void)m2; /* not, line 177 */
     990           0 :             if (z->c <= z->lb || z->p[z->c - 1] != 'H') goto lab0; /* literal, line 177 */
     991           0 :             z->c--;
     992           0 :             { z->lb = mlimit1; return 0; }
     993           0 :         lab0:
     994           0 :             z->c = z->l - m2;
     995             :         }
     996           0 :         if (out_grouping_b_U(z, g_v, 97, 251, 0)) { z->lb = mlimit1; return 0; } /* non v, line 177 */
     997           0 :         {   int ret = slice_del(z); /* delete, line 177 */
     998           0 :             if (ret < 0) return ret;
     999             :         }
    1000           0 :         z->lb = mlimit1;
    1001             :     }
    1002           0 :     return 1;
    1003             : }
    1004             : 
    1005           0 : static int r_verb_suffix(struct SN_env * z) { /* backwardmode */
    1006             :     int among_var;
    1007             : 
    1008             :     {   int mlimit1; /* setlimit, line 181 */
    1009           0 :         if (z->c < z->I[0]) return 0;
    1010           0 :         mlimit1 = z->lb; z->lb = z->I[0];
    1011           0 :         z->ket = z->c; /* [, line 182 */
    1012           0 :         among_var = find_among_b(z, a_6, 38); /* substring, line 182 */
    1013           0 :         if (!(among_var)) { z->lb = mlimit1; return 0; }
    1014           0 :         z->bra = z->c; /* ], line 182 */
    1015           0 :         switch (among_var) { /* among, line 182 */
    1016           0 :             case 1:
    1017           0 :                 {   int ret = r_R2(z); /* call R2, line 184 */
    1018           0 :                     if (ret == 0) { z->lb = mlimit1; return 0; }
    1019           0 :                     if (ret < 0) return ret;
    1020             :                 }
    1021           0 :                 {   int ret = slice_del(z); /* delete, line 184 */
    1022           0 :                     if (ret < 0) return ret;
    1023             :                 }
    1024           0 :                 break;
    1025           0 :             case 2:
    1026           0 :                 {   int ret = slice_del(z); /* delete, line 192 */
    1027           0 :                     if (ret < 0) return ret;
    1028             :                 }
    1029           0 :                 break;
    1030           0 :             case 3:
    1031           0 :                 {   int ret = slice_del(z); /* delete, line 197 */
    1032           0 :                     if (ret < 0) return ret;
    1033             :                 }
    1034           0 :                 {   int m2 = z->l - z->c; (void)m2; /* try, line 198 */
    1035           0 :                     z->ket = z->c; /* [, line 198 */
    1036           0 :                     if (z->c <= z->lb || z->p[z->c - 1] != 'e') { z->c = z->l - m2; goto lab0; } /* literal, line 198 */
    1037           0 :                     z->c--;
    1038           0 :                     z->bra = z->c; /* ], line 198 */
    1039           0 :                     {   int ret = slice_del(z); /* delete, line 198 */
    1040           0 :                         if (ret < 0) return ret;
    1041             :                     }
    1042           0 :                 lab0:
    1043             :                     ;
    1044             :                 }
    1045           0 :                 break;
    1046             :         }
    1047           0 :         z->lb = mlimit1;
    1048             :     }
    1049           0 :     return 1;
    1050             : }
    1051             : 
    1052           0 : static int r_residual_suffix(struct SN_env * z) { /* backwardmode */
    1053             :     int among_var;
    1054           0 :     {   int m1 = z->l - z->c; (void)m1; /* try, line 206 */
    1055           0 :         z->ket = z->c; /* [, line 206 */
    1056           0 :         if (z->c <= z->lb || z->p[z->c - 1] != 's') { z->c = z->l - m1; goto lab0; } /* literal, line 206 */
    1057           0 :         z->c--;
    1058           0 :         z->bra = z->c; /* ], line 206 */
    1059           0 :         {   int m_test2 = z->l - z->c; /* test, line 206 */
    1060           0 :             {   int m3 = z->l - z->c; (void)m3; /* or, line 206 */
    1061           0 :                 if (!(eq_s_b(z, 2, s_32))) goto lab2; /* literal, line 206 */
    1062           0 :                 goto lab1;
    1063           0 :             lab2:
    1064           0 :                 z->c = z->l - m3;
    1065           0 :                 if (out_grouping_b_U(z, g_keep_with_s, 97, 232, 0)) { z->c = z->l - m1; goto lab0; } /* non keep_with_s, line 206 */
    1066             :             }
    1067           0 :         lab1:
    1068           0 :             z->c = z->l - m_test2;
    1069             :         }
    1070           0 :         {   int ret = slice_del(z); /* delete, line 206 */
    1071           0 :             if (ret < 0) return ret;
    1072             :         }
    1073           0 :     lab0:
    1074             :         ;
    1075             :     }
    1076             : 
    1077             :     {   int mlimit4; /* setlimit, line 207 */
    1078           0 :         if (z->c < z->I[0]) return 0;
    1079           0 :         mlimit4 = z->lb; z->lb = z->I[0];
    1080           0 :         z->ket = z->c; /* [, line 208 */
    1081           0 :         if (z->c <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((278560 >> (z->p[z->c - 1] & 0x1f)) & 1)) { z->lb = mlimit4; return 0; } /* substring, line 208 */
    1082           0 :         among_var = find_among_b(z, a_7, 6);
    1083           0 :         if (!(among_var)) { z->lb = mlimit4; return 0; }
    1084           0 :         z->bra = z->c; /* ], line 208 */
    1085           0 :         switch (among_var) { /* among, line 208 */
    1086           0 :             case 1:
    1087           0 :                 {   int ret = r_R2(z); /* call R2, line 209 */
    1088           0 :                     if (ret == 0) { z->lb = mlimit4; return 0; }
    1089           0 :                     if (ret < 0) return ret;
    1090             :                 }
    1091           0 :                 {   int m5 = z->l - z->c; (void)m5; /* or, line 209 */
    1092           0 :                     if (z->c <= z->lb || z->p[z->c - 1] != 's') goto lab4; /* literal, line 209 */
    1093           0 :                     z->c--;
    1094           0 :                     goto lab3;
    1095           0 :                 lab4:
    1096           0 :                     z->c = z->l - m5;
    1097           0 :                     if (z->c <= z->lb || z->p[z->c - 1] != 't') { z->lb = mlimit4; return 0; } /* literal, line 209 */
    1098           0 :                     z->c--;
    1099             :                 }
    1100           0 :             lab3:
    1101           0 :                 {   int ret = slice_del(z); /* delete, line 209 */
    1102           0 :                     if (ret < 0) return ret;
    1103             :                 }
    1104           0 :                 break;
    1105           0 :             case 2:
    1106           0 :                 {   int ret = slice_from_s(z, 1, s_33); /* <-, line 211 */
    1107           0 :                     if (ret < 0) return ret;
    1108             :                 }
    1109           0 :                 break;
    1110           0 :             case 3:
    1111           0 :                 {   int ret = slice_del(z); /* delete, line 212 */
    1112           0 :                     if (ret < 0) return ret;
    1113             :                 }
    1114           0 :                 break;
    1115             :         }
    1116           0 :         z->lb = mlimit4;
    1117             :     }
    1118           0 :     return 1;
    1119             : }
    1120             : 
    1121           0 : static int r_un_double(struct SN_env * z) { /* backwardmode */
    1122           0 :     {   int m_test1 = z->l - z->c; /* test, line 218 */
    1123           0 :         if (z->c - 2 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((1069056 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0; /* among, line 218 */
    1124           0 :         if (!(find_among_b(z, a_8, 5))) return 0;
    1125           0 :         z->c = z->l - m_test1;
    1126             :     }
    1127           0 :     z->ket = z->c; /* [, line 218 */
    1128           0 :     {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
    1129           0 :         if (ret < 0) return 0;
    1130           0 :         z->c = ret; /* next, line 218 */
    1131             :     }
    1132           0 :     z->bra = z->c; /* ], line 218 */
    1133           0 :     {   int ret = slice_del(z); /* delete, line 218 */
    1134           0 :         if (ret < 0) return ret;
    1135             :     }
    1136           0 :     return 1;
    1137             : }
    1138             : 
    1139           0 : static int r_un_accent(struct SN_env * z) { /* backwardmode */
    1140           0 :     {   int i = 1;
    1141           0 :         while(1) {            if (out_grouping_b_U(z, g_v, 97, 251, 0)) goto lab0; /* non v, line 222 */
    1142           0 :             i--;
    1143           0 :             continue;
    1144           0 :         lab0:
    1145           0 :             break;
    1146             :         }
    1147           0 :         if (i > 0) return 0;
    1148             :     }
    1149           0 :     z->ket = z->c; /* [, line 223 */
    1150           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 223 */
    1151           0 :         if (!(eq_s_b(z, 2, s_34))) goto lab2; /* literal, line 223 */
    1152           0 :         goto lab1;
    1153           0 :     lab2:
    1154           0 :         z->c = z->l - m1;
    1155           0 :         if (!(eq_s_b(z, 2, s_35))) return 0; /* literal, line 223 */
    1156             :     }
    1157           0 : lab1:
    1158           0 :     z->bra = z->c; /* ], line 223 */
    1159           0 :     {   int ret = slice_from_s(z, 1, s_36); /* <-, line 223 */
    1160           0 :         if (ret < 0) return ret;
    1161             :     }
    1162           0 :     return 1;
    1163             : }
    1164             : 
    1165           0 : extern int french_UTF_8_stem(struct SN_env * z) { /* forwardmode */
    1166           0 :     {   int c1 = z->c; /* do, line 229 */
    1167           0 :         {   int ret = r_prelude(z); /* call prelude, line 229 */
    1168           0 :             if (ret < 0) return ret;
    1169             :         }
    1170           0 :         z->c = c1;
    1171             :     }
    1172             :     /* do, line 230 */
    1173           0 :     {   int ret = r_mark_regions(z); /* call mark_regions, line 230 */
    1174           0 :         if (ret < 0) return ret;
    1175             :     }
    1176           0 :     z->lb = z->c; z->c = z->l; /* backwards, line 231 */
    1177             : 
    1178           0 :     {   int m2 = z->l - z->c; (void)m2; /* do, line 233 */
    1179           0 :         {   int m3 = z->l - z->c; (void)m3; /* or, line 243 */
    1180           0 :             {   int m4 = z->l - z->c; (void)m4; /* and, line 239 */
    1181           0 :                 {   int m5 = z->l - z->c; (void)m5; /* or, line 235 */
    1182           0 :                     {   int ret = r_standard_suffix(z); /* call standard_suffix, line 235 */
    1183           0 :                         if (ret == 0) goto lab4;
    1184           0 :                         if (ret < 0) return ret;
    1185             :                     }
    1186           0 :                     goto lab3;
    1187           0 :                 lab4:
    1188           0 :                     z->c = z->l - m5;
    1189           0 :                     {   int ret = r_i_verb_suffix(z); /* call i_verb_suffix, line 236 */
    1190           0 :                         if (ret == 0) goto lab5;
    1191           0 :                         if (ret < 0) return ret;
    1192             :                     }
    1193           0 :                     goto lab3;
    1194           0 :                 lab5:
    1195           0 :                     z->c = z->l - m5;
    1196           0 :                     {   int ret = r_verb_suffix(z); /* call verb_suffix, line 237 */
    1197           0 :                         if (ret == 0) goto lab2;
    1198           0 :                         if (ret < 0) return ret;
    1199             :                     }
    1200             :                 }
    1201           0 :             lab3:
    1202           0 :                 z->c = z->l - m4;
    1203           0 :                 {   int m6 = z->l - z->c; (void)m6; /* try, line 240 */
    1204           0 :                     z->ket = z->c; /* [, line 240 */
    1205           0 :                     {   int m7 = z->l - z->c; (void)m7; /* or, line 240 */
    1206           0 :                         if (z->c <= z->lb || z->p[z->c - 1] != 'Y') goto lab8; /* literal, line 240 */
    1207           0 :                         z->c--;
    1208           0 :                         z->bra = z->c; /* ], line 240 */
    1209           0 :                         {   int ret = slice_from_s(z, 1, s_37); /* <-, line 240 */
    1210           0 :                             if (ret < 0) return ret;
    1211             :                         }
    1212           0 :                         goto lab7;
    1213           0 :                     lab8:
    1214           0 :                         z->c = z->l - m7;
    1215           0 :                         if (!(eq_s_b(z, 2, s_38))) { z->c = z->l - m6; goto lab6; } /* literal, line 241 */
    1216           0 :                         z->bra = z->c; /* ], line 241 */
    1217           0 :                         {   int ret = slice_from_s(z, 1, s_39); /* <-, line 241 */
    1218           0 :                             if (ret < 0) return ret;
    1219             :                         }
    1220             :                     }
    1221           0 :                 lab7:
    1222           0 :                 lab6:
    1223             :                     ;
    1224             :                 }
    1225             :             }
    1226           0 :             goto lab1;
    1227           0 :         lab2:
    1228           0 :             z->c = z->l - m3;
    1229           0 :             {   int ret = r_residual_suffix(z); /* call residual_suffix, line 244 */
    1230           0 :                 if (ret == 0) goto lab0;
    1231           0 :                 if (ret < 0) return ret;
    1232             :             }
    1233             :         }
    1234           0 :     lab1:
    1235           0 :     lab0:
    1236           0 :         z->c = z->l - m2;
    1237             :     }
    1238           0 :     {   int m8 = z->l - z->c; (void)m8; /* do, line 249 */
    1239           0 :         {   int ret = r_un_double(z); /* call un_double, line 249 */
    1240           0 :             if (ret < 0) return ret;
    1241             :         }
    1242           0 :         z->c = z->l - m8;
    1243             :     }
    1244           0 :     {   int m9 = z->l - z->c; (void)m9; /* do, line 250 */
    1245           0 :         {   int ret = r_un_accent(z); /* call un_accent, line 250 */
    1246           0 :             if (ret < 0) return ret;
    1247             :         }
    1248           0 :         z->c = z->l - m9;
    1249             :     }
    1250           0 :     z->c = z->lb;
    1251           0 :     {   int c10 = z->c; /* do, line 252 */
    1252           0 :         {   int ret = r_postlude(z); /* call postlude, line 252 */
    1253           0 :             if (ret < 0) return ret;
    1254             :         }
    1255           0 :         z->c = c10;
    1256             :     }
    1257           0 :     return 1;
    1258             : }
    1259             : 
    1260           0 : extern struct SN_env * french_UTF_8_create_env(void) { return SN_create_env(0, 3, 0); }
    1261             : 
    1262           0 : extern void french_UTF_8_close_env(struct SN_env * z) { SN_close_env(z, 0); }
    1263             : 

Generated by: LCOV version 1.13