LCOV - code coverage report
Current view: top level - src/backend/snowball/libstemmer - stem_ISO_8859_1_porter.c (source / functions) Hit Total Coverage
Test: PostgreSQL 19devel Lines: 0 364 0.0 %
Date: 2026-02-02 14:17:46 Functions: 0 14 0.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_ISO_8859_1_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_ISO_8859_1_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(z, g_v_WXY, 89, 121, 0)) return 0;
     217           0 :     if (in_grouping_b(z, g_v, 97, 121, 0)) return 0;
     218           0 :     return !out_grouping_b(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(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             :             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           0 :                     if (z->c <= z->lb) return 0;
     309           0 :                     z->c--;
     310           0 :                     z->bra = z->c;
     311             :                     {
     312           0 :                         int ret = slice_del(z);
     313           0 :                         if (ret < 0) return ret;
     314             :                     }
     315           0 :                     break;
     316           0 :                 case 3:
     317           0 :                     if (z->c != ((SN_local *)z)->i_p1) return 0;
     318             :                     {
     319           0 :                         int v_3 = z->l - z->c;
     320             :                         {
     321           0 :                             int ret = r_shortv(z);
     322           0 :                             if (ret <= 0) return ret;
     323             :                         }
     324           0 :                         z->c = z->l - v_3;
     325             :                     }
     326             :                     {
     327           0 :                         int saved_c = z->c;
     328           0 :                         int ret = insert_s(z, z->c, z->c, 1, s_4);
     329           0 :                         z->c = saved_c;
     330           0 :                         if (ret < 0) return ret;
     331             :                     }
     332           0 :                     break;
     333             :             }
     334           0 :             break;
     335             :     }
     336           0 :     return 1;
     337             : }
     338             : 
     339           0 : static int r_Step_1c(struct SN_env * z) {
     340           0 :     z->ket = z->c;
     341             :     do {
     342           0 :         int v_1 = z->l - z->c;
     343           0 :         if (z->c <= z->lb || z->p[z->c - 1] != 'y') goto lab0;
     344           0 :         z->c--;
     345           0 :         break;
     346           0 :     lab0:
     347           0 :         z->c = z->l - v_1;
     348           0 :         if (z->c <= z->lb || z->p[z->c - 1] != 'Y') return 0;
     349           0 :         z->c--;
     350             :     } while (0);
     351           0 :     z->bra = z->c;
     352             :     {
     353           0 :         int ret = out_grouping_b(z, g_v, 97, 121, 1);
     354           0 :         if (ret < 0) return 0;
     355           0 :         z->c -= ret;
     356             :     }
     357             :     {
     358           0 :         int ret = slice_from_s(z, 1, s_5);
     359           0 :         if (ret < 0) return ret;
     360             :     }
     361           0 :     return 1;
     362             : }
     363             : 
     364           0 : static int r_Step_2(struct SN_env * z) {
     365             :     int among_var;
     366           0 :     z->ket = z->c;
     367           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((815616 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
     368           0 :     among_var = find_among_b(z, a_3, 20, 0);
     369           0 :     if (!among_var) return 0;
     370           0 :     z->bra = z->c;
     371             :     {
     372           0 :         int ret = r_R1(z);
     373           0 :         if (ret <= 0) return ret;
     374             :     }
     375           0 :     switch (among_var) {
     376           0 :         case 1:
     377             :             {
     378           0 :                 int ret = slice_from_s(z, 4, s_6);
     379           0 :                 if (ret < 0) return ret;
     380             :             }
     381           0 :             break;
     382           0 :         case 2:
     383             :             {
     384           0 :                 int ret = slice_from_s(z, 4, s_7);
     385           0 :                 if (ret < 0) return ret;
     386             :             }
     387           0 :             break;
     388           0 :         case 3:
     389             :             {
     390           0 :                 int ret = slice_from_s(z, 4, s_8);
     391           0 :                 if (ret < 0) return ret;
     392             :             }
     393           0 :             break;
     394           0 :         case 4:
     395             :             {
     396           0 :                 int ret = slice_from_s(z, 4, s_9);
     397           0 :                 if (ret < 0) return ret;
     398             :             }
     399           0 :             break;
     400           0 :         case 5:
     401             :             {
     402           0 :                 int ret = slice_from_s(z, 3, s_10);
     403           0 :                 if (ret < 0) return ret;
     404             :             }
     405           0 :             break;
     406           0 :         case 6:
     407             :             {
     408           0 :                 int ret = slice_from_s(z, 1, s_11);
     409           0 :                 if (ret < 0) return ret;
     410             :             }
     411           0 :             break;
     412           0 :         case 7:
     413             :             {
     414           0 :                 int ret = slice_from_s(z, 3, s_12);
     415           0 :                 if (ret < 0) return ret;
     416             :             }
     417           0 :             break;
     418           0 :         case 8:
     419             :             {
     420           0 :                 int ret = slice_from_s(z, 3, s_13);
     421           0 :                 if (ret < 0) return ret;
     422             :             }
     423           0 :             break;
     424           0 :         case 9:
     425             :             {
     426           0 :                 int ret = slice_from_s(z, 2, s_14);
     427           0 :                 if (ret < 0) return ret;
     428             :             }
     429           0 :             break;
     430           0 :         case 10:
     431             :             {
     432           0 :                 int ret = slice_from_s(z, 3, s_15);
     433           0 :                 if (ret < 0) return ret;
     434             :             }
     435           0 :             break;
     436           0 :         case 11:
     437             :             {
     438           0 :                 int ret = slice_from_s(z, 3, s_16);
     439           0 :                 if (ret < 0) return ret;
     440             :             }
     441           0 :             break;
     442           0 :         case 12:
     443             :             {
     444           0 :                 int ret = slice_from_s(z, 3, s_17);
     445           0 :                 if (ret < 0) return ret;
     446             :             }
     447           0 :             break;
     448           0 :         case 13:
     449             :             {
     450           0 :                 int ret = slice_from_s(z, 3, s_18);
     451           0 :                 if (ret < 0) return ret;
     452             :             }
     453           0 :             break;
     454             :     }
     455           0 :     return 1;
     456             : }
     457             : 
     458           0 : static int r_Step_3(struct SN_env * z) {
     459             :     int among_var;
     460           0 :     z->ket = z->c;
     461           0 :     if (z->c - 2 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((528928 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
     462           0 :     among_var = find_among_b(z, a_4, 7, 0);
     463           0 :     if (!among_var) return 0;
     464           0 :     z->bra = z->c;
     465             :     {
     466           0 :         int ret = r_R1(z);
     467           0 :         if (ret <= 0) return ret;
     468             :     }
     469           0 :     switch (among_var) {
     470           0 :         case 1:
     471             :             {
     472           0 :                 int ret = slice_from_s(z, 2, s_19);
     473           0 :                 if (ret < 0) return ret;
     474             :             }
     475           0 :             break;
     476           0 :         case 2:
     477             :             {
     478           0 :                 int ret = slice_from_s(z, 2, s_20);
     479           0 :                 if (ret < 0) return ret;
     480             :             }
     481           0 :             break;
     482           0 :         case 3:
     483             :             {
     484           0 :                 int ret = slice_del(z);
     485           0 :                 if (ret < 0) return ret;
     486             :             }
     487           0 :             break;
     488             :     }
     489           0 :     return 1;
     490             : }
     491             : 
     492           0 : static int r_Step_4(struct SN_env * z) {
     493             :     int among_var;
     494           0 :     z->ket = z->c;
     495           0 :     if (z->c - 1 <= z->lb || z->p[z->c - 1] >> 5 != 3 || !((3961384 >> (z->p[z->c - 1] & 0x1f)) & 1)) return 0;
     496           0 :     among_var = find_among_b(z, a_5, 19, 0);
     497           0 :     if (!among_var) return 0;
     498           0 :     z->bra = z->c;
     499             :     {
     500           0 :         int ret = r_R2(z);
     501           0 :         if (ret <= 0) return ret;
     502             :     }
     503           0 :     switch (among_var) {
     504           0 :         case 1:
     505             :             {
     506           0 :                 int ret = slice_del(z);
     507           0 :                 if (ret < 0) return ret;
     508             :             }
     509           0 :             break;
     510           0 :         case 2:
     511             :             do {
     512           0 :                 int v_1 = z->l - z->c;
     513           0 :                 if (z->c <= z->lb || z->p[z->c - 1] != 's') goto lab0;
     514           0 :                 z->c--;
     515           0 :                 break;
     516           0 :             lab0:
     517           0 :                 z->c = z->l - v_1;
     518           0 :                 if (z->c <= z->lb || z->p[z->c - 1] != 't') return 0;
     519           0 :                 z->c--;
     520             :             } while (0);
     521             :             {
     522           0 :                 int ret = slice_del(z);
     523           0 :                 if (ret < 0) return ret;
     524             :             }
     525           0 :             break;
     526             :     }
     527           0 :     return 1;
     528             : }
     529             : 
     530           0 : static int r_Step_5a(struct SN_env * z) {
     531           0 :     z->ket = z->c;
     532           0 :     if (z->c <= z->lb || z->p[z->c - 1] != 'e') return 0;
     533           0 :     z->c--;
     534           0 :     z->bra = z->c;
     535             :     do {
     536             :         {
     537           0 :             int ret = r_R2(z);
     538           0 :             if (ret == 0) goto lab0;
     539           0 :             if (ret < 0) return ret;
     540             :         }
     541           0 :         break;
     542           0 :     lab0:
     543             :         {
     544           0 :             int ret = r_R1(z);
     545           0 :             if (ret <= 0) return ret;
     546             :         }
     547             :         {
     548           0 :             int v_1 = z->l - z->c;
     549             :             {
     550           0 :                 int ret = r_shortv(z);
     551           0 :                 if (ret == 0) goto lab1;
     552           0 :                 if (ret < 0) return ret;
     553             :             }
     554           0 :             return 0;
     555           0 :         lab1:
     556           0 :             z->c = z->l - v_1;
     557             :         }
     558             :     } while (0);
     559             :     {
     560           0 :         int ret = slice_del(z);
     561           0 :         if (ret < 0) return ret;
     562             :     }
     563           0 :     return 1;
     564             : }
     565             : 
     566           0 : static int r_Step_5b(struct SN_env * z) {
     567           0 :     z->ket = z->c;
     568           0 :     if (z->c <= z->lb || z->p[z->c - 1] != 'l') return 0;
     569           0 :     z->c--;
     570           0 :     z->bra = z->c;
     571             :     {
     572           0 :         int ret = r_R2(z);
     573           0 :         if (ret <= 0) return ret;
     574             :     }
     575           0 :     if (z->c <= z->lb || z->p[z->c - 1] != 'l') return 0;
     576           0 :     z->c--;
     577             :     {
     578           0 :         int ret = slice_del(z);
     579           0 :         if (ret < 0) return ret;
     580             :     }
     581           0 :     return 1;
     582             : }
     583             : 
     584           0 : extern int porter_ISO_8859_1_stem(struct SN_env * z) {
     585             :     int b_Y_found;
     586           0 :     b_Y_found = 0;
     587             :     {
     588           0 :         int v_1 = z->c;
     589           0 :         z->bra = z->c;
     590           0 :         if (z->c == z->l || z->p[z->c] != 'y') goto lab0;
     591           0 :         z->c++;
     592           0 :         z->ket = z->c;
     593             :         {
     594           0 :             int ret = slice_from_s(z, 1, s_21);
     595           0 :             if (ret < 0) return ret;
     596             :         }
     597           0 :         b_Y_found = 1;
     598           0 :     lab0:
     599           0 :         z->c = v_1;
     600             :     }
     601             :     {
     602           0 :         int v_2 = z->c;
     603           0 :         while (1) {
     604           0 :             int v_3 = z->c;
     605           0 :             while (1) {
     606           0 :                 int v_4 = z->c;
     607           0 :                 if (in_grouping(z, g_v, 97, 121, 0)) goto lab3;
     608           0 :                 z->bra = z->c;
     609           0 :                 if (z->c == z->l || z->p[z->c] != 'y') goto lab3;
     610           0 :                 z->c++;
     611           0 :                 z->ket = z->c;
     612           0 :                 z->c = v_4;
     613           0 :                 break;
     614           0 :             lab3:
     615           0 :                 z->c = v_4;
     616           0 :                 if (z->c >= z->l) goto lab2;
     617           0 :                 z->c++;
     618             :             }
     619             :             {
     620           0 :                 int ret = slice_from_s(z, 1, s_22);
     621           0 :                 if (ret < 0) return ret;
     622             :             }
     623           0 :             b_Y_found = 1;
     624           0 :             continue;
     625           0 :         lab2:
     626           0 :             z->c = v_3;
     627           0 :             break;
     628             :         }
     629           0 :         z->c = v_2;
     630             :     }
     631           0 :     ((SN_local *)z)->i_p1 = z->l;
     632           0 :     ((SN_local *)z)->i_p2 = z->l;
     633             :     {
     634           0 :         int v_5 = z->c;
     635             :         {
     636           0 :             int ret = out_grouping(z, g_v, 97, 121, 1);
     637           0 :             if (ret < 0) goto lab4;
     638           0 :             z->c += ret;
     639             :         }
     640             :         {
     641           0 :             int ret = in_grouping(z, g_v, 97, 121, 1);
     642           0 :             if (ret < 0) goto lab4;
     643           0 :             z->c += ret;
     644             :         }
     645           0 :         ((SN_local *)z)->i_p1 = z->c;
     646             :         {
     647           0 :             int ret = out_grouping(z, g_v, 97, 121, 1);
     648           0 :             if (ret < 0) goto lab4;
     649           0 :             z->c += ret;
     650             :         }
     651             :         {
     652           0 :             int ret = in_grouping(z, g_v, 97, 121, 1);
     653           0 :             if (ret < 0) goto lab4;
     654           0 :             z->c += ret;
     655             :         }
     656           0 :         ((SN_local *)z)->i_p2 = z->c;
     657           0 :     lab4:
     658           0 :         z->c = v_5;
     659             :     }
     660           0 :     z->lb = z->c; z->c = z->l;
     661             :     {
     662           0 :         int v_6 = z->l - z->c;
     663             :         {
     664           0 :             int ret = r_Step_1a(z);
     665           0 :             if (ret < 0) return ret;
     666             :         }
     667           0 :         z->c = z->l - v_6;
     668             :     }
     669             :     {
     670           0 :         int v_7 = z->l - z->c;
     671             :         {
     672           0 :             int ret = r_Step_1b(z);
     673           0 :             if (ret < 0) return ret;
     674             :         }
     675           0 :         z->c = z->l - v_7;
     676             :     }
     677             :     {
     678           0 :         int v_8 = z->l - z->c;
     679             :         {
     680           0 :             int ret = r_Step_1c(z);
     681           0 :             if (ret < 0) return ret;
     682             :         }
     683           0 :         z->c = z->l - v_8;
     684             :     }
     685             :     {
     686           0 :         int v_9 = z->l - z->c;
     687             :         {
     688           0 :             int ret = r_Step_2(z);
     689           0 :             if (ret < 0) return ret;
     690             :         }
     691           0 :         z->c = z->l - v_9;
     692             :     }
     693             :     {
     694           0 :         int v_10 = z->l - z->c;
     695             :         {
     696           0 :             int ret = r_Step_3(z);
     697           0 :             if (ret < 0) return ret;
     698             :         }
     699           0 :         z->c = z->l - v_10;
     700             :     }
     701             :     {
     702           0 :         int v_11 = z->l - z->c;
     703             :         {
     704           0 :             int ret = r_Step_4(z);
     705           0 :             if (ret < 0) return ret;
     706             :         }
     707           0 :         z->c = z->l - v_11;
     708             :     }
     709             :     {
     710           0 :         int v_12 = z->l - z->c;
     711             :         {
     712           0 :             int ret = r_Step_5a(z);
     713           0 :             if (ret < 0) return ret;
     714             :         }
     715           0 :         z->c = z->l - v_12;
     716             :     }
     717             :     {
     718           0 :         int v_13 = z->l - z->c;
     719             :         {
     720           0 :             int ret = r_Step_5b(z);
     721           0 :             if (ret < 0) return ret;
     722             :         }
     723           0 :         z->c = z->l - v_13;
     724             :     }
     725           0 :     z->c = z->lb;
     726             :     {
     727           0 :         int v_14 = z->c;
     728           0 :         if (!b_Y_found) goto lab5;
     729           0 :         while (1) {
     730           0 :             int v_15 = z->c;
     731           0 :             while (1) {
     732           0 :                 int v_16 = z->c;
     733           0 :                 z->bra = z->c;
     734           0 :                 if (z->c == z->l || z->p[z->c] != 'Y') goto lab7;
     735           0 :                 z->c++;
     736           0 :                 z->ket = z->c;
     737           0 :                 z->c = v_16;
     738           0 :                 break;
     739           0 :             lab7:
     740           0 :                 z->c = v_16;
     741           0 :                 if (z->c >= z->l) goto lab6;
     742           0 :                 z->c++;
     743             :             }
     744             :             {
     745           0 :                 int ret = slice_from_s(z, 1, s_23);
     746           0 :                 if (ret < 0) return ret;
     747             :             }
     748           0 :             continue;
     749           0 :         lab6:
     750           0 :             z->c = v_15;
     751           0 :             break;
     752             :         }
     753           0 :     lab5:
     754           0 :         z->c = v_14;
     755             :     }
     756           0 :     return 1;
     757             : }
     758             : 
     759           0 : extern struct SN_env * porter_ISO_8859_1_create_env(void) {
     760           0 :     struct SN_env * z = SN_new_env(sizeof(SN_local));
     761           0 :     if (z) {
     762           0 :         ((SN_local *)z)->i_p2 = 0;
     763           0 :         ((SN_local *)z)->i_p1 = 0;
     764             :     }
     765           0 :     return z;
     766             : }
     767             : 
     768           0 : extern void porter_ISO_8859_1_close_env(struct SN_env * z) {
     769           0 :     SN_delete_env(z);
     770           0 : }
     771             : 

Generated by: LCOV version 1.16