Plan 9 from Bell Labs’s /usr/web/sources/contrib/steve/root/sys/src/cmd/seft/stem_context_rules.i

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


/**************************************************************************
 *
 *  Context-sensitive rules associated with certain endings.
 *
 *  The notations of the rules are the same as in Lovins' paper
 *  except that rule A is replaced by a NULL in the data structure.
 *
 *  Function parameters:
 *      - stem_length: possible stem length
 *      - end        : pointer points to the end of the possible stem.
 *
 *************************************************************************/
 

//#include "string_wrapper.h"

#include <string.h>

/********* Context-sensitive rule function declarations ******************/
 
static int B();		static int C();
static int D();		static int E();
static int F();		static int G();
static int H();		static int I();
static int J();		static int K();
static int L();		static int M();
static int N();		static int O();
static int P();		static int Q();
static int R();		static int S();
static int T();		static int U();
static int V();		static int W();
static int X();		static int Y();
static int Z();		static int AA();
static int BB();	static int CC();

static int B(stem_length, end)
int stem_length;
char *end;
{
    return (stem_length >= 3);
}

static int C(stem_length, end)
int stem_length;
char *end;
{
    return (stem_length >= 4);
}
 
static int D(stem_length, end)
int stem_length;
char *end;
{
    return (stem_length >= 5);
}
 
static int E(stem_length, end)
int stem_length;
char *end;
{
    return (*end != 'e');
}
 
static int F(stem_length, end)
int stem_length;
char *end;
{
    return ((stem_length >= 3) && (*end != 'e'));
}
 
static int G(stem_length, end)
int stem_length;
char *end;
{
    return ((stem_length >= 3) && (*end == 'f'));
}
 
static int H(stem_length, end)
int stem_length;
char *end;
{
    char p1, p2;
    p1 = *end;
    p2 = *(end-1);
    return ((p1 == 't') || ((p1 == 'l') && (p2 == 'l')));
}
 
static int I(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
    return ((p1 != 'o') && (p1 != 'e'));
}
 
static int J(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
    return ((p1 != 'a') && (p1 != 'e'));
}

static int K(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
    return ((stem_length >= 3) &&
           ((p1 == 'l') || (p1 == 'i') ||
           ((p1 == 'e') && (*(end-2) == 'u'))));
}
 
static int L(stem_length, end)
int stem_length;
char *end;
{
    char p1, p2;
    p1 = *end;
    p2 = *(end-1);
    if (p1 == 's')
        return (p2 == 'o');
    else
        return ((p1 != 'u') && (p1 != 'x'));
}
 
static int M(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
    return ((p1 != 'a') && (p1 != 'c') &&
            (p1 != 'e') && (p1 != 'm'));
}
 
static int N(stem_length, end)
int stem_length;
char *end;
{
    if (stem_length >= 3)
    {
        if (*(end-2) == 's')
            return (stem_length >= 4);
        else
            return 1;
    }
    else
       return 0;
}
 
static int O(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
    return ((p1 == 'l') || (p1 == 'i'));
}
 
static int P(stem_length, end)
int stem_length;
char *end;
{
    return (*end != 'c');
}
 
static int Q(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
 
    return ((stem_length >= 3) && (p1 != 'l') && (p1 != 'n'));
}
 
static int R(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
    return ((p1 == 'n') || (p1 == 'r'));
}
 
static int S(stem_length, end)
int stem_length;
char *end;
{
    char p1,p2;
    p1 = *end;
    p2 = *(end-1);
 
    if (p1 == 't')
        return (p2 != 't');
    else
        return ((p1 == 'r') && (p2 == 'd'));
}
 
static int T(stem_length, end)
int stem_length;
char *end;
{
    char p1,p2;
    p1 = *end;
    p2 = *(end-1);
 
    if (p1 == 't')
        return (p2 != 'o');
    else
        return (p1 == 's');
}
 
static int U(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
 
    return ((p1 == 'l') || (p1 == 'm') ||
            (p1 == 'n') || (p1 == 'r'));
}
 
static int V(stem_length, end)
int stem_length;
char *end;
{
    return (*end == 'c');
}
 
static int W(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
 
    return ((p1 != 's') && (p1 != 'u'));
}
 
static int X(stem_length, end)
int stem_length;
char *end;
{
    char p1;
    p1 = *end;
 
    if (p1 == 'e')
        return ((stem_length >= 3) && (*(end-2) == 'u'));
    else
        return ((p1 == 'l') || (p1 == 'i'));
}
 
static int Y(stem_length, end)
int stem_length;
char *end;
{
    return ((*end == 'n') && (*(end-1) == 'i'));
}
 
static int Z(stem_length, end)
int stem_length;
char *end;
{
    return (*end != 'f');
}
 
static int AA(stem_length, end)
int stem_length;
char *end;
{
    char p1, p2;
    p1 = *end;
    p2 = *(end-1);
 
    if (p1 == 'h')
        return ((p2 == 'p') || (p2 == 't'));
    else if (p1 == 'r')
        return ((p2 == 'e') || (p2 == 'o'));
    else if (p1 == 's')
        return (p2 == 'e');
    else
        return ((p1 == 'd') || (p1 == 'f') ||
                (p1 == 'l') || (p1 == 't'));
}
 
static int BB(stem_length, end)
int stem_length;
char *end;
{
    if (stem_length >= 3)
    {   if (stem_length >= 4)
            return (strncmp(end-3,"ryst",4) != 0);
        else
            return (strncmp(end-2,"met",3) != 0);
    }
    else
       return 0;
}
 
static int CC(stem_length, end)
int stem_length;
char *end;
{
    return (*end == 'l');
}


Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to webmaster@9p.io.