# Generated by Snowball 2.2.0 - https://snowballstem.org/
from .basestemmer import BaseStemmer
from .among import Among
class LithuanianStemmer(BaseStemmer):
'''
This class implements the stemming algorithm defined by a snowball script.
Generated by Snowball 2.2.0 - https://snowballstem.org/
'''
a_0 = [
Among(u"a", -1, -1),
Among(u"ia", 0, -1),
Among(u"eria", 1, -1),
Among(u"osna", 0, -1),
Among(u"iosna", 3, -1),
Among(u"uosna", 3, -1),
Among(u"iuosna", 5, -1),
Among(u"ysna", 0, -1),
Among(u"\u0117sna", 0, -1),
Among(u"e", -1, -1),
Among(u"ie", 9, -1),
Among(u"enie", 10, -1),
Among(u"erie", 10, -1),
Among(u"oje", 9, -1),
Among(u"ioje", 13, -1),
Among(u"uje", 9, -1),
Among(u"iuje", 15, -1),
Among(u"yje", 9, -1),
Among(u"enyje", 17, -1),
Among(u"eryje", 17, -1),
Among(u"\u0117je", 9, -1),
Among(u"ame", 9, -1),
Among(u"iame", 21, -1),
Among(u"sime", 9, -1),
Among(u"ome", 9, -1),
Among(u"\u0117me", 9, -1),
Among(u"tum\u0117me", 25, -1),
Among(u"ose", 9, -1),
Among(u"iose", 27, -1),
Among(u"uose", 27, -1),
Among(u"iuose", 29, -1),
Among(u"yse", 9, -1),
Among(u"enyse", 31, -1),
Among(u"eryse", 31, -1),
Among(u"\u0117se", 9, -1),
Among(u"ate", 9, -1),
Among(u"iate", 35, -1),
Among(u"ite", 9, -1),
Among(u"kite", 37, -1),
Among(u"site", 37, -1),
Among(u"ote", 9, -1),
Among(u"tute", 9, -1),
Among(u"\u0117te", 9, -1),
Among(u"tum\u0117te", 42, -1),
Among(u"i", -1, -1),
Among(u"ai", 44, -1),
Among(u"iai", 45, -1),
Among(u"eriai", 46, -1),
Among(u"ei", 44, -1),
Among(u"tumei", 48, -1),
Among(u"ki", 44, -1),
Among(u"imi", 44, -1),
Among(u"erimi", 51, -1),
Among(u"umi", 44, -1),
Among(u"iumi", 53, -1),
Among(u"si", 44, -1),
Among(u"asi", 55, -1),
Among(u"iasi", 56, -1),
Among(u"esi", 55, -1),
Among(u"iesi", 58, -1),
Among(u"siesi", 59, -1),
Among(u"isi", 55, -1),
Among(u"aisi", 61, -1),
Among(u"eisi", 61, -1),
Among(u"tumeisi", 63, -1),
Among(u"uisi", 61, -1),
Among(u"osi", 55, -1),
Among(u"\u0117josi", 66, -1),
Among(u"uosi", 66, -1),
Among(u"iuosi", 68, -1),
Among(u"siuosi", 69, -1),
Among(u"usi", 55, -1),
Among(u"ausi", 71, -1),
Among(u"\u010Diausi", 72, -1),
Among(u"\u0105si", 55, -1),
Among(u"\u0117si", 55, -1),
Among(u"\u0173si", 55, -1),
Among(u"t\u0173si", 76, -1),
Among(u"ti", 44, -1),
Among(u"enti", 78, -1),
Among(u"inti", 78, -1),
Among(u"oti", 78, -1),
Among(u"ioti", 81, -1),
Among(u"uoti", 81, -1),
Among(u"iuoti", 83, -1),
Among(u"auti", 78, -1),
Among(u"iauti", 85, -1),
Among(u"yti", 78, -1),
Among(u"\u0117ti", 78, -1),
Among(u"tel\u0117ti", 88, -1),
Among(u"in\u0117ti", 88, -1),
Among(u"ter\u0117ti", 88, -1),
Among(u"ui", 44, -1),
Among(u"iui", 92, -1),
Among(u"eniui", 93, -1),
Among(u"oj", -1, -1),
Among(u"\u0117j", -1, -1),
Among(u"k", -1, -1),
Among(u"am", -1, -1),
Among(u"iam", 98, -1),
Among(u"iem", -1, -1),
Among(u"im", -1, -1),
Among(u"sim", 101, -1),
Among(u"om", -1, -1),
Among(u"tum", -1, -1),
Among(u"\u0117m", -1, -1),
Among(u"tum\u0117m", 105, -1),
Among(u"an", -1, -1),
Among(u"on", -1, -1),
Among(u"ion", 108, -1),
Among(u"un", -1, -1),
Among(u"iun", 110, -1),
Among(u"\u0117n", -1, -1),
Among(u"o", -1, -1),
Among(u"io", 113, -1),
Among(u"enio", 114, -1),
Among(u"\u0117jo", 113, -1),
Among(u"uo", 113, -1),
Among(u"s", -1, -1),
Among(u"as", 118, -1),
Among(u"ias", 119, -1),
Among(u"es", 118, -1),
Among(u"ies", 121, -1),
Among(u"is", 118, -1),
Among(u"ais", 123, -1),
Among(u"iais", 124, -1),
Among(u"tumeis", 123, -1),
Among(u"imis", 123, -1),
Among(u"enimis", 127, -1),
Among(u"omis", 123, -1),
Among(u"iomis", 129, -1),
Among(u"umis", 123, -1),
Among(u"\u0117mis", 123, -1),
Among(u"enis", 123, -1),
Among(u"asis", 123, -1),
Among(u"ysis", 123, -1),
Among(u"ams", 118, -1),
Among(u"iams", 136, -1),
Among(u"iems", 118, -1),
Among(u"ims", 118, -1),
Among(u"enims", 139, -1),
Among(u"erims", 139, -1),
Among(u"oms", 118, -1),
Among(u"ioms", 142, -1),
Among(u"ums", 118, -1),
Among(u"\u0117ms", 118, -1),
Among(u"ens", 118, -1),
Among(u"os", 118, -1),
Among(u"ios", 147, -1),
Among(u"uos", 147, -1),
Among(u"iuos", 149, -1),
Among(u"ers", 118, -1),
Among(u"us", 118, -1),
Among(u"aus", 152, -1),
Among(u"iaus", 153, -1),
Among(u"ius", 152, -1),
Among(u"ys", 118, -1),
Among(u"enys", 156, -1),
Among(u"erys", 156, -1),
Among(u"\u0105s", 118, -1),
Among(u"i\u0105s", 159, -1),
Among(u"\u0117s", 118, -1),
Among(u"am\u0117s", 161, -1),
Among(u"iam\u0117s", 162, -1),
Among(u"im\u0117s", 161, -1),
Among(u"kim\u0117s", 164, -1),
Among(u"sim\u0117s", 164, -1),
Among(u"om\u0117s", 161, -1),
Among(u"\u0117m\u0117s", 161, -1),
Among(u"tum\u0117m\u0117s", 168, -1),
Among(u"at\u0117s", 161, -1),
Among(u"iat\u0117s", 170, -1),
Among(u"sit\u0117s", 161, -1),
Among(u"ot\u0117s", 161, -1),
Among(u"\u0117t\u0117s", 161, -1),
Among(u"tum\u0117t\u0117s", 174, -1),
Among(u"\u012Fs", 118, -1),
Among(u"\u016Bs", 118, -1),
Among(u"t\u0173s", 118, -1),
Among(u"at", -1, -1),
Among(u"iat", 179, -1),
Among(u"it", -1, -1),
Among(u"sit", 181, -1),
Among(u"ot", -1, -1),
Among(u"\u0117t", -1, -1),
Among(u"tum\u0117t", 184, -1),
Among(u"u", -1, -1),
Among(u"au", 186, -1),
Among(u"iau", 187, -1),
Among(u"\u010Diau", 188, -1),
Among(u"iu", 186, -1),
Among(u"eniu", 190, -1),
Among(u"siu", 190, -1),
Among(u"y", -1, -1),
Among(u"\u0105", -1, -1),
Among(u"i\u0105", 194, -1),
Among(u"\u0117", -1, -1),
Among(u"\u0119", -1, -1),
Among(u"\u012F", -1, -1),
Among(u"en\u012F", 198, -1),
Among(u"er\u012F", 198, -1),
Among(u"\u0173", -1, -1),
Among(u"i\u0173", 201, -1),
Among(u"er\u0173", 201, -1)
]
a_1 = [
Among(u"ing", -1, -1),
Among(u"aj", -1, -1),
Among(u"iaj", 1, -1),
Among(u"iej", -1, -1),
Among(u"oj", -1, -1),
Among(u"ioj", 4, -1),
Among(u"uoj", 4, -1),
Among(u"iuoj", 6, -1),
Among(u"auj", -1, -1),
Among(u"\u0105j", -1, -1),
Among(u"i\u0105j", 9, -1),
Among(u"\u0117j", -1, -1),
Among(u"\u0173j", -1, -1),
Among(u"i\u0173j", 12, -1),
Among(u"ok", -1, -1),
Among(u"iok", 14, -1),
Among(u"iuk", -1, -1),
Among(u"uliuk", 16, -1),
Among(u"u\u010Diuk", 16, -1),
Among(u"i\u0161k", -1, -1),
Among(u"iul", -1, -1),
Among(u"yl", -1, -1),
Among(u"\u0117l", -1, -1),
Among(u"am", -1, -1),
Among(u"dam", 23, -1),
Among(u"jam", 23, -1),
Among(u"zgan", -1, -1),
Among(u"ain", -1, -1),
Among(u"esn", -1, -1),
Among(u"op", -1, -1),
Among(u"iop", 29, -1),
Among(u"ias", -1, -1),
Among(u"ies", -1, -1),
Among(u"ais", -1, -1),
Among(u"iais", 33, -1),
Among(u"os", -1, -1),
Among(u"ios", 35, -1),
Among(u"uos", 35, -1),
Among(u"iuos", 37, -1),
Among(u"aus", -1, -1),
Among(u"iaus", 39, -1),
Among(u"\u0105s", -1, -1),
Among(u"i\u0105s", 41, -1),
Among(u"\u0119s", -1, -1),
Among(u"ut\u0117ait", -1, -1),
Among(u"ant", -1, -1),
Among(u"iant", 45, -1),
Among(u"siant", 46, -1),
Among(u"int", -1, -1),
Among(u"ot", -1, -1),
Among(u"uot", 49, -1),
Among(u"iuot", 50, -1),
Among(u"yt", -1, -1),
Among(u"\u0117t", -1, -1),
Among(u"yk\u0161t", -1, -1),
Among(u"iau", -1, -1),
Among(u"dav", -1, -1),
Among(u"sv", -1, -1),
Among(u"\u0161v", -1, -1),
Among(u"yk\u0161\u010D", -1, -1),
Among(u"\u0119", -1, -1),
Among(u"\u0117j\u0119", 60, -1)
]
a_2 = [
Among(u"ojime", -1, 7),
Among(u"\u0117jime", -1, 3),
Among(u"avime", -1, 6),
Among(u"okate", -1, 8),
Among(u"aite", -1, 1),
Among(u"uote", -1, 2),
Among(u"asius", -1, 5),
Among(u"okat\u0117s", -1, 8),
Among(u"ait\u0117s", -1, 1),
Among(u"uot\u0117s", -1, 2),
Among(u"esiu", -1, 4)
]
a_3 = [
Among(u"\u010D", -1, 1),
Among(u"d\u017E", -1, 2)
]
a_4 = [
Among(u"gd", -1, 1)
]
g_v = [17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 64, 1, 0, 64, 0, 0, 0, 0, 0, 0, 0, 4, 4]
I_p1 = 0
def __r_R1(self):
if not self.I_p1 <= self.cursor:
return False
return True
def __r_step1(self):
if self.cursor < self.I_p1:
return False
v_2 = self.limit_backward
self.limit_backward = self.I_p1
self.ket = self.cursor
if self.find_among_b(LithuanianStemmer.a_0) == 0:
self.limit_backward = v_2
return False
self.bra = self.cursor
self.limit_backward = v_2
if not self.__r_R1():
return False
if not self.slice_del():
return False
return True
def __r_step2(self):
while True:
v_1 = self.limit - self.cursor
try:
if self.cursor < self.I_p1:
raise lab0()
v_3 = self.limit_backward
self.limit_backward = self.I_p1
self.ket = self.cursor
if self.find_among_b(LithuanianStemmer.a_1) == 0:
self.limit_backward = v_3
raise lab0()
self.bra = self.cursor
self.limit_backward = v_3
if not self.slice_del():
return False
continue
except lab0: pass
self.cursor = self.limit - v_1
break
return True
def __r_fix_conflicts(self):
self.ket = self.cursor
among_var = self.find_among_b(LithuanianStemmer.a_2)
if among_var == 0:
return False
self.bra = self.cursor
if among_var == 1:
if not self.slice_from(u"ait\u0117"):
return False
elif among_var == 2:
if not self.slice_from(u"uot\u0117"):
return False
elif among_var == 3:
if not self.slice_from(u"\u0117jimas"):
return False
elif among_var == 4:
if not self.slice_from(u"esys"):
return False
elif among_var == 5:
if not self.slice_from(u"asys"):
return False
elif among_var == 6:
if not self.slice_from(u"avimas"):
return False
elif among_var == 7:
if not self.slice_from(u"ojimas"):
return False
else:
if not self.slice_from(u"okat\u0117"):
return False
return True
def __r_fix_chdz(self):
self.ket = self.cursor
among_var = self.find_among_b(LithuanianStemmer.a_3)
if among_var == 0:
return False
self.bra = self.cursor
if among_var == 1:
if not self.slice_from(u"t"):
return False
else:
if not self.slice_from(u"d"):
return False
return True
def __r_fix_gd(self):
self.ket = self.cursor
if self.find_among_b(LithuanianStemmer.a_4) == 0:
return False
self.bra = self.cursor
if not self.slice_from(u"g"):
return False
return True
def _stem(self):
self.I_p1 = self.limit
v_1 = self.cursor
try:
v_2 = self.cursor
try:
v_3 = self.cursor
if not self.eq_s(u"a"):
self.cursor = v_2
raise lab1()
self.cursor = v_3
if not len(self.current) > 6:
self.cursor = v_2
raise lab1()
c = self.cursor + 1
if c > self.limit:
self.cursor = v_2
raise lab1()
self.cursor = c
except lab1: pass
if not self.go_out_grouping(LithuanianStemmer.g_v, 97, 371):
raise lab0()
self.cursor += 1
if not self.go_in_grouping(LithuanianStemmer.g_v, 97, 371):
raise lab0()
self.cursor += 1
self.I_p1 = self.cursor
except lab0: pass
self.cursor = v_1
self.limit_backward = self.cursor
self.cursor = self.limit
v_4 = self.limit - self.cursor
self.__r_fix_conflicts()
self.cursor = self.limit - v_4
v_5 = self.limit - self.cursor
self.__r_step1()
self.cursor = self.limit - v_5
v_6 = self.limit - self.cursor
self.__r_fix_chdz()
self.cursor = self.limit - v_6
v_7 = self.limit - self.cursor
self.__r_step2()
self.cursor = self.limit - v_7
v_8 = self.limit - self.cursor
self.__r_fix_chdz()
self.cursor = self.limit - v_8
v_9 = self.limit - self.cursor
self.__r_fix_gd()
self.cursor = self.limit - v_9
self.cursor = self.limit_backward
return True
class lab0(BaseException): pass
class lab1(BaseException): pass