LCOV - code coverage report
Current view: top level - src/backend/snowball/libstemmer - stem_UTF_8_turkish.c (source / functions) Hit Total Coverage
Test: PostgreSQL Lines: 0 1156 0.0 %
Date: 2017-09-29 15:12:54 Functions: 0 43 0.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : 
       2             : /* This file was generated automatically by the Snowball to ANSI C compiler */
       3             : 
       4             : #include "header.h"
       5             : 
       6             : #ifdef __cplusplus
       7             : extern "C" {
       8             : #endif
       9             : extern int turkish_UTF_8_stem(struct SN_env * z);
      10             : #ifdef __cplusplus
      11             : }
      12             : #endif
      13             : static int r_stem_suffix_chain_before_ki(struct SN_env * z);
      14             : static int r_stem_noun_suffixes(struct SN_env * z);
      15             : static int r_stem_nominal_verb_suffixes(struct SN_env * z);
      16             : static int r_postlude(struct SN_env * z);
      17             : static int r_post_process_last_consonants(struct SN_env * z);
      18             : static int r_more_than_one_syllable_word(struct SN_env * z);
      19             : static int r_mark_suffix_with_optional_s_consonant(struct SN_env * z);
      20             : static int r_mark_suffix_with_optional_n_consonant(struct SN_env * z);
      21             : static int r_mark_suffix_with_optional_U_vowel(struct SN_env * z);
      22             : static int r_mark_suffix_with_optional_y_consonant(struct SN_env * z);
      23             : static int r_mark_ysA(struct SN_env * z);
      24             : static int r_mark_ymUs_(struct SN_env * z);
      25             : static int r_mark_yken(struct SN_env * z);
      26             : static int r_mark_yDU(struct SN_env * z);
      27             : static int r_mark_yUz(struct SN_env * z);
      28             : static int r_mark_yUm(struct SN_env * z);
      29             : static int r_mark_yU(struct SN_env * z);
      30             : static int r_mark_ylA(struct SN_env * z);
      31             : static int r_mark_yA(struct SN_env * z);
      32             : static int r_mark_possessives(struct SN_env * z);
      33             : static int r_mark_sUnUz(struct SN_env * z);
      34             : static int r_mark_sUn(struct SN_env * z);
      35             : static int r_mark_sU(struct SN_env * z);
      36             : static int r_mark_nUz(struct SN_env * z);
      37             : static int r_mark_nUn(struct SN_env * z);
      38             : static int r_mark_nU(struct SN_env * z);
      39             : static int r_mark_ndAn(struct SN_env * z);
      40             : static int r_mark_ndA(struct SN_env * z);
      41             : static int r_mark_ncA(struct SN_env * z);
      42             : static int r_mark_nA(struct SN_env * z);
      43             : static int r_mark_lArI(struct SN_env * z);
      44             : static int r_mark_lAr(struct SN_env * z);
      45             : static int r_mark_ki(struct SN_env * z);
      46             : static int r_mark_DUr(struct SN_env * z);
      47             : static int r_mark_DAn(struct SN_env * z);
      48             : static int r_mark_DA(struct SN_env * z);
      49             : static int r_mark_cAsInA(struct SN_env * z);
      50             : static int r_is_reserved_word(struct SN_env * z);
      51             : static int r_check_vowel_harmony(struct SN_env * z);
      52             : static int r_append_U_to_stems_ending_with_d_or_g(struct SN_env * z);
      53             : #ifdef __cplusplus
      54             : extern "C" {
      55             : #endif
      56             : 
      57             : 
      58             : extern struct SN_env * turkish_UTF_8_create_env(void);
      59             : extern void turkish_UTF_8_close_env(struct SN_env * z);
      60             : 
      61             : 
      62             : #ifdef __cplusplus
      63             : }
      64             : #endif
      65             : static const symbol s_0_0[1] = { 'm' };
      66             : static const symbol s_0_1[1] = { 'n' };
      67             : static const symbol s_0_2[3] = { 'm', 'i', 'z' };
      68             : static const symbol s_0_3[3] = { 'n', 'i', 'z' };
      69             : static const symbol s_0_4[3] = { 'm', 'u', 'z' };
      70             : static const symbol s_0_5[3] = { 'n', 'u', 'z' };
      71             : static const symbol s_0_6[4] = { 'm', 0xC4, 0xB1, 'z' };
      72             : static const symbol s_0_7[4] = { 'n', 0xC4, 0xB1, 'z' };
      73             : static const symbol s_0_8[4] = { 'm', 0xC3, 0xBC, 'z' };
      74             : static const symbol s_0_9[4] = { 'n', 0xC3, 0xBC, 'z' };
      75             : 
      76             : static const struct among a_0[10] =
      77             : {
      78             : /*  0 */ { 1, s_0_0, -1, -1, 0},
      79             : /*  1 */ { 1, s_0_1, -1, -1, 0},
      80             : /*  2 */ { 3, s_0_2, -1, -1, 0},
      81             : /*  3 */ { 3, s_0_3, -1, -1, 0},
      82             : /*  4 */ { 3, s_0_4, -1, -1, 0},
      83             : /*  5 */ { 3, s_0_5, -1, -1, 0},
      84             : /*  6 */ { 4, s_0_6, -1, -1, 0},
      85             : /*  7 */ { 4, s_0_7, -1, -1, 0},
      86             : /*  8 */ { 4, s_0_8, -1, -1, 0},
      87             : /*  9 */ { 4, s_0_9, -1, -1, 0}
      88             : };
      89             : 
      90             : static const symbol s_1_0[4] = { 'l', 'e', 'r', 'i' };
      91             : static const symbol s_1_1[5] = { 'l', 'a', 'r', 0xC4, 0xB1 };
      92             : 
      93             : static const struct among a_1[2] =
      94             : {
      95             : /*  0 */ { 4, s_1_0, -1, -1, 0},
      96             : /*  1 */ { 5, s_1_1, -1, -1, 0}
      97             : };
      98             : 
      99             : static const symbol s_2_0[2] = { 'n', 'i' };
     100             : static const symbol s_2_1[2] = { 'n', 'u' };
     101             : static const symbol s_2_2[3] = { 'n', 0xC4, 0xB1 };
     102             : static const symbol s_2_3[3] = { 'n', 0xC3, 0xBC };
     103             : 
     104             : static const struct among a_2[4] =
     105             : {
     106             : /*  0 */ { 2, s_2_0, -1, -1, 0},
     107             : /*  1 */ { 2, s_2_1, -1, -1, 0},
     108             : /*  2 */ { 3, s_2_2, -1, -1, 0},
     109             : /*  3 */ { 3, s_2_3, -1, -1, 0}
     110             : };
     111             : 
     112             : static const symbol s_3_0[2] = { 'i', 'n' };
     113             : static const symbol s_3_1[2] = { 'u', 'n' };
     114             : static const symbol s_3_2[3] = { 0xC4, 0xB1, 'n' };
     115             : static const symbol s_3_3[3] = { 0xC3, 0xBC, 'n' };
     116             : 
     117             : static const struct among a_3[4] =
     118             : {
     119             : /*  0 */ { 2, s_3_0, -1, -1, 0},
     120             : /*  1 */ { 2, s_3_1, -1, -1, 0},
     121             : /*  2 */ { 3, s_3_2, -1, -1, 0},
     122             : /*  3 */ { 3, s_3_3, -1, -1, 0}
     123             : };
     124             : 
     125             : static const symbol s_4_0[1] = { 'a' };
     126             : static const symbol s_4_1[1] = { 'e' };
     127             : 
     128             : static const struct among a_4[2] =
     129             : {
     130             : /*  0 */ { 1, s_4_0, -1, -1, 0},
     131             : /*  1 */ { 1, s_4_1, -1, -1, 0}
     132             : };
     133             : 
     134             : static const symbol s_5_0[2] = { 'n', 'a' };
     135             : static const symbol s_5_1[2] = { 'n', 'e' };
     136             : 
     137             : static const struct among a_5[2] =
     138             : {
     139             : /*  0 */ { 2, s_5_0, -1, -1, 0},
     140             : /*  1 */ { 2, s_5_1, -1, -1, 0}
     141             : };
     142             : 
     143             : static const symbol s_6_0[2] = { 'd', 'a' };
     144             : static const symbol s_6_1[2] = { 't', 'a' };
     145             : static const symbol s_6_2[2] = { 'd', 'e' };
     146             : static const symbol s_6_3[2] = { 't', 'e' };
     147             : 
     148             : static const struct among a_6[4] =
     149             : {
     150             : /*  0 */ { 2, s_6_0, -1, -1, 0},
     151             : /*  1 */ { 2, s_6_1, -1, -1, 0},
     152             : /*  2 */ { 2, s_6_2, -1, -1, 0},
     153             : /*  3 */ { 2, s_6_3, -1, -1, 0}
     154             : };
     155             : 
     156             : static const symbol s_7_0[3] = { 'n', 'd', 'a' };
     157             : static const symbol s_7_1[3] = { 'n', 'd', 'e' };
     158             : 
     159             : static const struct among a_7[2] =
     160             : {
     161             : /*  0 */ { 3, s_7_0, -1, -1, 0},
     162             : /*  1 */ { 3, s_7_1, -1, -1, 0}
     163             : };
     164             : 
     165             : static const symbol s_8_0[3] = { 'd', 'a', 'n' };
     166             : static const symbol s_8_1[3] = { 't', 'a', 'n' };
     167             : static const symbol s_8_2[3] = { 'd', 'e', 'n' };
     168             : static const symbol s_8_3[3] = { 't', 'e', 'n' };
     169             : 
     170             : static const struct among a_8[4] =
     171             : {
     172             : /*  0 */ { 3, s_8_0, -1, -1, 0},
     173             : /*  1 */ { 3, s_8_1, -1, -1, 0},
     174             : /*  2 */ { 3, s_8_2, -1, -1, 0},
     175             : /*  3 */ { 3, s_8_3, -1, -1, 0}
     176             : };
     177             : 
     178             : static const symbol s_9_0[4] = { 'n', 'd', 'a', 'n' };
     179             : static const symbol s_9_1[4] = { 'n', 'd', 'e', 'n' };
     180             : 
     181             : static const struct among a_9[2] =
     182             : {
     183             : /*  0 */ { 4, s_9_0, -1, -1, 0},
     184             : /*  1 */ { 4, s_9_1, -1, -1, 0}
     185             : };
     186             : 
     187             : static const symbol s_10_0[2] = { 'l', 'a' };
     188             : static const symbol s_10_1[2] = { 'l', 'e' };
     189             : 
     190             : static const struct among a_10[2] =
     191             : {
     192             : /*  0 */ { 2, s_10_0, -1, -1, 0},
     193             : /*  1 */ { 2, s_10_1, -1, -1, 0}
     194             : };
     195             : 
     196             : static const symbol s_11_0[2] = { 'c', 'a' };
     197             : static const symbol s_11_1[2] = { 'c', 'e' };
     198             : 
     199             : static const struct among a_11[2] =
     200             : {
     201             : /*  0 */ { 2, s_11_0, -1, -1, 0},
     202             : /*  1 */ { 2, s_11_1, -1, -1, 0}
     203             : };
     204             : 
     205             : static const symbol s_12_0[2] = { 'i', 'm' };
     206             : static const symbol s_12_1[2] = { 'u', 'm' };
     207             : static const symbol s_12_2[3] = { 0xC4, 0xB1, 'm' };
     208             : static const symbol s_12_3[3] = { 0xC3, 0xBC, 'm' };
     209             : 
     210             : static const struct among a_12[4] =
     211             : {
     212             : /*  0 */ { 2, s_12_0, -1, -1, 0},
     213             : /*  1 */ { 2, s_12_1, -1, -1, 0},
     214             : /*  2 */ { 3, s_12_2, -1, -1, 0},
     215             : /*  3 */ { 3, s_12_3, -1, -1, 0}
     216             : };
     217             : 
     218             : static const symbol s_13_0[3] = { 's', 'i', 'n' };
     219             : static const symbol s_13_1[3] = { 's', 'u', 'n' };
     220             : static const symbol s_13_2[4] = { 's', 0xC4, 0xB1, 'n' };
     221             : static const symbol s_13_3[4] = { 's', 0xC3, 0xBC, 'n' };
     222             : 
     223             : static const struct among a_13[4] =
     224             : {
     225             : /*  0 */ { 3, s_13_0, -1, -1, 0},
     226             : /*  1 */ { 3, s_13_1, -1, -1, 0},
     227             : /*  2 */ { 4, s_13_2, -1, -1, 0},
     228             : /*  3 */ { 4, s_13_3, -1, -1, 0}
     229             : };
     230             : 
     231             : static const symbol s_14_0[2] = { 'i', 'z' };
     232             : static const symbol s_14_1[2] = { 'u', 'z' };
     233             : static const symbol s_14_2[3] = { 0xC4, 0xB1, 'z' };
     234             : static const symbol s_14_3[3] = { 0xC3, 0xBC, 'z' };
     235             : 
     236             : static const struct among a_14[4] =
     237             : {
     238             : /*  0 */ { 2, s_14_0, -1, -1, 0},
     239             : /*  1 */ { 2, s_14_1, -1, -1, 0},
     240             : /*  2 */ { 3, s_14_2, -1, -1, 0},
     241             : /*  3 */ { 3, s_14_3, -1, -1, 0}
     242             : };
     243             : 
     244             : static const symbol s_15_0[5] = { 's', 'i', 'n', 'i', 'z' };
     245             : static const symbol s_15_1[5] = { 's', 'u', 'n', 'u', 'z' };
     246             : static const symbol s_15_2[7] = { 's', 0xC4, 0xB1, 'n', 0xC4, 0xB1, 'z' };
     247             : static const symbol s_15_3[7] = { 's', 0xC3, 0xBC, 'n', 0xC3, 0xBC, 'z' };
     248             : 
     249             : static const struct among a_15[4] =
     250             : {
     251             : /*  0 */ { 5, s_15_0, -1, -1, 0},
     252             : /*  1 */ { 5, s_15_1, -1, -1, 0},
     253             : /*  2 */ { 7, s_15_2, -1, -1, 0},
     254             : /*  3 */ { 7, s_15_3, -1, -1, 0}
     255             : };
     256             : 
     257             : static const symbol s_16_0[3] = { 'l', 'a', 'r' };
     258             : static const symbol s_16_1[3] = { 'l', 'e', 'r' };
     259             : 
     260             : static const struct among a_16[2] =
     261             : {
     262             : /*  0 */ { 3, s_16_0, -1, -1, 0},
     263             : /*  1 */ { 3, s_16_1, -1, -1, 0}
     264             : };
     265             : 
     266             : static const symbol s_17_0[3] = { 'n', 'i', 'z' };
     267             : static const symbol s_17_1[3] = { 'n', 'u', 'z' };
     268             : static const symbol s_17_2[4] = { 'n', 0xC4, 0xB1, 'z' };
     269             : static const symbol s_17_3[4] = { 'n', 0xC3, 0xBC, 'z' };
     270             : 
     271             : static const struct among a_17[4] =
     272             : {
     273             : /*  0 */ { 3, s_17_0, -1, -1, 0},
     274             : /*  1 */ { 3, s_17_1, -1, -1, 0},
     275             : /*  2 */ { 4, s_17_2, -1, -1, 0},
     276             : /*  3 */ { 4, s_17_3, -1, -1, 0}
     277             : };
     278             : 
     279             : static const symbol s_18_0[3] = { 'd', 'i', 'r' };
     280             : static const symbol s_18_1[3] = { 't', 'i', 'r' };
     281             : static const symbol s_18_2[3] = { 'd', 'u', 'r' };
     282             : static const symbol s_18_3[3] = { 't', 'u', 'r' };
     283             : static const symbol s_18_4[4] = { 'd', 0xC4, 0xB1, 'r' };
     284             : static const symbol s_18_5[4] = { 't', 0xC4, 0xB1, 'r' };
     285             : static const symbol s_18_6[4] = { 'd', 0xC3, 0xBC, 'r' };
     286             : static const symbol s_18_7[4] = { 't', 0xC3, 0xBC, 'r' };
     287             : 
     288             : static const struct among a_18[8] =
     289             : {
     290             : /*  0 */ { 3, s_18_0, -1, -1, 0},
     291             : /*  1 */ { 3, s_18_1, -1, -1, 0},
     292             : /*  2 */ { 3, s_18_2, -1, -1, 0},
     293             : /*  3 */ { 3, s_18_3, -1, -1, 0},
     294             : /*  4 */ { 4, s_18_4, -1, -1, 0},
     295             : /*  5 */ { 4, s_18_5, -1, -1, 0},
     296             : /*  6 */ { 4, s_18_6, -1, -1, 0},
     297             : /*  7 */ { 4, s_18_7, -1, -1, 0}
     298             : };
     299             : 
     300             : static const symbol s_19_0[7] = { 'c', 'a', 's', 0xC4, 0xB1, 'n', 'a' };
     301             : static const symbol s_19_1[6] = { 'c', 'e', 's', 'i', 'n', 'e' };
     302             : 
     303             : static const struct among a_19[2] =
     304             : {
     305             : /*  0 */ { 7, s_19_0, -1, -1, 0},
     306             : /*  1 */ { 6, s_19_1, -1, -1, 0}
     307             : };
     308             : 
     309             : static const symbol s_20_0[2] = { 'd', 'i' };
     310             : static const symbol s_20_1[2] = { 't', 'i' };
     311             : static const symbol s_20_2[3] = { 'd', 'i', 'k' };
     312             : static const symbol s_20_3[3] = { 't', 'i', 'k' };
     313             : static const symbol s_20_4[3] = { 'd', 'u', 'k' };
     314             : static const symbol s_20_5[3] = { 't', 'u', 'k' };
     315             : static const symbol s_20_6[4] = { 'd', 0xC4, 0xB1, 'k' };
     316             : static const symbol s_20_7[4] = { 't', 0xC4, 0xB1, 'k' };
     317             : static const symbol s_20_8[4] = { 'd', 0xC3, 0xBC, 'k' };
     318             : static const symbol s_20_9[4] = { 't', 0xC3, 0xBC, 'k' };
     319             : static const symbol s_20_10[3] = { 'd', 'i', 'm' };
     320             : static const symbol s_20_11[3] = { 't', 'i', 'm' };
     321             : static const symbol s_20_12[3] = { 'd', 'u', 'm' };
     322             : static const symbol s_20_13[3] = { 't', 'u', 'm' };
     323             : static const symbol s_20_14[4] = { 'd', 0xC4, 0xB1, 'm' };
     324             : static const symbol s_20_15[4] = { 't', 0xC4, 0xB1, 'm' };
     325             : static const symbol s_20_16[4] = { 'd', 0xC3, 0xBC, 'm' };
     326             : static const symbol s_20_17[4] = { 't', 0xC3, 0xBC, 'm' };
     327             : static const symbol s_20_18[3] = { 'd', 'i', 'n' };
     328             : static const symbol s_20_19[3] = { 't', 'i', 'n' };
     329             : static const symbol s_20_20[3] = { 'd', 'u', 'n' };
     330             : static const symbol s_20_21[3] = { 't', 'u', 'n' };
     331             : static const symbol s_20_22[4] = { 'd', 0xC4, 0xB1, 'n' };
     332             : static const symbol s_20_23[4] = { 't', 0xC4, 0xB1, 'n' };
     333             : static const symbol s_20_24[4] = { 'd', 0xC3, 0xBC, 'n' };
     334             : static const symbol s_20_25[4] = { 't', 0xC3, 0xBC, 'n' };
     335             : static const symbol s_20_26[2] = { 'd', 'u' };
     336             : static const symbol s_20_27[2] = { 't', 'u' };
     337             : static const symbol s_20_28[3] = { 'd', 0xC4, 0xB1 };
     338             : static const symbol s_20_29[3] = { 't', 0xC4, 0xB1 };
     339             : static const symbol s_20_30[3] = { 'd', 0xC3, 0xBC };
     340             : static const symbol s_20_31[3] = { 't', 0xC3, 0xBC };
     341             : 
     342             : static const struct among a_20[32] =
     343             : {
     344             : /*  0 */ { 2, s_20_0, -1, -1, 0},
     345             : /*  1 */ { 2, s_20_1, -1, -1, 0},
     346             : /*  2 */ { 3, s_20_2, -1, -1, 0},
     347             : /*  3 */ { 3, s_20_3, -1, -1, 0},
     348             : /*  4 */ { 3, s_20_4, -1, -1, 0},
     349             : /*  5 */ { 3, s_20_5, -1, -1, 0},
     350             : /*  6 */ { 4, s_20_6, -1, -1, 0},
     351             : /*  7 */ { 4, s_20_7, -1, -1, 0},
     352             : /*  8 */ { 4, s_20_8, -1, -1, 0},
     353             : /*  9 */ { 4, s_20_9, -1, -1, 0},
     354             : /* 10 */ { 3, s_20_10, -1, -1, 0},
     355             : /* 11 */ { 3, s_20_11, -1, -1, 0},
     356             : /* 12 */ { 3, s_20_12, -1, -1, 0},
     357             : /* 13 */ { 3, s_20_13, -1, -1, 0},
     358             : /* 14 */ { 4, s_20_14, -1, -1, 0},
     359             : /* 15 */ { 4, s_20_15, -1, -1, 0},
     360             : /* 16 */ { 4, s_20_16, -1, -1, 0},
     361             : /* 17 */ { 4, s_20_17, -1, -1, 0},
     362             : /* 18 */ { 3, s_20_18, -1, -1, 0},
     363             : /* 19 */ { 3, s_20_19, -1, -1, 0},
     364             : /* 20 */ { 3, s_20_20, -1, -1, 0},
     365             : /* 21 */ { 3, s_20_21, -1, -1, 0},
     366             : /* 22 */ { 4, s_20_22, -1, -1, 0},
     367             : /* 23 */ { 4, s_20_23, -1, -1, 0},
     368             : /* 24 */ { 4, s_20_24, -1, -1, 0},
     369             : /* 25 */ { 4, s_20_25, -1, -1, 0},
     370             : /* 26 */ { 2, s_20_26, -1, -1, 0},
     371             : /* 27 */ { 2, s_20_27, -1, -1, 0},
     372             : /* 28 */ { 3, s_20_28, -1, -1, 0},
     373             : /* 29 */ { 3, s_20_29, -1, -1, 0},
     374             : /* 30 */ { 3, s_20_30, -1, -1, 0},
     375             : /* 31 */ { 3, s_20_31, -1, -1, 0}
     376             : };
     377             : 
     378             : static const symbol s_21_0[2] = { 's', 'a' };
     379             : static const symbol s_21_1[2] = { 's', 'e' };
     380             : static const symbol s_21_2[3] = { 's', 'a', 'k' };
     381             : static const symbol s_21_3[3] = { 's', 'e', 'k' };
     382             : static const symbol s_21_4[3] = { 's', 'a', 'm' };
     383             : static const symbol s_21_5[3] = { 's', 'e', 'm' };
     384             : static const symbol s_21_6[3] = { 's', 'a', 'n' };
     385             : static const symbol s_21_7[3] = { 's', 'e', 'n' };
     386             : 
     387             : static const struct among a_21[8] =
     388             : {
     389             : /*  0 */ { 2, s_21_0, -1, -1, 0},
     390             : /*  1 */ { 2, s_21_1, -1, -1, 0},
     391             : /*  2 */ { 3, s_21_2, -1, -1, 0},
     392             : /*  3 */ { 3, s_21_3, -1, -1, 0},
     393             : /*  4 */ { 3, s_21_4, -1, -1, 0},
     394             : /*  5 */ { 3, s_21_5, -1, -1, 0},
     395             : /*  6 */ { 3, s_21_6, -1, -1, 0},
     396             : /*  7 */ { 3, s_21_7, -1, -1, 0}
     397             : };
     398             : 
     399             : static const symbol s_22_0[4] = { 'm', 'i', 0xC5, 0x9F };
     400             : static const symbol s_22_1[4] = { 'm', 'u', 0xC5, 0x9F };
     401             : static const symbol s_22_2[5] = { 'm', 0xC4, 0xB1, 0xC5, 0x9F };
     402             : static const symbol s_22_3[5] = { 'm', 0xC3, 0xBC, 0xC5, 0x9F };
     403             : 
     404             : static const struct among a_22[4] =
     405             : {
     406             : /*  0 */ { 4, s_22_0, -1, -1, 0},
     407             : /*  1 */ { 4, s_22_1, -1, -1, 0},
     408             : /*  2 */ { 5, s_22_2, -1, -1, 0},
     409             : /*  3 */ { 5, s_22_3, -1, -1, 0}
     410             : };
     411             : 
     412             : static const symbol s_23_0[1] = { 'b' };
     413             : static const symbol s_23_1[1] = { 'c' };
     414             : static const symbol s_23_2[1] = { 'd' };
     415             : static const symbol s_23_3[2] = { 0xC4, 0x9F };
     416             : 
     417             : static const struct among a_23[4] =
     418             : {
     419             : /*  0 */ { 1, s_23_0, -1, 1, 0},
     420             : /*  1 */ { 1, s_23_1, -1, 2, 0},
     421             : /*  2 */ { 1, s_23_2, -1, 3, 0},
     422             : /*  3 */ { 2, s_23_3, -1, 4, 0}
     423             : };
     424             : 
     425             : static const unsigned char g_vowel[] = { 17, 65, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 32, 8, 0, 0, 0, 0, 0, 0, 1 };
     426             : 
     427             : static const unsigned char g_U[] = { 1, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 1 };
     428             : 
     429             : static const unsigned char g_vowel1[] = { 1, 64, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 };
     430             : 
     431             : static const unsigned char g_vowel2[] = { 17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 130 };
     432             : 
     433             : static const unsigned char g_vowel3[] = { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 };
     434             : 
     435             : static const unsigned char g_vowel4[] = { 17 };
     436             : 
     437             : static const unsigned char g_vowel5[] = { 65 };
     438             : 
     439             : static const unsigned char g_vowel6[] = { 65 };
     440             : 
     441             : static const symbol s_0[] = { 'a' };
     442             : static const symbol s_1[] = { 'e' };
     443             : static const symbol s_2[] = { 0xC4, 0xB1 };
     444             : static const symbol s_3[] = { 'i' };
     445             : static const symbol s_4[] = { 'o' };
     446             : static const symbol s_5[] = { 0xC3, 0xB6 };
     447             : static const symbol s_6[] = { 'u' };
     448             : static const symbol s_7[] = { 0xC3, 0xBC };
     449             : static const symbol s_8[] = { 'n' };
     450             : static const symbol s_9[] = { 'n' };
     451             : static const symbol s_10[] = { 's' };
     452             : static const symbol s_11[] = { 's' };
     453             : static const symbol s_12[] = { 'y' };
     454             : static const symbol s_13[] = { 'y' };
     455             : static const symbol s_14[] = { 'k', 'i' };
     456             : static const symbol s_15[] = { 'k', 'e', 'n' };
     457             : static const symbol s_16[] = { 'p' };
     458             : static const symbol s_17[] = { 0xC3, 0xA7 };
     459             : static const symbol s_18[] = { 't' };
     460             : static const symbol s_19[] = { 'k' };
     461             : static const symbol s_20[] = { 'd' };
     462             : static const symbol s_21[] = { 'g' };
     463             : static const symbol s_22[] = { 'a' };
     464             : static const symbol s_23[] = { 0xC4, 0xB1 };
     465             : static const symbol s_24[] = { 0xC4, 0xB1 };
     466             : static const symbol s_25[] = { 'e' };
     467             : static const symbol s_26[] = { 'i' };
     468             : static const symbol s_27[] = { 'i' };
     469             : static const symbol s_28[] = { 'o' };
     470             : static const symbol s_29[] = { 'u' };
     471             : static const symbol s_30[] = { 'u' };
     472             : static const symbol s_31[] = { 0xC3, 0xB6 };
     473             : static const symbol s_32[] = { 0xC3, 0xBC };
     474             : static const symbol s_33[] = { 0xC3, 0xBC };
     475             : static const symbol s_34[] = { 'a', 'd' };
     476             : static const symbol s_35[] = { 's', 'o', 'y', 'a', 'd' };
     477             : 
     478           0 : static int r_check_vowel_harmony(struct SN_env * z) {
     479           0 :     {   int m_test = z->l - z->c; /* test, line 112 */
     480           0 :         if (out_grouping_b_U(z, g_vowel, 97, 305, 1) < 0) return 0; /* goto */ /* grouping vowel, line 114 */
     481           0 :         {   int m1 = z->l - z->c; (void)m1; /* or, line 116 */
     482           0 :             if (!(eq_s_b(z, 1, s_0))) goto lab1;
     483           0 :             if (out_grouping_b_U(z, g_vowel1, 97, 305, 1) < 0) goto lab1; /* goto */ /* grouping vowel1, line 116 */
     484           0 :             goto lab0;
     485             :         lab1:
     486           0 :             z->c = z->l - m1;
     487           0 :             if (!(eq_s_b(z, 1, s_1))) goto lab2;
     488           0 :             if (out_grouping_b_U(z, g_vowel2, 101, 252, 1) < 0) goto lab2; /* goto */ /* grouping vowel2, line 117 */
     489           0 :             goto lab0;
     490             :         lab2:
     491           0 :             z->c = z->l - m1;
     492           0 :             if (!(eq_s_b(z, 2, s_2))) goto lab3;
     493           0 :             if (out_grouping_b_U(z, g_vowel3, 97, 305, 1) < 0) goto lab3; /* goto */ /* grouping vowel3, line 118 */
     494           0 :             goto lab0;
     495             :         lab3:
     496           0 :             z->c = z->l - m1;
     497           0 :             if (!(eq_s_b(z, 1, s_3))) goto lab4;
     498           0 :             if (out_grouping_b_U(z, g_vowel4, 101, 105, 1) < 0) goto lab4; /* goto */ /* grouping vowel4, line 119 */
     499           0 :             goto lab0;
     500             :         lab4:
     501           0 :             z->c = z->l - m1;
     502           0 :             if (!(eq_s_b(z, 1, s_4))) goto lab5;
     503           0 :             if (out_grouping_b_U(z, g_vowel5, 111, 117, 1) < 0) goto lab5; /* goto */ /* grouping vowel5, line 120 */
     504           0 :             goto lab0;
     505             :         lab5:
     506           0 :             z->c = z->l - m1;
     507           0 :             if (!(eq_s_b(z, 2, s_5))) goto lab6;
     508           0 :             if (out_grouping_b_U(z, g_vowel6, 246, 252, 1) < 0) goto lab6; /* goto */ /* grouping vowel6, line 121 */
     509           0 :             goto lab0;
     510             :         lab6:
     511           0 :             z->c = z->l - m1;
     512           0 :             if (!(eq_s_b(z, 1, s_6))) goto lab7;
     513           0 :             if (out_grouping_b_U(z, g_vowel5, 111, 117, 1) < 0) goto lab7; /* goto */ /* grouping vowel5, line 122 */
     514           0 :             goto lab0;
     515             :         lab7:
     516           0 :             z->c = z->l - m1;
     517           0 :             if (!(eq_s_b(z, 2, s_7))) return 0;
     518           0 :             if (out_grouping_b_U(z, g_vowel6, 246, 252, 1) < 0) return 0; /* goto */ /* grouping vowel6, line 123 */
     519             :         }
     520             :     lab0:
     521           0 :         z->c = z->l - m_test;
     522             :     }
     523           0 :     return 1;
     524             : }
     525             : 
     526           0 : static int r_mark_suffix_with_optional_n_consonant(struct SN_env * z) {
     527           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 134 */
     528           0 :         {   int m_test = z->l - z->c; /* test, line 133 */
     529           0 :             if (!(eq_s_b(z, 1, s_8))) goto lab1;
     530           0 :             z->c = z->l - m_test;
     531             :         }
     532           0 :         {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     533           0 :             if (ret < 0) goto lab1;
     534           0 :             z->c = ret; /* next, line 133 */
     535             :         }
     536           0 :         {   int m_test = z->l - z->c; /* test, line 133 */
     537           0 :             if (in_grouping_b_U(z, g_vowel, 97, 305, 0)) goto lab1;
     538           0 :             z->c = z->l - m_test;
     539             :         }
     540           0 :         goto lab0;
     541             :     lab1:
     542           0 :         z->c = z->l - m1;
     543           0 :         {   int m2 = z->l - z->c; (void)m2; /* not, line 135 */
     544           0 :             {   int m_test = z->l - z->c; /* test, line 135 */
     545           0 :                 if (!(eq_s_b(z, 1, s_9))) goto lab2;
     546           0 :                 z->c = z->l - m_test;
     547             :             }
     548           0 :             return 0;
     549             :         lab2:
     550           0 :             z->c = z->l - m2;
     551             :         }
     552           0 :         {   int m_test = z->l - z->c; /* test, line 135 */
     553           0 :             {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     554           0 :                 if (ret < 0) return 0;
     555           0 :                 z->c = ret; /* next, line 135 */
     556             :             }
     557           0 :             {   int m_test = z->l - z->c; /* test, line 135 */
     558           0 :                 if (in_grouping_b_U(z, g_vowel, 97, 305, 0)) return 0;
     559           0 :                 z->c = z->l - m_test;
     560             :             }
     561           0 :             z->c = z->l - m_test;
     562             :         }
     563             :     }
     564             : lab0:
     565           0 :     return 1;
     566             : }
     567             : 
     568           0 : static int r_mark_suffix_with_optional_s_consonant(struct SN_env * z) {
     569           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 145 */
     570           0 :         {   int m_test = z->l - z->c; /* test, line 144 */
     571           0 :             if (!(eq_s_b(z, 1, s_10))) goto lab1;
     572           0 :             z->c = z->l - m_test;
     573             :         }
     574           0 :         {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     575           0 :             if (ret < 0) goto lab1;
     576           0 :             z->c = ret; /* next, line 144 */
     577             :         }
     578           0 :         {   int m_test = z->l - z->c; /* test, line 144 */
     579           0 :             if (in_grouping_b_U(z, g_vowel, 97, 305, 0)) goto lab1;
     580           0 :             z->c = z->l - m_test;
     581             :         }
     582           0 :         goto lab0;
     583             :     lab1:
     584           0 :         z->c = z->l - m1;
     585           0 :         {   int m2 = z->l - z->c; (void)m2; /* not, line 146 */
     586           0 :             {   int m_test = z->l - z->c; /* test, line 146 */
     587           0 :                 if (!(eq_s_b(z, 1, s_11))) goto lab2;
     588           0 :                 z->c = z->l - m_test;
     589             :             }
     590           0 :             return 0;
     591             :         lab2:
     592           0 :             z->c = z->l - m2;
     593             :         }
     594           0 :         {   int m_test = z->l - z->c; /* test, line 146 */
     595           0 :             {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     596           0 :                 if (ret < 0) return 0;
     597           0 :                 z->c = ret; /* next, line 146 */
     598             :             }
     599           0 :             {   int m_test = z->l - z->c; /* test, line 146 */
     600           0 :                 if (in_grouping_b_U(z, g_vowel, 97, 305, 0)) return 0;
     601           0 :                 z->c = z->l - m_test;
     602             :             }
     603           0 :             z->c = z->l - m_test;
     604             :         }
     605             :     }
     606             : lab0:
     607           0 :     return 1;
     608             : }
     609             : 
     610           0 : static int r_mark_suffix_with_optional_y_consonant(struct SN_env * z) {
     611           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 155 */
     612           0 :         {   int m_test = z->l - z->c; /* test, line 154 */
     613           0 :             if (!(eq_s_b(z, 1, s_12))) goto lab1;
     614           0 :             z->c = z->l - m_test;
     615             :         }
     616           0 :         {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     617           0 :             if (ret < 0) goto lab1;
     618           0 :             z->c = ret; /* next, line 154 */
     619             :         }
     620           0 :         {   int m_test = z->l - z->c; /* test, line 154 */
     621           0 :             if (in_grouping_b_U(z, g_vowel, 97, 305, 0)) goto lab1;
     622           0 :             z->c = z->l - m_test;
     623             :         }
     624           0 :         goto lab0;
     625             :     lab1:
     626           0 :         z->c = z->l - m1;
     627           0 :         {   int m2 = z->l - z->c; (void)m2; /* not, line 156 */
     628           0 :             {   int m_test = z->l - z->c; /* test, line 156 */
     629           0 :                 if (!(eq_s_b(z, 1, s_13))) goto lab2;
     630           0 :                 z->c = z->l - m_test;
     631             :             }
     632           0 :             return 0;
     633             :         lab2:
     634           0 :             z->c = z->l - m2;
     635             :         }
     636           0 :         {   int m_test = z->l - z->c; /* test, line 156 */
     637           0 :             {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     638           0 :                 if (ret < 0) return 0;
     639           0 :                 z->c = ret; /* next, line 156 */
     640             :             }
     641           0 :             {   int m_test = z->l - z->c; /* test, line 156 */
     642           0 :                 if (in_grouping_b_U(z, g_vowel, 97, 305, 0)) return 0;
     643           0 :                 z->c = z->l - m_test;
     644             :             }
     645           0 :             z->c = z->l - m_test;
     646             :         }
     647             :     }
     648             : lab0:
     649           0 :     return 1;
     650             : }
     651             : 
     652           0 : static int r_mark_suffix_with_optional_U_vowel(struct SN_env * z) {
     653           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 161 */
     654           0 :         {   int m_test = z->l - z->c; /* test, line 160 */
     655           0 :             if (in_grouping_b_U(z, g_U, 105, 305, 0)) goto lab1;
     656           0 :             z->c = z->l - m_test;
     657             :         }
     658           0 :         {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     659           0 :             if (ret < 0) goto lab1;
     660           0 :             z->c = ret; /* next, line 160 */
     661             :         }
     662           0 :         {   int m_test = z->l - z->c; /* test, line 160 */
     663           0 :             if (out_grouping_b_U(z, g_vowel, 97, 305, 0)) goto lab1;
     664           0 :             z->c = z->l - m_test;
     665             :         }
     666           0 :         goto lab0;
     667             :     lab1:
     668           0 :         z->c = z->l - m1;
     669           0 :         {   int m2 = z->l - z->c; (void)m2; /* not, line 162 */
     670           0 :             {   int m_test = z->l - z->c; /* test, line 162 */
     671           0 :                 if (in_grouping_b_U(z, g_U, 105, 305, 0)) goto lab2;
     672           0 :                 z->c = z->l - m_test;
     673             :             }
     674           0 :             return 0;
     675             :         lab2:
     676           0 :             z->c = z->l - m2;
     677             :         }
     678           0 :         {   int m_test = z->l - z->c; /* test, line 162 */
     679           0 :             {   int ret = skip_utf8(z->p, z->c, z->lb, 0, -1);
     680           0 :                 if (ret < 0) return 0;
     681           0 :                 z->c = ret; /* next, line 162 */
     682             :             }
     683           0 :             {   int m_test = z->l - z->c; /* test, line 162 */
     684           0 :                 if (out_grouping_b_U(z, g_vowel, 97, 305, 0)) return 0;
     685           0 :                 z->c = z->l - m_test;
     686             :             }
     687           0 :             z->c = z->l - m_test;
     688             :         }
     689             :     }
     690             : lab0:
     691           0 :     return 1;
     692             : }
     693             : 
     694           0 : static int r_mark_possessives(struct SN_env * z) {
     695           0 :     if (z->c <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((67133440 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
     696           0 :     if (!(find_among_b(z, a_0, 10))) return 0; /* among, line 167 */
     697           0 :     {   int ret = r_mark_suffix_with_optional_U_vowel(z);
     698           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_U_vowel, line 169 */
     699           0 :         if (ret < 0) return ret;
     700             :     }
     701           0 :     return 1;
     702             : }
     703             : 
     704           0 : static int r_mark_sU(struct SN_env * z) {
     705           0 :     {   int ret = r_check_vowel_harmony(z);
     706           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 173 */
     707           0 :         if (ret < 0) return ret;
     708             :     }
     709           0 :     if (in_grouping_b_U(z, g_U, 105, 305, 0)) return 0;
     710           0 :     {   int ret = r_mark_suffix_with_optional_s_consonant(z);
     711           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_s_consonant, line 175 */
     712           0 :         if (ret < 0) return ret;
     713             :     }
     714           0 :     return 1;
     715             : }
     716             : 
     717           0 : static int r_mark_lArI(struct SN_env * z) {
     718           0 :     if (z->c - 3 <= z->lb || (z->p[z->c - 1] != 105 && z->p[z->c - 1] != 177)) return 0;
     719           0 :     if (!(find_among_b(z, a_1, 2))) return 0; /* among, line 179 */
     720           0 :     return 1;
     721             : }
     722             : 
     723           0 : static int r_mark_yU(struct SN_env * z) {
     724           0 :     {   int ret = r_check_vowel_harmony(z);
     725           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 183 */
     726           0 :         if (ret < 0) return ret;
     727             :     }
     728           0 :     if (in_grouping_b_U(z, g_U, 105, 305, 0)) return 0;
     729           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     730           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 185 */
     731           0 :         if (ret < 0) return ret;
     732             :     }
     733           0 :     return 1;
     734             : }
     735             : 
     736           0 : static int r_mark_nU(struct SN_env * z) {
     737           0 :     {   int ret = r_check_vowel_harmony(z);
     738           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 189 */
     739           0 :         if (ret < 0) return ret;
     740             :     }
     741           0 :     if (!(find_among_b(z, a_2, 4))) return 0; /* among, line 190 */
     742           0 :     return 1;
     743             : }
     744             : 
     745           0 : static int r_mark_nUn(struct SN_env * z) {
     746           0 :     {   int ret = r_check_vowel_harmony(z);
     747           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 194 */
     748           0 :         if (ret < 0) return ret;
     749             :     }
     750           0 :     if (z->c - 1 <= z->lb || z->p[z->c - 1] != 110) return 0;
     751           0 :     if (!(find_among_b(z, a_3, 4))) return 0; /* among, line 195 */
     752           0 :     {   int ret = r_mark_suffix_with_optional_n_consonant(z);
     753           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_n_consonant, line 196 */
     754           0 :         if (ret < 0) return ret;
     755             :     }
     756           0 :     return 1;
     757             : }
     758             : 
     759           0 : static int r_mark_yA(struct SN_env * z) {
     760           0 :     {   int ret = r_check_vowel_harmony(z);
     761           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 200 */
     762           0 :         if (ret < 0) return ret;
     763             :     }
     764           0 :     if (z->c <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     765           0 :     if (!(find_among_b(z, a_4, 2))) return 0; /* among, line 201 */
     766           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     767           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 202 */
     768           0 :         if (ret < 0) return ret;
     769             :     }
     770           0 :     return 1;
     771             : }
     772             : 
     773           0 : static int r_mark_nA(struct SN_env * z) {
     774           0 :     {   int ret = r_check_vowel_harmony(z);
     775           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 206 */
     776           0 :         if (ret < 0) return ret;
     777             :     }
     778           0 :     if (z->c - 1 <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     779           0 :     if (!(find_among_b(z, a_5, 2))) return 0; /* among, line 207 */
     780           0 :     return 1;
     781             : }
     782             : 
     783           0 : static int r_mark_DA(struct SN_env * z) {
     784           0 :     {   int ret = r_check_vowel_harmony(z);
     785           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 211 */
     786           0 :         if (ret < 0) return ret;
     787             :     }
     788           0 :     if (z->c - 1 <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     789           0 :     if (!(find_among_b(z, a_6, 4))) return 0; /* among, line 212 */
     790           0 :     return 1;
     791             : }
     792             : 
     793           0 : static int r_mark_ndA(struct SN_env * z) {
     794           0 :     {   int ret = r_check_vowel_harmony(z);
     795           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 216 */
     796           0 :         if (ret < 0) return ret;
     797             :     }
     798           0 :     if (z->c - 2 <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     799           0 :     if (!(find_among_b(z, a_7, 2))) return 0; /* among, line 217 */
     800           0 :     return 1;
     801             : }
     802             : 
     803           0 : static int r_mark_DAn(struct SN_env * z) {
     804           0 :     {   int ret = r_check_vowel_harmony(z);
     805           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 221 */
     806           0 :         if (ret < 0) return ret;
     807             :     }
     808           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] != 110) return 0;
     809           0 :     if (!(find_among_b(z, a_8, 4))) return 0; /* among, line 222 */
     810           0 :     return 1;
     811             : }
     812             : 
     813           0 : static int r_mark_ndAn(struct SN_env * z) {
     814           0 :     {   int ret = r_check_vowel_harmony(z);
     815           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 226 */
     816           0 :         if (ret < 0) return ret;
     817             :     }
     818           0 :     if (z->c - 3 <= z->lb || z->p[z->c - 1] != 110) return 0;
     819           0 :     if (!(find_among_b(z, a_9, 2))) return 0; /* among, line 227 */
     820           0 :     return 1;
     821             : }
     822             : 
     823           0 : static int r_mark_ylA(struct SN_env * z) {
     824           0 :     {   int ret = r_check_vowel_harmony(z);
     825           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 231 */
     826           0 :         if (ret < 0) return ret;
     827             :     }
     828           0 :     if (z->c - 1 <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     829           0 :     if (!(find_among_b(z, a_10, 2))) return 0; /* among, line 232 */
     830           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     831           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 233 */
     832           0 :         if (ret < 0) return ret;
     833             :     }
     834           0 :     return 1;
     835             : }
     836             : 
     837           0 : static int r_mark_ki(struct SN_env * z) {
     838           0 :     if (!(eq_s_b(z, 2, s_14))) return 0;
     839           0 :     return 1;
     840             : }
     841             : 
     842           0 : static int r_mark_ncA(struct SN_env * z) {
     843           0 :     {   int ret = r_check_vowel_harmony(z);
     844           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 241 */
     845           0 :         if (ret < 0) return ret;
     846             :     }
     847           0 :     if (z->c - 1 <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     848           0 :     if (!(find_among_b(z, a_11, 2))) return 0; /* among, line 242 */
     849           0 :     {   int ret = r_mark_suffix_with_optional_n_consonant(z);
     850           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_n_consonant, line 243 */
     851           0 :         if (ret < 0) return ret;
     852             :     }
     853           0 :     return 1;
     854             : }
     855             : 
     856           0 : static int r_mark_yUm(struct SN_env * z) {
     857           0 :     {   int ret = r_check_vowel_harmony(z);
     858           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 247 */
     859           0 :         if (ret < 0) return ret;
     860             :     }
     861           0 :     if (z->c - 1 <= z->lb || z->p[z->c - 1] != 109) return 0;
     862           0 :     if (!(find_among_b(z, a_12, 4))) return 0; /* among, line 248 */
     863           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     864           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 249 */
     865           0 :         if (ret < 0) return ret;
     866             :     }
     867           0 :     return 1;
     868             : }
     869             : 
     870           0 : static int r_mark_sUn(struct SN_env * z) {
     871           0 :     {   int ret = r_check_vowel_harmony(z);
     872           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 253 */
     873           0 :         if (ret < 0) return ret;
     874             :     }
     875           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] != 110) return 0;
     876           0 :     if (!(find_among_b(z, a_13, 4))) return 0; /* among, line 254 */
     877           0 :     return 1;
     878             : }
     879             : 
     880           0 : static int r_mark_yUz(struct SN_env * z) {
     881           0 :     {   int ret = r_check_vowel_harmony(z);
     882           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 258 */
     883           0 :         if (ret < 0) return ret;
     884             :     }
     885           0 :     if (z->c - 1 <= z->lb || z->p[z->c - 1] != 122) return 0;
     886           0 :     if (!(find_among_b(z, a_14, 4))) return 0; /* among, line 259 */
     887           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     888           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 260 */
     889           0 :         if (ret < 0) return ret;
     890             :     }
     891           0 :     return 1;
     892             : }
     893             : 
     894           0 : static int r_mark_sUnUz(struct SN_env * z) {
     895           0 :     if (z->c - 4 <= z->lb || z->p[z->c - 1] != 122) return 0;
     896           0 :     if (!(find_among_b(z, a_15, 4))) return 0; /* among, line 264 */
     897           0 :     return 1;
     898             : }
     899             : 
     900           0 : static int r_mark_lAr(struct SN_env * z) {
     901           0 :     {   int ret = r_check_vowel_harmony(z);
     902           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 268 */
     903           0 :         if (ret < 0) return ret;
     904             :     }
     905           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] != 114) return 0;
     906           0 :     if (!(find_among_b(z, a_16, 2))) return 0; /* among, line 269 */
     907           0 :     return 1;
     908             : }
     909             : 
     910           0 : static int r_mark_nUz(struct SN_env * z) {
     911           0 :     {   int ret = r_check_vowel_harmony(z);
     912           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 273 */
     913           0 :         if (ret < 0) return ret;
     914             :     }
     915           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] != 122) return 0;
     916           0 :     if (!(find_among_b(z, a_17, 4))) return 0; /* among, line 274 */
     917           0 :     return 1;
     918             : }
     919             : 
     920           0 : static int r_mark_DUr(struct SN_env * z) {
     921           0 :     {   int ret = r_check_vowel_harmony(z);
     922           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 278 */
     923           0 :         if (ret < 0) return ret;
     924             :     }
     925           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] != 114) return 0;
     926           0 :     if (!(find_among_b(z, a_18, 8))) return 0; /* among, line 279 */
     927           0 :     return 1;
     928             : }
     929             : 
     930           0 : static int r_mark_cAsInA(struct SN_env * z) {
     931           0 :     if (z->c - 5 <= z->lb || (z->p[z->c - 1] != 97 && z->p[z->c - 1] != 101)) return 0;
     932           0 :     if (!(find_among_b(z, a_19, 2))) return 0; /* among, line 283 */
     933           0 :     return 1;
     934             : }
     935             : 
     936           0 : static int r_mark_yDU(struct SN_env * z) {
     937           0 :     {   int ret = r_check_vowel_harmony(z);
     938           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 287 */
     939           0 :         if (ret < 0) return ret;
     940             :     }
     941           0 :     if (!(find_among_b(z, a_20, 32))) return 0; /* among, line 288 */
     942           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     943           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 292 */
     944           0 :         if (ret < 0) return ret;
     945             :     }
     946           0 :     return 1;
     947             : }
     948             : 
     949           0 : static int r_mark_ysA(struct SN_env * z) {
     950           0 :     if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((26658 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
     951           0 :     if (!(find_among_b(z, a_21, 8))) return 0; /* among, line 297 */
     952           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     953           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 298 */
     954           0 :         if (ret < 0) return ret;
     955             :     }
     956           0 :     return 1;
     957             : }
     958             : 
     959           0 : static int r_mark_ymUs_(struct SN_env * z) {
     960           0 :     {   int ret = r_check_vowel_harmony(z);
     961           0 :         if (ret == 0) return 0; /* call check_vowel_harmony, line 302 */
     962           0 :         if (ret < 0) return ret;
     963             :     }
     964           0 :     if (z->c - 3 <= z->lb || z->p[z->c - 1] != 159) return 0;
     965           0 :     if (!(find_among_b(z, a_22, 4))) return 0; /* among, line 303 */
     966           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     967           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 304 */
     968           0 :         if (ret < 0) return ret;
     969             :     }
     970           0 :     return 1;
     971             : }
     972             : 
     973           0 : static int r_mark_yken(struct SN_env * z) {
     974           0 :     if (!(eq_s_b(z, 3, s_15))) return 0;
     975           0 :     {   int ret = r_mark_suffix_with_optional_y_consonant(z);
     976           0 :         if (ret == 0) return 0; /* call mark_suffix_with_optional_y_consonant, line 308 */
     977           0 :         if (ret < 0) return ret;
     978             :     }
     979           0 :     return 1;
     980             : }
     981             : 
     982           0 : static int r_stem_nominal_verb_suffixes(struct SN_env * z) {
     983           0 :     z->ket = z->c; /* [, line 312 */
     984           0 :     z->B[0] = 1; /* set continue_stemming_noun_suffixes, line 313 */
     985           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 315 */
     986           0 :         {   int m2 = z->l - z->c; (void)m2; /* or, line 314 */
     987           0 :             {   int ret = r_mark_ymUs_(z);
     988           0 :                 if (ret == 0) goto lab3; /* call mark_ymUs_, line 314 */
     989           0 :                 if (ret < 0) return ret;
     990             :             }
     991           0 :             goto lab2;
     992             :         lab3:
     993           0 :             z->c = z->l - m2;
     994           0 :             {   int ret = r_mark_yDU(z);
     995           0 :                 if (ret == 0) goto lab4; /* call mark_yDU, line 314 */
     996           0 :                 if (ret < 0) return ret;
     997             :             }
     998           0 :             goto lab2;
     999             :         lab4:
    1000           0 :             z->c = z->l - m2;
    1001           0 :             {   int ret = r_mark_ysA(z);
    1002           0 :                 if (ret == 0) goto lab5; /* call mark_ysA, line 314 */
    1003           0 :                 if (ret < 0) return ret;
    1004             :             }
    1005           0 :             goto lab2;
    1006             :         lab5:
    1007           0 :             z->c = z->l - m2;
    1008           0 :             {   int ret = r_mark_yken(z);
    1009           0 :                 if (ret == 0) goto lab1; /* call mark_yken, line 314 */
    1010           0 :                 if (ret < 0) return ret;
    1011             :             }
    1012             :         }
    1013             :     lab2:
    1014           0 :         goto lab0;
    1015             :     lab1:
    1016           0 :         z->c = z->l - m1;
    1017           0 :         {   int ret = r_mark_cAsInA(z);
    1018           0 :             if (ret == 0) goto lab6; /* call mark_cAsInA, line 316 */
    1019           0 :             if (ret < 0) return ret;
    1020             :         }
    1021           0 :         {   int m3 = z->l - z->c; (void)m3; /* or, line 316 */
    1022           0 :             {   int ret = r_mark_sUnUz(z);
    1023           0 :                 if (ret == 0) goto lab8; /* call mark_sUnUz, line 316 */
    1024           0 :                 if (ret < 0) return ret;
    1025             :             }
    1026           0 :             goto lab7;
    1027             :         lab8:
    1028           0 :             z->c = z->l - m3;
    1029           0 :             {   int ret = r_mark_lAr(z);
    1030           0 :                 if (ret == 0) goto lab9; /* call mark_lAr, line 316 */
    1031           0 :                 if (ret < 0) return ret;
    1032             :             }
    1033           0 :             goto lab7;
    1034             :         lab9:
    1035           0 :             z->c = z->l - m3;
    1036           0 :             {   int ret = r_mark_yUm(z);
    1037           0 :                 if (ret == 0) goto lab10; /* call mark_yUm, line 316 */
    1038           0 :                 if (ret < 0) return ret;
    1039             :             }
    1040           0 :             goto lab7;
    1041             :         lab10:
    1042           0 :             z->c = z->l - m3;
    1043           0 :             {   int ret = r_mark_sUn(z);
    1044           0 :                 if (ret == 0) goto lab11; /* call mark_sUn, line 316 */
    1045           0 :                 if (ret < 0) return ret;
    1046             :             }
    1047           0 :             goto lab7;
    1048             :         lab11:
    1049           0 :             z->c = z->l - m3;
    1050           0 :             {   int ret = r_mark_yUz(z);
    1051           0 :                 if (ret == 0) goto lab12; /* call mark_yUz, line 316 */
    1052           0 :                 if (ret < 0) return ret;
    1053             :             }
    1054           0 :             goto lab7;
    1055             :         lab12:
    1056           0 :             z->c = z->l - m3;
    1057             :         }
    1058             :     lab7:
    1059           0 :         {   int ret = r_mark_ymUs_(z);
    1060           0 :             if (ret == 0) goto lab6; /* call mark_ymUs_, line 316 */
    1061           0 :             if (ret < 0) return ret;
    1062             :         }
    1063           0 :         goto lab0;
    1064             :     lab6:
    1065           0 :         z->c = z->l - m1;
    1066           0 :         {   int ret = r_mark_lAr(z);
    1067           0 :             if (ret == 0) goto lab13; /* call mark_lAr, line 319 */
    1068           0 :             if (ret < 0) return ret;
    1069             :         }
    1070           0 :         z->bra = z->c; /* ], line 319 */
    1071           0 :         {   int ret = slice_del(z); /* delete, line 319 */
    1072           0 :             if (ret < 0) return ret;
    1073             :         }
    1074           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 319 */
    1075           0 :             z->ket = z->c; /* [, line 319 */
    1076           0 :             {   int m4 = z->l - z->c; (void)m4; /* or, line 319 */
    1077           0 :                 {   int ret = r_mark_DUr(z);
    1078           0 :                     if (ret == 0) goto lab16; /* call mark_DUr, line 319 */
    1079           0 :                     if (ret < 0) return ret;
    1080             :                 }
    1081           0 :                 goto lab15;
    1082             :             lab16:
    1083           0 :                 z->c = z->l - m4;
    1084           0 :                 {   int ret = r_mark_yDU(z);
    1085           0 :                     if (ret == 0) goto lab17; /* call mark_yDU, line 319 */
    1086           0 :                     if (ret < 0) return ret;
    1087             :                 }
    1088           0 :                 goto lab15;
    1089             :             lab17:
    1090           0 :                 z->c = z->l - m4;
    1091           0 :                 {   int ret = r_mark_ysA(z);
    1092           0 :                     if (ret == 0) goto lab18; /* call mark_ysA, line 319 */
    1093           0 :                     if (ret < 0) return ret;
    1094             :                 }
    1095           0 :                 goto lab15;
    1096             :             lab18:
    1097           0 :                 z->c = z->l - m4;
    1098           0 :                 {   int ret = r_mark_ymUs_(z);
    1099           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab14; } /* call mark_ymUs_, line 319 */
    1100           0 :                     if (ret < 0) return ret;
    1101             :                 }
    1102             :             }
    1103             :         lab15:
    1104             :         lab14:
    1105             :             ;
    1106             :         }
    1107           0 :         z->B[0] = 0; /* unset continue_stemming_noun_suffixes, line 320 */
    1108           0 :         goto lab0;
    1109             :     lab13:
    1110           0 :         z->c = z->l - m1;
    1111           0 :         {   int ret = r_mark_nUz(z);
    1112           0 :             if (ret == 0) goto lab19; /* call mark_nUz, line 323 */
    1113           0 :             if (ret < 0) return ret;
    1114             :         }
    1115           0 :         {   int m5 = z->l - z->c; (void)m5; /* or, line 323 */
    1116           0 :             {   int ret = r_mark_yDU(z);
    1117           0 :                 if (ret == 0) goto lab21; /* call mark_yDU, line 323 */
    1118           0 :                 if (ret < 0) return ret;
    1119             :             }
    1120           0 :             goto lab20;
    1121             :         lab21:
    1122           0 :             z->c = z->l - m5;
    1123           0 :             {   int ret = r_mark_ysA(z);
    1124           0 :                 if (ret == 0) goto lab19; /* call mark_ysA, line 323 */
    1125           0 :                 if (ret < 0) return ret;
    1126             :             }
    1127             :         }
    1128             :     lab20:
    1129           0 :         goto lab0;
    1130             :     lab19:
    1131           0 :         z->c = z->l - m1;
    1132           0 :         {   int m6 = z->l - z->c; (void)m6; /* or, line 325 */
    1133           0 :             {   int ret = r_mark_sUnUz(z);
    1134           0 :                 if (ret == 0) goto lab24; /* call mark_sUnUz, line 325 */
    1135           0 :                 if (ret < 0) return ret;
    1136             :             }
    1137           0 :             goto lab23;
    1138             :         lab24:
    1139           0 :             z->c = z->l - m6;
    1140           0 :             {   int ret = r_mark_yUz(z);
    1141           0 :                 if (ret == 0) goto lab25; /* call mark_yUz, line 325 */
    1142           0 :                 if (ret < 0) return ret;
    1143             :             }
    1144           0 :             goto lab23;
    1145             :         lab25:
    1146           0 :             z->c = z->l - m6;
    1147           0 :             {   int ret = r_mark_sUn(z);
    1148           0 :                 if (ret == 0) goto lab26; /* call mark_sUn, line 325 */
    1149           0 :                 if (ret < 0) return ret;
    1150             :             }
    1151           0 :             goto lab23;
    1152             :         lab26:
    1153           0 :             z->c = z->l - m6;
    1154           0 :             {   int ret = r_mark_yUm(z);
    1155           0 :                 if (ret == 0) goto lab22; /* call mark_yUm, line 325 */
    1156           0 :                 if (ret < 0) return ret;
    1157             :             }
    1158             :         }
    1159             :     lab23:
    1160           0 :         z->bra = z->c; /* ], line 325 */
    1161           0 :         {   int ret = slice_del(z); /* delete, line 325 */
    1162           0 :             if (ret < 0) return ret;
    1163             :         }
    1164           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 325 */
    1165           0 :             z->ket = z->c; /* [, line 325 */
    1166           0 :             {   int ret = r_mark_ymUs_(z);
    1167           0 :                 if (ret == 0) { z->c = z->l - m_keep; goto lab27; } /* call mark_ymUs_, line 325 */
    1168           0 :                 if (ret < 0) return ret;
    1169             :             }
    1170             :         lab27:
    1171             :             ;
    1172             :         }
    1173           0 :         goto lab0;
    1174             :     lab22:
    1175           0 :         z->c = z->l - m1;
    1176           0 :         {   int ret = r_mark_DUr(z);
    1177           0 :             if (ret == 0) return 0; /* call mark_DUr, line 327 */
    1178           0 :             if (ret < 0) return ret;
    1179             :         }
    1180           0 :         z->bra = z->c; /* ], line 327 */
    1181           0 :         {   int ret = slice_del(z); /* delete, line 327 */
    1182           0 :             if (ret < 0) return ret;
    1183             :         }
    1184           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 327 */
    1185           0 :             z->ket = z->c; /* [, line 327 */
    1186           0 :             {   int m7 = z->l - z->c; (void)m7; /* or, line 327 */
    1187           0 :                 {   int ret = r_mark_sUnUz(z);
    1188           0 :                     if (ret == 0) goto lab30; /* call mark_sUnUz, line 327 */
    1189           0 :                     if (ret < 0) return ret;
    1190             :                 }
    1191           0 :                 goto lab29;
    1192             :             lab30:
    1193           0 :                 z->c = z->l - m7;
    1194           0 :                 {   int ret = r_mark_lAr(z);
    1195           0 :                     if (ret == 0) goto lab31; /* call mark_lAr, line 327 */
    1196           0 :                     if (ret < 0) return ret;
    1197             :                 }
    1198           0 :                 goto lab29;
    1199             :             lab31:
    1200           0 :                 z->c = z->l - m7;
    1201           0 :                 {   int ret = r_mark_yUm(z);
    1202           0 :                     if (ret == 0) goto lab32; /* call mark_yUm, line 327 */
    1203           0 :                     if (ret < 0) return ret;
    1204             :                 }
    1205           0 :                 goto lab29;
    1206             :             lab32:
    1207           0 :                 z->c = z->l - m7;
    1208           0 :                 {   int ret = r_mark_sUn(z);
    1209           0 :                     if (ret == 0) goto lab33; /* call mark_sUn, line 327 */
    1210           0 :                     if (ret < 0) return ret;
    1211             :                 }
    1212           0 :                 goto lab29;
    1213             :             lab33:
    1214           0 :                 z->c = z->l - m7;
    1215           0 :                 {   int ret = r_mark_yUz(z);
    1216           0 :                     if (ret == 0) goto lab34; /* call mark_yUz, line 327 */
    1217           0 :                     if (ret < 0) return ret;
    1218             :                 }
    1219           0 :                 goto lab29;
    1220             :             lab34:
    1221           0 :                 z->c = z->l - m7;
    1222             :             }
    1223             :         lab29:
    1224           0 :             {   int ret = r_mark_ymUs_(z);
    1225           0 :                 if (ret == 0) { z->c = z->l - m_keep; goto lab28; } /* call mark_ymUs_, line 327 */
    1226           0 :                 if (ret < 0) return ret;
    1227             :             }
    1228             :         lab28:
    1229             :             ;
    1230             :         }
    1231             :     }
    1232             : lab0:
    1233           0 :     z->bra = z->c; /* ], line 328 */
    1234           0 :     {   int ret = slice_del(z); /* delete, line 328 */
    1235           0 :         if (ret < 0) return ret;
    1236             :     }
    1237           0 :     return 1;
    1238             : }
    1239             : 
    1240           0 : static int r_stem_suffix_chain_before_ki(struct SN_env * z) {
    1241           0 :     z->ket = z->c; /* [, line 333 */
    1242           0 :     {   int ret = r_mark_ki(z);
    1243           0 :         if (ret == 0) return 0; /* call mark_ki, line 334 */
    1244           0 :         if (ret < 0) return ret;
    1245             :     }
    1246           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 342 */
    1247           0 :         {   int ret = r_mark_DA(z);
    1248           0 :             if (ret == 0) goto lab1; /* call mark_DA, line 336 */
    1249           0 :             if (ret < 0) return ret;
    1250             :         }
    1251           0 :         z->bra = z->c; /* ], line 336 */
    1252           0 :         {   int ret = slice_del(z); /* delete, line 336 */
    1253           0 :             if (ret < 0) return ret;
    1254             :         }
    1255           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 336 */
    1256           0 :             z->ket = z->c; /* [, line 336 */
    1257           0 :             {   int m2 = z->l - z->c; (void)m2; /* or, line 338 */
    1258           0 :                 {   int ret = r_mark_lAr(z);
    1259           0 :                     if (ret == 0) goto lab4; /* call mark_lAr, line 337 */
    1260           0 :                     if (ret < 0) return ret;
    1261             :                 }
    1262           0 :                 z->bra = z->c; /* ], line 337 */
    1263           0 :                 {   int ret = slice_del(z); /* delete, line 337 */
    1264           0 :                     if (ret < 0) return ret;
    1265             :                 }
    1266           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 337 */
    1267           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1268           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab5; } /* call stem_suffix_chain_before_ki, line 337 */
    1269           0 :                         if (ret < 0) return ret;
    1270             :                     }
    1271             :                 lab5:
    1272             :                     ;
    1273             :                 }
    1274           0 :                 goto lab3;
    1275             :             lab4:
    1276           0 :                 z->c = z->l - m2;
    1277           0 :                 {   int ret = r_mark_possessives(z);
    1278           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab2; } /* call mark_possessives, line 339 */
    1279           0 :                     if (ret < 0) return ret;
    1280             :                 }
    1281           0 :                 z->bra = z->c; /* ], line 339 */
    1282           0 :                 {   int ret = slice_del(z); /* delete, line 339 */
    1283           0 :                     if (ret < 0) return ret;
    1284             :                 }
    1285           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 339 */
    1286           0 :                     z->ket = z->c; /* [, line 339 */
    1287           0 :                     {   int ret = r_mark_lAr(z);
    1288           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab6; } /* call mark_lAr, line 339 */
    1289           0 :                         if (ret < 0) return ret;
    1290             :                     }
    1291           0 :                     z->bra = z->c; /* ], line 339 */
    1292           0 :                     {   int ret = slice_del(z); /* delete, line 339 */
    1293           0 :                         if (ret < 0) return ret;
    1294             :                     }
    1295           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1296           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab6; } /* call stem_suffix_chain_before_ki, line 339 */
    1297           0 :                         if (ret < 0) return ret;
    1298             :                     }
    1299             :                 lab6:
    1300             :                     ;
    1301             :                 }
    1302             :             }
    1303             :         lab3:
    1304             :         lab2:
    1305             :             ;
    1306             :         }
    1307           0 :         goto lab0;
    1308             :     lab1:
    1309           0 :         z->c = z->l - m1;
    1310           0 :         {   int ret = r_mark_nUn(z);
    1311           0 :             if (ret == 0) goto lab7; /* call mark_nUn, line 343 */
    1312           0 :             if (ret < 0) return ret;
    1313             :         }
    1314           0 :         z->bra = z->c; /* ], line 343 */
    1315           0 :         {   int ret = slice_del(z); /* delete, line 343 */
    1316           0 :             if (ret < 0) return ret;
    1317             :         }
    1318           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 343 */
    1319           0 :             z->ket = z->c; /* [, line 343 */
    1320           0 :             {   int m3 = z->l - z->c; (void)m3; /* or, line 345 */
    1321           0 :                 {   int ret = r_mark_lArI(z);
    1322           0 :                     if (ret == 0) goto lab10; /* call mark_lArI, line 344 */
    1323           0 :                     if (ret < 0) return ret;
    1324             :                 }
    1325           0 :                 z->bra = z->c; /* ], line 344 */
    1326           0 :                 {   int ret = slice_del(z); /* delete, line 344 */
    1327           0 :                     if (ret < 0) return ret;
    1328             :                 }
    1329           0 :                 goto lab9;
    1330             :             lab10:
    1331           0 :                 z->c = z->l - m3;
    1332           0 :                 z->ket = z->c; /* [, line 346 */
    1333           0 :                 {   int m4 = z->l - z->c; (void)m4; /* or, line 346 */
    1334           0 :                     {   int ret = r_mark_possessives(z);
    1335           0 :                         if (ret == 0) goto lab13; /* call mark_possessives, line 346 */
    1336           0 :                         if (ret < 0) return ret;
    1337             :                     }
    1338           0 :                     goto lab12;
    1339             :                 lab13:
    1340           0 :                     z->c = z->l - m4;
    1341           0 :                     {   int ret = r_mark_sU(z);
    1342           0 :                         if (ret == 0) goto lab11; /* call mark_sU, line 346 */
    1343           0 :                         if (ret < 0) return ret;
    1344             :                     }
    1345             :                 }
    1346             :             lab12:
    1347           0 :                 z->bra = z->c; /* ], line 346 */
    1348           0 :                 {   int ret = slice_del(z); /* delete, line 346 */
    1349           0 :                     if (ret < 0) return ret;
    1350             :                 }
    1351           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 346 */
    1352           0 :                     z->ket = z->c; /* [, line 346 */
    1353           0 :                     {   int ret = r_mark_lAr(z);
    1354           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab14; } /* call mark_lAr, line 346 */
    1355           0 :                         if (ret < 0) return ret;
    1356             :                     }
    1357           0 :                     z->bra = z->c; /* ], line 346 */
    1358           0 :                     {   int ret = slice_del(z); /* delete, line 346 */
    1359           0 :                         if (ret < 0) return ret;
    1360             :                     }
    1361           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1362           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab14; } /* call stem_suffix_chain_before_ki, line 346 */
    1363           0 :                         if (ret < 0) return ret;
    1364             :                     }
    1365             :                 lab14:
    1366             :                     ;
    1367             :                 }
    1368           0 :                 goto lab9;
    1369             :             lab11:
    1370           0 :                 z->c = z->l - m3;
    1371           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1372           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab8; } /* call stem_suffix_chain_before_ki, line 348 */
    1373           0 :                     if (ret < 0) return ret;
    1374             :                 }
    1375             :             }
    1376             :         lab9:
    1377             :         lab8:
    1378             :             ;
    1379             :         }
    1380           0 :         goto lab0;
    1381             :     lab7:
    1382           0 :         z->c = z->l - m1;
    1383           0 :         {   int ret = r_mark_ndA(z);
    1384           0 :             if (ret == 0) return 0; /* call mark_ndA, line 351 */
    1385           0 :             if (ret < 0) return ret;
    1386             :         }
    1387           0 :         {   int m5 = z->l - z->c; (void)m5; /* or, line 353 */
    1388           0 :             {   int ret = r_mark_lArI(z);
    1389           0 :                 if (ret == 0) goto lab16; /* call mark_lArI, line 352 */
    1390           0 :                 if (ret < 0) return ret;
    1391             :             }
    1392           0 :             z->bra = z->c; /* ], line 352 */
    1393           0 :             {   int ret = slice_del(z); /* delete, line 352 */
    1394           0 :                 if (ret < 0) return ret;
    1395             :             }
    1396           0 :             goto lab15;
    1397             :         lab16:
    1398           0 :             z->c = z->l - m5;
    1399           0 :             {   int ret = r_mark_sU(z);
    1400           0 :                 if (ret == 0) goto lab17; /* call mark_sU, line 354 */
    1401           0 :                 if (ret < 0) return ret;
    1402             :             }
    1403           0 :             z->bra = z->c; /* ], line 354 */
    1404           0 :             {   int ret = slice_del(z); /* delete, line 354 */
    1405           0 :                 if (ret < 0) return ret;
    1406             :             }
    1407           0 :             {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 354 */
    1408           0 :                 z->ket = z->c; /* [, line 354 */
    1409           0 :                 {   int ret = r_mark_lAr(z);
    1410           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab18; } /* call mark_lAr, line 354 */
    1411           0 :                     if (ret < 0) return ret;
    1412             :                 }
    1413           0 :                 z->bra = z->c; /* ], line 354 */
    1414           0 :                 {   int ret = slice_del(z); /* delete, line 354 */
    1415           0 :                     if (ret < 0) return ret;
    1416             :                 }
    1417           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1418           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab18; } /* call stem_suffix_chain_before_ki, line 354 */
    1419           0 :                     if (ret < 0) return ret;
    1420             :                 }
    1421             :             lab18:
    1422             :                 ;
    1423             :             }
    1424           0 :             goto lab15;
    1425             :         lab17:
    1426           0 :             z->c = z->l - m5;
    1427           0 :             {   int ret = r_stem_suffix_chain_before_ki(z);
    1428           0 :                 if (ret == 0) return 0; /* call stem_suffix_chain_before_ki, line 356 */
    1429           0 :                 if (ret < 0) return ret;
    1430             :             }
    1431             :         }
    1432             :     lab15:
    1433             :         ;
    1434             :     }
    1435             : lab0:
    1436           0 :     return 1;
    1437             : }
    1438             : 
    1439           0 : static int r_stem_noun_suffixes(struct SN_env * z) {
    1440           0 :     {   int m1 = z->l - z->c; (void)m1; /* or, line 363 */
    1441           0 :         z->ket = z->c; /* [, line 362 */
    1442           0 :         {   int ret = r_mark_lAr(z);
    1443           0 :             if (ret == 0) goto lab1; /* call mark_lAr, line 362 */
    1444           0 :             if (ret < 0) return ret;
    1445             :         }
    1446           0 :         z->bra = z->c; /* ], line 362 */
    1447           0 :         {   int ret = slice_del(z); /* delete, line 362 */
    1448           0 :             if (ret < 0) return ret;
    1449             :         }
    1450           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 362 */
    1451           0 :             {   int ret = r_stem_suffix_chain_before_ki(z);
    1452           0 :                 if (ret == 0) { z->c = z->l - m_keep; goto lab2; } /* call stem_suffix_chain_before_ki, line 362 */
    1453           0 :                 if (ret < 0) return ret;
    1454             :             }
    1455             :         lab2:
    1456             :             ;
    1457             :         }
    1458           0 :         goto lab0;
    1459             :     lab1:
    1460           0 :         z->c = z->l - m1;
    1461           0 :         z->ket = z->c; /* [, line 364 */
    1462           0 :         {   int ret = r_mark_ncA(z);
    1463           0 :             if (ret == 0) goto lab3; /* call mark_ncA, line 364 */
    1464           0 :             if (ret < 0) return ret;
    1465             :         }
    1466           0 :         z->bra = z->c; /* ], line 364 */
    1467           0 :         {   int ret = slice_del(z); /* delete, line 364 */
    1468           0 :             if (ret < 0) return ret;
    1469             :         }
    1470           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 365 */
    1471           0 :             {   int m2 = z->l - z->c; (void)m2; /* or, line 367 */
    1472           0 :                 z->ket = z->c; /* [, line 366 */
    1473           0 :                 {   int ret = r_mark_lArI(z);
    1474           0 :                     if (ret == 0) goto lab6; /* call mark_lArI, line 366 */
    1475           0 :                     if (ret < 0) return ret;
    1476             :                 }
    1477           0 :                 z->bra = z->c; /* ], line 366 */
    1478           0 :                 {   int ret = slice_del(z); /* delete, line 366 */
    1479           0 :                     if (ret < 0) return ret;
    1480             :                 }
    1481           0 :                 goto lab5;
    1482             :             lab6:
    1483           0 :                 z->c = z->l - m2;
    1484           0 :                 z->ket = z->c; /* [, line 368 */
    1485           0 :                 {   int m3 = z->l - z->c; (void)m3; /* or, line 368 */
    1486           0 :                     {   int ret = r_mark_possessives(z);
    1487           0 :                         if (ret == 0) goto lab9; /* call mark_possessives, line 368 */
    1488           0 :                         if (ret < 0) return ret;
    1489             :                     }
    1490           0 :                     goto lab8;
    1491             :                 lab9:
    1492           0 :                     z->c = z->l - m3;
    1493           0 :                     {   int ret = r_mark_sU(z);
    1494           0 :                         if (ret == 0) goto lab7; /* call mark_sU, line 368 */
    1495           0 :                         if (ret < 0) return ret;
    1496             :                     }
    1497             :                 }
    1498             :             lab8:
    1499           0 :                 z->bra = z->c; /* ], line 368 */
    1500           0 :                 {   int ret = slice_del(z); /* delete, line 368 */
    1501           0 :                     if (ret < 0) return ret;
    1502             :                 }
    1503           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 368 */
    1504           0 :                     z->ket = z->c; /* [, line 368 */
    1505           0 :                     {   int ret = r_mark_lAr(z);
    1506           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab10; } /* call mark_lAr, line 368 */
    1507           0 :                         if (ret < 0) return ret;
    1508             :                     }
    1509           0 :                     z->bra = z->c; /* ], line 368 */
    1510           0 :                     {   int ret = slice_del(z); /* delete, line 368 */
    1511           0 :                         if (ret < 0) return ret;
    1512             :                     }
    1513           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1514           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab10; } /* call stem_suffix_chain_before_ki, line 368 */
    1515           0 :                         if (ret < 0) return ret;
    1516             :                     }
    1517             :                 lab10:
    1518             :                     ;
    1519             :                 }
    1520           0 :                 goto lab5;
    1521             :             lab7:
    1522           0 :                 z->c = z->l - m2;
    1523           0 :                 z->ket = z->c; /* [, line 370 */
    1524           0 :                 {   int ret = r_mark_lAr(z);
    1525           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab4; } /* call mark_lAr, line 370 */
    1526           0 :                     if (ret < 0) return ret;
    1527             :                 }
    1528           0 :                 z->bra = z->c; /* ], line 370 */
    1529           0 :                 {   int ret = slice_del(z); /* delete, line 370 */
    1530           0 :                     if (ret < 0) return ret;
    1531             :                 }
    1532           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1533           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab4; } /* call stem_suffix_chain_before_ki, line 370 */
    1534           0 :                     if (ret < 0) return ret;
    1535             :                 }
    1536             :             }
    1537             :         lab5:
    1538             :         lab4:
    1539             :             ;
    1540             :         }
    1541           0 :         goto lab0;
    1542             :     lab3:
    1543           0 :         z->c = z->l - m1;
    1544           0 :         z->ket = z->c; /* [, line 374 */
    1545           0 :         {   int m4 = z->l - z->c; (void)m4; /* or, line 374 */
    1546           0 :             {   int ret = r_mark_ndA(z);
    1547           0 :                 if (ret == 0) goto lab13; /* call mark_ndA, line 374 */
    1548           0 :                 if (ret < 0) return ret;
    1549             :             }
    1550           0 :             goto lab12;
    1551             :         lab13:
    1552           0 :             z->c = z->l - m4;
    1553           0 :             {   int ret = r_mark_nA(z);
    1554           0 :                 if (ret == 0) goto lab11; /* call mark_nA, line 374 */
    1555           0 :                 if (ret < 0) return ret;
    1556             :             }
    1557             :         }
    1558             :     lab12:
    1559           0 :         {   int m5 = z->l - z->c; (void)m5; /* or, line 377 */
    1560           0 :             {   int ret = r_mark_lArI(z);
    1561           0 :                 if (ret == 0) goto lab15; /* call mark_lArI, line 376 */
    1562           0 :                 if (ret < 0) return ret;
    1563             :             }
    1564           0 :             z->bra = z->c; /* ], line 376 */
    1565           0 :             {   int ret = slice_del(z); /* delete, line 376 */
    1566           0 :                 if (ret < 0) return ret;
    1567             :             }
    1568           0 :             goto lab14;
    1569             :         lab15:
    1570           0 :             z->c = z->l - m5;
    1571           0 :             {   int ret = r_mark_sU(z);
    1572           0 :                 if (ret == 0) goto lab16; /* call mark_sU, line 378 */
    1573           0 :                 if (ret < 0) return ret;
    1574             :             }
    1575           0 :             z->bra = z->c; /* ], line 378 */
    1576           0 :             {   int ret = slice_del(z); /* delete, line 378 */
    1577           0 :                 if (ret < 0) return ret;
    1578             :             }
    1579           0 :             {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 378 */
    1580           0 :                 z->ket = z->c; /* [, line 378 */
    1581           0 :                 {   int ret = r_mark_lAr(z);
    1582           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab17; } /* call mark_lAr, line 378 */
    1583           0 :                     if (ret < 0) return ret;
    1584             :                 }
    1585           0 :                 z->bra = z->c; /* ], line 378 */
    1586           0 :                 {   int ret = slice_del(z); /* delete, line 378 */
    1587           0 :                     if (ret < 0) return ret;
    1588             :                 }
    1589           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1590           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab17; } /* call stem_suffix_chain_before_ki, line 378 */
    1591           0 :                     if (ret < 0) return ret;
    1592             :                 }
    1593             :             lab17:
    1594             :                 ;
    1595             :             }
    1596           0 :             goto lab14;
    1597             :         lab16:
    1598           0 :             z->c = z->l - m5;
    1599           0 :             {   int ret = r_stem_suffix_chain_before_ki(z);
    1600           0 :                 if (ret == 0) goto lab11; /* call stem_suffix_chain_before_ki, line 380 */
    1601           0 :                 if (ret < 0) return ret;
    1602             :             }
    1603             :         }
    1604             :     lab14:
    1605           0 :         goto lab0;
    1606             :     lab11:
    1607           0 :         z->c = z->l - m1;
    1608           0 :         z->ket = z->c; /* [, line 384 */
    1609           0 :         {   int m6 = z->l - z->c; (void)m6; /* or, line 384 */
    1610           0 :             {   int ret = r_mark_ndAn(z);
    1611           0 :                 if (ret == 0) goto lab20; /* call mark_ndAn, line 384 */
    1612           0 :                 if (ret < 0) return ret;
    1613             :             }
    1614           0 :             goto lab19;
    1615             :         lab20:
    1616           0 :             z->c = z->l - m6;
    1617           0 :             {   int ret = r_mark_nU(z);
    1618           0 :                 if (ret == 0) goto lab18; /* call mark_nU, line 384 */
    1619           0 :                 if (ret < 0) return ret;
    1620             :             }
    1621             :         }
    1622             :     lab19:
    1623           0 :         {   int m7 = z->l - z->c; (void)m7; /* or, line 384 */
    1624           0 :             {   int ret = r_mark_sU(z);
    1625           0 :                 if (ret == 0) goto lab22; /* call mark_sU, line 384 */
    1626           0 :                 if (ret < 0) return ret;
    1627             :             }
    1628           0 :             z->bra = z->c; /* ], line 384 */
    1629           0 :             {   int ret = slice_del(z); /* delete, line 384 */
    1630           0 :                 if (ret < 0) return ret;
    1631             :             }
    1632           0 :             {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 384 */
    1633           0 :                 z->ket = z->c; /* [, line 384 */
    1634           0 :                 {   int ret = r_mark_lAr(z);
    1635           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab23; } /* call mark_lAr, line 384 */
    1636           0 :                     if (ret < 0) return ret;
    1637             :                 }
    1638           0 :                 z->bra = z->c; /* ], line 384 */
    1639           0 :                 {   int ret = slice_del(z); /* delete, line 384 */
    1640           0 :                     if (ret < 0) return ret;
    1641             :                 }
    1642           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1643           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab23; } /* call stem_suffix_chain_before_ki, line 384 */
    1644           0 :                     if (ret < 0) return ret;
    1645             :                 }
    1646             :             lab23:
    1647             :                 ;
    1648             :             }
    1649           0 :             goto lab21;
    1650             :         lab22:
    1651           0 :             z->c = z->l - m7;
    1652           0 :             {   int ret = r_mark_lArI(z);
    1653           0 :                 if (ret == 0) goto lab18; /* call mark_lArI, line 384 */
    1654           0 :                 if (ret < 0) return ret;
    1655             :             }
    1656             :         }
    1657             :     lab21:
    1658           0 :         goto lab0;
    1659             :     lab18:
    1660           0 :         z->c = z->l - m1;
    1661           0 :         z->ket = z->c; /* [, line 386 */
    1662           0 :         {   int ret = r_mark_DAn(z);
    1663           0 :             if (ret == 0) goto lab24; /* call mark_DAn, line 386 */
    1664           0 :             if (ret < 0) return ret;
    1665             :         }
    1666           0 :         z->bra = z->c; /* ], line 386 */
    1667           0 :         {   int ret = slice_del(z); /* delete, line 386 */
    1668           0 :             if (ret < 0) return ret;
    1669             :         }
    1670           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 386 */
    1671           0 :             z->ket = z->c; /* [, line 386 */
    1672           0 :             {   int m8 = z->l - z->c; (void)m8; /* or, line 389 */
    1673           0 :                 {   int ret = r_mark_possessives(z);
    1674           0 :                     if (ret == 0) goto lab27; /* call mark_possessives, line 388 */
    1675           0 :                     if (ret < 0) return ret;
    1676             :                 }
    1677           0 :                 z->bra = z->c; /* ], line 388 */
    1678           0 :                 {   int ret = slice_del(z); /* delete, line 388 */
    1679           0 :                     if (ret < 0) return ret;
    1680             :                 }
    1681           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 388 */
    1682           0 :                     z->ket = z->c; /* [, line 388 */
    1683           0 :                     {   int ret = r_mark_lAr(z);
    1684           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab28; } /* call mark_lAr, line 388 */
    1685           0 :                         if (ret < 0) return ret;
    1686             :                     }
    1687           0 :                     z->bra = z->c; /* ], line 388 */
    1688           0 :                     {   int ret = slice_del(z); /* delete, line 388 */
    1689           0 :                         if (ret < 0) return ret;
    1690             :                     }
    1691           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1692           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab28; } /* call stem_suffix_chain_before_ki, line 388 */
    1693           0 :                         if (ret < 0) return ret;
    1694             :                     }
    1695             :                 lab28:
    1696             :                     ;
    1697             :                 }
    1698           0 :                 goto lab26;
    1699             :             lab27:
    1700           0 :                 z->c = z->l - m8;
    1701           0 :                 {   int ret = r_mark_lAr(z);
    1702           0 :                     if (ret == 0) goto lab29; /* call mark_lAr, line 390 */
    1703           0 :                     if (ret < 0) return ret;
    1704             :                 }
    1705           0 :                 z->bra = z->c; /* ], line 390 */
    1706           0 :                 {   int ret = slice_del(z); /* delete, line 390 */
    1707           0 :                     if (ret < 0) return ret;
    1708             :                 }
    1709           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 390 */
    1710           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1711           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab30; } /* call stem_suffix_chain_before_ki, line 390 */
    1712           0 :                         if (ret < 0) return ret;
    1713             :                     }
    1714             :                 lab30:
    1715             :                     ;
    1716             :                 }
    1717           0 :                 goto lab26;
    1718             :             lab29:
    1719           0 :                 z->c = z->l - m8;
    1720           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1721           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab25; } /* call stem_suffix_chain_before_ki, line 392 */
    1722           0 :                     if (ret < 0) return ret;
    1723             :                 }
    1724             :             }
    1725             :         lab26:
    1726             :         lab25:
    1727             :             ;
    1728             :         }
    1729           0 :         goto lab0;
    1730             :     lab24:
    1731           0 :         z->c = z->l - m1;
    1732           0 :         z->ket = z->c; /* [, line 396 */
    1733           0 :         {   int m9 = z->l - z->c; (void)m9; /* or, line 396 */
    1734           0 :             {   int ret = r_mark_nUn(z);
    1735           0 :                 if (ret == 0) goto lab33; /* call mark_nUn, line 396 */
    1736           0 :                 if (ret < 0) return ret;
    1737             :             }
    1738           0 :             goto lab32;
    1739             :         lab33:
    1740           0 :             z->c = z->l - m9;
    1741           0 :             {   int ret = r_mark_ylA(z);
    1742           0 :                 if (ret == 0) goto lab31; /* call mark_ylA, line 396 */
    1743           0 :                 if (ret < 0) return ret;
    1744             :             }
    1745             :         }
    1746             :     lab32:
    1747           0 :         z->bra = z->c; /* ], line 396 */
    1748           0 :         {   int ret = slice_del(z); /* delete, line 396 */
    1749           0 :             if (ret < 0) return ret;
    1750             :         }
    1751           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 397 */
    1752           0 :             {   int m10 = z->l - z->c; (void)m10; /* or, line 399 */
    1753           0 :                 z->ket = z->c; /* [, line 398 */
    1754           0 :                 {   int ret = r_mark_lAr(z);
    1755           0 :                     if (ret == 0) goto lab36; /* call mark_lAr, line 398 */
    1756           0 :                     if (ret < 0) return ret;
    1757             :                 }
    1758           0 :                 z->bra = z->c; /* ], line 398 */
    1759           0 :                 {   int ret = slice_del(z); /* delete, line 398 */
    1760           0 :                     if (ret < 0) return ret;
    1761             :                 }
    1762           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1763           0 :                     if (ret == 0) goto lab36; /* call stem_suffix_chain_before_ki, line 398 */
    1764           0 :                     if (ret < 0) return ret;
    1765             :                 }
    1766           0 :                 goto lab35;
    1767             :             lab36:
    1768           0 :                 z->c = z->l - m10;
    1769           0 :                 z->ket = z->c; /* [, line 400 */
    1770           0 :                 {   int m11 = z->l - z->c; (void)m11; /* or, line 400 */
    1771           0 :                     {   int ret = r_mark_possessives(z);
    1772           0 :                         if (ret == 0) goto lab39; /* call mark_possessives, line 400 */
    1773           0 :                         if (ret < 0) return ret;
    1774             :                     }
    1775           0 :                     goto lab38;
    1776             :                 lab39:
    1777           0 :                     z->c = z->l - m11;
    1778           0 :                     {   int ret = r_mark_sU(z);
    1779           0 :                         if (ret == 0) goto lab37; /* call mark_sU, line 400 */
    1780           0 :                         if (ret < 0) return ret;
    1781             :                     }
    1782             :                 }
    1783             :             lab38:
    1784           0 :                 z->bra = z->c; /* ], line 400 */
    1785           0 :                 {   int ret = slice_del(z); /* delete, line 400 */
    1786           0 :                     if (ret < 0) return ret;
    1787             :                 }
    1788           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 400 */
    1789           0 :                     z->ket = z->c; /* [, line 400 */
    1790           0 :                     {   int ret = r_mark_lAr(z);
    1791           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab40; } /* call mark_lAr, line 400 */
    1792           0 :                         if (ret < 0) return ret;
    1793             :                     }
    1794           0 :                     z->bra = z->c; /* ], line 400 */
    1795           0 :                     {   int ret = slice_del(z); /* delete, line 400 */
    1796           0 :                         if (ret < 0) return ret;
    1797             :                     }
    1798           0 :                     {   int ret = r_stem_suffix_chain_before_ki(z);
    1799           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab40; } /* call stem_suffix_chain_before_ki, line 400 */
    1800           0 :                         if (ret < 0) return ret;
    1801             :                     }
    1802             :                 lab40:
    1803             :                     ;
    1804             :                 }
    1805           0 :                 goto lab35;
    1806             :             lab37:
    1807           0 :                 z->c = z->l - m10;
    1808           0 :                 {   int ret = r_stem_suffix_chain_before_ki(z);
    1809           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab34; } /* call stem_suffix_chain_before_ki, line 402 */
    1810           0 :                     if (ret < 0) return ret;
    1811             :                 }
    1812             :             }
    1813             :         lab35:
    1814             :         lab34:
    1815             :             ;
    1816             :         }
    1817           0 :         goto lab0;
    1818             :     lab31:
    1819           0 :         z->c = z->l - m1;
    1820           0 :         z->ket = z->c; /* [, line 406 */
    1821           0 :         {   int ret = r_mark_lArI(z);
    1822           0 :             if (ret == 0) goto lab41; /* call mark_lArI, line 406 */
    1823           0 :             if (ret < 0) return ret;
    1824             :         }
    1825           0 :         z->bra = z->c; /* ], line 406 */
    1826           0 :         {   int ret = slice_del(z); /* delete, line 406 */
    1827           0 :             if (ret < 0) return ret;
    1828             :         }
    1829           0 :         goto lab0;
    1830             :     lab41:
    1831           0 :         z->c = z->l - m1;
    1832           0 :         {   int ret = r_stem_suffix_chain_before_ki(z);
    1833           0 :             if (ret == 0) goto lab42; /* call stem_suffix_chain_before_ki, line 408 */
    1834           0 :             if (ret < 0) return ret;
    1835             :         }
    1836           0 :         goto lab0;
    1837             :     lab42:
    1838           0 :         z->c = z->l - m1;
    1839           0 :         z->ket = z->c; /* [, line 410 */
    1840           0 :         {   int m12 = z->l - z->c; (void)m12; /* or, line 410 */
    1841           0 :             {   int ret = r_mark_DA(z);
    1842           0 :                 if (ret == 0) goto lab45; /* call mark_DA, line 410 */
    1843           0 :                 if (ret < 0) return ret;
    1844             :             }
    1845           0 :             goto lab44;
    1846             :         lab45:
    1847           0 :             z->c = z->l - m12;
    1848           0 :             {   int ret = r_mark_yU(z);
    1849           0 :                 if (ret == 0) goto lab46; /* call mark_yU, line 410 */
    1850           0 :                 if (ret < 0) return ret;
    1851             :             }
    1852           0 :             goto lab44;
    1853             :         lab46:
    1854           0 :             z->c = z->l - m12;
    1855           0 :             {   int ret = r_mark_yA(z);
    1856           0 :                 if (ret == 0) goto lab43; /* call mark_yA, line 410 */
    1857           0 :                 if (ret < 0) return ret;
    1858             :             }
    1859             :         }
    1860             :     lab44:
    1861           0 :         z->bra = z->c; /* ], line 410 */
    1862           0 :         {   int ret = slice_del(z); /* delete, line 410 */
    1863           0 :             if (ret < 0) return ret;
    1864             :         }
    1865           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 410 */
    1866           0 :             z->ket = z->c; /* [, line 410 */
    1867           0 :             {   int m13 = z->l - z->c; (void)m13; /* or, line 410 */
    1868           0 :                 {   int ret = r_mark_possessives(z);
    1869           0 :                     if (ret == 0) goto lab49; /* call mark_possessives, line 410 */
    1870           0 :                     if (ret < 0) return ret;
    1871             :                 }
    1872           0 :                 z->bra = z->c; /* ], line 410 */
    1873           0 :                 {   int ret = slice_del(z); /* delete, line 410 */
    1874           0 :                     if (ret < 0) return ret;
    1875             :                 }
    1876           0 :                 {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 410 */
    1877           0 :                     z->ket = z->c; /* [, line 410 */
    1878           0 :                     {   int ret = r_mark_lAr(z);
    1879           0 :                         if (ret == 0) { z->c = z->l - m_keep; goto lab50; } /* call mark_lAr, line 410 */
    1880           0 :                         if (ret < 0) return ret;
    1881             :                     }
    1882             :                 lab50:
    1883             :                     ;
    1884             :                 }
    1885           0 :                 goto lab48;
    1886             :             lab49:
    1887           0 :                 z->c = z->l - m13;
    1888           0 :                 {   int ret = r_mark_lAr(z);
    1889           0 :                     if (ret == 0) { z->c = z->l - m_keep; goto lab47; } /* call mark_lAr, line 410 */
    1890           0 :                     if (ret < 0) return ret;
    1891             :                 }
    1892             :             }
    1893             :         lab48:
    1894           0 :             z->bra = z->c; /* ], line 410 */
    1895           0 :             {   int ret = slice_del(z); /* delete, line 410 */
    1896           0 :                 if (ret < 0) return ret;
    1897             :             }
    1898           0 :             z->ket = z->c; /* [, line 410 */
    1899           0 :             {   int ret = r_stem_suffix_chain_before_ki(z);
    1900           0 :                 if (ret == 0) { z->c = z->l - m_keep; goto lab47; } /* call stem_suffix_chain_before_ki, line 410 */
    1901           0 :                 if (ret < 0) return ret;
    1902             :             }
    1903             :         lab47:
    1904             :             ;
    1905             :         }
    1906           0 :         goto lab0;
    1907             :     lab43:
    1908           0 :         z->c = z->l - m1;
    1909           0 :         z->ket = z->c; /* [, line 412 */
    1910           0 :         {   int m14 = z->l - z->c; (void)m14; /* or, line 412 */
    1911           0 :             {   int ret = r_mark_possessives(z);
    1912           0 :                 if (ret == 0) goto lab52; /* call mark_possessives, line 412 */
    1913           0 :                 if (ret < 0) return ret;
    1914             :             }
    1915           0 :             goto lab51;
    1916             :         lab52:
    1917           0 :             z->c = z->l - m14;
    1918           0 :             {   int ret = r_mark_sU(z);
    1919           0 :                 if (ret == 0) return 0; /* call mark_sU, line 412 */
    1920           0 :                 if (ret < 0) return ret;
    1921             :             }
    1922             :         }
    1923             :     lab51:
    1924           0 :         z->bra = z->c; /* ], line 412 */
    1925           0 :         {   int ret = slice_del(z); /* delete, line 412 */
    1926           0 :             if (ret < 0) return ret;
    1927             :         }
    1928           0 :         {   int m_keep = z->l - z->c;/* (void) m_keep;*/ /* try, line 412 */
    1929           0 :             z->ket = z->c; /* [, line 412 */
    1930           0 :             {   int ret = r_mark_lAr(z);
    1931           0 :                 if (ret == 0) { z->c = z->l - m_keep; goto lab53; } /* call mark_lAr, line 412 */
    1932           0 :                 if (ret < 0) return ret;
    1933             :             }
    1934           0 :             z->bra = z->c; /* ], line 412 */
    1935           0 :             {   int ret = slice_del(z); /* delete, line 412 */
    1936           0 :                 if (ret < 0) return ret;
    1937             :             }
    1938           0 :             {   int ret = r_stem_suffix_chain_before_ki(z);
    1939           0 :                 if (ret == 0) { z->c = z->l - m_keep; goto lab53; } /* call stem_suffix_chain_before_ki, line 412 */
    1940           0 :                 if (ret < 0) return ret;
    1941             :             }
    1942             :         lab53:
    1943             :             ;
    1944             :         }
    1945             :     }
    1946             : lab0:
    1947           0 :     return 1;
    1948             : }
    1949             : 
    1950           0 : static int r_post_process_last_consonants(struct SN_env * z) {
    1951             :     int among_var;
    1952           0 :     z->ket = z->c; /* [, line 416 */
    1953           0 :     among_var = find_among_b(z, a_23, 4); /* substring, line 416 */
    1954           0 :     if (!(among_var)) return 0;
    1955           0 :     z->bra = z->c; /* ], line 416 */
    1956           0 :     switch(among_var) {
    1957           0 :         case 0: return 0;
    1958             :         case 1:
    1959           0 :             {   int ret = slice_from_s(z, 1, s_16); /* <-, line 417 */
    1960           0 :                 if (ret < 0) return ret;
    1961             :             }
    1962           0 :             break;
    1963             :         case 2:
    1964           0 :             {   int ret = slice_from_s(z, 2, s_17); /* <-, line 418 */
    1965           0 :                 if (ret < 0) return ret;
    1966             :             }
    1967           0 :             break;
    1968             :         case 3:
    1969           0 :             {   int ret = slice_from_s(z, 1, s_18); /* <-, line 419 */
    1970           0 :                 if (ret < 0) return ret;
    1971             :             }
    1972           0 :             break;
    1973             :         case 4:
    1974           0 :             {   int ret = slice_from_s(z, 1, s_19); /* <-, line 420 */
    1975           0 :                 if (ret < 0) return ret;
    1976             :             }
    1977           0 :             break;
    1978             :     }
    1979           0 :     return 1;
    1980             : }
    1981             : 
    1982           0 : static int r_append_U_to_stems_ending_with_d_or_g(struct SN_env * z) {
    1983           0 :     {   int m_test = z->l - z->c; /* test, line 431 */
    1984           0 :         {   int m1 = z->l - z->c; (void)m1; /* or, line 431 */
    1985           0 :             if (!(eq_s_b(z, 1, s_20))) goto lab1;
    1986           0 :             goto lab0;
    1987             :         lab1:
    1988           0 :             z->c = z->l - m1;
    1989           0 :             if (!(eq_s_b(z, 1, s_21))) return 0;
    1990             :         }
    1991             :     lab0:
    1992           0 :         z->c = z->l - m_test;
    1993             :     }
    1994           0 :     {   int m2 = z->l - z->c; (void)m2; /* or, line 433 */
    1995           0 :         {   int m_test = z->l - z->c; /* test, line 432 */
    1996           0 :             if (out_grouping_b_U(z, g_vowel, 97, 305, 1) < 0) goto lab3; /* goto */ /* grouping vowel, line 432 */
    1997           0 :             {   int m3 = z->l - z->c; (void)m3; /* or, line 432 */
    1998           0 :                 if (!(eq_s_b(z, 1, s_22))) goto lab5;
    1999           0 :                 goto lab4;
    2000             :             lab5:
    2001           0 :                 z->c = z->l - m3;
    2002           0 :                 if (!(eq_s_b(z, 2, s_23))) goto lab3;
    2003             :             }
    2004             :         lab4:
    2005           0 :             z->c = z->l - m_test;
    2006             :         }
    2007           0 :         {   int c_keep = z->c;
    2008           0 :             int ret = insert_s(z, z->c, z->c, 2, s_24); /* <+, line 432 */
    2009           0 :             z->c = c_keep;
    2010           0 :             if (ret < 0) return ret;
    2011             :         }
    2012           0 :         goto lab2;
    2013             :     lab3:
    2014           0 :         z->c = z->l - m2;
    2015           0 :         {   int m_test = z->l - z->c; /* test, line 434 */
    2016           0 :             if (out_grouping_b_U(z, g_vowel, 97, 305, 1) < 0) goto lab6; /* goto */ /* grouping vowel, line 434 */
    2017           0 :             {   int m4 = z->l - z->c; (void)m4; /* or, line 434 */
    2018           0 :                 if (!(eq_s_b(z, 1, s_25))) goto lab8;
    2019           0 :                 goto lab7;
    2020             :             lab8:
    2021           0 :                 z->c = z->l - m4;
    2022           0 :                 if (!(eq_s_b(z, 1, s_26))) goto lab6;
    2023             :             }
    2024             :         lab7:
    2025           0 :             z->c = z->l - m_test;
    2026             :         }
    2027           0 :         {   int c_keep = z->c;
    2028           0 :             int ret = insert_s(z, z->c, z->c, 1, s_27); /* <+, line 434 */
    2029           0 :             z->c = c_keep;
    2030           0 :             if (ret < 0) return ret;
    2031             :         }
    2032           0 :         goto lab2;
    2033             :     lab6:
    2034           0 :         z->c = z->l - m2;
    2035           0 :         {   int m_test = z->l - z->c; /* test, line 436 */
    2036           0 :             if (out_grouping_b_U(z, g_vowel, 97, 305, 1) < 0) goto lab9; /* goto */ /* grouping vowel, line 436 */
    2037           0 :             {   int m5 = z->l - z->c; (void)m5; /* or, line 436 */
    2038           0 :                 if (!(eq_s_b(z, 1, s_28))) goto lab11;
    2039           0 :                 goto lab10;
    2040             :             lab11:
    2041           0 :                 z->c = z->l - m5;
    2042           0 :                 if (!(eq_s_b(z, 1, s_29))) goto lab9;
    2043             :             }
    2044             :         lab10:
    2045           0 :             z->c = z->l - m_test;
    2046             :         }
    2047           0 :         {   int c_keep = z->c;
    2048           0 :             int ret = insert_s(z, z->c, z->c, 1, s_30); /* <+, line 436 */
    2049           0 :             z->c = c_keep;
    2050           0 :             if (ret < 0) return ret;
    2051             :         }
    2052           0 :         goto lab2;
    2053             :     lab9:
    2054           0 :         z->c = z->l - m2;
    2055           0 :         {   int m_test = z->l - z->c; /* test, line 438 */
    2056           0 :             if (out_grouping_b_U(z, g_vowel, 97, 305, 1) < 0) return 0; /* goto */ /* grouping vowel, line 438 */
    2057           0 :             {   int m6 = z->l - z->c; (void)m6; /* or, line 438 */
    2058           0 :                 if (!(eq_s_b(z, 2, s_31))) goto lab13;
    2059           0 :                 goto lab12;
    2060             :             lab13:
    2061           0 :                 z->c = z->l - m6;
    2062           0 :                 if (!(eq_s_b(z, 2, s_32))) return 0;
    2063             :             }
    2064             :         lab12:
    2065           0 :             z->c = z->l - m_test;
    2066             :         }
    2067           0 :         {   int c_keep = z->c;
    2068           0 :             int ret = insert_s(z, z->c, z->c, 2, s_33); /* <+, line 438 */
    2069           0 :             z->c = c_keep;
    2070           0 :             if (ret < 0) return ret;
    2071             :         }
    2072             :     }
    2073             : lab2:
    2074           0 :     return 1;
    2075             : }
    2076             : 
    2077           0 : static int r_more_than_one_syllable_word(struct SN_env * z) {
    2078           0 :     {   int c_test = z->c; /* test, line 446 */
    2079           0 :         {   int i = 2;
    2080             :             while(1) { /* atleast, line 446 */
    2081           0 :                 int c1 = z->c;
    2082             :                 {    /* gopast */ /* grouping vowel, line 446 */
    2083           0 :                     int ret = out_grouping_U(z, g_vowel, 97, 305, 1);
    2084           0 :                     if (ret < 0) goto lab0;
    2085           0 :                     z->c += ret;
    2086             :                 }
    2087           0 :                 i--;
    2088           0 :                 continue;
    2089             :             lab0:
    2090           0 :                 z->c = c1;
    2091           0 :                 break;
    2092           0 :             }
    2093           0 :             if (i > 0) return 0;
    2094             :         }
    2095           0 :         z->c = c_test;
    2096             :     }
    2097           0 :     return 1;
    2098             : }
    2099             : 
    2100           0 : static int r_is_reserved_word(struct SN_env * z) {
    2101           0 :     {   int c1 = z->c; /* or, line 451 */
    2102           0 :         {   int c_test = z->c; /* test, line 450 */
    2103             :             while(1) { /* gopast, line 450 */
    2104           0 :                 if (!(eq_s(z, 2, s_34))) goto lab2;
    2105           0 :                 break;
    2106             :             lab2:
    2107           0 :                 {   int ret = skip_utf8(z->p, z->c, 0, z->l, 1);
    2108           0 :                     if (ret < 0) goto lab1;
    2109           0 :                     z->c = ret; /* gopast, line 450 */
    2110             :                 }
    2111           0 :             }
    2112           0 :             z->I[0] = 2;
    2113           0 :             if (!(z->I[0] == z->l)) goto lab1;
    2114           0 :             z->c = c_test;
    2115             :         }
    2116           0 :         goto lab0;
    2117             :     lab1:
    2118           0 :         z->c = c1;
    2119           0 :         {   int c_test = z->c; /* test, line 452 */
    2120             :             while(1) { /* gopast, line 452 */
    2121           0 :                 if (!(eq_s(z, 5, s_35))) goto lab3;
    2122           0 :                 break;
    2123             :             lab3:
    2124           0 :                 {   int ret = skip_utf8(z->p, z->c, 0, z->l, 1);
    2125           0 :                     if (ret < 0) return 0;
    2126           0 :                     z->c = ret; /* gopast, line 452 */
    2127             :                 }
    2128           0 :             }
    2129           0 :             z->I[0] = 5;
    2130           0 :             if (!(z->I[0] == z->l)) return 0;
    2131           0 :             z->c = c_test;
    2132             :         }
    2133             :     }
    2134             : lab0:
    2135           0 :     return 1;
    2136             : }
    2137             : 
    2138           0 : static int r_postlude(struct SN_env * z) {
    2139           0 :     {   int c1 = z->c; /* not, line 456 */
    2140           0 :         {   int ret = r_is_reserved_word(z);
    2141           0 :             if (ret == 0) goto lab0; /* call is_reserved_word, line 456 */
    2142           0 :             if (ret < 0) return ret;
    2143             :         }
    2144           0 :         return 0;
    2145             :     lab0:
    2146           0 :         z->c = c1;
    2147             :     }
    2148           0 :     z->lb = z->c; z->c = z->l; /* backwards, line 457 */
    2149             : 
    2150           0 :     {   int m2 = z->l - z->c; (void)m2; /* do, line 458 */
    2151           0 :         {   int ret = r_append_U_to_stems_ending_with_d_or_g(z);
    2152           0 :             if (ret == 0) goto lab1; /* call append_U_to_stems_ending_with_d_or_g, line 458 */
    2153           0 :             if (ret < 0) return ret;
    2154             :         }
    2155             :     lab1:
    2156           0 :         z->c = z->l - m2;
    2157             :     }
    2158           0 :     {   int m3 = z->l - z->c; (void)m3; /* do, line 459 */
    2159           0 :         {   int ret = r_post_process_last_consonants(z);
    2160           0 :             if (ret == 0) goto lab2; /* call post_process_last_consonants, line 459 */
    2161           0 :             if (ret < 0) return ret;
    2162             :         }
    2163             :     lab2:
    2164           0 :         z->c = z->l - m3;
    2165             :     }
    2166           0 :     z->c = z->lb;
    2167           0 :     return 1;
    2168             : }
    2169             : 
    2170           0 : extern int turkish_UTF_8_stem(struct SN_env * z) {
    2171           0 :     {   int ret = r_more_than_one_syllable_word(z);
    2172           0 :         if (ret == 0) return 0; /* call more_than_one_syllable_word, line 465 */
    2173           0 :         if (ret < 0) return ret;
    2174             :     }
    2175           0 :     z->lb = z->c; z->c = z->l; /* backwards, line 467 */
    2176             : 
    2177           0 :     {   int m1 = z->l - z->c; (void)m1; /* do, line 468 */
    2178           0 :         {   int ret = r_stem_nominal_verb_suffixes(z);
    2179           0 :             if (ret == 0) goto lab0; /* call stem_nominal_verb_suffixes, line 468 */
    2180           0 :             if (ret < 0) return ret;
    2181             :         }
    2182             :     lab0:
    2183           0 :         z->c = z->l - m1;
    2184             :     }
    2185           0 :     if (!(z->B[0])) return 0; /* Boolean test continue_stemming_noun_suffixes, line 469 */
    2186           0 :     {   int m2 = z->l - z->c; (void)m2; /* do, line 470 */
    2187           0 :         {   int ret = r_stem_noun_suffixes(z);
    2188           0 :             if (ret == 0) goto lab1; /* call stem_noun_suffixes, line 470 */
    2189           0 :             if (ret < 0) return ret;
    2190             :         }
    2191             :     lab1:
    2192           0 :         z->c = z->l - m2;
    2193             :     }
    2194           0 :     z->c = z->lb;
    2195           0 :     {   int ret = r_postlude(z);
    2196           0 :         if (ret == 0) return 0; /* call postlude, line 473 */
    2197           0 :         if (ret < 0) return ret;
    2198             :     }
    2199           0 :     return 1;
    2200             : }
    2201             : 
    2202           0 : extern struct SN_env * turkish_UTF_8_create_env(void) { return SN_create_env(0, 1, 1); }
    2203             : 
    2204           0 : extern void turkish_UTF_8_close_env(struct SN_env * z) { SN_close_env(z, 0); }
    2205             : 

Generated by: LCOV version 1.11