针对pulse-transit的工具
This commit is contained in:
265
dist/client/sphinx/search/non-minified-js/swedish-stemmer.js
vendored
Normal file
265
dist/client/sphinx/search/non-minified-js/swedish-stemmer.js
vendored
Normal file
@@ -0,0 +1,265 @@
|
||||
// Generated by Snowball 2.1.0 - https://snowballstem.org/
|
||||
|
||||
/**@constructor*/
|
||||
SwedishStemmer = function() {
|
||||
var base = new BaseStemmer();
|
||||
/** @const */ var a_0 = [
|
||||
["a", -1, 1],
|
||||
["arna", 0, 1],
|
||||
["erna", 0, 1],
|
||||
["heterna", 2, 1],
|
||||
["orna", 0, 1],
|
||||
["ad", -1, 1],
|
||||
["e", -1, 1],
|
||||
["ade", 6, 1],
|
||||
["ande", 6, 1],
|
||||
["arne", 6, 1],
|
||||
["are", 6, 1],
|
||||
["aste", 6, 1],
|
||||
["en", -1, 1],
|
||||
["anden", 12, 1],
|
||||
["aren", 12, 1],
|
||||
["heten", 12, 1],
|
||||
["ern", -1, 1],
|
||||
["ar", -1, 1],
|
||||
["er", -1, 1],
|
||||
["heter", 18, 1],
|
||||
["or", -1, 1],
|
||||
["s", -1, 2],
|
||||
["as", 21, 1],
|
||||
["arnas", 22, 1],
|
||||
["ernas", 22, 1],
|
||||
["ornas", 22, 1],
|
||||
["es", 21, 1],
|
||||
["ades", 26, 1],
|
||||
["andes", 26, 1],
|
||||
["ens", 21, 1],
|
||||
["arens", 29, 1],
|
||||
["hetens", 29, 1],
|
||||
["erns", 21, 1],
|
||||
["at", -1, 1],
|
||||
["andet", -1, 1],
|
||||
["het", -1, 1],
|
||||
["ast", -1, 1]
|
||||
];
|
||||
|
||||
/** @const */ var a_1 = [
|
||||
["dd", -1, -1],
|
||||
["gd", -1, -1],
|
||||
["nn", -1, -1],
|
||||
["dt", -1, -1],
|
||||
["gt", -1, -1],
|
||||
["kt", -1, -1],
|
||||
["tt", -1, -1]
|
||||
];
|
||||
|
||||
/** @const */ var a_2 = [
|
||||
["ig", -1, 1],
|
||||
["lig", 0, 1],
|
||||
["els", -1, 1],
|
||||
["fullt", -1, 3],
|
||||
["l\u00F6st", -1, 2]
|
||||
];
|
||||
|
||||
/** @const */ var /** Array<int> */ g_v = [17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 24, 0, 32];
|
||||
|
||||
/** @const */ var /** Array<int> */ g_s_ending = [119, 127, 149];
|
||||
|
||||
var /** number */ I_x = 0;
|
||||
var /** number */ I_p1 = 0;
|
||||
|
||||
|
||||
/** @return {boolean} */
|
||||
function r_mark_regions() {
|
||||
I_p1 = base.limit;
|
||||
var /** number */ v_1 = base.cursor;
|
||||
{
|
||||
var /** number */ c1 = base.cursor + 3;
|
||||
if (c1 > base.limit)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
base.cursor = c1;
|
||||
}
|
||||
I_x = base.cursor;
|
||||
base.cursor = v_1;
|
||||
golab0: while(true)
|
||||
{
|
||||
var /** number */ v_2 = base.cursor;
|
||||
lab1: {
|
||||
if (!(base.in_grouping(g_v, 97, 246)))
|
||||
{
|
||||
break lab1;
|
||||
}
|
||||
base.cursor = v_2;
|
||||
break golab0;
|
||||
}
|
||||
base.cursor = v_2;
|
||||
if (base.cursor >= base.limit)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
base.cursor++;
|
||||
}
|
||||
golab2: while(true)
|
||||
{
|
||||
lab3: {
|
||||
if (!(base.out_grouping(g_v, 97, 246)))
|
||||
{
|
||||
break lab3;
|
||||
}
|
||||
break golab2;
|
||||
}
|
||||
if (base.cursor >= base.limit)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
base.cursor++;
|
||||
}
|
||||
I_p1 = base.cursor;
|
||||
lab4: {
|
||||
if (!(I_p1 < I_x))
|
||||
{
|
||||
break lab4;
|
||||
}
|
||||
I_p1 = I_x;
|
||||
}
|
||||
return true;
|
||||
};
|
||||
|
||||
/** @return {boolean} */
|
||||
function r_main_suffix() {
|
||||
var /** number */ among_var;
|
||||
if (base.cursor < I_p1)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
var /** number */ v_2 = base.limit_backward;
|
||||
base.limit_backward = I_p1;
|
||||
base.ket = base.cursor;
|
||||
among_var = base.find_among_b(a_0);
|
||||
if (among_var == 0)
|
||||
{
|
||||
base.limit_backward = v_2;
|
||||
return false;
|
||||
}
|
||||
base.bra = base.cursor;
|
||||
base.limit_backward = v_2;
|
||||
switch (among_var) {
|
||||
case 1:
|
||||
if (!base.slice_del())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
if (!(base.in_grouping_b(g_s_ending, 98, 121)))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
if (!base.slice_del())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
}
|
||||
return true;
|
||||
};
|
||||
|
||||
/** @return {boolean} */
|
||||
function r_consonant_pair() {
|
||||
if (base.cursor < I_p1)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
var /** number */ v_2 = base.limit_backward;
|
||||
base.limit_backward = I_p1;
|
||||
var /** number */ v_3 = base.limit - base.cursor;
|
||||
if (base.find_among_b(a_1) == 0)
|
||||
{
|
||||
base.limit_backward = v_2;
|
||||
return false;
|
||||
}
|
||||
base.cursor = base.limit - v_3;
|
||||
base.ket = base.cursor;
|
||||
if (base.cursor <= base.limit_backward)
|
||||
{
|
||||
base.limit_backward = v_2;
|
||||
return false;
|
||||
}
|
||||
base.cursor--;
|
||||
base.bra = base.cursor;
|
||||
if (!base.slice_del())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
base.limit_backward = v_2;
|
||||
return true;
|
||||
};
|
||||
|
||||
/** @return {boolean} */
|
||||
function r_other_suffix() {
|
||||
var /** number */ among_var;
|
||||
if (base.cursor < I_p1)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
var /** number */ v_2 = base.limit_backward;
|
||||
base.limit_backward = I_p1;
|
||||
base.ket = base.cursor;
|
||||
among_var = base.find_among_b(a_2);
|
||||
if (among_var == 0)
|
||||
{
|
||||
base.limit_backward = v_2;
|
||||
return false;
|
||||
}
|
||||
base.bra = base.cursor;
|
||||
switch (among_var) {
|
||||
case 1:
|
||||
if (!base.slice_del())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
if (!base.slice_from("l\u00F6s"))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (!base.slice_from("full"))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
}
|
||||
base.limit_backward = v_2;
|
||||
return true;
|
||||
};
|
||||
|
||||
this.stem = /** @return {boolean} */ function() {
|
||||
var /** number */ v_1 = base.cursor;
|
||||
r_mark_regions();
|
||||
base.cursor = v_1;
|
||||
base.limit_backward = base.cursor; base.cursor = base.limit;
|
||||
var /** number */ v_2 = base.limit - base.cursor;
|
||||
r_main_suffix();
|
||||
base.cursor = base.limit - v_2;
|
||||
var /** number */ v_3 = base.limit - base.cursor;
|
||||
r_consonant_pair();
|
||||
base.cursor = base.limit - v_3;
|
||||
var /** number */ v_4 = base.limit - base.cursor;
|
||||
r_other_suffix();
|
||||
base.cursor = base.limit - v_4;
|
||||
base.cursor = base.limit_backward;
|
||||
return true;
|
||||
};
|
||||
|
||||
/**@return{string}*/
|
||||
this['stemWord'] = function(/**string*/word) {
|
||||
base.setCurrent(word);
|
||||
this.stem();
|
||||
return base.getCurrent();
|
||||
};
|
||||
};
|
||||
Reference in New Issue
Block a user