// This file was generated automatically by the Snowball to Java compiler
package org.tartarus.snowball.ext;
import org.tartarus.snowball.Among;
import org.tartarus.snowball.SnowballProgram;
This class was automatically generated by a Snowball to Java compiler
It implements the stemming algorithm defined by a snowball script.
/**
* This class was automatically generated by a Snowball to Java compiler
* It implements the stemming algorithm defined by a snowball script.
*/
@SuppressWarnings("unused") public class LovinsStemmer extends SnowballProgram {
private static final long serialVersionUID = 1L;
/* patched */ private static final java.lang.invoke.MethodHandles.Lookup methodObject = java.lang.invoke.MethodHandles.lookup();
private final static Among a_0[] = {
new Among ( "d", -1, -1, "", methodObject ),
new Among ( "f", -1, -1, "", methodObject ),
new Among ( "ph", -1, -1, "", methodObject ),
new Among ( "th", -1, -1, "", methodObject ),
new Among ( "l", -1, -1, "", methodObject ),
new Among ( "er", -1, -1, "", methodObject ),
new Among ( "or", -1, -1, "", methodObject ),
new Among ( "es", -1, -1, "", methodObject ),
new Among ( "t", -1, -1, "", methodObject )
};
private final static Among a_1[] = {
new Among ( "s'", -1, 1, "r_A", methodObject ),
new Among ( "a", -1, 1, "r_A", methodObject ),
new Among ( "ia", 1, 1, "r_A", methodObject ),
new Among ( "ata", 1, 1, "r_A", methodObject ),
new Among ( "ic", -1, 1, "r_A", methodObject ),
new Among ( "aic", 4, 1, "r_A", methodObject ),
new Among ( "allic", 4, 1, "r_BB", methodObject ),
new Among ( "aric", 4, 1, "r_A", methodObject ),
new Among ( "atic", 4, 1, "r_B", methodObject ),
new Among ( "itic", 4, 1, "r_H", methodObject ),
new Among ( "antic", 4, 1, "r_C", methodObject ),
new Among ( "istic", 4, 1, "r_A", methodObject ),
new Among ( "alistic", 11, 1, "r_B", methodObject ),
new Among ( "aristic", 11, 1, "r_A", methodObject ),
new Among ( "ivistic", 11, 1, "r_A", methodObject ),
new Among ( "ed", -1, 1, "r_E", methodObject ),
new Among ( "anced", 15, 1, "r_B", methodObject ),
new Among ( "enced", 15, 1, "r_A", methodObject ),
new Among ( "ished", 15, 1, "r_A", methodObject ),
new Among ( "ied", 15, 1, "r_A", methodObject ),
new Among ( "ened", 15, 1, "r_E", methodObject ),
new Among ( "ioned", 15, 1, "r_A", methodObject ),
new Among ( "ated", 15, 1, "r_I", methodObject ),
new Among ( "ented", 15, 1, "r_C", methodObject ),
new Among ( "ized", 15, 1, "r_F", methodObject ),
new Among ( "arized", 24, 1, "r_A", methodObject ),
new Among ( "oid", -1, 1, "r_A", methodObject ),
new Among ( "aroid", 26, 1, "r_A", methodObject ),
new Among ( "hood", -1, 1, "r_A", methodObject ),
new Among ( "ehood", 28, 1, "r_A", methodObject ),
new Among ( "ihood", 28, 1, "r_A", methodObject ),
new Among ( "elihood", 30, 1, "r_E", methodObject ),
new Among ( "ward", -1, 1, "r_A", methodObject ),
new Among ( "e", -1, 1, "r_A", methodObject ),
new Among ( "ae", 33, 1, "r_A", methodObject ),
new Among ( "ance", 33, 1, "r_B", methodObject ),
new Among ( "icance", 35, 1, "r_A", methodObject ),
new Among ( "ence", 33, 1, "r_A", methodObject ),
new Among ( "ide", 33, 1, "r_L", methodObject ),
new Among ( "icide", 38, 1, "r_A", methodObject ),
new Among ( "otide", 38, 1, "r_A", methodObject ),
new Among ( "age", 33, 1, "r_B", methodObject ),
new Among ( "able", 33, 1, "r_A", methodObject ),
new Among ( "atable", 42, 1, "r_A", methodObject ),
new Among ( "izable", 42, 1, "r_E", methodObject ),
new Among ( "arizable", 44, 1, "r_A", methodObject ),
new Among ( "ible", 33, 1, "r_A", methodObject ),
new Among ( "encible", 46, 1, "r_A", methodObject ),
new Among ( "ene", 33, 1, "r_E", methodObject ),
new Among ( "ine", 33, 1, "r_M", methodObject ),
new Among ( "idine", 49, 1, "r_I", methodObject ),
new Among ( "one", 33, 1, "r_R", methodObject ),
new Among ( "ature", 33, 1, "r_E", methodObject ),
new Among ( "eature", 52, 1, "r_Z", methodObject ),
new Among ( "ese", 33, 1, "r_A", methodObject ),
new Among ( "wise", 33, 1, "r_A", methodObject ),
new Among ( "ate", 33, 1, "r_A", methodObject ),
new Among ( "entiate", 56, 1, "r_A", methodObject ),
new Among ( "inate", 56, 1, "r_A", methodObject ),
new Among ( "ionate", 56, 1, "r_D", methodObject ),
new Among ( "ite", 33, 1, "r_AA", methodObject ),
new Among ( "ive", 33, 1, "r_A", methodObject ),
new Among ( "ative", 61, 1, "r_A", methodObject ),
new Among ( "ize", 33, 1, "r_F", methodObject ),
new Among ( "alize", 63, 1, "r_A", methodObject ),
new Among ( "icalize", 64, 1, "r_A", methodObject ),
new Among ( "ialize", 64, 1, "r_A", methodObject ),
new Among ( "entialize", 66, 1, "r_A", methodObject ),
new Among ( "ionalize", 64, 1, "r_A", methodObject ),
new Among ( "arize", 63, 1, "r_A", methodObject ),
new Among ( "ing", -1, 1, "r_N", methodObject ),
new Among ( "ancing", 70, 1, "r_B", methodObject ),
new Among ( "encing", 70, 1, "r_A", methodObject ),
new Among ( "aging", 70, 1, "r_B", methodObject ),
new Among ( "ening", 70, 1, "r_E", methodObject ),
new Among ( "ioning", 70, 1, "r_A", methodObject ),
new Among ( "ating", 70, 1, "r_I", methodObject ),
new Among ( "enting", 70, 1, "r_C", methodObject ),
new Among ( "ying", 70, 1, "r_B", methodObject ),
new Among ( "izing", 70, 1, "r_F", methodObject ),
new Among ( "arizing", 79, 1, "r_A", methodObject ),
new Among ( "ish", -1, 1, "r_C", methodObject ),
new Among ( "yish", 81, 1, "r_A", methodObject ),
new Among ( "i", -1, 1, "r_A", methodObject ),
new Among ( "al", -1, 1, "r_BB", methodObject ),
new Among ( "ical", 84, 1, "r_A", methodObject ),
new Among ( "aical", 85, 1, "r_A", methodObject ),
new Among ( "istical", 85, 1, "r_A", methodObject ),
new Among ( "oidal", 84, 1, "r_A", methodObject ),
new Among ( "eal", 84, 1, "r_Y", methodObject ),
new Among ( "ial", 84, 1, "r_A", methodObject ),
new Among ( "ancial", 90, 1, "r_A", methodObject ),
new Among ( "arial", 90, 1, "r_A", methodObject ),
new Among ( "ential", 90, 1, "r_A", methodObject ),
new Among ( "ional", 84, 1, "r_A", methodObject ),
new Among ( "ational", 94, 1, "r_B", methodObject ),
new Among ( "izational", 95, 1, "r_A", methodObject ),
new Among ( "ental", 84, 1, "r_A", methodObject ),
new Among ( "ful", -1, 1, "r_A", methodObject ),
new Among ( "eful", 98, 1, "r_A", methodObject ),
new Among ( "iful", 98, 1, "r_A", methodObject ),
new Among ( "yl", -1, 1, "r_R", methodObject ),
new Among ( "ism", -1, 1, "r_B", methodObject ),
new Among ( "icism", 102, 1, "r_A", methodObject ),
new Among ( "oidism", 102, 1, "r_A", methodObject ),
new Among ( "alism", 102, 1, "r_B", methodObject ),
new Among ( "icalism", 105, 1, "r_A", methodObject ),
new Among ( "ionalism", 105, 1, "r_A", methodObject ),
new Among ( "inism", 102, 1, "r_J", methodObject ),
new Among ( "ativism", 102, 1, "r_A", methodObject ),
new Among ( "um", -1, 1, "r_U", methodObject ),
new Among ( "ium", 110, 1, "r_A", methodObject ),
new Among ( "ian", -1, 1, "r_A", methodObject ),
new Among ( "ician", 112, 1, "r_A", methodObject ),
new Among ( "en", -1, 1, "r_F", methodObject ),
new Among ( "ogen", 114, 1, "r_A", methodObject ),
new Among ( "on", -1, 1, "r_S", methodObject ),
new Among ( "ion", 116, 1, "r_Q", methodObject ),
new Among ( "ation", 117, 1, "r_B", methodObject ),
new Among ( "ication", 118, 1, "r_G", methodObject ),
new Among ( "entiation", 118, 1, "r_A", methodObject ),
new Among ( "ination", 118, 1, "r_A", methodObject ),
new Among ( "isation", 118, 1, "r_A", methodObject ),
new Among ( "arisation", 122, 1, "r_A", methodObject ),
new Among ( "entation", 118, 1, "r_A", methodObject ),
new Among ( "ization", 118, 1, "r_F", methodObject ),
new Among ( "arization", 125, 1, "r_A", methodObject ),
new Among ( "action", 117, 1, "r_G", methodObject ),
new Among ( "o", -1, 1, "r_A", methodObject ),
new Among ( "ar", -1, 1, "r_X", methodObject ),
new Among ( "ear", 129, 1, "r_Y", methodObject ),
new Among ( "ier", -1, 1, "r_A", methodObject ),
new Among ( "ariser", -1, 1, "r_A", methodObject ),
new Among ( "izer", -1, 1, "r_F", methodObject ),
new Among ( "arizer", 133, 1, "r_A", methodObject ),
new Among ( "or", -1, 1, "r_T", methodObject ),
new Among ( "ator", 135, 1, "r_A", methodObject ),
new Among ( "s", -1, 1, "r_W", methodObject ),
new Among ( "'s", 137, 1, "r_A", methodObject ),
new Among ( "as", 137, 1, "r_B", methodObject ),
new Among ( "ics", 137, 1, "r_A", methodObject ),
new Among ( "istics", 140, 1, "r_A", methodObject ),
new Among ( "es", 137, 1, "r_E", methodObject ),
new Among ( "ances", 142, 1, "r_B", methodObject ),
new Among ( "ences", 142, 1, "r_A", methodObject ),
new Among ( "ides", 142, 1, "r_L", methodObject ),
new Among ( "oides", 145, 1, "r_A", methodObject ),
new Among ( "ages", 142, 1, "r_B", methodObject ),
new Among ( "ies", 142, 1, "r_P", methodObject ),
new Among ( "acies", 148, 1, "r_A", methodObject ),
new Among ( "ancies", 148, 1, "r_A", methodObject ),
new Among ( "encies", 148, 1, "r_A", methodObject ),
new Among ( "aries", 148, 1, "r_A", methodObject ),
new Among ( "ities", 148, 1, "r_A", methodObject ),
new Among ( "alities", 153, 1, "r_A", methodObject ),
new Among ( "ivities", 153, 1, "r_A", methodObject ),
new Among ( "ines", 142, 1, "r_M", methodObject ),
new Among ( "nesses", 142, 1, "r_A", methodObject ),
new Among ( "ates", 142, 1, "r_A", methodObject ),
new Among ( "atives", 142, 1, "r_A", methodObject ),
new Among ( "ings", 137, 1, "r_N", methodObject ),
new Among ( "is", 137, 1, "r_A", methodObject ),
new Among ( "als", 137, 1, "r_BB", methodObject ),
new Among ( "ials", 162, 1, "r_A", methodObject ),
new Among ( "entials", 163, 1, "r_A", methodObject ),
new Among ( "ionals", 162, 1, "r_A", methodObject ),
new Among ( "isms", 137, 1, "r_B", methodObject ),
new Among ( "ians", 137, 1, "r_A", methodObject ),
new Among ( "icians", 167, 1, "r_A", methodObject ),
new Among ( "ions", 137, 1, "r_B", methodObject ),
new Among ( "ations", 169, 1, "r_B", methodObject ),
new Among ( "arisations", 170, 1, "r_A", methodObject ),
new Among ( "entations", 170, 1, "r_A", methodObject ),
new Among ( "izations", 170, 1, "r_A", methodObject ),
new Among ( "arizations", 173, 1, "r_A", methodObject ),
new Among ( "ars", 137, 1, "r_O", methodObject ),
new Among ( "iers", 137, 1, "r_A", methodObject ),
new Among ( "izers", 137, 1, "r_F", methodObject ),
new Among ( "ators", 137, 1, "r_A", methodObject ),
new Among ( "less", 137, 1, "r_A", methodObject ),
new Among ( "eless", 179, 1, "r_A", methodObject ),
new Among ( "ness", 137, 1, "r_A", methodObject ),
new Among ( "eness", 181, 1, "r_E", methodObject ),
new Among ( "ableness", 182, 1, "r_A", methodObject ),
new Among ( "eableness", 183, 1, "r_E", methodObject ),
new Among ( "ibleness", 182, 1, "r_A", methodObject ),
new Among ( "ateness", 182, 1, "r_A", methodObject ),
new Among ( "iteness", 182, 1, "r_A", methodObject ),
new Among ( "iveness", 182, 1, "r_A", methodObject ),
new Among ( "ativeness", 188, 1, "r_A", methodObject ),
new Among ( "ingness", 181, 1, "r_A", methodObject ),
new Among ( "ishness", 181, 1, "r_A", methodObject ),
new Among ( "iness", 181, 1, "r_A", methodObject ),
new Among ( "ariness", 192, 1, "r_E", methodObject ),
new Among ( "alness", 181, 1, "r_A", methodObject ),
new Among ( "icalness", 194, 1, "r_A", methodObject ),
new Among ( "antialness", 194, 1, "r_A", methodObject ),
new Among ( "entialness", 194, 1, "r_A", methodObject ),
new Among ( "ionalness", 194, 1, "r_A", methodObject ),
new Among ( "fulness", 181, 1, "r_A", methodObject ),
new Among ( "lessness", 181, 1, "r_A", methodObject ),
new Among ( "ousness", 181, 1, "r_A", methodObject ),
new Among ( "eousness", 201, 1, "r_A", methodObject ),
new Among ( "iousness", 201, 1, "r_A", methodObject ),
new Among ( "itousness", 201, 1, "r_A", methodObject ),
new Among ( "entness", 181, 1, "r_A", methodObject ),
new Among ( "ants", 137, 1, "r_B", methodObject ),
new Among ( "ists", 137, 1, "r_A", methodObject ),
new Among ( "icists", 207, 1, "r_A", methodObject ),
new Among ( "us", 137, 1, "r_V", methodObject ),
new Among ( "ous", 209, 1, "r_A", methodObject ),
new Among ( "eous", 210, 1, "r_A", methodObject ),
new Among ( "aceous", 211, 1, "r_A", methodObject ),
new Among ( "antaneous", 211, 1, "r_A", methodObject ),
new Among ( "ious", 210, 1, "r_A", methodObject ),
new Among ( "acious", 214, 1, "r_B", methodObject ),
new Among ( "itous", 210, 1, "r_A", methodObject ),
new Among ( "ant", -1, 1, "r_B", methodObject ),
new Among ( "icant", 217, 1, "r_A", methodObject ),
new Among ( "ent", -1, 1, "r_C", methodObject ),
new Among ( "ement", 219, 1, "r_A", methodObject ),
new Among ( "izement", 220, 1, "r_A", methodObject ),
new Among ( "ist", -1, 1, "r_A", methodObject ),
new Among ( "icist", 222, 1, "r_A", methodObject ),
new Among ( "alist", 222, 1, "r_A", methodObject ),
new Among ( "icalist", 224, 1, "r_A", methodObject ),
new Among ( "ialist", 224, 1, "r_A", methodObject ),
new Among ( "ionist", 222, 1, "r_A", methodObject ),
new Among ( "entist", 222, 1, "r_A", methodObject ),
new Among ( "y", -1, 1, "r_B", methodObject ),
new Among ( "acy", 229, 1, "r_A", methodObject ),
new Among ( "ancy", 229, 1, "r_B", methodObject ),
new Among ( "ency", 229, 1, "r_A", methodObject ),
new Among ( "ly", 229, 1, "r_B", methodObject ),
new Among ( "ealy", 233, 1, "r_Y", methodObject ),
new Among ( "ably", 233, 1, "r_A", methodObject ),
new Among ( "ibly", 233, 1, "r_A", methodObject ),
new Among ( "edly", 233, 1, "r_E", methodObject ),
new Among ( "iedly", 237, 1, "r_A", methodObject ),
new Among ( "ely", 233, 1, "r_E", methodObject ),
new Among ( "ately", 239, 1, "r_A", methodObject ),
new Among ( "ively", 239, 1, "r_A", methodObject ),
new Among ( "atively", 241, 1, "r_A", methodObject ),
new Among ( "ingly", 233, 1, "r_B", methodObject ),
new Among ( "atingly", 243, 1, "r_A", methodObject ),
new Among ( "ily", 233, 1, "r_A", methodObject ),
new Among ( "lily", 245, 1, "r_A", methodObject ),
new Among ( "arily", 245, 1, "r_A", methodObject ),
new Among ( "ally", 233, 1, "r_B", methodObject ),
new Among ( "ically", 248, 1, "r_A", methodObject ),
new Among ( "aically", 249, 1, "r_A", methodObject ),
new Among ( "allically", 249, 1, "r_C", methodObject ),
new Among ( "istically", 249, 1, "r_A", methodObject ),
new Among ( "alistically", 252, 1, "r_B", methodObject ),
new Among ( "oidally", 248, 1, "r_A", methodObject ),
new Among ( "ially", 248, 1, "r_A", methodObject ),
new Among ( "entially", 255, 1, "r_A", methodObject ),
new Among ( "ionally", 248, 1, "r_A", methodObject ),
new Among ( "ationally", 257, 1, "r_B", methodObject ),
new Among ( "izationally", 258, 1, "r_B", methodObject ),
new Among ( "entally", 248, 1, "r_A", methodObject ),
new Among ( "fully", 233, 1, "r_A", methodObject ),
new Among ( "efully", 261, 1, "r_A", methodObject ),
new Among ( "ifully", 261, 1, "r_A", methodObject ),
new Among ( "enly", 233, 1, "r_E", methodObject ),
new Among ( "arly", 233, 1, "r_K", methodObject ),
new Among ( "early", 265, 1, "r_Y", methodObject ),
new Among ( "lessly", 233, 1, "r_A", methodObject ),
new Among ( "ously", 233, 1, "r_A", methodObject ),
new Among ( "eously", 268, 1, "r_A", methodObject ),
new Among ( "iously", 268, 1, "r_A", methodObject ),
new Among ( "ently", 233, 1, "r_A", methodObject ),
new Among ( "ary", 229, 1, "r_F", methodObject ),
new Among ( "ery", 229, 1, "r_E", methodObject ),
new Among ( "icianry", 229, 1, "r_A", methodObject ),
new Among ( "atory", 229, 1, "r_A", methodObject ),
new Among ( "ity", 229, 1, "r_A", methodObject ),
new Among ( "acity", 276, 1, "r_A", methodObject ),
new Among ( "icity", 276, 1, "r_A", methodObject ),
new Among ( "eity", 276, 1, "r_A", methodObject ),
new Among ( "ality", 276, 1, "r_A", methodObject ),
new Among ( "icality", 280, 1, "r_A", methodObject ),
new Among ( "iality", 280, 1, "r_A", methodObject ),
new Among ( "antiality", 282, 1, "r_A", methodObject ),
new Among ( "entiality", 282, 1, "r_A", methodObject ),
new Among ( "ionality", 280, 1, "r_A", methodObject ),
new Among ( "elity", 276, 1, "r_A", methodObject ),
new Among ( "ability", 276, 1, "r_A", methodObject ),
new Among ( "izability", 287, 1, "r_A", methodObject ),
new Among ( "arizability", 288, 1, "r_A", methodObject ),
new Among ( "ibility", 276, 1, "r_A", methodObject ),
new Among ( "inity", 276, 1, "r_CC", methodObject ),
new Among ( "arity", 276, 1, "r_B", methodObject ),
new Among ( "ivity", 276, 1, "r_A", methodObject )
};
private final static Among a_2[] = {
new Among ( "bb", -1, -1, "", methodObject ),
new Among ( "dd", -1, -1, "", methodObject ),
new Among ( "gg", -1, -1, "", methodObject ),
new Among ( "ll", -1, -1, "", methodObject ),
new Among ( "mm", -1, -1, "", methodObject ),
new Among ( "nn", -1, -1, "", methodObject ),
new Among ( "pp", -1, -1, "", methodObject ),
new Among ( "rr", -1, -1, "", methodObject ),
new Among ( "ss", -1, -1, "", methodObject ),
new Among ( "tt", -1, -1, "", methodObject )
};
private final static Among a_3[] = {
new Among ( "uad", -1, 18, "", methodObject ),
new Among ( "vad", -1, 19, "", methodObject ),
new Among ( "cid", -1, 20, "", methodObject ),
new Among ( "lid", -1, 21, "", methodObject ),
new Among ( "erid", -1, 22, "", methodObject ),
new Among ( "pand", -1, 23, "", methodObject ),
new Among ( "end", -1, 24, "", methodObject ),
new Among ( "ond", -1, 25, "", methodObject ),
new Among ( "lud", -1, 26, "", methodObject ),
new Among ( "rud", -1, 27, "", methodObject ),
new Among ( "ul", -1, 9, "", methodObject ),
new Among ( "her", -1, 28, "", methodObject ),
new Among ( "metr", -1, 7, "", methodObject ),
new Among ( "istr", -1, 6, "", methodObject ),
new Among ( "urs", -1, 5, "", methodObject ),
new Among ( "uct", -1, 2, "", methodObject ),
new Among ( "et", -1, 32, "", methodObject ),
new Among ( "mit", -1, 29, "", methodObject ),
new Among ( "ent", -1, 30, "", methodObject ),
new Among ( "umpt", -1, 3, "", methodObject ),
new Among ( "rpt", -1, 4, "", methodObject ),
new Among ( "ert", -1, 31, "", methodObject ),
new Among ( "yt", -1, 33, "", methodObject ),
new Among ( "iev", -1, 1, "", methodObject ),
new Among ( "olv", -1, 8, "", methodObject ),
new Among ( "ax", -1, 14, "", methodObject ),
new Among ( "ex", -1, 15, "", methodObject ),
new Among ( "bex", 26, 10, "", methodObject ),
new Among ( "dex", 26, 11, "", methodObject ),
new Among ( "pex", 26, 12, "", methodObject ),
new Among ( "tex", 26, 13, "", methodObject ),
new Among ( "ix", -1, 16, "", methodObject ),
new Among ( "lux", -1, 17, "", methodObject ),
new Among ( "yz", -1, 34, "", methodObject )
};
private void copy_from(LovinsStemmer other) {
super.copy_from(other);
}
private boolean r_A() {
// (, line 21
// hop, line 21
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
return true;
}
private boolean r_B() {
// (, line 22
// hop, line 22
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
return true;
}
private boolean r_C() {
// (, line 23
// hop, line 23
{
int c = cursor - 4;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
return true;
}
private boolean r_D() {
// (, line 24
// hop, line 24
{
int c = cursor - 5;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
return true;
}
private boolean r_E() {
int v_1;
int v_2;
// (, line 25
// test, line 25
v_1 = limit - cursor;
// hop, line 25
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 25
{
v_2 = limit - cursor;
lab0: do {
// literal, line 25
if (!(eq_s_b(1, "e")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
return true;
}
private boolean r_F() {
int v_1;
int v_2;
// (, line 26
// test, line 26
v_1 = limit - cursor;
// hop, line 26
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 26
{
v_2 = limit - cursor;
lab0: do {
// literal, line 26
if (!(eq_s_b(1, "e")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
return true;
}
private boolean r_G() {
int v_1;
// (, line 27
// test, line 27
v_1 = limit - cursor;
// hop, line 27
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// literal, line 27
if (!(eq_s_b(1, "f")))
{
return false;
}
return true;
}
private boolean r_H() {
int v_1;
int v_2;
// (, line 28
// test, line 28
v_1 = limit - cursor;
// hop, line 28
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 28
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 28
if (!(eq_s_b(1, "t")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
// literal, line 28
if (!(eq_s_b(2, "ll")))
{
return false;
}
} while (false);
return true;
}
private boolean r_I() {
int v_1;
int v_2;
int v_3;
// (, line 29
// test, line 29
v_1 = limit - cursor;
// hop, line 29
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 29
{
v_2 = limit - cursor;
lab0: do {
// literal, line 29
if (!(eq_s_b(1, "o")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 29
{
v_3 = limit - cursor;
lab1: do {
// literal, line 29
if (!(eq_s_b(1, "e")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_3;
}
return true;
}
private boolean r_J() {
int v_1;
int v_2;
int v_3;
// (, line 30
// test, line 30
v_1 = limit - cursor;
// hop, line 30
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 30
{
v_2 = limit - cursor;
lab0: do {
// literal, line 30
if (!(eq_s_b(1, "a")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 30
{
v_3 = limit - cursor;
lab1: do {
// literal, line 30
if (!(eq_s_b(1, "e")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_3;
}
return true;
}
private boolean r_K() {
int v_1;
int v_2;
// (, line 31
// test, line 31
v_1 = limit - cursor;
// hop, line 31
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 31
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 31
if (!(eq_s_b(1, "l")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
lab2: do {
// literal, line 31
if (!(eq_s_b(1, "i")))
{
break lab2;
}
break lab0;
} while (false);
cursor = limit - v_2;
// (, line 31
// literal, line 31
if (!(eq_s_b(1, "e")))
{
return false;
}
// next, line 31
if (cursor <= limit_backward)
{
return false;
}
cursor--;
// literal, line 31
if (!(eq_s_b(1, "u")))
{
return false;
}
} while (false);
return true;
}
private boolean r_L() {
int v_1;
int v_2;
int v_3;
int v_4;
int v_5;
// (, line 32
// test, line 32
v_1 = limit - cursor;
// hop, line 32
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 32
{
v_2 = limit - cursor;
lab0: do {
// literal, line 32
if (!(eq_s_b(1, "u")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 32
{
v_3 = limit - cursor;
lab1: do {
// literal, line 32
if (!(eq_s_b(1, "x")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_3;
}
// not, line 32
{
v_4 = limit - cursor;
lab2: do {
// (, line 32
// literal, line 32
if (!(eq_s_b(1, "s")))
{
break lab2;
}
// not, line 32
{
v_5 = limit - cursor;
lab3: do {
// literal, line 32
if (!(eq_s_b(1, "o")))
{
break lab3;
}
break lab2;
} while (false);
cursor = limit - v_5;
}
return false;
} while (false);
cursor = limit - v_4;
}
return true;
}
private boolean r_M() {
int v_1;
int v_2;
int v_3;
int v_4;
int v_5;
// (, line 33
// test, line 33
v_1 = limit - cursor;
// hop, line 33
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 33
{
v_2 = limit - cursor;
lab0: do {
// literal, line 33
if (!(eq_s_b(1, "a")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 33
{
v_3 = limit - cursor;
lab1: do {
// literal, line 33
if (!(eq_s_b(1, "c")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_3;
}
// not, line 33
{
v_4 = limit - cursor;
lab2: do {
// literal, line 33
if (!(eq_s_b(1, "e")))
{
break lab2;
}
return false;
} while (false);
cursor = limit - v_4;
}
// not, line 33
{
v_5 = limit - cursor;
lab3: do {
// literal, line 33
if (!(eq_s_b(1, "m")))
{
break lab3;
}
return false;
} while (false);
cursor = limit - v_5;
}
return true;
}
private boolean r_N() {
int v_1;
int v_2;
int v_3;
// (, line 34
// test, line 34
v_1 = limit - cursor;
// hop, line 34
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// (, line 34
// hop, line 34
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
// or, line 34
lab0: do {
v_2 = limit - cursor;
lab1: do {
// not, line 34
{
v_3 = limit - cursor;
lab2: do {
// literal, line 34
if (!(eq_s_b(1, "s")))
{
break lab2;
}
break lab1;
} while (false);
cursor = limit - v_3;
}
break lab0;
} while (false);
cursor = limit - v_2;
// hop, line 34
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
} while (false);
return true;
}
private boolean r_O() {
int v_1;
int v_2;
// (, line 35
// test, line 35
v_1 = limit - cursor;
// hop, line 35
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 35
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 35
if (!(eq_s_b(1, "l")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
// literal, line 35
if (!(eq_s_b(1, "i")))
{
return false;
}
} while (false);
return true;
}
private boolean r_P() {
int v_1;
int v_2;
// (, line 36
// test, line 36
v_1 = limit - cursor;
// hop, line 36
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 36
{
v_2 = limit - cursor;
lab0: do {
// literal, line 36
if (!(eq_s_b(1, "c")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
return true;
}
private boolean r_Q() {
int v_1;
int v_2;
int v_3;
int v_4;
// (, line 37
// test, line 37
v_1 = limit - cursor;
// hop, line 37
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// test, line 37
v_2 = limit - cursor;
// hop, line 37
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_2;
// not, line 37
{
v_3 = limit - cursor;
lab0: do {
// literal, line 37
if (!(eq_s_b(1, "l")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_3;
}
// not, line 37
{
v_4 = limit - cursor;
lab1: do {
// literal, line 37
if (!(eq_s_b(1, "n")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_4;
}
return true;
}
private boolean r_R() {
int v_1;
int v_2;
// (, line 38
// test, line 38
v_1 = limit - cursor;
// hop, line 38
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 38
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 38
if (!(eq_s_b(1, "n")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
// literal, line 38
if (!(eq_s_b(1, "r")))
{
return false;
}
} while (false);
return true;
}
private boolean r_S() {
int v_1;
int v_2;
int v_3;
// (, line 39
// test, line 39
v_1 = limit - cursor;
// hop, line 39
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 39
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 39
if (!(eq_s_b(2, "dr")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
// (, line 39
// literal, line 39
if (!(eq_s_b(1, "t")))
{
return false;
}
// not, line 39
{
v_3 = limit - cursor;
lab2: do {
// literal, line 39
if (!(eq_s_b(1, "t")))
{
break lab2;
}
return false;
} while (false);
cursor = limit - v_3;
}
} while (false);
return true;
}
private boolean r_T() {
int v_1;
int v_2;
int v_3;
// (, line 40
// test, line 40
v_1 = limit - cursor;
// hop, line 40
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 40
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 40
if (!(eq_s_b(1, "s")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
// (, line 40
// literal, line 40
if (!(eq_s_b(1, "t")))
{
return false;
}
// not, line 40
{
v_3 = limit - cursor;
lab2: do {
// literal, line 40
if (!(eq_s_b(1, "o")))
{
break lab2;
}
return false;
} while (false);
cursor = limit - v_3;
}
} while (false);
return true;
}
private boolean r_U() {
int v_1;
int v_2;
// (, line 41
// test, line 41
v_1 = limit - cursor;
// hop, line 41
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 41
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 41
if (!(eq_s_b(1, "l")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
lab2: do {
// literal, line 41
if (!(eq_s_b(1, "m")))
{
break lab2;
}
break lab0;
} while (false);
cursor = limit - v_2;
lab3: do {
// literal, line 41
if (!(eq_s_b(1, "n")))
{
break lab3;
}
break lab0;
} while (false);
cursor = limit - v_2;
// literal, line 41
if (!(eq_s_b(1, "r")))
{
return false;
}
} while (false);
return true;
}
private boolean r_V() {
int v_1;
// (, line 42
// test, line 42
v_1 = limit - cursor;
// hop, line 42
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// literal, line 42
if (!(eq_s_b(1, "c")))
{
return false;
}
return true;
}
private boolean r_W() {
int v_1;
int v_2;
int v_3;
// (, line 43
// test, line 43
v_1 = limit - cursor;
// hop, line 43
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 43
{
v_2 = limit - cursor;
lab0: do {
// literal, line 43
if (!(eq_s_b(1, "s")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 43
{
v_3 = limit - cursor;
lab1: do {
// literal, line 43
if (!(eq_s_b(1, "u")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_3;
}
return true;
}
private boolean r_X() {
int v_1;
int v_2;
// (, line 44
// test, line 44
v_1 = limit - cursor;
// hop, line 44
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// or, line 44
lab0: do {
v_2 = limit - cursor;
lab1: do {
// literal, line 44
if (!(eq_s_b(1, "l")))
{
break lab1;
}
break lab0;
} while (false);
cursor = limit - v_2;
lab2: do {
// literal, line 44
if (!(eq_s_b(1, "i")))
{
break lab2;
}
break lab0;
} while (false);
cursor = limit - v_2;
// (, line 44
// literal, line 44
if (!(eq_s_b(1, "e")))
{
return false;
}
// next, line 44
if (cursor <= limit_backward)
{
return false;
}
cursor--;
// literal, line 44
if (!(eq_s_b(1, "u")))
{
return false;
}
} while (false);
return true;
}
private boolean r_Y() {
int v_1;
// (, line 45
// test, line 45
v_1 = limit - cursor;
// hop, line 45
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// literal, line 45
if (!(eq_s_b(2, "in")))
{
return false;
}
return true;
}
private boolean r_Z() {
int v_1;
int v_2;
// (, line 46
// test, line 46
v_1 = limit - cursor;
// hop, line 46
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 46
{
v_2 = limit - cursor;
lab0: do {
// literal, line 46
if (!(eq_s_b(1, "f")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
return true;
}
private boolean r_AA() {
int v_1;
// (, line 47
// test, line 47
v_1 = limit - cursor;
// hop, line 47
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// among, line 47
if (find_among_b(a_0, 9) == 0)
{
return false;
}
return true;
}
private boolean r_BB() {
int v_1;
int v_2;
int v_3;
// (, line 49
// test, line 49
v_1 = limit - cursor;
// hop, line 49
{
int c = cursor - 3;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// not, line 49
{
v_2 = limit - cursor;
lab0: do {
// literal, line 49
if (!(eq_s_b(3, "met")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 49
{
v_3 = limit - cursor;
lab1: do {
// literal, line 49
if (!(eq_s_b(4, "ryst")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_3;
}
return true;
}
private boolean r_CC() {
int v_1;
// (, line 50
// test, line 50
v_1 = limit - cursor;
// hop, line 50
{
int c = cursor - 2;
if (limit_backward > c || c > limit)
{
return false;
}
cursor = c;
}
cursor = limit - v_1;
// literal, line 50
if (!(eq_s_b(1, "l")))
{
return false;
}
return true;
}
private boolean r_endings() {
int among_var;
// (, line 55
// [, line 56
ket = cursor;
// substring, line 56
among_var = find_among_b(a_1, 294);
if (among_var == 0)
{
return false;
}
// ], line 56
bra = cursor;
switch(among_var) {
case 0:
return false;
case 1:
// (, line 145
// delete, line 145
slice_del();
break;
}
return true;
}
private boolean r_undouble() {
int v_1;
// (, line 151
// test, line 152
v_1 = limit - cursor;
// substring, line 152
if (find_among_b(a_2, 10) == 0)
{
return false;
}
cursor = limit - v_1;
// [, line 154
ket = cursor;
// next, line 154
if (cursor <= limit_backward)
{
return false;
}
cursor--;
// ], line 154
bra = cursor;
// delete, line 154
slice_del();
return true;
}
private boolean r_respell() {
int among_var;
int v_1;
int v_2;
int v_3;
int v_4;
int v_5;
int v_6;
int v_7;
int v_8;
// (, line 159
// [, line 160
ket = cursor;
// substring, line 160
among_var = find_among_b(a_3, 34);
if (among_var == 0)
{
return false;
}
// ], line 160
bra = cursor;
switch(among_var) {
case 0:
return false;
case 1:
// (, line 161
// <-, line 161
slice_from("ief");
break;
case 2:
// (, line 162
// <-, line 162
slice_from("uc");
break;
case 3:
// (, line 163
// <-, line 163
slice_from("um");
break;
case 4:
// (, line 164
// <-, line 164
slice_from("rb");
break;
case 5:
// (, line 165
// <-, line 165
slice_from("ur");
break;
case 6:
// (, line 166
// <-, line 166
slice_from("ister");
break;
case 7:
// (, line 167
// <-, line 167
slice_from("meter");
break;
case 8:
// (, line 168
// <-, line 168
slice_from("olut");
break;
case 9:
// (, line 169
// not, line 169
{
v_1 = limit - cursor;
lab0: do {
// literal, line 169
if (!(eq_s_b(1, "a")))
{
break lab0;
}
return false;
} while (false);
cursor = limit - v_1;
}
// not, line 169
{
v_2 = limit - cursor;
lab1: do {
// literal, line 169
if (!(eq_s_b(1, "i")))
{
break lab1;
}
return false;
} while (false);
cursor = limit - v_2;
}
// not, line 169
{
v_3 = limit - cursor;
lab2: do {
// literal, line 169
if (!(eq_s_b(1, "o")))
{
break lab2;
}
return false;
} while (false);
cursor = limit - v_3;
}
// <-, line 169
slice_from("l");
break;
case 10:
// (, line 170
// <-, line 170
slice_from("bic");
break;
case 11:
// (, line 171
// <-, line 171
slice_from("dic");
break;
case 12:
// (, line 172
// <-, line 172
slice_from("pic");
break;
case 13:
// (, line 173
// <-, line 173
slice_from("tic");
break;
case 14:
// (, line 174
// <-, line 174
slice_from("ac");
break;
case 15:
// (, line 175
// <-, line 175
slice_from("ec");
break;
case 16:
// (, line 176
// <-, line 176
slice_from("ic");
break;
case 17:
// (, line 177
// <-, line 177
slice_from("luc");
break;
case 18:
// (, line 178
// <-, line 178
slice_from("uas");
break;
case 19:
// (, line 179
// <-, line 179
slice_from("vas");
break;
case 20:
// (, line 180
// <-, line 180
slice_from("cis");
break;
case 21:
// (, line 181
// <-, line 181
slice_from("lis");
break;
case 22:
// (, line 182
// <-, line 182
slice_from("eris");
break;
case 23:
// (, line 183
// <-, line 183
slice_from("pans");
break;
case 24:
// (, line 184
// not, line 184
{
v_4 = limit - cursor;
lab3: do {
// literal, line 184
if (!(eq_s_b(1, "s")))
{
break lab3;
}
return false;
} while (false);
cursor = limit - v_4;
}
// <-, line 184
slice_from("ens");
break;
case 25:
// (, line 185
// <-, line 185
slice_from("ons");
break;
case 26:
// (, line 186
// <-, line 186
slice_from("lus");
break;
case 27:
// (, line 187
// <-, line 187
slice_from("rus");
break;
case 28:
// (, line 188
// not, line 188
{
v_5 = limit - cursor;
lab4: do {
// literal, line 188
if (!(eq_s_b(1, "p")))
{
break lab4;
}
return false;
} while (false);
cursor = limit - v_5;
}
// not, line 188
{
v_6 = limit - cursor;
lab5: do {
// literal, line 188
if (!(eq_s_b(1, "t")))
{
break lab5;
}
return false;
} while (false);
cursor = limit - v_6;
}
// <-, line 188
slice_from("hes");
break;
case 29:
// (, line 189
// <-, line 189
slice_from("mis");
break;
case 30:
// (, line 190
// not, line 190
{
v_7 = limit - cursor;
lab6: do {
// literal, line 190
if (!(eq_s_b(1, "m")))
{
break lab6;
}
return false;
} while (false);
cursor = limit - v_7;
}
// <-, line 190
slice_from("ens");
break;
case 31:
// (, line 192
// <-, line 192
slice_from("ers");
break;
case 32:
// (, line 193
// not, line 193
{
v_8 = limit - cursor;
lab7: do {
// literal, line 193
if (!(eq_s_b(1, "n")))
{
break lab7;
}
return false;
} while (false);
cursor = limit - v_8;
}
// <-, line 193
slice_from("es");
break;
case 33:
// (, line 194
// <-, line 194
slice_from("ys");
break;
case 34:
// (, line 195
// <-, line 195
slice_from("ys");
break;
}
return true;
}
@Override
public boolean stem() {
int v_1;
int v_2;
int v_3;
// (, line 200
// backwards, line 202
limit_backward = cursor; cursor = limit;
// (, line 202
// do, line 203
v_1 = limit - cursor;
lab0: do {
// call endings, line 203
if (!r_endings())
{
break lab0;
}
} while (false);
cursor = limit - v_1;
// do, line 204
v_2 = limit - cursor;
lab1: do {
// call undouble, line 204
if (!r_undouble())
{
break lab1;
}
} while (false);
cursor = limit - v_2;
// do, line 205
v_3 = limit - cursor;
lab2: do {
// call respell, line 205
if (!r_respell())
{
break lab2;
}
} while (false);
cursor = limit - v_3;
cursor = limit_backward; return true;
}
@Override
public boolean equals( Object o ) {
return o instanceof LovinsStemmer;
}
@Override
public int hashCode() {
return LovinsStemmer.class.getName().hashCode();
}
}