#![allow(non_upper_case_globals)]
#![allow(non_snake_case)]
#![allow(unused_variables)]
#![allow(unused_mut)]
use snowball::SnowballEnv;
use snowball::Among;
static A_0: &'static [Among<Context>; 32] = &[
Among("hed", -1, 1, None),
Among("ethed", 0, 1, None),
Among("ered", -1, 1, None),
Among("e", -1, 1, None),
Among("erede", 3, 1, None),
Among("ende", 3, 1, None),
Among("erende", 5, 1, None),
Among("ene", 3, 1, None),
Among("erne", 3, 1, None),
Among("ere", 3, 1, None),
Among("en", -1, 1, None),
Among("heden", 10, 1, None),
Among("eren", 10, 1, None),
Among("er", -1, 1, None),
Among("heder", 13, 1, None),
Among("erer", 13, 1, None),
Among("s", -1, 2, None),
Among("heds", 16, 1, None),
Among("es", 16, 1, None),
Among("endes", 18, 1, None),
Among("erendes", 19, 1, None),
Among("enes", 18, 1, None),
Among("ernes", 18, 1, None),
Among("eres", 18, 1, None),
Among("ens", 16, 1, None),
Among("hedens", 24, 1, None),
Among("erens", 24, 1, None),
Among("ers", 16, 1, None),
Among("ets", 16, 1, None),
Among("erets", 28, 1, None),
Among("et", -1, 1, None),
Among("eret", 30, 1, None),
];
static A_1: &'static [Among<Context>; 4] = &[
Among("gd", -1, -1, None),
Among("dt", -1, -1, None),
Among("gt", -1, -1, None),
Among("kt", -1, -1, None),
];
static A_2: &'static [Among<Context>; 5] = &[
Among("ig", -1, 1, None),
Among("lig", 0, 1, None),
Among("elig", 1, 1, None),
Among("els", -1, 1, None),
Among("l\u{00F8}st", -1, 2, None),
];
static G_v: &'static [u8; 19] = &[17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 48, 0, 128];
static G_s_ending: &'static [u8; 17] = &[239, 254, 42, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16];
#[derive(Clone)]
struct Context {
i_x: usize,
i_p1: usize,
S_ch: String,
}
fn r_mark_regions(env: &mut SnowballEnv, context: &mut Context) -> bool {
context.i_p1 = env.limit;
let v_1 = env.cursor;
let c = env.byte_index_for_hop(3);
if 0 as i32 > c || c > env.limit as i32 {
return false;
}
env.cursor = c as usize;
context.i_x = env.cursor;
env.cursor = v_1;
'golab0: loop {
let v_2 = env.cursor;
'lab1: loop {
if !env.in_grouping(G_v, 97, 248) {
break 'lab1;
}
env.cursor = v_2;
break 'golab0;
}
env.cursor = v_2;
if env.cursor >= env.limit {
return false;
}
env.next_char();
}
'golab2: loop {
'lab3: loop {
if !env.out_grouping(G_v, 97, 248) {
break 'lab3;
}
break 'golab2;
}
if env.cursor >= env.limit {
return false;
}
env.next_char();
}
context.i_p1 = env.cursor;
'lab4: loop {
if !(context.i_p1 < context.i_x){
break 'lab4;
}
context.i_p1 = context.i_x;
break 'lab4;
}
return true;
}
fn r_main_suffix(env: &mut SnowballEnv, context: &mut Context) -> bool {
let mut among_var;
let v_1 = env.limit - env.cursor;
if env.cursor < context.i_p1 {
return false;
}
env.cursor = context.i_p1;
let v_2 = env.limit_backward;
env.limit_backward = env.cursor;
env.cursor = env.limit - v_1;
env.ket = env.cursor;
among_var = env.find_among_b(A_0, context);
if among_var == 0 {
env.limit_backward = v_2;
return false;
}
env.bra = env.cursor;
env.limit_backward = v_2;
if among_var == 0 {
return false;
} else if among_var == 1 {
if !env.slice_del() {
return false;
}
} else if among_var == 2 {
if !env.in_grouping_b(G_s_ending, 97, 229) {
return false;
}
if !env.slice_del() {
return false;
}
}
return true;
}
fn r_consonant_pair(env: &mut SnowballEnv, context: &mut Context) -> bool {
let v_1 = env.limit - env.cursor;
let v_2 = env.limit - env.cursor;
if env.cursor < context.i_p1 {
return false;
}
env.cursor = context.i_p1;
let v_3 = env.limit_backward;
env.limit_backward = env.cursor;
env.cursor = env.limit - v_2;
env.ket = env.cursor;
if env.find_among_b(A_1, context) == 0 {
env.limit_backward = v_3;
return false;
}
env.bra = env.cursor;
env.limit_backward = v_3;
env.cursor = env.limit - v_1;
if env.cursor <= env.limit_backward {
return false;
}
env.previous_char();
env.bra = env.cursor;
if !env.slice_del() {
return false;
}
return true;
}
fn r_other_suffix(env: &mut SnowballEnv, context: &mut Context) -> bool {
let mut among_var;
let v_1 = env.limit - env.cursor;
'lab0: loop {
env.ket = env.cursor;
if !env.eq_s_b(&"st") {
break 'lab0;
}
env.bra = env.cursor;
if !env.eq_s_b(&"ig") {
break 'lab0;
}
if !env.slice_del() {
return false;
}
break 'lab0;
}
env.cursor = env.limit - v_1;
let v_2 = env.limit - env.cursor;
if env.cursor < context.i_p1 {
return false;
}
env.cursor = context.i_p1;
let v_3 = env.limit_backward;
env.limit_backward = env.cursor;
env.cursor = env.limit - v_2;
env.ket = env.cursor;
among_var = env.find_among_b(A_2, context);
if among_var == 0 {
env.limit_backward = v_3;
return false;
}
env.bra = env.cursor;
env.limit_backward = v_3;
if among_var == 0 {
return false;
} else if among_var == 1 {
if !env.slice_del() {
return false;
}
let v_4 = env.limit - env.cursor;
'lab1: loop {
if !r_consonant_pair(env, context) {
break 'lab1;
}
break 'lab1;
}
env.cursor = env.limit - v_4;
} else if among_var == 2 {
if !env.slice_from("l\u{00F8}s") {
return false;
}
}
return true;
}
fn r_undouble(env: &mut SnowballEnv, context: &mut Context) -> bool {
let v_1 = env.limit - env.cursor;
if env.cursor < context.i_p1 {
return false;
}
env.cursor = context.i_p1;
let v_2 = env.limit_backward;
env.limit_backward = env.cursor;
env.cursor = env.limit - v_1;
env.ket = env.cursor;
if !env.out_grouping_b(G_v, 97, 248) {
env.limit_backward = v_2;
return false;
}
env.bra = env.cursor;
context.S_ch = env.slice_to();
if context.S_ch.is_empty() {
return false;
}
env.limit_backward = v_2;
if !env.eq_s_b(&context.S_ch) {
return false;
}
if !env.slice_del() {
return false;
}
return true;
}
pub fn stem(env: &mut SnowballEnv) -> bool {
let mut context = &mut Context {
i_x: 0,
i_p1: 0,
S_ch: String::new(),
};
let v_1 = env.cursor;
'lab0: loop {
if !r_mark_regions(env, context) {
break 'lab0;
}
break 'lab0;
}
env.cursor = v_1;
env.limit_backward = env.cursor;
env.cursor = env.limit;
let v_2 = env.limit - env.cursor;
'lab1: loop {
if !r_main_suffix(env, context) {
break 'lab1;
}
break 'lab1;
}
env.cursor = env.limit - v_2;
let v_3 = env.limit - env.cursor;
'lab2: loop {
if !r_consonant_pair(env, context) {
break 'lab2;
}
break 'lab2;
}
env.cursor = env.limit - v_3;
let v_4 = env.limit - env.cursor;
'lab3: loop {
if !r_other_suffix(env, context) {
break 'lab3;
}
break 'lab3;
}
env.cursor = env.limit - v_4;
let v_5 = env.limit - env.cursor;
'lab4: loop {
if !r_undouble(env, context) {
break 'lab4;
}
break 'lab4;
}
env.cursor = env.limit - v_5;
env.cursor = env.limit_backward;
return true;
}