Header And Logo

PostgreSQL
| The world's most advanced open source database.

Functions

stem_ISO_8859_1_portuguese.h File Reference

This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Functions

struct SN_envportuguese_ISO_8859_1_create_env (void)
void portuguese_ISO_8859_1_close_env (struct SN_env *z)
int portuguese_ISO_8859_1_stem (struct SN_env *z)

Function Documentation

void portuguese_ISO_8859_1_close_env ( struct SN_env z  ) 

Definition at line 1016 of file stem_ISO_8859_1_portuguese.c.

References SN_close_env().

{ SN_close_env(z, 0); }

struct SN_env* portuguese_ISO_8859_1_create_env ( void   )  [read]

Definition at line 1014 of file stem_ISO_8859_1_portuguese.c.

References SN_create_env().

{ return SN_create_env(0, 3, 0); }

int portuguese_ISO_8859_1_stem ( struct SN_env z  ) 

Definition at line 926 of file stem_ISO_8859_1_portuguese.c.

References SN_env::bra, SN_env::c, eq_s_b(), SN_env::ket, SN_env::l, SN_env::lb, r_mark_regions(), r_postlude(), r_prelude(), r_residual_form(), r_residual_suffix(), r_RV(), r_standard_suffix(), r_verb_suffix(), s_16, s_17, and slice_del().

                                                         {
    {   int c1 = z->c; /* do, line 202 */
        {   int ret = r_prelude(z);
            if (ret == 0) goto lab0; /* call prelude, line 202 */
            if (ret < 0) return ret;
        }
    lab0:
        z->c = c1;
    }
    {   int c2 = z->c; /* do, line 203 */
        {   int ret = r_mark_regions(z);
            if (ret == 0) goto lab1; /* call mark_regions, line 203 */
            if (ret < 0) return ret;
        }
    lab1:
        z->c = c2;
    }
    z->lb = z->c; z->c = z->l; /* backwards, line 204 */

    {   int m3 = z->l - z->c; (void)m3; /* do, line 205 */
        {   int m4 = z->l - z->c; (void)m4; /* or, line 209 */
            {   int m5 = z->l - z->c; (void)m5; /* and, line 207 */
                {   int m6 = z->l - z->c; (void)m6; /* or, line 206 */
                    {   int ret = r_standard_suffix(z);
                        if (ret == 0) goto lab6; /* call standard_suffix, line 206 */
                        if (ret < 0) return ret;
                    }
                    goto lab5;
                lab6:
                    z->c = z->l - m6;
                    {   int ret = r_verb_suffix(z);
                        if (ret == 0) goto lab4; /* call verb_suffix, line 206 */
                        if (ret < 0) return ret;
                    }
                }
            lab5:
                z->c = z->l - m5;
                {   int m7 = z->l - z->c; (void)m7; /* do, line 207 */
                    z->ket = z->c; /* [, line 207 */
                    if (!(eq_s_b(z, 1, s_16))) goto lab7;
                    z->bra = z->c; /* ], line 207 */
                    {   int m_test = z->l - z->c; /* test, line 207 */
                        if (!(eq_s_b(z, 1, s_17))) goto lab7;
                        z->c = z->l - m_test;
                    }
                    {   int ret = r_RV(z);
                        if (ret == 0) goto lab7; /* call RV, line 207 */
                        if (ret < 0) return ret;
                    }
                    {   int ret = slice_del(z); /* delete, line 207 */
                        if (ret < 0) return ret;
                    }
                lab7:
                    z->c = z->l - m7;
                }
            }
            goto lab3;
        lab4:
            z->c = z->l - m4;
            {   int ret = r_residual_suffix(z);
                if (ret == 0) goto lab2; /* call residual_suffix, line 209 */
                if (ret < 0) return ret;
            }
        }
    lab3:
    lab2:
        z->c = z->l - m3;
    }
    {   int m8 = z->l - z->c; (void)m8; /* do, line 211 */
        {   int ret = r_residual_form(z);
            if (ret == 0) goto lab8; /* call residual_form, line 211 */
            if (ret < 0) return ret;
        }
    lab8:
        z->c = z->l - m8;
    }
    z->c = z->lb;
    {   int c9 = z->c; /* do, line 213 */
        {   int ret = r_postlude(z);
            if (ret == 0) goto lab9; /* call postlude, line 213 */
            if (ret < 0) return ret;
        }
    lab9:
        z->c = c9;
    }
    return 1;
}