LUCENE-1189: Fixed the QueryParser to handle escaped characters within quoted terms correctly.

git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@660674 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael Busch 2008-05-27 19:55:36 +00:00
parent f32b5a5698
commit df7fb0f45c
6 changed files with 194 additions and 181 deletions

View File

@ -109,6 +109,9 @@ Bug fixes
10. LUCENE-1046: Removed dead code in SpellChecker 10. LUCENE-1046: Removed dead code in SpellChecker
(Daniel Naber via Otis Gospodnetic) (Daniel Naber via Otis Gospodnetic)
11. LUCENE-1189: Fixed the QueryParser to handle escaped characters within
quoted terms correctly. (Tomer Gabel via Michael Busch)
New features New features
1. LUCENE-1137: Added Token.set/getFlags() accessors for passing more information about a Token through the analysis 1. LUCENE-1137: Added Token.set/getFlags() accessors for passing more information about a Token through the analysis

View File

@ -1337,10 +1337,10 @@ public class QueryParser implements QueryParserConstants {
jj_la1_1(); jj_la1_1();
} }
private static void jj_la1_0() { private static void jj_la1_0() {
jj_la1_0 = new int[] {0x180,0x180,0xe00,0xe00,0x1f69f80,0x48000,0x10000,0x1f69000,0x1348000,0x80000,0x80000,0x10000,0x18000000,0x2000000,0x18000000,0x10000,0x80000000,0x20000000,0x80000000,0x10000,0x80000,0x10000,0x1f68000,}; jj_la1_0 = new int[] {0x300,0x300,0x1c00,0x1c00,0x3ed3f00,0x90000,0x20000,0x3ed2000,0x2690000,0x100000,0x100000,0x20000,0x30000000,0x4000000,0x30000000,0x20000,0x0,0x40000000,0x0,0x20000,0x100000,0x20000,0x3ed0000,};
} }
private static void jj_la1_1() { private static void jj_la1_1() {
jj_la1_1 = new int[] {0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x0,0x1,0x0,0x0,0x0,0x0,}; jj_la1_1 = new int[] {0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x3,0x0,0x3,0x0,0x0,0x0,0x0,};
} }
final private JJCalls[] jj_2_rtns = new JJCalls[1]; final private JJCalls[] jj_2_rtns = new JJCalls[1];
private boolean jj_rescan = false; private boolean jj_rescan = false;
@ -1489,10 +1489,7 @@ public class QueryParser implements QueryParserConstants {
public ParseException generateParseException() { public ParseException generateParseException() {
jj_expentries.removeAllElements(); jj_expentries.removeAllElements();
boolean[] la1tokens = new boolean[33]; boolean[] la1tokens = new boolean[34];
for (int i = 0; i < 33; i++) {
la1tokens[i] = false;
}
if (jj_kind >= 0) { if (jj_kind >= 0) {
la1tokens[jj_kind] = true; la1tokens[jj_kind] = true;
jj_kind = -1; jj_kind = -1;
@ -1509,7 +1506,7 @@ public class QueryParser implements QueryParserConstants {
} }
} }
} }
for (int i = 0; i < 33; i++) { for (int i = 0; i < 34; i++) {
if (la1tokens[i]) { if (la1tokens[i]) {
jj_expentry = new int[1]; jj_expentry = new int[1];
jj_expentry[0] = i; jj_expentry[0] = i;
@ -1535,6 +1532,7 @@ public class QueryParser implements QueryParserConstants {
final private void jj_rescan_token() { final private void jj_rescan_token() {
jj_rescan = true; jj_rescan = true;
for (int i = 0; i < 1; i++) { for (int i = 0; i < 1; i++) {
try {
JJCalls p = jj_2_rtns[i]; JJCalls p = jj_2_rtns[i];
do { do {
if (p.gen > jj_gen) { if (p.gen > jj_gen) {
@ -1545,6 +1543,7 @@ public class QueryParser implements QueryParserConstants {
} }
p = p.next; p = p.next;
} while (p != null); } while (p != null);
} catch(LookaheadSuccess ls) { }
} }
jj_rescan = false; jj_rescan = false;
} }

View File

@ -908,6 +908,7 @@ PARSER_END(QueryParser)
| <_ESCAPED_CHAR> ) > | <_ESCAPED_CHAR> ) >
| <#_TERM_CHAR: ( <_TERM_START_CHAR> | <_ESCAPED_CHAR> | "-" | "+" ) > | <#_TERM_CHAR: ( <_TERM_START_CHAR> | <_ESCAPED_CHAR> | "-" | "+" ) >
| <#_WHITESPACE: ( " " | "\t" | "\n" | "\r") > | <#_WHITESPACE: ( " " | "\t" | "\n" | "\r") >
| <#_QUOTED_CHAR: ( ~[ "\"", "\\" ] | <_ESCAPED_CHAR> ) >
} }
<DEFAULT, RangeIn, RangeEx> SKIP : { <DEFAULT, RangeIn, RangeEx> SKIP : {
@ -925,7 +926,7 @@ PARSER_END(QueryParser)
| <COLON: ":" > | <COLON: ":" >
| <STAR: "*" > | <STAR: "*" >
| <CARAT: "^" > : Boost | <CARAT: "^" > : Boost
| <QUOTED: "\"" (~["\""] | "\\\"")* "\""> | <QUOTED: "\"" (<_QUOTED_CHAR>)* "\"">
| <TERM: <_TERM_START_CHAR> (<_TERM_CHAR>)* > | <TERM: <_TERM_START_CHAR> (<_TERM_CHAR>)* >
| <FUZZY_SLOP: "~" ( (<_NUM_CHAR>)+ ( "." (<_NUM_CHAR>)+ )? )? > | <FUZZY_SLOP: "~" ( (<_NUM_CHAR>)+ ( "." (<_NUM_CHAR>)+ )? )? >
| <PREFIXTERM: ("*") | ( <_TERM_START_CHAR> (<_TERM_CHAR>)* "*" ) > | <PREFIXTERM: ("*") | ( <_TERM_START_CHAR> (<_TERM_CHAR>)* "*" ) >

View File

@ -9,32 +9,33 @@ public interface QueryParserConstants {
int _TERM_START_CHAR = 3; int _TERM_START_CHAR = 3;
int _TERM_CHAR = 4; int _TERM_CHAR = 4;
int _WHITESPACE = 5; int _WHITESPACE = 5;
int AND = 7; int _QUOTED_CHAR = 6;
int OR = 8; int AND = 8;
int NOT = 9; int OR = 9;
int PLUS = 10; int NOT = 10;
int MINUS = 11; int PLUS = 11;
int LPAREN = 12; int MINUS = 12;
int RPAREN = 13; int LPAREN = 13;
int COLON = 14; int RPAREN = 14;
int STAR = 15; int COLON = 15;
int CARAT = 16; int STAR = 16;
int QUOTED = 17; int CARAT = 17;
int TERM = 18; int QUOTED = 18;
int FUZZY_SLOP = 19; int TERM = 19;
int PREFIXTERM = 20; int FUZZY_SLOP = 20;
int WILDTERM = 21; int PREFIXTERM = 21;
int RANGEIN_START = 22; int WILDTERM = 22;
int RANGEEX_START = 23; int RANGEIN_START = 23;
int NUMBER = 24; int RANGEEX_START = 24;
int RANGEIN_TO = 25; int NUMBER = 25;
int RANGEIN_END = 26; int RANGEIN_TO = 26;
int RANGEIN_QUOTED = 27; int RANGEIN_END = 27;
int RANGEIN_GOOP = 28; int RANGEIN_QUOTED = 28;
int RANGEEX_TO = 29; int RANGEIN_GOOP = 29;
int RANGEEX_END = 30; int RANGEEX_TO = 30;
int RANGEEX_QUOTED = 31; int RANGEEX_END = 31;
int RANGEEX_GOOP = 32; int RANGEEX_QUOTED = 32;
int RANGEEX_GOOP = 33;
int Boost = 0; int Boost = 0;
int RangeEx = 1; int RangeEx = 1;
@ -48,7 +49,8 @@ public interface QueryParserConstants {
"<_TERM_START_CHAR>", "<_TERM_START_CHAR>",
"<_TERM_CHAR>", "<_TERM_CHAR>",
"<_WHITESPACE>", "<_WHITESPACE>",
"<token of kind 6>", "<_QUOTED_CHAR>",
"<token of kind 7>",
"<AND>", "<AND>",
"<OR>", "<OR>",
"<NOT>", "<NOT>",

View File

@ -45,23 +45,23 @@ private final int jjMoveStringLiteralDfa0_3()
switch(curChar) switch(curChar)
{ {
case 40: case 40:
return jjStopAtPos(0, 12);
case 41:
return jjStopAtPos(0, 13); return jjStopAtPos(0, 13);
case 42: case 41:
return jjStartNfaWithStates_3(0, 15, 36);
case 43:
return jjStopAtPos(0, 10);
case 45:
return jjStopAtPos(0, 11);
case 58:
return jjStopAtPos(0, 14); return jjStopAtPos(0, 14);
case 42:
return jjStartNfaWithStates_3(0, 16, 36);
case 43:
return jjStopAtPos(0, 11);
case 45:
return jjStopAtPos(0, 12);
case 58:
return jjStopAtPos(0, 15);
case 91: case 91:
return jjStopAtPos(0, 22);
case 94:
return jjStopAtPos(0, 16);
case 123:
return jjStopAtPos(0, 23); return jjStopAtPos(0, 23);
case 94:
return jjStopAtPos(0, 17);
case 123:
return jjStopAtPos(0, 24);
default : default :
return jjMoveNfa_3(0, 0); return jjMoveNfa_3(0, 0);
} }
@ -125,57 +125,56 @@ private final int jjMoveNfa_3(int startState, int curPos)
case 25: case 25:
if ((0xfbfffcf8ffffd9ffL & l) == 0L) if ((0xfbfffcf8ffffd9ffL & l) == 0L)
break; break;
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 0: case 0:
if ((0xfbffd4f8ffffd9ffL & l) != 0L) if ((0xfbffd4f8ffffd9ffL & l) != 0L)
{ {
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
} }
else if ((0x100002600L & l) != 0L) else if ((0x100002600L & l) != 0L)
{ {
if (kind > 6) if (kind > 7)
kind = 6; kind = 7;
} }
else if (curChar == 34) else if (curChar == 34)
jjCheckNAddStates(0, 2); jjCheckNAddStates(0, 2);
else if (curChar == 33) else if (curChar == 33)
{ {
if (kind > 9) if (kind > 10)
kind = 9; kind = 10;
} }
if ((0x7bffd0f8ffffd9ffL & l) != 0L) if ((0x7bffd0f8ffffd9ffL & l) != 0L)
{ {
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddStates(3, 7); jjCheckNAddStates(3, 7);
} }
else if (curChar == 42) else if (curChar == 42)
{ {
if (kind > 20) if (kind > 21)
kind = 20; kind = 21;
} }
if (curChar == 38) if (curChar == 38)
jjstateSet[jjnewStateCnt++] = 4; jjstateSet[jjnewStateCnt++] = 4;
break; break;
case 4: case 4:
if (curChar == 38 && kind > 7) if (curChar == 38 && kind > 8)
kind = 7; kind = 8;
break; break;
case 5: case 5:
if (curChar == 38) if (curChar == 38)
jjstateSet[jjnewStateCnt++] = 4; jjstateSet[jjnewStateCnt++] = 4;
break; break;
case 13: case 13:
if (curChar == 33 && kind > 9) if (curChar == 33 && kind > 10)
kind = 9; kind = 10;
break; break;
case 14: case 14:
case 16:
if (curChar == 34) if (curChar == 34)
jjCheckNAddStates(0, 2); jjCheckNAddStates(0, 2);
break; break;
@ -183,15 +182,18 @@ private final int jjMoveNfa_3(int startState, int curPos)
if ((0xfffffffbffffffffL & l) != 0L) if ((0xfffffffbffffffffL & l) != 0L)
jjCheckNAddStates(0, 2); jjCheckNAddStates(0, 2);
break; break;
case 17:
jjCheckNAddStates(0, 2);
break;
case 18: case 18:
if (curChar == 34 && kind > 17) if (curChar == 34 && kind > 18)
kind = 17; kind = 18;
break; break;
case 20: case 20:
if ((0x3ff000000000000L & l) == 0L) if ((0x3ff000000000000L & l) == 0L)
break; break;
if (kind > 19) if (kind > 20)
kind = 19; kind = 20;
jjAddStates(8, 9); jjAddStates(8, 9);
break; break;
case 21: case 21:
@ -201,43 +203,43 @@ private final int jjMoveNfa_3(int startState, int curPos)
case 22: case 22:
if ((0x3ff000000000000L & l) == 0L) if ((0x3ff000000000000L & l) == 0L)
break; break;
if (kind > 19) if (kind > 20)
kind = 19; kind = 20;
jjCheckNAdd(22); jjCheckNAdd(22);
break; break;
case 23: case 23:
if (curChar == 42 && kind > 20) if (curChar == 42 && kind > 21)
kind = 20; kind = 21;
break; break;
case 24: case 24:
if ((0xfbffd4f8ffffd9ffL & l) == 0L) if ((0xfbffd4f8ffffd9ffL & l) == 0L)
break; break;
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 27: case 27:
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 28: case 28:
if ((0x7bffd0f8ffffd9ffL & l) == 0L) if ((0x7bffd0f8ffffd9ffL & l) == 0L)
break; break;
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddStates(3, 7); jjCheckNAddStates(3, 7);
break; break;
case 29: case 29:
if ((0x7bfff8f8ffffd9ffL & l) == 0L) if ((0x7bfff8f8ffffd9ffL & l) == 0L)
break; break;
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddTwoStates(29, 30); jjCheckNAddTwoStates(29, 30);
break; break;
case 31: case 31:
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddTwoStates(29, 30); jjCheckNAddTwoStates(29, 30);
break; break;
case 32: case 32:
@ -261,8 +263,8 @@ private final int jjMoveNfa_3(int startState, int curPos)
case 36: case 36:
if ((0x97ffffff87ffffffL & l) != 0L) if ((0x97ffffff87ffffffL & l) != 0L)
{ {
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
} }
else if (curChar == 92) else if (curChar == 92)
@ -271,22 +273,22 @@ private final int jjMoveNfa_3(int startState, int curPos)
case 0: case 0:
if ((0x97ffffff87ffffffL & l) != 0L) if ((0x97ffffff87ffffffL & l) != 0L)
{ {
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddStates(3, 7); jjCheckNAddStates(3, 7);
} }
else if (curChar == 92) else if (curChar == 92)
jjCheckNAddStates(13, 15); jjCheckNAddStates(13, 15);
else if (curChar == 126) else if (curChar == 126)
{ {
if (kind > 19) if (kind > 20)
kind = 19; kind = 20;
jjstateSet[jjnewStateCnt++] = 20; jjstateSet[jjnewStateCnt++] = 20;
} }
if ((0x97ffffff87ffffffL & l) != 0L) if ((0x97ffffff87ffffffL & l) != 0L)
{ {
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
} }
if (curChar == 78) if (curChar == 78)
@ -299,8 +301,8 @@ private final int jjMoveNfa_3(int startState, int curPos)
jjstateSet[jjnewStateCnt++] = 2; jjstateSet[jjnewStateCnt++] = 2;
break; break;
case 1: case 1:
if (curChar == 68 && kind > 7) if (curChar == 68 && kind > 8)
kind = 7; kind = 8;
break; break;
case 2: case 2:
if (curChar == 78) if (curChar == 78)
@ -311,24 +313,24 @@ private final int jjMoveNfa_3(int startState, int curPos)
jjstateSet[jjnewStateCnt++] = 2; jjstateSet[jjnewStateCnt++] = 2;
break; break;
case 6: case 6:
if (curChar == 82 && kind > 8) if (curChar == 82 && kind > 9)
kind = 8; kind = 9;
break; break;
case 7: case 7:
if (curChar == 79) if (curChar == 79)
jjstateSet[jjnewStateCnt++] = 6; jjstateSet[jjnewStateCnt++] = 6;
break; break;
case 8: case 8:
if (curChar == 124 && kind > 8) if (curChar == 124 && kind > 9)
kind = 8; kind = 9;
break; break;
case 9: case 9:
if (curChar == 124) if (curChar == 124)
jjstateSet[jjnewStateCnt++] = 8; jjstateSet[jjnewStateCnt++] = 8;
break; break;
case 10: case 10:
if (curChar == 84 && kind > 9) if (curChar == 84 && kind > 10)
kind = 9; kind = 10;
break; break;
case 11: case 11:
if (curChar == 79) if (curChar == 79)
@ -339,31 +341,35 @@ private final int jjMoveNfa_3(int startState, int curPos)
jjstateSet[jjnewStateCnt++] = 11; jjstateSet[jjnewStateCnt++] = 11;
break; break;
case 15: case 15:
jjAddStates(0, 2); if ((0xffffffffefffffffL & l) != 0L)
jjCheckNAddStates(0, 2);
break;
case 16:
if (curChar == 92)
jjstateSet[jjnewStateCnt++] = 17;
break; break;
case 17: case 17:
if (curChar == 92) jjCheckNAddStates(0, 2);
jjstateSet[jjnewStateCnt++] = 16;
break; break;
case 19: case 19:
if (curChar != 126) if (curChar != 126)
break; break;
if (kind > 19) if (kind > 20)
kind = 19; kind = 20;
jjstateSet[jjnewStateCnt++] = 20; jjstateSet[jjnewStateCnt++] = 20;
break; break;
case 24: case 24:
if ((0x97ffffff87ffffffL & l) == 0L) if ((0x97ffffff87ffffffL & l) == 0L)
break; break;
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 25: case 25:
if ((0x97ffffff87ffffffL & l) == 0L) if ((0x97ffffff87ffffffL & l) == 0L)
break; break;
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 26: case 26:
@ -371,22 +377,22 @@ private final int jjMoveNfa_3(int startState, int curPos)
jjCheckNAddTwoStates(27, 27); jjCheckNAddTwoStates(27, 27);
break; break;
case 27: case 27:
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 28: case 28:
if ((0x97ffffff87ffffffL & l) == 0L) if ((0x97ffffff87ffffffL & l) == 0L)
break; break;
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddStates(3, 7); jjCheckNAddStates(3, 7);
break; break;
case 29: case 29:
if ((0x97ffffff87ffffffL & l) == 0L) if ((0x97ffffff87ffffffL & l) == 0L)
break; break;
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddTwoStates(29, 30); jjCheckNAddTwoStates(29, 30);
break; break;
case 30: case 30:
@ -394,8 +400,8 @@ private final int jjMoveNfa_3(int startState, int curPos)
jjCheckNAddTwoStates(31, 31); jjCheckNAddTwoStates(31, 31);
break; break;
case 31: case 31:
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddTwoStates(29, 30); jjCheckNAddTwoStates(29, 30);
break; break;
case 32: case 32:
@ -433,48 +439,49 @@ private final int jjMoveNfa_3(int startState, int curPos)
case 27: case 27:
if (!jjCanMove_0(hiByte, i1, i2, l1, l2)) if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
break; break;
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 0: case 0:
if (jjCanMove_0(hiByte, i1, i2, l1, l2)) if (jjCanMove_0(hiByte, i1, i2, l1, l2))
{ {
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
} }
if (jjCanMove_0(hiByte, i1, i2, l1, l2)) if (jjCanMove_0(hiByte, i1, i2, l1, l2))
{ {
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddStates(3, 7); jjCheckNAddStates(3, 7);
} }
break; break;
case 15: case 15:
case 17:
if (jjCanMove_0(hiByte, i1, i2, l1, l2)) if (jjCanMove_0(hiByte, i1, i2, l1, l2))
jjAddStates(0, 2); jjCheckNAddStates(0, 2);
break; break;
case 24: case 24:
if (!jjCanMove_0(hiByte, i1, i2, l1, l2)) if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
break; break;
if (kind > 21) if (kind > 22)
kind = 21; kind = 22;
jjCheckNAddTwoStates(25, 26); jjCheckNAddTwoStates(25, 26);
break; break;
case 28: case 28:
if (!jjCanMove_0(hiByte, i1, i2, l1, l2)) if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
break; break;
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddStates(3, 7); jjCheckNAddStates(3, 7);
break; break;
case 29: case 29:
case 31: case 31:
if (!jjCanMove_0(hiByte, i1, i2, l1, l2)) if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
break; break;
if (kind > 18) if (kind > 19)
kind = 18; kind = 19;
jjCheckNAddTwoStates(29, 30); jjCheckNAddTwoStates(29, 30);
break; break;
case 32: case 32:
@ -504,9 +511,9 @@ private final int jjStopStringLiteralDfa_1(int pos, long active0)
switch (pos) switch (pos)
{ {
case 0: case 0:
if ((active0 & 0x20000000L) != 0L) if ((active0 & 0x40000000L) != 0L)
{ {
jjmatchedKind = 32; jjmatchedKind = 33;
return 6; return 6;
} }
return -1; return -1;
@ -531,9 +538,9 @@ private final int jjMoveStringLiteralDfa0_1()
switch(curChar) switch(curChar)
{ {
case 84: case 84:
return jjMoveStringLiteralDfa1_1(0x20000000L); return jjMoveStringLiteralDfa1_1(0x40000000L);
case 125: case 125:
return jjStopAtPos(0, 30); return jjStopAtPos(0, 31);
default : default :
return jjMoveNfa_1(0, 0); return jjMoveNfa_1(0, 0);
} }
@ -548,8 +555,8 @@ private final int jjMoveStringLiteralDfa1_1(long active0)
switch(curChar) switch(curChar)
{ {
case 79: case 79:
if ((active0 & 0x20000000L) != 0L) if ((active0 & 0x40000000L) != 0L)
return jjStartNfaWithStates_1(1, 29, 6); return jjStartNfaWithStates_1(1, 30, 6);
break; break;
default : default :
break; break;
@ -578,14 +585,14 @@ private final int jjMoveNfa_1(int startState, int curPos)
case 0: case 0:
if ((0xfffffffeffffffffL & l) != 0L) if ((0xfffffffeffffffffL & l) != 0L)
{ {
if (kind > 32) if (kind > 33)
kind = 32; kind = 33;
jjCheckNAdd(6); jjCheckNAdd(6);
} }
if ((0x100002600L & l) != 0L) if ((0x100002600L & l) != 0L)
{ {
if (kind > 6) if (kind > 7)
kind = 6; kind = 7;
} }
else if (curChar == 34) else if (curChar == 34)
jjCheckNAddTwoStates(2, 4); jjCheckNAddTwoStates(2, 4);
@ -603,14 +610,14 @@ private final int jjMoveNfa_1(int startState, int curPos)
jjCheckNAddStates(16, 18); jjCheckNAddStates(16, 18);
break; break;
case 5: case 5:
if (curChar == 34 && kind > 31) if (curChar == 34 && kind > 32)
kind = 31; kind = 32;
break; break;
case 6: case 6:
if ((0xfffffffeffffffffL & l) == 0L) if ((0xfffffffeffffffffL & l) == 0L)
break; break;
if (kind > 32) if (kind > 33)
kind = 32; kind = 33;
jjCheckNAdd(6); jjCheckNAdd(6);
break; break;
default : break; default : break;
@ -628,8 +635,8 @@ private final int jjMoveNfa_1(int startState, int curPos)
case 6: case 6:
if ((0xdfffffffffffffffL & l) == 0L) if ((0xdfffffffffffffffL & l) == 0L)
break; break;
if (kind > 32) if (kind > 33)
kind = 32; kind = 33;
jjCheckNAdd(6); jjCheckNAdd(6);
break; break;
case 2: case 2:
@ -658,8 +665,8 @@ private final int jjMoveNfa_1(int startState, int curPos)
case 6: case 6:
if (!jjCanMove_0(hiByte, i1, i2, l1, l2)) if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
break; break;
if (kind > 32) if (kind > 33)
kind = 32; kind = 33;
jjCheckNAdd(6); jjCheckNAdd(6);
break; break;
case 2: case 2:
@ -709,8 +716,8 @@ private final int jjMoveNfa_0(int startState, int curPos)
case 0: case 0:
if ((0x3ff000000000000L & l) == 0L) if ((0x3ff000000000000L & l) == 0L)
break; break;
if (kind > 24) if (kind > 25)
kind = 24; kind = 25;
jjAddStates(19, 20); jjAddStates(19, 20);
break; break;
case 1: case 1:
@ -720,8 +727,8 @@ private final int jjMoveNfa_0(int startState, int curPos)
case 2: case 2:
if ((0x3ff000000000000L & l) == 0L) if ((0x3ff000000000000L & l) == 0L)
break; break;
if (kind > 24) if (kind > 25)
kind = 24; kind = 25;
jjCheckNAdd(2); jjCheckNAdd(2);
break; break;
default : break; default : break;
@ -772,9 +779,9 @@ private final int jjStopStringLiteralDfa_2(int pos, long active0)
switch (pos) switch (pos)
{ {
case 0: case 0:
if ((active0 & 0x2000000L) != 0L) if ((active0 & 0x4000000L) != 0L)
{ {
jjmatchedKind = 28; jjmatchedKind = 29;
return 6; return 6;
} }
return -1; return -1;
@ -799,9 +806,9 @@ private final int jjMoveStringLiteralDfa0_2()
switch(curChar) switch(curChar)
{ {
case 84: case 84:
return jjMoveStringLiteralDfa1_2(0x2000000L); return jjMoveStringLiteralDfa1_2(0x4000000L);
case 93: case 93:
return jjStopAtPos(0, 26); return jjStopAtPos(0, 27);
default : default :
return jjMoveNfa_2(0, 0); return jjMoveNfa_2(0, 0);
} }
@ -816,8 +823,8 @@ private final int jjMoveStringLiteralDfa1_2(long active0)
switch(curChar) switch(curChar)
{ {
case 79: case 79:
if ((active0 & 0x2000000L) != 0L) if ((active0 & 0x4000000L) != 0L)
return jjStartNfaWithStates_2(1, 25, 6); return jjStartNfaWithStates_2(1, 26, 6);
break; break;
default : default :
break; break;
@ -846,14 +853,14 @@ private final int jjMoveNfa_2(int startState, int curPos)
case 0: case 0:
if ((0xfffffffeffffffffL & l) != 0L) if ((0xfffffffeffffffffL & l) != 0L)
{ {
if (kind > 28) if (kind > 29)
kind = 28; kind = 29;
jjCheckNAdd(6); jjCheckNAdd(6);
} }
if ((0x100002600L & l) != 0L) if ((0x100002600L & l) != 0L)
{ {
if (kind > 6) if (kind > 7)
kind = 6; kind = 7;
} }
else if (curChar == 34) else if (curChar == 34)
jjCheckNAddTwoStates(2, 4); jjCheckNAddTwoStates(2, 4);
@ -871,14 +878,14 @@ private final int jjMoveNfa_2(int startState, int curPos)
jjCheckNAddStates(16, 18); jjCheckNAddStates(16, 18);
break; break;
case 5: case 5:
if (curChar == 34 && kind > 27) if (curChar == 34 && kind > 28)
kind = 27; kind = 28;
break; break;
case 6: case 6:
if ((0xfffffffeffffffffL & l) == 0L) if ((0xfffffffeffffffffL & l) == 0L)
break; break;
if (kind > 28) if (kind > 29)
kind = 28; kind = 29;
jjCheckNAdd(6); jjCheckNAdd(6);
break; break;
default : break; default : break;
@ -896,8 +903,8 @@ private final int jjMoveNfa_2(int startState, int curPos)
case 6: case 6:
if ((0xffffffffdfffffffL & l) == 0L) if ((0xffffffffdfffffffL & l) == 0L)
break; break;
if (kind > 28) if (kind > 29)
kind = 28; kind = 29;
jjCheckNAdd(6); jjCheckNAdd(6);
break; break;
case 2: case 2:
@ -926,8 +933,8 @@ private final int jjMoveNfa_2(int startState, int curPos)
case 6: case 6:
if (!jjCanMove_0(hiByte, i1, i2, l1, l2)) if (!jjCanMove_0(hiByte, i1, i2, l1, l2))
break; break;
if (kind > 28) if (kind > 29)
kind = 28; kind = 29;
jjCheckNAdd(6); jjCheckNAdd(6);
break; break;
case 2: case 2:
@ -952,7 +959,7 @@ private final int jjMoveNfa_2(int startState, int curPos)
} }
} }
static final int[] jjnextStates = { static final int[] jjnextStates = {
15, 17, 18, 29, 32, 23, 33, 30, 20, 21, 32, 23, 33, 31, 34, 27, 15, 16, 18, 29, 32, 23, 33, 30, 20, 21, 32, 23, 33, 31, 34, 27,
2, 4, 5, 0, 1, 2, 4, 5, 0, 1,
}; };
private static final boolean jjCanMove_0(int hiByte, int i1, int i2, long l1, long l2) private static final boolean jjCanMove_0(int hiByte, int i1, int i2, long l1, long l2)
@ -968,9 +975,9 @@ private static final boolean jjCanMove_0(int hiByte, int i1, int i2, long l1, lo
} }
} }
public static final String[] jjstrLiteralImages = { public static final String[] jjstrLiteralImages = {
"", null, null, null, null, null, null, null, null, null, "\53", "\55", "\50", "", null, null, null, null, null, null, null, null, null, null, "\53", "\55",
"\51", "\72", "\52", "\136", null, null, null, null, null, "\133", "\173", null, "\50", "\51", "\72", "\52", "\136", null, null, null, null, null, "\133", "\173",
"\124\117", "\135", null, null, "\124\117", "\175", null, null, }; null, "\124\117", "\135", null, null, "\124\117", "\175", null, null, };
public static final String[] lexStateNames = { public static final String[] lexStateNames = {
"Boost", "Boost",
"RangeEx", "RangeEx",
@ -978,25 +985,23 @@ public static final String[] lexStateNames = {
"DEFAULT", "DEFAULT",
}; };
public static final int[] jjnewLexState = { public static final int[] jjnewLexState = {
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, -1, -1, -1, -1, -1, 2, 1, 3, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, -1, -1, -1, -1, -1, 2, 1,
-1, 3, -1, -1, -1, 3, -1, -1, 3, -1, 3, -1, -1, -1, 3, -1, -1,
}; };
static final long[] jjtoToken = { static final long[] jjtoToken = {
0x1ffffff81L, 0x3ffffff01L,
}; };
static final long[] jjtoSkip = { static final long[] jjtoSkip = {
0x40L, 0x80L,
}; };
protected CharStream input_stream; protected CharStream input_stream;
private final int[] jjrounds = new int[36]; private final int[] jjrounds = new int[36];
private final int[] jjstateSet = new int[72]; private final int[] jjstateSet = new int[72];
protected char curChar; protected char curChar;
public QueryParserTokenManager(CharStream stream) public QueryParserTokenManager(CharStream stream){
{
input_stream = stream; input_stream = stream;
} }
public QueryParserTokenManager(CharStream stream, int lexState) public QueryParserTokenManager(CharStream stream, int lexState){
{
this(stream); this(stream);
SwitchTo(lexState); SwitchTo(lexState);
} }

View File

@ -614,6 +614,9 @@ public class TestQueryParser extends LuceneTestCase {
assertQueryEquals("\\\\", a, "\\"); // escaped backslash assertQueryEquals("\\\\", a, "\\"); // escaped backslash
assertParseException("\\"); // a backslash must always be escaped assertParseException("\\"); // a backslash must always be escaped
// LUCENE-1189
assertQueryEquals("(\"a\\\\\") or (\"b\")", a ,"a\\ or b");
} }
public void testQueryStringEscaping() throws Exception { public void testQueryStringEscaping() throws Exception {