summaryrefslogtreecommitdiffstats
path: root/sphinx/search/non-minified-js/swedish-stemmer.js
diff options
context:
space:
mode:
Diffstat (limited to 'sphinx/search/non-minified-js/swedish-stemmer.js')
-rw-r--r--sphinx/search/non-minified-js/swedish-stemmer.js265
1 files changed, 265 insertions, 0 deletions
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<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();
+ };
+};