summaryrefslogtreecommitdiffstats
path: root/sphinx/search/non-minified-js/norwegian-stemmer.js
diff options
context:
space:
mode:
Diffstat (limited to 'sphinx/search/non-minified-js/norwegian-stemmer.js')
-rw-r--r--sphinx/search/non-minified-js/norwegian-stemmer.js261
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();
+ };
+};