diff options
Diffstat (limited to 'sphinx/search/non-minified-js/norwegian-stemmer.js')
-rw-r--r-- | sphinx/search/non-minified-js/norwegian-stemmer.js | 261 |
1 files changed, 261 insertions, 0 deletions
diff --git a/sphinx/search/non-minified-js/norwegian-stemmer.js b/sphinx/search/non-minified-js/norwegian-stemmer.js new file mode 100644 index 0000000..e176063 --- /dev/null +++ b/sphinx/search/non-minified-js/norwegian-stemmer.js @@ -0,0 +1,261 @@ +// Generated by Snowball 2.1.0 - https://snowballstem.org/ + +/**@constructor*/ +NorwegianStemmer = function() { + var base = new BaseStemmer(); + /** @const */ var a_0 = [ + ["a", -1, 1], + ["e", -1, 1], + ["ede", 1, 1], + ["ande", 1, 1], + ["ende", 1, 1], + ["ane", 1, 1], + ["ene", 1, 1], + ["hetene", 6, 1], + ["erte", 1, 3], + ["en", -1, 1], + ["heten", 9, 1], + ["ar", -1, 1], + ["er", -1, 1], + ["heter", 12, 1], + ["s", -1, 2], + ["as", 14, 1], + ["es", 14, 1], + ["edes", 16, 1], + ["endes", 16, 1], + ["enes", 16, 1], + ["hetenes", 19, 1], + ["ens", 14, 1], + ["hetens", 21, 1], + ["ers", 14, 1], + ["ets", 14, 1], + ["et", -1, 1], + ["het", 25, 1], + ["ert", -1, 3], + ["ast", -1, 1] + ]; + + /** @const */ var a_1 = [ + ["dt", -1, -1], + ["vt", -1, -1] + ]; + + /** @const */ var a_2 = [ + ["leg", -1, 1], + ["eleg", 0, 1], + ["ig", -1, 1], + ["eig", 2, 1], + ["lig", 2, 1], + ["elig", 4, 1], + ["els", -1, 1], + ["lov", -1, 1], + ["elov", 7, 1], + ["slov", 7, 1], + ["hetslov", 9, 1] + ]; + + /** @const */ var /** Array<int> */ g_v = [17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 48, 0, 128]; + + /** @const */ var /** Array<int> */ g_s_ending = [119, 125, 149, 1]; + + 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, 248))) + { + 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, 248))) + { + 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: + lab0: { + var /** number */ v_3 = base.limit - base.cursor; + lab1: { + if (!(base.in_grouping_b(g_s_ending, 98, 122))) + { + break lab1; + } + break lab0; + } + base.cursor = base.limit - v_3; + if (!(base.eq_s_b("k"))) + { + return false; + } + if (!(base.out_grouping_b(g_v, 97, 248))) + { + return false; + } + } + if (!base.slice_del()) + { + return false; + } + break; + case 3: + if (!base.slice_from("er")) + { + return false; + } + break; + } + return true; + }; + + /** @return {boolean} */ + function r_consonant_pair() { + var /** number */ v_1 = base.limit - base.cursor; + if (base.cursor < I_p1) + { + return false; + } + var /** number */ v_3 = base.limit_backward; + base.limit_backward = I_p1; + base.ket = base.cursor; + if (base.find_among_b(a_1) == 0) + { + base.limit_backward = v_3; + return false; + } + base.bra = base.cursor; + base.limit_backward = v_3; + base.cursor = base.limit - v_1; + if (base.cursor <= base.limit_backward) + { + return false; + } + base.cursor--; + base.bra = base.cursor; + if (!base.slice_del()) + { + return false; + } + return true; + }; + + /** @return {boolean} */ + function r_other_suffix() { + if (base.cursor < I_p1) + { + return false; + } + var /** number */ v_2 = base.limit_backward; + base.limit_backward = I_p1; + base.ket = base.cursor; + if (base.find_among_b(a_2) == 0) + { + base.limit_backward = v_2; + return false; + } + base.bra = base.cursor; + base.limit_backward = v_2; + if (!base.slice_del()) + { + return false; + } + 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(); + }; +}; |