LCOV - code coverage report
Current view: top level - src/backend/snowball/libstemmer - stem_UTF_8_porter.c (source / functions) Coverage Total Hit
Test: PostgreSQL 19devel Lines: 0.0 % 368 0
Test Date: 2026-02-28 04:14:42 Functions: 0.0 % 14 0
Legend: Lines:     hit not hit

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

Generated by: LCOV version 2.0-1