From cf7da1843c45a4c2df7a749f7886a2d2ba0ee92a Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 15 Apr 2024 19:25:40 +0200 Subject: Adding upstream version 7.2.6. Signed-off-by: Daniel Baumann --- sphinx/search/non-minified-js/swedish-stemmer.js | 265 +++++++++++++++++++++++ 1 file changed, 265 insertions(+) create mode 100644 sphinx/search/non-minified-js/swedish-stemmer.js (limited to 'sphinx/search/non-minified-js/swedish-stemmer.js') diff --git a/sphinx/search/non-minified-js/swedish-stemmer.js b/sphinx/search/non-minified-js/swedish-stemmer.js new file mode 100644 index 0000000..4d7d49f --- /dev/null +++ b/sphinx/search/non-minified-js/swedish-stemmer.js @@ -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 */ g_v = [17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 24, 0, 32]; + + /** @const */ var /** Array */ 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(); + }; +}; -- cgit v1.2.3