00001
00002
00003 #include <limits.h>
00004 #include "porter.h"
00005
00006 #define s_0_0 (s_0_1 + 2)
00007 static const symbol s_pool[] = {
00008 #define s_0_1 0
00009 'i', 'e', 's',
00010 #define s_0_2 3
00011 's', 's', 'e', 's',
00012 #define s_0_3 s_0_2
00013 #define s_1_1 7
00014 'b', 'b',
00015 #define s_1_2 9
00016 'd', 'd',
00017 #define s_1_3 11
00018 'f', 'f',
00019 #define s_1_4 13
00020 'g', 'g',
00021 #define s_1_5 15
00022 'b', 'l',
00023 #define s_1_6 17
00024 'm', 'm',
00025 #define s_1_7 19
00026 'n', 'n',
00027 #define s_1_8 21
00028 'p', 'p',
00029 #define s_1_9 23
00030 'r', 'r',
00031 #define s_1_10 25
00032 'a', 't',
00033 #define s_1_11 27
00034 't', 't',
00035 #define s_1_12 29
00036 'i', 'z',
00037 #define s_2_0 (s_2_1 + 1)
00038 #define s_2_1 31
00039 'e', 'e', 'd',
00040 #define s_2_2 34
00041 'i', 'n', 'g',
00042 #define s_3_0 37
00043 'a', 'n', 'c', 'i',
00044 #define s_3_1 41
00045 'e', 'n', 'c', 'i',
00046 #define s_3_2 45
00047 'a', 'b', 'l', 'i',
00048 #define s_3_3 49
00049 'e', 'l', 'i',
00050 #define s_3_4 52
00051 'a', 'l', 'l', 'i',
00052 #define s_3_5 56
00053 'o', 'u', 's', 'l', 'i',
00054 #define s_3_6 61
00055 'e', 'n', 't', 'l', 'i',
00056 #define s_3_7 66
00057 'a', 'l', 'i', 't', 'i',
00058 #define s_3_8 71
00059 'b', 'i', 'l', 'i', 't', 'i',
00060 #define s_3_9 77
00061 'i', 'v', 'i', 't', 'i',
00062 #define s_3_10 (s_3_11 + 1)
00063 #define s_3_11 82
00064 'a', 't', 'i', 'o', 'n', 'a', 'l',
00065 #define s_3_12 89
00066 'a', 'l', 'i', 's', 'm',
00067 #define s_3_13 s_3_11
00068 #define s_3_14 94
00069 'i', 'z', 'a', 't', 'i', 'o', 'n',
00070 #define s_3_15 101
00071 'i', 'z', 'e', 'r',
00072 #define s_3_16 105
00073 'a', 't', 'o', 'r',
00074 #define s_3_17 109
00075 'i', 'v', 'e', 'n', 'e', 's', 's',
00076 #define s_3_18 116
00077 'f', 'u', 'l', 'n', 'e', 's', 's',
00078 #define s_3_19 123
00079 'o', 'u', 's', 'n', 'e', 's', 's',
00080 #define s_4_0 130
00081 'i', 'c', 'a', 't', 'e',
00082 #define s_4_1 135
00083 'a', 't', 'i', 'v', 'e',
00084 #define s_4_2 140
00085 'a', 'l', 'i', 'z', 'e',
00086 #define s_4_3 145
00087 'i', 'c', 'i', 't', 'i',
00088 #define s_4_4 150
00089 'i', 'c', 'a', 'l',
00090 #define s_4_5 154
00091 'f', 'u', 'l',
00092 #define s_4_6 157
00093 'n', 'e', 's', 's',
00094 #define s_5_0 161
00095 'i', 'c',
00096 #define s_5_1 163
00097 'a', 'n', 'c', 'e',
00098 #define s_5_2 167
00099 'e', 'n', 'c', 'e',
00100 #define s_5_3 171
00101 'a', 'b', 'l', 'e',
00102 #define s_5_4 175
00103 'i', 'b', 'l', 'e',
00104 #define s_5_5 179
00105 'a', 't', 'e',
00106 #define s_5_6 182
00107 'i', 'v', 'e',
00108 #define s_5_7 185
00109 'i', 'z', 'e',
00110 #define s_5_8 188
00111 'i', 't', 'i',
00112 #define s_5_9 191
00113 'a', 'l',
00114 #define s_5_10 193
00115 'i', 's', 'm',
00116 #define s_5_11 196
00117 'i', 'o', 'n',
00118 #define s_5_12 199
00119 'e', 'r',
00120 #define s_5_13 201
00121 'o', 'u', 's',
00122 #define s_5_14 204
00123 'a', 'n', 't',
00124 #define s_5_15 (s_5_16 + 1)
00125 #define s_5_16 (s_5_17 + 1)
00126 #define s_5_17 207
00127 'e', 'm', 'e', 'n', 't',
00128 #define s_5_18 s_5_13
00129 };
00130
00131
00132 static const struct among a_0[4] =
00133 {
00134 { 1, s_0_0, -1, 3},
00135 { 3, s_0_1, 0, 2},
00136 { 4, s_0_2, 0, 1},
00137 { 2, s_0_3, 0, -1}
00138 };
00139
00140
00141 static const struct among a_1[13] =
00142 {
00143 { 0, 0, -1, 3},
00144 { 2, s_1_1, 0, 2},
00145 { 2, s_1_2, 0, 2},
00146 { 2, s_1_3, 0, 2},
00147 { 2, s_1_4, 0, 2},
00148 { 2, s_1_5, 0, 1},
00149 { 2, s_1_6, 0, 2},
00150 { 2, s_1_7, 0, 2},
00151 { 2, s_1_8, 0, 2},
00152 { 2, s_1_9, 0, 2},
00153 { 2, s_1_10, 0, 1},
00154 { 2, s_1_11, 0, 2},
00155 { 2, s_1_12, 0, 1}
00156 };
00157
00158
00159 static const struct among a_2[3] =
00160 {
00161 { 2, s_2_0, -1, 2},
00162 { 3, s_2_1, 0, 1},
00163 { 3, s_2_2, -1, 2}
00164 };
00165
00166
00167 static const struct among a_3[20] =
00168 {
00169 { 4, s_3_0, -1, 3},
00170 { 4, s_3_1, -1, 2},
00171 { 4, s_3_2, -1, 4},
00172 { 3, s_3_3, -1, 6},
00173 { 4, s_3_4, -1, 9},
00174 { 5, s_3_5, -1, 12},
00175 { 5, s_3_6, -1, 5},
00176 { 5, s_3_7, -1, 10},
00177 { 6, s_3_8, -1, 14},
00178 { 5, s_3_9, -1, 13},
00179 { 6, s_3_10, -1, 1},
00180 { 7, s_3_11, 10, 8},
00181 { 5, s_3_12, -1, 10},
00182 { 5, s_3_13, -1, 8},
00183 { 7, s_3_14, 13, 7},
00184 { 4, s_3_15, -1, 7},
00185 { 4, s_3_16, -1, 8},
00186 { 7, s_3_17, -1, 13},
00187 { 7, s_3_18, -1, 11},
00188 { 7, s_3_19, -1, 12}
00189 };
00190
00191
00192 static const struct among a_4[7] =
00193 {
00194 { 5, s_4_0, -1, 2},
00195 { 5, s_4_1, -1, 3},
00196 { 5, s_4_2, -1, 1},
00197 { 5, s_4_3, -1, 2},
00198 { 4, s_4_4, -1, 2},
00199 { 3, s_4_5, -1, 3},
00200 { 4, s_4_6, -1, 3}
00201 };
00202
00203
00204 static const struct among a_5[19] =
00205 {
00206 { 2, s_5_0, -1, 1},
00207 { 4, s_5_1, -1, 1},
00208 { 4, s_5_2, -1, 1},
00209 { 4, s_5_3, -1, 1},
00210 { 4, s_5_4, -1, 1},
00211 { 3, s_5_5, -1, 1},
00212 { 3, s_5_6, -1, 1},
00213 { 3, s_5_7, -1, 1},
00214 { 3, s_5_8, -1, 1},
00215 { 2, s_5_9, -1, 1},
00216 { 3, s_5_10, -1, 1},
00217 { 3, s_5_11, -1, 2},
00218 { 2, s_5_12, -1, 1},
00219 { 3, s_5_13, -1, 1},
00220 { 3, s_5_14, -1, 1},
00221 { 3, s_5_15, -1, 1},
00222 { 4, s_5_16, 15, 1},
00223 { 5, s_5_17, 16, 1},
00224 { 2, s_5_18, -1, 1}
00225 };
00226
00227 static const unsigned char g_v[] = { 17, 65, 16, 1 };
00228
00229 static const unsigned char g_v_WXY[] = { 1, 17, 65, 208, 1 };
00230
00231 static const symbol s_0[] = { 's', 's' };
00232 static const symbol s_1[] = { 'i' };
00233 static const symbol s_2[] = { 'e', 'e' };
00234 static const symbol s_3[] = { 'e' };
00235 static const symbol s_4[] = { 'e' };
00236 static const symbol s_5[] = { 'i' };
00237 static const symbol s_6[] = { 't', 'i', 'o', 'n' };
00238 static const symbol s_7[] = { 'e', 'n', 'c', 'e' };
00239 static const symbol s_8[] = { 'a', 'n', 'c', 'e' };
00240 static const symbol s_9[] = { 'a', 'b', 'l', 'e' };
00241 static const symbol s_10[] = { 'e', 'n', 't' };
00242 static const symbol s_11[] = { 'e' };
00243 static const symbol s_12[] = { 'i', 'z', 'e' };
00244 static const symbol s_13[] = { 'a', 't', 'e' };
00245 static const symbol s_14[] = { 'a', 'l' };
00246 static const symbol s_15[] = { 'a', 'l' };
00247 static const symbol s_16[] = { 'f', 'u', 'l' };
00248 static const symbol s_17[] = { 'o', 'u', 's' };
00249 static const symbol s_18[] = { 'i', 'v', 'e' };
00250 static const symbol s_19[] = { 'b', 'l', 'e' };
00251 static const symbol s_20[] = { 'a', 'l' };
00252 static const symbol s_21[] = { 'i', 'c' };
00253 static const symbol s_22[] = { 'Y' };
00254 static const symbol s_23[] = { 'Y' };
00255 static const symbol s_24[] = { 'y' };
00256
00257 int Xapian::InternalStemPorter::r_shortv() {
00258 if (out_grouping_b_U(g_v_WXY, 89, 121, 0)) return 0;
00259 if (in_grouping_b_U(g_v, 97, 121, 0)) return 0;
00260 if (out_grouping_b_U(g_v, 97, 121, 0)) return 0;
00261 return 1;
00262 }
00263
00264 int Xapian::InternalStemPorter::r_R1() {
00265 if (!(I_p1 <= c)) return 0;
00266 return 1;
00267 }
00268
00269 int Xapian::InternalStemPorter::r_R2() {
00270 if (!(I_p2 <= c)) return 0;
00271 return 1;
00272 }
00273
00274 int Xapian::InternalStemPorter::r_Step_1a() {
00275 int among_var;
00276 ket = c;
00277 if (c <= lb || p[c - 1] != 115) return 0;
00278 among_var = find_among_b(s_pool, a_0, 4, 0, 0);
00279 if (!(among_var)) return 0;
00280 bra = c;
00281 switch(among_var) {
00282 case 0: return 0;
00283 case 1:
00284 { int ret = slice_from_s(2, s_0);
00285 if (ret < 0) return ret;
00286 }
00287 break;
00288 case 2:
00289 { int ret = slice_from_s(1, s_1);
00290 if (ret < 0) return ret;
00291 }
00292 break;
00293 case 3:
00294 if (slice_del() == -1) return -1;
00295 break;
00296 }
00297 return 1;
00298 }
00299
00300 int Xapian::InternalStemPorter::r_Step_1b() {
00301 int among_var;
00302 ket = c;
00303 if (c - 1 <= lb || (p[c - 1] != 100 && p[c - 1] != 103)) return 0;
00304 among_var = find_among_b(s_pool, a_2, 3, 0, 0);
00305 if (!(among_var)) return 0;
00306 bra = c;
00307 switch(among_var) {
00308 case 0: return 0;
00309 case 1:
00310 { int ret = r_R1();
00311 if (ret <= 0) return ret;
00312 }
00313 { int ret = slice_from_s(2, s_2);
00314 if (ret < 0) return ret;
00315 }
00316 break;
00317 case 2:
00318 { int m_test1 = l - c;
00319 { int ret = out_grouping_b_U(g_v, 97, 121, 1);
00320 if (ret < 0) return 0;
00321 c -= ret;
00322 }
00323 c = l - m_test1;
00324 }
00325 if (slice_del() == -1) return -1;
00326 { int m_test2 = l - c;
00327 if (c - 1 <= lb || p[c - 1] >> 5 != 3 || !((68514004 >> (p[c - 1] & 0x1f)) & 1)) among_var = 3; else
00328 among_var = find_among_b(s_pool, a_1, 13, 0, 0);
00329 if (!(among_var)) return 0;
00330 c = l - m_test2;
00331 }
00332 switch(among_var) {
00333 case 0: return 0;
00334 case 1:
00335 { int saved_c = c;
00336 insert_s(c, c, 1, s_3);
00337 c = saved_c;
00338 }
00339 break;
00340 case 2:
00341 ket = c;
00342 { int ret = skip_utf8(p, c, lb, 0, -1);
00343 if (ret < 0) return 0;
00344 c = ret;
00345 }
00346 bra = c;
00347 if (slice_del() == -1) return -1;
00348 break;
00349 case 3:
00350 if (c != I_p1) return 0;
00351 { int m_test3 = l - c;
00352 { int ret = r_shortv();
00353 if (ret <= 0) return ret;
00354 }
00355 c = l - m_test3;
00356 }
00357 { int saved_c = c;
00358 insert_s(c, c, 1, s_4);
00359 c = saved_c;
00360 }
00361 break;
00362 }
00363 break;
00364 }
00365 return 1;
00366 }
00367
00368 int Xapian::InternalStemPorter::r_Step_1c() {
00369 ket = c;
00370 { int m1 = l - c; (void)m1;
00371 if (c <= lb || p[c - 1] != 'y') goto lab1;
00372 c--;
00373 goto lab0;
00374 lab1:
00375 c = l - m1;
00376 if (c <= lb || p[c - 1] != 'Y') return 0;
00377 c--;
00378 }
00379 lab0:
00380 bra = c;
00381 { int ret = out_grouping_b_U(g_v, 97, 121, 1);
00382 if (ret < 0) return 0;
00383 c -= ret;
00384 }
00385 { int ret = slice_from_s(1, s_5);
00386 if (ret < 0) return ret;
00387 }
00388 return 1;
00389 }
00390
00391 int Xapian::InternalStemPorter::r_Step_2() {
00392 int among_var;
00393 ket = c;
00394 if (c - 2 <= lb || p[c - 1] >> 5 != 3 || !((815616 >> (p[c - 1] & 0x1f)) & 1)) return 0;
00395 among_var = find_among_b(s_pool, a_3, 20, 0, 0);
00396 if (!(among_var)) return 0;
00397 bra = c;
00398 { int ret = r_R1();
00399 if (ret <= 0) return ret;
00400 }
00401 switch(among_var) {
00402 case 0: return 0;
00403 case 1:
00404 { int ret = slice_from_s(4, s_6);
00405 if (ret < 0) return ret;
00406 }
00407 break;
00408 case 2:
00409 { int ret = slice_from_s(4, s_7);
00410 if (ret < 0) return ret;
00411 }
00412 break;
00413 case 3:
00414 { int ret = slice_from_s(4, s_8);
00415 if (ret < 0) return ret;
00416 }
00417 break;
00418 case 4:
00419 { int ret = slice_from_s(4, s_9);
00420 if (ret < 0) return ret;
00421 }
00422 break;
00423 case 5:
00424 { int ret = slice_from_s(3, s_10);
00425 if (ret < 0) return ret;
00426 }
00427 break;
00428 case 6:
00429 { int ret = slice_from_s(1, s_11);
00430 if (ret < 0) return ret;
00431 }
00432 break;
00433 case 7:
00434 { int ret = slice_from_s(3, s_12);
00435 if (ret < 0) return ret;
00436 }
00437 break;
00438 case 8:
00439 { int ret = slice_from_s(3, s_13);
00440 if (ret < 0) return ret;
00441 }
00442 break;
00443 case 9:
00444 { int ret = slice_from_s(2, s_14);
00445 if (ret < 0) return ret;
00446 }
00447 break;
00448 case 10:
00449 { int ret = slice_from_s(2, s_15);
00450 if (ret < 0) return ret;
00451 }
00452 break;
00453 case 11:
00454 { int ret = slice_from_s(3, s_16);
00455 if (ret < 0) return ret;
00456 }
00457 break;
00458 case 12:
00459 { int ret = slice_from_s(3, s_17);
00460 if (ret < 0) return ret;
00461 }
00462 break;
00463 case 13:
00464 { int ret = slice_from_s(3, s_18);
00465 if (ret < 0) return ret;
00466 }
00467 break;
00468 case 14:
00469 { int ret = slice_from_s(3, s_19);
00470 if (ret < 0) return ret;
00471 }
00472 break;
00473 }
00474 return 1;
00475 }
00476
00477 int Xapian::InternalStemPorter::r_Step_3() {
00478 int among_var;
00479 ket = c;
00480 if (c - 2 <= lb || p[c - 1] >> 5 != 3 || !((528928 >> (p[c - 1] & 0x1f)) & 1)) return 0;
00481 among_var = find_among_b(s_pool, a_4, 7, 0, 0);
00482 if (!(among_var)) return 0;
00483 bra = c;
00484 { int ret = r_R1();
00485 if (ret <= 0) return ret;
00486 }
00487 switch(among_var) {
00488 case 0: return 0;
00489 case 1:
00490 { int ret = slice_from_s(2, s_20);
00491 if (ret < 0) return ret;
00492 }
00493 break;
00494 case 2:
00495 { int ret = slice_from_s(2, s_21);
00496 if (ret < 0) return ret;
00497 }
00498 break;
00499 case 3:
00500 if (slice_del() == -1) return -1;
00501 break;
00502 }
00503 return 1;
00504 }
00505
00506 int Xapian::InternalStemPorter::r_Step_4() {
00507 int among_var;
00508 ket = c;
00509 if (c - 1 <= lb || p[c - 1] >> 5 != 3 || !((3961384 >> (p[c - 1] & 0x1f)) & 1)) return 0;
00510 among_var = find_among_b(s_pool, a_5, 19, 0, 0);
00511 if (!(among_var)) return 0;
00512 bra = c;
00513 { int ret = r_R2();
00514 if (ret <= 0) return ret;
00515 }
00516 switch(among_var) {
00517 case 0: return 0;
00518 case 1:
00519 if (slice_del() == -1) return -1;
00520 break;
00521 case 2:
00522 { int m1 = l - c; (void)m1;
00523 if (c <= lb || p[c - 1] != 's') goto lab1;
00524 c--;
00525 goto lab0;
00526 lab1:
00527 c = l - m1;
00528 if (c <= lb || p[c - 1] != 't') return 0;
00529 c--;
00530 }
00531 lab0:
00532 if (slice_del() == -1) return -1;
00533 break;
00534 }
00535 return 1;
00536 }
00537
00538 int Xapian::InternalStemPorter::r_Step_5a() {
00539 ket = c;
00540 if (c <= lb || p[c - 1] != 'e') return 0;
00541 c--;
00542 bra = c;
00543 { int m1 = l - c; (void)m1;
00544 { int ret = r_R2();
00545 if (ret == 0) goto lab1;
00546 if (ret < 0) return ret;
00547 }
00548 goto lab0;
00549 lab1:
00550 c = l - m1;
00551 { int ret = r_R1();
00552 if (ret <= 0) return ret;
00553 }
00554 { int m2 = l - c; (void)m2;
00555 { int ret = r_shortv();
00556 if (ret == 0) goto lab2;
00557 if (ret < 0) return ret;
00558 }
00559 return 0;
00560 lab2:
00561 c = l - m2;
00562 }
00563 }
00564 lab0:
00565 if (slice_del() == -1) return -1;
00566 return 1;
00567 }
00568
00569 int Xapian::InternalStemPorter::r_Step_5b() {
00570 ket = c;
00571 if (c <= lb || p[c - 1] != 'l') return 0;
00572 c--;
00573 bra = c;
00574 { int ret = r_R2();
00575 if (ret <= 0) return ret;
00576 }
00577 if (c <= lb || p[c - 1] != 'l') return 0;
00578 c--;
00579 if (slice_del() == -1) return -1;
00580 return 1;
00581 }
00582
00583 int Xapian::InternalStemPorter::stem() {
00584 B_Y_found = 0;
00585 { int c1 = c;
00586 bra = c;
00587 if (c == l || p[c] != 'y') goto lab0;
00588 c++;
00589 ket = c;
00590 { int ret = slice_from_s(1, s_22);
00591 if (ret < 0) return ret;
00592 }
00593 B_Y_found = 1;
00594 lab0:
00595 c = c1;
00596 }
00597 { int c2 = c;
00598 while(1) {
00599 int c3 = c;
00600 while(1) {
00601 int c4 = c;
00602 if (in_grouping_U(g_v, 97, 121, 0)) goto lab3;
00603 bra = c;
00604 if (c == l || p[c] != 'y') goto lab3;
00605 c++;
00606 ket = c;
00607 c = c4;
00608 break;
00609 lab3:
00610 c = c4;
00611 { int ret = skip_utf8(p, c, 0, l, 1);
00612 if (ret < 0) goto lab2;
00613 c = ret;
00614 }
00615 }
00616 { int ret = slice_from_s(1, s_23);
00617 if (ret < 0) return ret;
00618 }
00619 B_Y_found = 1;
00620 continue;
00621 lab2:
00622 c = c3;
00623 break;
00624 }
00625 c = c2;
00626 }
00627 I_p1 = l;
00628 I_p2 = l;
00629 { int c5 = c;
00630 { int ret = out_grouping_U(g_v, 97, 121, 1);
00631 if (ret < 0) goto lab4;
00632 c += ret;
00633 }
00634 { int ret = in_grouping_U(g_v, 97, 121, 1);
00635 if (ret < 0) goto lab4;
00636 c += ret;
00637 }
00638 I_p1 = c;
00639 { int ret = out_grouping_U(g_v, 97, 121, 1);
00640 if (ret < 0) goto lab4;
00641 c += ret;
00642 }
00643 { int ret = in_grouping_U(g_v, 97, 121, 1);
00644 if (ret < 0) goto lab4;
00645 c += ret;
00646 }
00647 I_p2 = c;
00648 lab4:
00649 c = c5;
00650 }
00651 lb = c; c = l;
00652
00653 { int m6 = l - c; (void)m6;
00654 { int ret = r_Step_1a();
00655 if (ret == 0) goto lab5;
00656 if (ret < 0) return ret;
00657 }
00658 lab5:
00659 c = l - m6;
00660 }
00661 { int m7 = l - c; (void)m7;
00662 { int ret = r_Step_1b();
00663 if (ret == 0) goto lab6;
00664 if (ret < 0) return ret;
00665 }
00666 lab6:
00667 c = l - m7;
00668 }
00669 { int m8 = l - c; (void)m8;
00670 { int ret = r_Step_1c();
00671 if (ret == 0) goto lab7;
00672 if (ret < 0) return ret;
00673 }
00674 lab7:
00675 c = l - m8;
00676 }
00677 { int m9 = l - c; (void)m9;
00678 { int ret = r_Step_2();
00679 if (ret == 0) goto lab8;
00680 if (ret < 0) return ret;
00681 }
00682 lab8:
00683 c = l - m9;
00684 }
00685 { int m10 = l - c; (void)m10;
00686 { int ret = r_Step_3();
00687 if (ret == 0) goto lab9;
00688 if (ret < 0) return ret;
00689 }
00690 lab9:
00691 c = l - m10;
00692 }
00693 { int m11 = l - c; (void)m11;
00694 { int ret = r_Step_4();
00695 if (ret == 0) goto lab10;
00696 if (ret < 0) return ret;
00697 }
00698 lab10:
00699 c = l - m11;
00700 }
00701 { int m12 = l - c; (void)m12;
00702 { int ret = r_Step_5a();
00703 if (ret == 0) goto lab11;
00704 if (ret < 0) return ret;
00705 }
00706 lab11:
00707 c = l - m12;
00708 }
00709 { int m13 = l - c; (void)m13;
00710 { int ret = r_Step_5b();
00711 if (ret == 0) goto lab12;
00712 if (ret < 0) return ret;
00713 }
00714 lab12:
00715 c = l - m13;
00716 }
00717 c = lb;
00718 { int c14 = c;
00719 if (!(B_Y_found)) goto lab13;
00720 while(1) {
00721 int c15 = c;
00722 while(1) {
00723 int c16 = c;
00724 bra = c;
00725 if (c == l || p[c] != 'Y') goto lab15;
00726 c++;
00727 ket = c;
00728 c = c16;
00729 break;
00730 lab15:
00731 c = c16;
00732 { int ret = skip_utf8(p, c, 0, l, 1);
00733 if (ret < 0) goto lab14;
00734 c = ret;
00735 }
00736 }
00737 { int ret = slice_from_s(1, s_24);
00738 if (ret < 0) return ret;
00739 }
00740 continue;
00741 lab14:
00742 c = c15;
00743 break;
00744 }
00745 lab13:
00746 c = c14;
00747 }
00748 return 1;
00749 }
00750
00751 Xapian::InternalStemPorter::InternalStemPorter()
00752 : B_Y_found(0), I_p2(0), I_p1(0)
00753 {
00754 }
00755
00756 Xapian::InternalStemPorter::~InternalStemPorter()
00757 {
00758 }
00759
00760 std::string
00761 Xapian::InternalStemPorter::get_description() const
00762 {
00763 return "porter";
00764 }