mirror of https://github.com/apache/lucene.git
LUCENE-1792: Fix new query parser to set rewrite method for multi-term queries.
git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@805633 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
7700fa3626
commit
565a6d22b5
|
@ -75,6 +75,9 @@ Bug fixes
|
||||||
that the regexp must match the entire string, not just a prefix.
|
that the regexp must match the entire string, not just a prefix.
|
||||||
(Trejkaz via Mike McCandless)
|
(Trejkaz via Mike McCandless)
|
||||||
|
|
||||||
|
10. LUCENE-1792: Fix new query parser to set rewrite method for
|
||||||
|
multi-term queries. (Luis Alves, Mike McCandless via Michael Busch)
|
||||||
|
|
||||||
|
|
||||||
New features
|
New features
|
||||||
|
|
||||||
|
|
|
@ -122,7 +122,7 @@ public class QueryParserHelper {
|
||||||
* @param syntaxParser
|
* @param syntaxParser
|
||||||
* the text parser that will be used to parse the query string
|
* the text parser that will be used to parse the query string
|
||||||
*
|
*
|
||||||
* @see #getTextParser()
|
* @see #getSyntaxParser()
|
||||||
* @see SyntaxParser
|
* @see SyntaxParser
|
||||||
*/
|
*/
|
||||||
public void setSyntaxParser(SyntaxParser syntaxParser) {
|
public void setSyntaxParser(SyntaxParser syntaxParser) {
|
||||||
|
@ -193,7 +193,7 @@ public class QueryParserHelper {
|
||||||
* @see SyntaxParser
|
* @see SyntaxParser
|
||||||
* @see #setSyntaxParser(SyntaxParser)
|
* @see #setSyntaxParser(SyntaxParser)
|
||||||
*/
|
*/
|
||||||
public SyntaxParser getTextParser() {
|
public SyntaxParser getSyntaxParser() {
|
||||||
return this.syntaxParser;
|
return this.syntaxParser;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,7 +225,7 @@ public class QueryParserHelper {
|
||||||
* In this method the three phases are executed: <br/>
|
* In this method the three phases are executed: <br/>
|
||||||
* <br/>
|
* <br/>
|
||||||
* 1st - the query string is parsed using the
|
* 1st - the query string is parsed using the
|
||||||
* text parser returned by {@link #getTextParser()}, the result is a query
|
* text parser returned by {@link #getSyntaxParser()}, the result is a query
|
||||||
* node tree <br/>
|
* node tree <br/>
|
||||||
* <br/>
|
* <br/>
|
||||||
* 2nd - the query node tree is processed by the
|
* 2nd - the query node tree is processed by the
|
||||||
|
@ -246,7 +246,7 @@ public class QueryParserHelper {
|
||||||
*/
|
*/
|
||||||
public Object parse(String query, String defaultField)
|
public Object parse(String query, String defaultField)
|
||||||
throws QueryNodeException {
|
throws QueryNodeException {
|
||||||
QueryNode queryTree = getTextParser().parse(query, defaultField);
|
QueryNode queryTree = getSyntaxParser().parse(query, defaultField);
|
||||||
|
|
||||||
QueryNodeProcessor processor = getQueryNodeProcessor();
|
QueryNodeProcessor processor = getQueryNodeProcessor();
|
||||||
|
|
||||||
|
|
|
@ -75,11 +75,11 @@ public class FieldQueryNode extends QueryNodeImpl implements TextableQueryNode,
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CharSequence getTermEscaped(EscapeQuerySyntax escaper) {
|
protected CharSequence getTermEscaped(EscapeQuerySyntax escaper) {
|
||||||
return escaper.escape(this.text, Locale.getDefault(), Type.NORMAL);
|
return escaper.escape(this.text, Locale.getDefault(), Type.NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
CharSequence getTermEscapeQuoted(EscapeQuerySyntax escaper) {
|
protected CharSequence getTermEscapeQuoted(EscapeQuerySyntax escaper) {
|
||||||
return escaper.escape(this.text, Locale.getDefault(), Type.STRING);
|
return escaper.escape(this.text, Locale.getDefault(), Type.STRING);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,57 +0,0 @@
|
||||||
package org.apache.lucene.queryParser.core.nodes;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link PrefixWildcardQueryNode} represents wildcardquery that matches abc*
|
|
||||||
* or *. This does not apply to phrases, this is a special case on the original
|
|
||||||
* lucene parser. TODO: refactor the code to remove this special case from the
|
|
||||||
* parser. and probably do it on a Processor
|
|
||||||
*/
|
|
||||||
public class PrefixWildcardQueryNode extends WildcardQueryNode {
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 6851557641826407515L;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param field
|
|
||||||
* - field name
|
|
||||||
* @param text
|
|
||||||
* - value including the wildcard
|
|
||||||
* @param begin
|
|
||||||
* - position in the query string
|
|
||||||
* @param end
|
|
||||||
* - position in the query string
|
|
||||||
*/
|
|
||||||
public PrefixWildcardQueryNode(CharSequence field, CharSequence text,
|
|
||||||
int begin, int end) {
|
|
||||||
super(field, text, begin, end);
|
|
||||||
}
|
|
||||||
|
|
||||||
public String toString() {
|
|
||||||
return "<prefixWildcard field='" + this.field + "' term='" + this.text
|
|
||||||
+ "'/>";
|
|
||||||
}
|
|
||||||
|
|
||||||
public PrefixWildcardQueryNode cloneTree() throws CloneNotSupportedException {
|
|
||||||
PrefixWildcardQueryNode clone = (PrefixWildcardQueryNode) super.cloneTree();
|
|
||||||
|
|
||||||
// nothing to do here
|
|
||||||
|
|
||||||
return clone;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,76 +0,0 @@
|
||||||
package org.apache.lucene.queryParser.core.nodes;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import org.apache.lucene.queryParser.core.parser.EscapeQuerySyntax;
|
|
||||||
import org.apache.lucene.search.MultiTermQuery;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link WildcardQueryNode} represents wildcard query This does not apply to
|
|
||||||
* phrases. Examples: a*b*c Fl?w? m?ke*g
|
|
||||||
*/
|
|
||||||
public class WildcardQueryNode extends FieldQueryNode {
|
|
||||||
private static final long serialVersionUID = 0L;
|
|
||||||
private MultiTermQuery.RewriteMethod multiTermRewriteMethod;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param field
|
|
||||||
* - field name
|
|
||||||
* @param text
|
|
||||||
* - value that contains one or more wild card characters (? or *)
|
|
||||||
* @param begin
|
|
||||||
* - position in the query string
|
|
||||||
* @param end
|
|
||||||
* - position in the query string
|
|
||||||
*/
|
|
||||||
public WildcardQueryNode(CharSequence field, CharSequence text, int begin,
|
|
||||||
int end) {
|
|
||||||
super(field, text, begin, end);
|
|
||||||
}
|
|
||||||
|
|
||||||
public CharSequence toQueryString(EscapeQuerySyntax escaper) {
|
|
||||||
if (isDefaultField(this.field)) {
|
|
||||||
return getTermEscaped(escaper);
|
|
||||||
} else {
|
|
||||||
return this.field + ":" + getTermEscaped(escaper);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public String toString() {
|
|
||||||
return "<wildcard field='" + this.field + "' term='" + this.text + "'/>";
|
|
||||||
}
|
|
||||||
|
|
||||||
public WildcardQueryNode cloneTree() throws CloneNotSupportedException {
|
|
||||||
WildcardQueryNode clone = (WildcardQueryNode) super.cloneTree();
|
|
||||||
|
|
||||||
// nothing to do here
|
|
||||||
|
|
||||||
return clone;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return the rewrite method
|
|
||||||
*/
|
|
||||||
public MultiTermQuery.RewriteMethod getMultiTermRewriteMethod() {
|
|
||||||
return multiTermRewriteMethod;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setMultiTermRewriteMethod(MultiTermQuery.RewriteMethod method) {
|
|
||||||
multiTermRewriteMethod = method;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -85,10 +85,6 @@ public final class UnescapedCharSequence implements CharSequence {
|
||||||
newLength);
|
newLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean wasEscaped(int index) {
|
|
||||||
return this.wasEscaped[index];
|
|
||||||
}
|
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return new String(this.chars);
|
return new String(this.chars);
|
||||||
}
|
}
|
||||||
|
@ -138,4 +134,23 @@ public final class UnescapedCharSequence implements CharSequence {
|
||||||
}
|
}
|
||||||
return result.toString();
|
return result.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean wasEscaped(int index) {
|
||||||
|
return this.wasEscaped[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
static final public boolean wasEscaped(CharSequence text, int index) {
|
||||||
|
if (text instanceof UnescapedCharSequence)
|
||||||
|
return ((UnescapedCharSequence)text).wasEscaped[index];
|
||||||
|
else return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static CharSequence toLowerCase(CharSequence text) {
|
||||||
|
if (text instanceof UnescapedCharSequence) {
|
||||||
|
char[] chars = text.toString().toLowerCase().toCharArray();
|
||||||
|
boolean[] wasEscaped = ((UnescapedCharSequence)text).wasEscaped;
|
||||||
|
return new UnescapedCharSequence(chars, wasEscaped, 0, chars.length);
|
||||||
|
} else
|
||||||
|
return new UnescapedCharSequence(text.toString().toLowerCase());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,15 +38,15 @@ import org.apache.lucene.queryParser.standard.builders.StandardQueryBuilder;
|
||||||
import org.apache.lucene.queryParser.standard.builders.StandardQueryTreeBuilder;
|
import org.apache.lucene.queryParser.standard.builders.StandardQueryTreeBuilder;
|
||||||
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
|
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
|
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
|
||||||
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
|
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute;
|
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.DefaultPhraseSlopAttribute;
|
import org.apache.lucene.queryParser.standard.config.DefaultPhraseSlopAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
|
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
|
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.StandardQueryConfigHandler;
|
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
|
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.config.StandardQueryConfigHandler;
|
||||||
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
||||||
import org.apache.lucene.queryParser.standard.processors.StandardQueryNodeProcessorPipeline;
|
import org.apache.lucene.queryParser.standard.processors.StandardQueryNodeProcessorPipeline;
|
||||||
import org.apache.lucene.search.FuzzyQuery;
|
import org.apache.lucene.search.FuzzyQuery;
|
||||||
|
|
|
@ -31,18 +31,18 @@ import org.apache.lucene.queryParser.standard.builders.StandardQueryTreeBuilder;
|
||||||
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
|
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
|
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
|
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.FieldDateResolutionMapAttribute;
|
|
||||||
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute;
|
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.DefaultPhraseSlopAttribute;
|
import org.apache.lucene.queryParser.standard.config.DefaultPhraseSlopAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.FieldBoostMapAttribute;
|
import org.apache.lucene.queryParser.standard.config.FieldBoostMapAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.config.FieldDateResolutionMapAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.FuzzyAttribute;
|
import org.apache.lucene.queryParser.standard.config.FuzzyAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
|
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
|
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.MultiFieldAttribute;
|
import org.apache.lucene.queryParser.standard.config.MultiFieldAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.StandardQueryConfigHandler;
|
|
||||||
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
|
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.config.StandardQueryConfigHandler;
|
||||||
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator;
|
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator;
|
||||||
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
||||||
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
||||||
|
|
|
@ -19,8 +19,10 @@ package org.apache.lucene.queryParser.standard.builders;
|
||||||
|
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeException;
|
import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.PrefixWildcardQueryNode;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
import org.apache.lucene.search.PrefixQuery;
|
import org.apache.lucene.search.PrefixQuery;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -34,11 +36,17 @@ public class PrefixWildcardQueryNodeBuilder implements StandardQueryBuilder {
|
||||||
}
|
}
|
||||||
|
|
||||||
public PrefixQuery build(QueryNode queryNode) throws QueryNodeException {
|
public PrefixQuery build(QueryNode queryNode) throws QueryNodeException {
|
||||||
|
|
||||||
PrefixWildcardQueryNode wildcardNode = (PrefixWildcardQueryNode) queryNode;
|
PrefixWildcardQueryNode wildcardNode = (PrefixWildcardQueryNode) queryNode;
|
||||||
|
|
||||||
PrefixQuery q = new PrefixQuery(new Term(wildcardNode.getFieldAsString(),
|
String text = wildcardNode.getText().subSequence(0, wildcardNode.getText().length() - 1).toString();
|
||||||
wildcardNode.getTextAsString()));
|
PrefixQuery q = new PrefixQuery(new Term(wildcardNode.getFieldAsString(), text));
|
||||||
q.setRewriteMethod(wildcardNode.getMultiTermRewriteMethod());
|
|
||||||
|
MultiTermQuery.RewriteMethod method = (MultiTermQuery.RewriteMethod)queryNode.getTag(MultiTermRewriteMethodAttribute.TAG_ID);
|
||||||
|
if (method != null) {
|
||||||
|
q.setRewriteMethod(method);
|
||||||
|
}
|
||||||
|
|
||||||
return q;
|
return q;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,9 @@ import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode.CompareOperator;
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode.CompareOperator;
|
||||||
|
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
import org.apache.lucene.search.TermRangeQuery;
|
import org.apache.lucene.search.TermRangeQuery;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,7 +56,11 @@ public class RangeQueryNodeBuilder implements StandardQueryBuilder {
|
||||||
TermRangeQuery rangeQuery = new TermRangeQuery(field, lower
|
TermRangeQuery rangeQuery = new TermRangeQuery(field, lower
|
||||||
.getTextAsString(), upper.getTextAsString(), lowerInclusive,
|
.getTextAsString(), upper.getTextAsString(), lowerInclusive,
|
||||||
upperInclusive, rangeNode.getCollator());
|
upperInclusive, rangeNode.getCollator());
|
||||||
rangeQuery.setRewriteMethod(rangeNode.getMultiTermRewriteMethod());
|
|
||||||
|
MultiTermQuery.RewriteMethod method = (MultiTermQuery.RewriteMethod)queryNode.getTag(MultiTermRewriteMethodAttribute.TAG_ID);
|
||||||
|
if (method != null) {
|
||||||
|
rangeQuery.setRewriteMethod(method);
|
||||||
|
}
|
||||||
|
|
||||||
return rangeQuery;
|
return rangeQuery;
|
||||||
|
|
||||||
|
|
|
@ -27,14 +27,14 @@ import org.apache.lucene.queryParser.core.nodes.GroupQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.MatchAllDocsQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.MatchAllDocsQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.MatchNoDocsQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.MatchNoDocsQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ModifierQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ModifierQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.TokenizedPhraseQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.TokenizedPhraseQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.standard.nodes.StandardBooleanQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.standard.nodes.MultiPhraseQueryNode;
|
import org.apache.lucene.queryParser.standard.nodes.MultiPhraseQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.PrefixWildcardQueryNode;
|
||||||
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.StandardBooleanQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
import org.apache.lucene.queryParser.standard.processors.StandardQueryNodeProcessorPipeline;
|
import org.apache.lucene.queryParser.standard.processors.StandardQueryNodeProcessorPipeline;
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,9 @@ package org.apache.lucene.queryParser.standard.builders;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeException;
|
import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
import org.apache.lucene.search.WildcardQuery;
|
import org.apache.lucene.search.WildcardQuery;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -38,7 +40,12 @@ public class WildcardQueryNodeBuilder implements StandardQueryBuilder {
|
||||||
|
|
||||||
WildcardQuery q = new WildcardQuery(new Term(wildcardNode.getFieldAsString(),
|
WildcardQuery q = new WildcardQuery(new Term(wildcardNode.getFieldAsString(),
|
||||||
wildcardNode.getTextAsString()));
|
wildcardNode.getTextAsString()));
|
||||||
q.setRewriteMethod(wildcardNode.getMultiTermRewriteMethod());
|
|
||||||
|
MultiTermQuery.RewriteMethod method = (MultiTermQuery.RewriteMethod)queryNode.getTag(MultiTermRewriteMethodAttribute.TAG_ID);
|
||||||
|
if (method != null) {
|
||||||
|
q.setRewriteMethod(method);
|
||||||
|
}
|
||||||
|
|
||||||
return q;
|
return q;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,9 @@ import org.apache.lucene.util.Attribute;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public interface MultiTermRewriteMethodAttribute extends Attribute {
|
public interface MultiTermRewriteMethodAttribute extends Attribute {
|
||||||
|
|
||||||
|
public static final CharSequence TAG_ID = "MultiTermRewriteMethodAttribute";
|
||||||
|
|
||||||
public void setMultiTermRewriteMethod(MultiTermQuery.RewriteMethod method);
|
public void setMultiTermRewriteMethod(MultiTermQuery.RewriteMethod method);
|
||||||
|
|
||||||
public MultiTermQuery.RewriteMethod getMultiTermRewriteMethod();
|
public MultiTermQuery.RewriteMethod getMultiTermRewriteMethod();
|
||||||
|
|
|
@ -48,7 +48,7 @@ public class StandardQueryConfigHandler extends QueryConfigHandler {
|
||||||
addAttribute(PositionIncrementsAttribute.class);
|
addAttribute(PositionIncrementsAttribute.class);
|
||||||
addAttribute(LocaleAttribute.class);
|
addAttribute(LocaleAttribute.class);
|
||||||
addAttribute(DefaultPhraseSlopAttribute.class);
|
addAttribute(DefaultPhraseSlopAttribute.class);
|
||||||
//addAttribute(DateResolutionAttribute.class);
|
addAttribute(MultiTermRewriteMethodAttribute.class);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
package org.apache.lucene.queryParser.standard.nodes;
|
||||||
|
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link PrefixWildcardQueryNode} represents wildcardquery that matches abc*
|
||||||
|
* or *. This does not apply to phrases, this is a special case on the original
|
||||||
|
* lucene parser. TODO: refactor the code to remove this special case from the
|
||||||
|
* parser. and probably do it on a Processor
|
||||||
|
*/
|
||||||
|
public class PrefixWildcardQueryNode extends WildcardQueryNode {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 6851557641826407515L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param field
|
||||||
|
* - field name
|
||||||
|
* @param text
|
||||||
|
* - value including the wildcard
|
||||||
|
* @param begin
|
||||||
|
* - position in the query string
|
||||||
|
* @param end
|
||||||
|
* - position in the query string
|
||||||
|
*/
|
||||||
|
public PrefixWildcardQueryNode(CharSequence field, CharSequence text,
|
||||||
|
int begin, int end) {
|
||||||
|
super(field, text, begin, end);
|
||||||
|
}
|
||||||
|
|
||||||
|
public PrefixWildcardQueryNode(FieldQueryNode fqn) {
|
||||||
|
this(fqn.getField(), fqn.getText(), fqn.getBegin(), fqn.getEnd());
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return "<prefixWildcard field='" + this.field + "' term='" + this.text
|
||||||
|
+ "'/>";
|
||||||
|
}
|
||||||
|
|
||||||
|
public PrefixWildcardQueryNode cloneTree() throws CloneNotSupportedException {
|
||||||
|
PrefixWildcardQueryNode clone = (PrefixWildcardQueryNode) super.cloneTree();
|
||||||
|
|
||||||
|
// nothing to do here
|
||||||
|
|
||||||
|
return clone;
|
||||||
|
}
|
||||||
|
}
|
|
@ -23,7 +23,6 @@ import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
||||||
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.processors.ParametricRangeQueryNodeProcessor;
|
import org.apache.lucene.queryParser.standard.processors.ParametricRangeQueryNodeProcessor;
|
||||||
import org.apache.lucene.search.MultiTermQuery;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This query node represents a range query. It also holds which collator will
|
* This query node represents a range query. It also holds which collator will
|
||||||
|
@ -39,17 +38,13 @@ public class RangeQueryNode extends ParametricRangeQueryNode {
|
||||||
|
|
||||||
private Collator collator;
|
private Collator collator;
|
||||||
|
|
||||||
private MultiTermQuery.RewriteMethod multiTermRewriteMethod;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param lower
|
* @param lower
|
||||||
* @param upper
|
* @param upper
|
||||||
*/
|
*/
|
||||||
public RangeQueryNode(ParametricQueryNode lower, ParametricQueryNode upper,
|
public RangeQueryNode(ParametricQueryNode lower, ParametricQueryNode upper, Collator collator) {
|
||||||
Collator collator, MultiTermQuery.RewriteMethod multiTermRewriteMethod) {
|
|
||||||
super(lower, upper);
|
super(lower, upper);
|
||||||
|
|
||||||
this.multiTermRewriteMethod = multiTermRewriteMethod;
|
|
||||||
this.collator = collator;
|
this.collator = collator;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -71,10 +66,4 @@ public class RangeQueryNode extends ParametricRangeQueryNode {
|
||||||
return this.collator;
|
return this.collator;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return the rewrite method
|
|
||||||
*/
|
|
||||||
public MultiTermQuery.RewriteMethod getMultiTermRewriteMethod() {
|
|
||||||
return multiTermRewriteMethod;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
package org.apache.lucene.queryParser.standard.nodes;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.parser.EscapeQuerySyntax;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link WildcardQueryNode} represents wildcard query This does not apply to
|
||||||
|
* phrases. Examples: a*b*c Fl?w? m?ke*g
|
||||||
|
*/
|
||||||
|
public class WildcardQueryNode extends FieldQueryNode {
|
||||||
|
private static final long serialVersionUID = 0L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param field
|
||||||
|
* - field name
|
||||||
|
* @param text
|
||||||
|
* - value that contains one or more wild card characters (? or *)
|
||||||
|
* @param begin
|
||||||
|
* - position in the query string
|
||||||
|
* @param end
|
||||||
|
* - position in the query string
|
||||||
|
*/
|
||||||
|
public WildcardQueryNode(CharSequence field, CharSequence text, int begin,
|
||||||
|
int end) {
|
||||||
|
super(field, text, begin, end);
|
||||||
|
}
|
||||||
|
|
||||||
|
public WildcardQueryNode(FieldQueryNode fqn) {
|
||||||
|
this(fqn.getField(), fqn.getText(), fqn.getBegin(), fqn.getEnd());
|
||||||
|
}
|
||||||
|
|
||||||
|
public CharSequence toQueryString(EscapeQuerySyntax escaper) {
|
||||||
|
if (isDefaultField(this.field)) {
|
||||||
|
return getTermEscaped(escaper);
|
||||||
|
} else {
|
||||||
|
return this.field + ":" + getTermEscaped(escaper);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return "<wildcard field='" + this.field + "' term='" + this.text + "'/>";
|
||||||
|
}
|
||||||
|
|
||||||
|
public WildcardQueryNode cloneTree() throws CloneNotSupportedException {
|
||||||
|
WildcardQueryNode clone = (WildcardQueryNode) super.cloneTree();
|
||||||
|
|
||||||
|
// nothing to do here
|
||||||
|
|
||||||
|
return clone;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -614,4 +614,4 @@ class JavaCharStream
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
/* JavaCC - StandardChecksum=065d79d49fcd02f542903038e37bd9d9 (do not edit this line) */
|
/* JavaCC - OriginalChecksum=d665eff1df49d9f82f07f7dc863fcd22 (do not edit this line) */
|
||||||
|
|
|
@ -19,14 +19,10 @@ package org.apache.lucene.queryParser.standard.parser;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
|
||||||
import org.apache.lucene.messages.Message;
|
import org.apache.lucene.messages.Message;
|
||||||
import org.apache.lucene.messages.MessageImpl;
|
import org.apache.lucene.messages.MessageImpl;
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeError;
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeException;
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeParseException;
|
import org.apache.lucene.queryParser.core.QueryNodeParseException;
|
||||||
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
||||||
import org.apache.lucene.queryParser.core.nodes.AndQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.AndQueryNode;
|
||||||
|
@ -34,19 +30,14 @@ import org.apache.lucene.queryParser.core.nodes.BooleanQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.BoostQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.BoostQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ModifierQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.GroupQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.GroupQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.OpaqueQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ModifierQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.OrQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.OrQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.ProximityQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNodeImpl;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QuotedFieldQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QuotedFieldQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
||||||
|
|
||||||
@SuppressWarnings("all")
|
@SuppressWarnings("all")
|
||||||
|
@ -178,11 +169,8 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
case PLUS:
|
case PLUS:
|
||||||
case MINUS:
|
case MINUS:
|
||||||
case LPAREN:
|
case LPAREN:
|
||||||
case STAR:
|
|
||||||
case QUOTED:
|
case QUOTED:
|
||||||
case TERM:
|
case TERM:
|
||||||
case PREFIXTERM:
|
|
||||||
case WILDTERM:
|
|
||||||
case RANGEIN_START:
|
case RANGEIN_START:
|
||||||
case RANGEEX_START:
|
case RANGEEX_START:
|
||||||
case NUMBER:
|
case NUMBER:
|
||||||
|
@ -322,31 +310,15 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
Token fieldToken=null, boost=null;
|
Token fieldToken=null, boost=null;
|
||||||
boolean group = false;
|
boolean group = false;
|
||||||
if (jj_2_1(2)) {
|
if (jj_2_1(2)) {
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
|
||||||
case TERM:
|
|
||||||
fieldToken = jj_consume_token(TERM);
|
fieldToken = jj_consume_token(TERM);
|
||||||
jj_consume_token(COLON);
|
jj_consume_token(COLON);
|
||||||
field=EscapeQuerySyntaxImpl.discardEscapeChar(fieldToken.image);
|
field=EscapeQuerySyntaxImpl.discardEscapeChar(fieldToken.image);
|
||||||
break;
|
|
||||||
case STAR:
|
|
||||||
jj_consume_token(STAR);
|
|
||||||
jj_consume_token(COLON);
|
|
||||||
field="*";
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
jj_la1[7] = jj_gen;
|
|
||||||
jj_consume_token(-1);
|
|
||||||
throw new ParseException();
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
case STAR:
|
|
||||||
case QUOTED:
|
case QUOTED:
|
||||||
case TERM:
|
case TERM:
|
||||||
case PREFIXTERM:
|
|
||||||
case WILDTERM:
|
|
||||||
case RANGEIN_START:
|
case RANGEIN_START:
|
||||||
case RANGEEX_START:
|
case RANGEEX_START:
|
||||||
case NUMBER:
|
case NUMBER:
|
||||||
|
@ -362,13 +334,13 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
boost = jj_consume_token(NUMBER);
|
boost = jj_consume_token(NUMBER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[8] = jj_gen;
|
jj_la1[7] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
group=true;
|
group=true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[9] = jj_gen;
|
jj_la1[8] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -393,40 +365,23 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
|
|
||||||
final public QueryNode Term(CharSequence field) throws ParseException {
|
final public QueryNode Term(CharSequence field) throws ParseException {
|
||||||
Token term, boost=null, fuzzySlop=null, goop1, goop2;
|
Token term, boost=null, fuzzySlop=null, goop1, goop2;
|
||||||
boolean prefix = false;
|
|
||||||
boolean wildcard = false;
|
|
||||||
boolean fuzzy = false;
|
boolean fuzzy = false;
|
||||||
QueryNode q =null;
|
QueryNode q =null;
|
||||||
ParametricQueryNode qLower, qUpper;
|
ParametricQueryNode qLower, qUpper;
|
||||||
float defaultMinSimilarity = 0.5f;
|
float defaultMinSimilarity = 0.5f;
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
case STAR:
|
|
||||||
case TERM:
|
case TERM:
|
||||||
case PREFIXTERM:
|
|
||||||
case WILDTERM:
|
|
||||||
case NUMBER:
|
case NUMBER:
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
case TERM:
|
case TERM:
|
||||||
term = jj_consume_token(TERM);
|
term = jj_consume_token(TERM);
|
||||||
q = new FieldQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn);
|
q = new FieldQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn);
|
||||||
break;
|
break;
|
||||||
case STAR:
|
|
||||||
term = jj_consume_token(STAR);
|
|
||||||
wildcard=true; q = new WildcardQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn);
|
|
||||||
break;
|
|
||||||
case PREFIXTERM:
|
|
||||||
term = jj_consume_token(PREFIXTERM);
|
|
||||||
prefix=true; q = new PrefixWildcardQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn);
|
|
||||||
break;
|
|
||||||
case WILDTERM:
|
|
||||||
term = jj_consume_token(WILDTERM);
|
|
||||||
wildcard=true; q = new WildcardQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn);
|
|
||||||
break;
|
|
||||||
case NUMBER:
|
case NUMBER:
|
||||||
term = jj_consume_token(NUMBER);
|
term = jj_consume_token(NUMBER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[10] = jj_gen;
|
jj_la1[9] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -436,7 +391,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
fuzzy=true;
|
fuzzy=true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[11] = jj_gen;
|
jj_la1[10] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
|
@ -449,15 +404,15 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
fuzzy=true;
|
fuzzy=true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[12] = jj_gen;
|
jj_la1[11] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[13] = jj_gen;
|
jj_la1[12] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
if (!wildcard && !prefix && fuzzy) {
|
if (fuzzy) {
|
||||||
float fms = defaultMinSimilarity;
|
float fms = defaultMinSimilarity;
|
||||||
try {
|
try {
|
||||||
fms = Float.valueOf(fuzzySlop.image.substring(1)).floatValue();
|
fms = Float.valueOf(fuzzySlop.image.substring(1)).floatValue();
|
||||||
|
@ -478,7 +433,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
goop1 = jj_consume_token(RANGEIN_QUOTED);
|
goop1 = jj_consume_token(RANGEIN_QUOTED);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[14] = jj_gen;
|
jj_la1[13] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -487,7 +442,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
jj_consume_token(RANGEIN_TO);
|
jj_consume_token(RANGEIN_TO);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[15] = jj_gen;
|
jj_la1[14] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
|
@ -498,7 +453,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
goop2 = jj_consume_token(RANGEIN_QUOTED);
|
goop2 = jj_consume_token(RANGEIN_QUOTED);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[16] = jj_gen;
|
jj_la1[15] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -509,7 +464,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
boost = jj_consume_token(NUMBER);
|
boost = jj_consume_token(NUMBER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[17] = jj_gen;
|
jj_la1[16] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
if (goop1.kind == RANGEIN_QUOTED) {
|
if (goop1.kind == RANGEIN_QUOTED) {
|
||||||
|
@ -535,7 +490,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
goop1 = jj_consume_token(RANGEEX_QUOTED);
|
goop1 = jj_consume_token(RANGEEX_QUOTED);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[18] = jj_gen;
|
jj_la1[17] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -544,7 +499,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
jj_consume_token(RANGEEX_TO);
|
jj_consume_token(RANGEEX_TO);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[19] = jj_gen;
|
jj_la1[18] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
|
@ -555,7 +510,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
goop2 = jj_consume_token(RANGEEX_QUOTED);
|
goop2 = jj_consume_token(RANGEEX_QUOTED);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[20] = jj_gen;
|
jj_la1[19] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -566,7 +521,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
boost = jj_consume_token(NUMBER);
|
boost = jj_consume_token(NUMBER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[21] = jj_gen;
|
jj_la1[20] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
if (goop1.kind == RANGEEX_QUOTED) {
|
if (goop1.kind == RANGEEX_QUOTED) {
|
||||||
|
@ -589,7 +544,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
fuzzySlop = jj_consume_token(FUZZY_SLOP);
|
fuzzySlop = jj_consume_token(FUZZY_SLOP);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[22] = jj_gen;
|
jj_la1[21] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
|
||||||
|
@ -598,7 +553,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
boost = jj_consume_token(NUMBER);
|
boost = jj_consume_token(NUMBER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[23] = jj_gen;
|
jj_la1[22] = jj_gen;
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
int phraseSlop = 0;
|
int phraseSlop = 0;
|
||||||
|
@ -616,7 +571,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
jj_la1[24] = jj_gen;
|
jj_la1[23] = jj_gen;
|
||||||
jj_consume_token(-1);
|
jj_consume_token(-1);
|
||||||
throw new ParseException();
|
throw new ParseException();
|
||||||
}
|
}
|
||||||
|
@ -645,28 +600,12 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
finally { jj_save(0, xla); }
|
finally { jj_save(0, xla); }
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean jj_3R_5() {
|
private boolean jj_3_1() {
|
||||||
if (jj_scan_token(STAR)) return true;
|
|
||||||
if (jj_scan_token(COLON)) return true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean jj_3R_4() {
|
|
||||||
if (jj_scan_token(TERM)) return true;
|
if (jj_scan_token(TERM)) return true;
|
||||||
if (jj_scan_token(COLON)) return true;
|
if (jj_scan_token(COLON)) return true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean jj_3_1() {
|
|
||||||
Token xsp;
|
|
||||||
xsp = jj_scanpos;
|
|
||||||
if (jj_3R_4()) {
|
|
||||||
jj_scanpos = xsp;
|
|
||||||
if (jj_3R_5()) return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Generated Token Manager. */
|
/** Generated Token Manager. */
|
||||||
public StandardSyntaxParserTokenManager token_source;
|
public StandardSyntaxParserTokenManager token_source;
|
||||||
JavaCharStream jj_input_stream;
|
JavaCharStream jj_input_stream;
|
||||||
|
@ -678,18 +617,13 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
private Token jj_scanpos, jj_lastpos;
|
private Token jj_scanpos, jj_lastpos;
|
||||||
private int jj_la;
|
private int jj_la;
|
||||||
private int jj_gen;
|
private int jj_gen;
|
||||||
final private int[] jj_la1 = new int[25];
|
final private int[] jj_la1 = new int[24];
|
||||||
static private int[] jj_la1_0;
|
static private int[] jj_la1_0;
|
||||||
static private int[] jj_la1_1;
|
|
||||||
static {
|
static {
|
||||||
jj_la1_init_0();
|
jj_la1_init_0();
|
||||||
jj_la1_init_1();
|
|
||||||
}
|
}
|
||||||
private static void jj_la1_init_0() {
|
private static void jj_la1_init_0() {
|
||||||
jj_la1_0 = new int[] {0x300,0x300,0x1c00,0x1c00,0x3ed3c00,0x200,0x100,0x90000,0x20000,0x3ed2000,0x2690000,0x100000,0x100000,0x20000,0x30000000,0x4000000,0x30000000,0x20000,0x0,0x40000000,0x0,0x20000,0x100000,0x20000,0x3ed0000,};
|
jj_la1_0 = new int[] {0x300,0x300,0x1c00,0x1c00,0x763c00,0x200,0x100,0x10000,0x762000,0x440000,0x80000,0x80000,0x10000,0x6000000,0x800000,0x6000000,0x10000,0x60000000,0x8000000,0x60000000,0x10000,0x80000,0x10000,0x760000,};
|
||||||
}
|
|
||||||
private static void jj_la1_init_1() {
|
|
||||||
jj_la1_1 = new int[] {0x0,0x0,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;
|
||||||
|
@ -706,7 +640,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
token = new Token();
|
token = new Token();
|
||||||
jj_ntk = -1;
|
jj_ntk = -1;
|
||||||
jj_gen = 0;
|
jj_gen = 0;
|
||||||
for (int i = 0; i < 25; i++) jj_la1[i] = -1;
|
for (int i = 0; i < 24; i++) jj_la1[i] = -1;
|
||||||
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -721,7 +655,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
token = new Token();
|
token = new Token();
|
||||||
jj_ntk = -1;
|
jj_ntk = -1;
|
||||||
jj_gen = 0;
|
jj_gen = 0;
|
||||||
for (int i = 0; i < 25; i++) jj_la1[i] = -1;
|
for (int i = 0; i < 24; i++) jj_la1[i] = -1;
|
||||||
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -732,7 +666,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
token = new Token();
|
token = new Token();
|
||||||
jj_ntk = -1;
|
jj_ntk = -1;
|
||||||
jj_gen = 0;
|
jj_gen = 0;
|
||||||
for (int i = 0; i < 25; i++) jj_la1[i] = -1;
|
for (int i = 0; i < 24; i++) jj_la1[i] = -1;
|
||||||
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -743,7 +677,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
token = new Token();
|
token = new Token();
|
||||||
jj_ntk = -1;
|
jj_ntk = -1;
|
||||||
jj_gen = 0;
|
jj_gen = 0;
|
||||||
for (int i = 0; i < 25; i++) jj_la1[i] = -1;
|
for (int i = 0; i < 24; i++) jj_la1[i] = -1;
|
||||||
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -753,7 +687,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
token = new Token();
|
token = new Token();
|
||||||
jj_ntk = -1;
|
jj_ntk = -1;
|
||||||
jj_gen = 0;
|
jj_gen = 0;
|
||||||
for (int i = 0; i < 25; i++) jj_la1[i] = -1;
|
for (int i = 0; i < 24; i++) jj_la1[i] = -1;
|
||||||
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -763,7 +697,7 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
token = new Token();
|
token = new Token();
|
||||||
jj_ntk = -1;
|
jj_ntk = -1;
|
||||||
jj_gen = 0;
|
jj_gen = 0;
|
||||||
for (int i = 0; i < 25; i++) jj_la1[i] = -1;
|
for (int i = 0; i < 24; i++) jj_la1[i] = -1;
|
||||||
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -875,24 +809,21 @@ public class StandardSyntaxParser implements SyntaxParser, StandardSyntaxParserC
|
||||||
/** Generate ParseException. */
|
/** Generate ParseException. */
|
||||||
public ParseException generateParseException() {
|
public ParseException generateParseException() {
|
||||||
jj_expentries.clear();
|
jj_expentries.clear();
|
||||||
boolean[] la1tokens = new boolean[34];
|
boolean[] la1tokens = new boolean[31];
|
||||||
if (jj_kind >= 0) {
|
if (jj_kind >= 0) {
|
||||||
la1tokens[jj_kind] = true;
|
la1tokens[jj_kind] = true;
|
||||||
jj_kind = -1;
|
jj_kind = -1;
|
||||||
}
|
}
|
||||||
for (int i = 0; i < 25; i++) {
|
for (int i = 0; i < 24; i++) {
|
||||||
if (jj_la1[i] == jj_gen) {
|
if (jj_la1[i] == jj_gen) {
|
||||||
for (int j = 0; j < 32; j++) {
|
for (int j = 0; j < 32; j++) {
|
||||||
if ((jj_la1_0[i] & (1<<j)) != 0) {
|
if ((jj_la1_0[i] & (1<<j)) != 0) {
|
||||||
la1tokens[j] = true;
|
la1tokens[j] = true;
|
||||||
}
|
}
|
||||||
if ((jj_la1_1[i] & (1<<j)) != 0) {
|
|
||||||
la1tokens[32+j] = true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
for (int i = 0; i < 31; 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;
|
||||||
|
|
|
@ -52,13 +52,11 @@ import org.apache.lucene.queryParser.core.nodes.OpaqueQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.OrQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.OrQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ProximityQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ProximityQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNodeImpl;
|
import org.apache.lucene.queryParser.core.nodes.QueryNodeImpl;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QuotedFieldQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QuotedFieldQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
||||||
|
|
||||||
@SuppressWarnings("all")
|
@SuppressWarnings("all")
|
||||||
|
@ -110,7 +108,7 @@ PARSER_END(StandardSyntaxParser)
|
||||||
// every character that follows a backslash is considered as an escaped character
|
// every character that follows a backslash is considered as an escaped character
|
||||||
| <#_ESCAPED_CHAR: "\\" ~[] >
|
| <#_ESCAPED_CHAR: "\\" ~[] >
|
||||||
| <#_TERM_START_CHAR: ( ~[ " ", "\t", "\n", "\r", "\u3000", "+", "-", "!", "(", ")", ":", "^",
|
| <#_TERM_START_CHAR: ( ~[ " ", "\t", "\n", "\r", "\u3000", "+", "-", "!", "(", ")", ":", "^",
|
||||||
"[", "]", "\"", "{", "}", "~", "*", "?", "\\" ]
|
"[", "]", "\"", "{", "}", "~", "\\" ]
|
||||||
| <_ESCAPED_CHAR> ) >
|
| <_ESCAPED_CHAR> ) >
|
||||||
| <#_TERM_CHAR: ( <_TERM_START_CHAR> | <_ESCAPED_CHAR> | "-" | "+" ) >
|
| <#_TERM_CHAR: ( <_TERM_START_CHAR> | <_ESCAPED_CHAR> | "-" | "+" ) >
|
||||||
| <#_WHITESPACE: ( " " | "\t" | "\n" | "\r" | "\u3000") >
|
| <#_WHITESPACE: ( " " | "\t" | "\n" | "\r" | "\u3000") >
|
||||||
|
@ -130,13 +128,10 @@ PARSER_END(StandardSyntaxParser)
|
||||||
| <LPAREN: "(" >
|
| <LPAREN: "(" >
|
||||||
| <RPAREN: ")" >
|
| <RPAREN: ")" >
|
||||||
| <COLON: ":" >
|
| <COLON: ":" >
|
||||||
| <STAR: "*" >
|
|
||||||
| <CARAT: "^" > : Boost
|
| <CARAT: "^" > : Boost
|
||||||
| <QUOTED: "\"" (<_QUOTED_CHAR>)* "\"">
|
| <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>)* "*" ) >
|
|
||||||
| <WILDTERM: (<_TERM_START_CHAR> | [ "*", "?" ]) (<_TERM_CHAR> | ( [ "*", "?" ] ))* >
|
|
||||||
| <RANGEIN_START: "[" > : RangeIn
|
| <RANGEIN_START: "[" > : RangeIn
|
||||||
| <RANGEEX_START: "{" > : RangeEx
|
| <RANGEEX_START: "{" > : RangeEx
|
||||||
}
|
}
|
||||||
|
@ -347,7 +342,6 @@ QueryNode Clause(CharSequence field) : {
|
||||||
LOOKAHEAD(2)
|
LOOKAHEAD(2)
|
||||||
(
|
(
|
||||||
fieldToken=<TERM> <COLON> {field=EscapeQuerySyntaxImpl.discardEscapeChar(fieldToken.image);}
|
fieldToken=<TERM> <COLON> {field=EscapeQuerySyntaxImpl.discardEscapeChar(fieldToken.image);}
|
||||||
| <STAR> <COLON> {field="*";}
|
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -379,8 +373,6 @@ QueryNode Clause(CharSequence field) : {
|
||||||
|
|
||||||
QueryNode Term(CharSequence field) : {
|
QueryNode Term(CharSequence field) : {
|
||||||
Token term, boost=null, fuzzySlop=null, goop1, goop2;
|
Token term, boost=null, fuzzySlop=null, goop1, goop2;
|
||||||
boolean prefix = false;
|
|
||||||
boolean wildcard = false;
|
|
||||||
boolean fuzzy = false;
|
boolean fuzzy = false;
|
||||||
QueryNode q =null;
|
QueryNode q =null;
|
||||||
ParametricQueryNode qLower, qUpper;
|
ParametricQueryNode qLower, qUpper;
|
||||||
|
@ -390,15 +382,12 @@ QueryNode Term(CharSequence field) : {
|
||||||
(
|
(
|
||||||
(
|
(
|
||||||
term=<TERM> { q = new FieldQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn); }
|
term=<TERM> { q = new FieldQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn); }
|
||||||
| term=<STAR> { wildcard=true; q = new WildcardQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn); }
|
|
||||||
| term=<PREFIXTERM> { prefix=true; q = new PrefixWildcardQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn); }
|
|
||||||
| term=<WILDTERM> { wildcard=true; q = new WildcardQueryNode(field, EscapeQuerySyntaxImpl.discardEscapeChar(term.image), term.beginColumn, term.endColumn); }
|
|
||||||
| term=<NUMBER>
|
| term=<NUMBER>
|
||||||
)
|
)
|
||||||
[ fuzzySlop=<FUZZY_SLOP> { fuzzy=true; } ]
|
[ fuzzySlop=<FUZZY_SLOP> { fuzzy=true; } ]
|
||||||
[ <CARAT> boost=<NUMBER> [ fuzzySlop=<FUZZY_SLOP> { fuzzy=true; } ] ]
|
[ <CARAT> boost=<NUMBER> [ fuzzySlop=<FUZZY_SLOP> { fuzzy=true; } ] ]
|
||||||
{
|
{
|
||||||
if (!wildcard && !prefix && fuzzy) {
|
if (fuzzy) {
|
||||||
float fms = defaultMinSimilarity;
|
float fms = defaultMinSimilarity;
|
||||||
try {
|
try {
|
||||||
fms = Float.valueOf(fuzzySlop.image.substring(1)).floatValue();
|
fms = Float.valueOf(fuzzySlop.image.substring(1)).floatValue();
|
||||||
|
|
|
@ -39,41 +39,35 @@ public interface StandardSyntaxParserConstants {
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int COLON = 15;
|
int COLON = 15;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int STAR = 16;
|
int CARAT = 16;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int CARAT = 17;
|
int QUOTED = 17;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int QUOTED = 18;
|
int TERM = 18;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int TERM = 19;
|
int FUZZY_SLOP = 19;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int FUZZY_SLOP = 20;
|
int RANGEIN_START = 20;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int PREFIXTERM = 21;
|
int RANGEEX_START = 21;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int WILDTERM = 22;
|
int NUMBER = 22;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEIN_START = 23;
|
int RANGEIN_TO = 23;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEEX_START = 24;
|
int RANGEIN_END = 24;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int NUMBER = 25;
|
int RANGEIN_QUOTED = 25;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEIN_TO = 26;
|
int RANGEIN_GOOP = 26;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEIN_END = 27;
|
int RANGEEX_TO = 27;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEIN_QUOTED = 28;
|
int RANGEEX_END = 28;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEIN_GOOP = 29;
|
int RANGEEX_QUOTED = 29;
|
||||||
/** RegularExpression Id. */
|
/** RegularExpression Id. */
|
||||||
int RANGEEX_TO = 30;
|
int RANGEEX_GOOP = 30;
|
||||||
/** RegularExpression Id. */
|
|
||||||
int RANGEEX_END = 31;
|
|
||||||
/** RegularExpression Id. */
|
|
||||||
int RANGEEX_QUOTED = 32;
|
|
||||||
/** RegularExpression Id. */
|
|
||||||
int RANGEEX_GOOP = 33;
|
|
||||||
|
|
||||||
/** Lexical state. */
|
/** Lexical state. */
|
||||||
int Boost = 0;
|
int Boost = 0;
|
||||||
|
@ -102,13 +96,10 @@ public interface StandardSyntaxParserConstants {
|
||||||
"\"(\"",
|
"\"(\"",
|
||||||
"\")\"",
|
"\")\"",
|
||||||
"\":\"",
|
"\":\"",
|
||||||
"\"*\"",
|
|
||||||
"\"^\"",
|
"\"^\"",
|
||||||
"<QUOTED>",
|
"<QUOTED>",
|
||||||
"<TERM>",
|
"<TERM>",
|
||||||
"<FUZZY_SLOP>",
|
"<FUZZY_SLOP>",
|
||||||
"<PREFIXTERM>",
|
|
||||||
"<WILDTERM>",
|
|
||||||
"\"[\"",
|
"\"[\"",
|
||||||
"\"{\"",
|
"\"{\"",
|
||||||
"<NUMBER>",
|
"<NUMBER>",
|
||||||
|
|
|
@ -17,35 +17,6 @@ package org.apache.lucene.queryParser.standard.parser;
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.StringReader;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Vector;
|
|
||||||
import org.apache.lucene.messages.Message;
|
|
||||||
import org.apache.lucene.messages.MessageImpl;
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeError;
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeException;
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeParseException;
|
|
||||||
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.AndQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.BooleanQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.BoostQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.ModifierQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.GroupQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.OpaqueQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.OrQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.SlopQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.ProximityQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNodeImpl;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QuotedFieldQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
|
||||||
|
|
||||||
/** Token Manager. */
|
/** Token Manager. */
|
||||||
public class StandardSyntaxParserTokenManager implements StandardSyntaxParserConstants
|
public class StandardSyntaxParserTokenManager implements StandardSyntaxParserConstants
|
||||||
|
@ -81,8 +52,6 @@ private int jjMoveStringLiteralDfa0_3()
|
||||||
return jjStopAtPos(0, 13);
|
return jjStopAtPos(0, 13);
|
||||||
case 41:
|
case 41:
|
||||||
return jjStopAtPos(0, 14);
|
return jjStopAtPos(0, 14);
|
||||||
case 42:
|
|
||||||
return jjStartNfaWithStates_3(0, 16, 36);
|
|
||||||
case 43:
|
case 43:
|
||||||
return jjStopAtPos(0, 11);
|
return jjStopAtPos(0, 11);
|
||||||
case 45:
|
case 45:
|
||||||
|
@ -90,23 +59,15 @@ private int jjMoveStringLiteralDfa0_3()
|
||||||
case 58:
|
case 58:
|
||||||
return jjStopAtPos(0, 15);
|
return jjStopAtPos(0, 15);
|
||||||
case 91:
|
case 91:
|
||||||
return jjStopAtPos(0, 23);
|
return jjStopAtPos(0, 20);
|
||||||
case 94:
|
case 94:
|
||||||
return jjStopAtPos(0, 17);
|
return jjStopAtPos(0, 16);
|
||||||
case 123:
|
case 123:
|
||||||
return jjStopAtPos(0, 24);
|
return jjStopAtPos(0, 21);
|
||||||
default :
|
default :
|
||||||
return jjMoveNfa_3(0, 0);
|
return jjMoveNfa_3(0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
private int jjStartNfaWithStates_3(int pos, int kind, int state)
|
|
||||||
{
|
|
||||||
jjmatchedKind = kind;
|
|
||||||
jjmatchedPos = pos;
|
|
||||||
try { curChar = input_stream.readChar(); }
|
|
||||||
catch(java.io.IOException e) { return pos + 1; }
|
|
||||||
return jjMoveNfa_3(state, pos + 1);
|
|
||||||
}
|
|
||||||
static final long[] jjbitVec0 = {
|
static final long[] jjbitVec0 = {
|
||||||
0x1L, 0x0L, 0x0L, 0x0L
|
0x1L, 0x0L, 0x0L, 0x0L
|
||||||
};
|
};
|
||||||
|
@ -122,7 +83,7 @@ static final long[] jjbitVec4 = {
|
||||||
private int jjMoveNfa_3(int startState, int curPos)
|
private int jjMoveNfa_3(int startState, int curPos)
|
||||||
{
|
{
|
||||||
int startsAt = 0;
|
int startsAt = 0;
|
||||||
jjnewStateCnt = 36;
|
jjnewStateCnt = 28;
|
||||||
int i = 1;
|
int i = 1;
|
||||||
jjstateSet[0] = startState;
|
jjstateSet[0] = startState;
|
||||||
int kind = 0x7fffffff;
|
int kind = 0x7fffffff;
|
||||||
|
@ -137,20 +98,12 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
{
|
{
|
||||||
switch(jjstateSet[--i])
|
switch(jjstateSet[--i])
|
||||||
{
|
{
|
||||||
case 36:
|
|
||||||
case 25:
|
|
||||||
if ((0xfbfffcf8ffffd9ffL & l) == 0L)
|
|
||||||
break;
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
break;
|
|
||||||
case 0:
|
case 0:
|
||||||
if ((0xfbffd4f8ffffd9ffL & l) != 0L)
|
if ((0xfbffd4f8ffffd9ffL & l) != 0L)
|
||||||
{
|
{
|
||||||
if (kind > 22)
|
if (kind > 18)
|
||||||
kind = 22;
|
kind = 18;
|
||||||
jjCheckNAddTwoStates(25, 26);
|
jjCheckNAddTwoStates(20, 21);
|
||||||
}
|
}
|
||||||
else if ((0x100002600L & l) != 0L)
|
else if ((0x100002600L & l) != 0L)
|
||||||
{
|
{
|
||||||
|
@ -164,17 +117,6 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
if (kind > 10)
|
if (kind > 10)
|
||||||
kind = 10;
|
kind = 10;
|
||||||
}
|
}
|
||||||
if ((0x7bffd0f8ffffd9ffL & l) != 0L)
|
|
||||||
{
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddStates(3, 7);
|
|
||||||
}
|
|
||||||
else if (curChar == 42)
|
|
||||||
{
|
|
||||||
if (kind > 21)
|
|
||||||
kind = 21;
|
|
||||||
}
|
|
||||||
if (curChar == 38)
|
if (curChar == 38)
|
||||||
jjstateSet[jjnewStateCnt++] = 4;
|
jjstateSet[jjnewStateCnt++] = 4;
|
||||||
break;
|
break;
|
||||||
|
@ -202,68 +144,45 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
jjCheckNAddStates(0, 2);
|
jjCheckNAddStates(0, 2);
|
||||||
break;
|
break;
|
||||||
case 18:
|
case 18:
|
||||||
if (curChar == 34 && kind > 18)
|
if (curChar == 34 && kind > 17)
|
||||||
kind = 18;
|
kind = 17;
|
||||||
break;
|
break;
|
||||||
case 20:
|
case 19:
|
||||||
if ((0x3ff000000000000L & l) == 0L)
|
|
||||||
break;
|
|
||||||
if (kind > 20)
|
|
||||||
kind = 20;
|
|
||||||
jjAddStates(8, 9);
|
|
||||||
break;
|
|
||||||
case 21:
|
|
||||||
if (curChar == 46)
|
|
||||||
jjCheckNAdd(22);
|
|
||||||
break;
|
|
||||||
case 22:
|
|
||||||
if ((0x3ff000000000000L & l) == 0L)
|
|
||||||
break;
|
|
||||||
if (kind > 20)
|
|
||||||
kind = 20;
|
|
||||||
jjCheckNAdd(22);
|
|
||||||
break;
|
|
||||||
case 23:
|
|
||||||
if (curChar == 42 && kind > 21)
|
|
||||||
kind = 21;
|
|
||||||
break;
|
|
||||||
case 24:
|
|
||||||
if ((0xfbffd4f8ffffd9ffL & l) == 0L)
|
if ((0xfbffd4f8ffffd9ffL & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 22)
|
if (kind > 18)
|
||||||
kind = 22;
|
kind = 18;
|
||||||
jjCheckNAddTwoStates(25, 26);
|
jjCheckNAddTwoStates(20, 21);
|
||||||
|
break;
|
||||||
|
case 20:
|
||||||
|
if ((0xfbfffcf8ffffd9ffL & l) == 0L)
|
||||||
|
break;
|
||||||
|
if (kind > 18)
|
||||||
|
kind = 18;
|
||||||
|
jjCheckNAddTwoStates(20, 21);
|
||||||
|
break;
|
||||||
|
case 22:
|
||||||
|
if (kind > 18)
|
||||||
|
kind = 18;
|
||||||
|
jjCheckNAddTwoStates(20, 21);
|
||||||
|
break;
|
||||||
|
case 25:
|
||||||
|
if ((0x3ff000000000000L & l) == 0L)
|
||||||
|
break;
|
||||||
|
if (kind > 19)
|
||||||
|
kind = 19;
|
||||||
|
jjAddStates(3, 4);
|
||||||
|
break;
|
||||||
|
case 26:
|
||||||
|
if (curChar == 46)
|
||||||
|
jjCheckNAdd(27);
|
||||||
break;
|
break;
|
||||||
case 27:
|
case 27:
|
||||||
if (kind > 22)
|
if ((0x3ff000000000000L & l) == 0L)
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
break;
|
|
||||||
case 28:
|
|
||||||
if ((0x7bffd0f8ffffd9ffL & l) == 0L)
|
|
||||||
break;
|
break;
|
||||||
if (kind > 19)
|
if (kind > 19)
|
||||||
kind = 19;
|
kind = 19;
|
||||||
jjCheckNAddStates(3, 7);
|
jjCheckNAdd(27);
|
||||||
break;
|
|
||||||
case 29:
|
|
||||||
if ((0x7bfff8f8ffffd9ffL & l) == 0L)
|
|
||||||
break;
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddTwoStates(29, 30);
|
|
||||||
break;
|
|
||||||
case 31:
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddTwoStates(29, 30);
|
|
||||||
break;
|
|
||||||
case 32:
|
|
||||||
if ((0x7bfff8f8ffffd9ffL & l) != 0L)
|
|
||||||
jjCheckNAddStates(10, 12);
|
|
||||||
break;
|
|
||||||
case 34:
|
|
||||||
jjCheckNAddStates(10, 12);
|
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
}
|
}
|
||||||
|
@ -276,37 +195,21 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
{
|
{
|
||||||
switch(jjstateSet[--i])
|
switch(jjstateSet[--i])
|
||||||
{
|
{
|
||||||
case 36:
|
|
||||||
if ((0x97ffffff87ffffffL & l) != 0L)
|
|
||||||
{
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
}
|
|
||||||
else if (curChar == 92)
|
|
||||||
jjCheckNAddTwoStates(27, 27);
|
|
||||||
break;
|
|
||||||
case 0:
|
case 0:
|
||||||
if ((0x97ffffff87ffffffL & l) != 0L)
|
if ((0x97ffffff87ffffffL & l) != 0L)
|
||||||
{
|
{
|
||||||
if (kind > 19)
|
if (kind > 18)
|
||||||
kind = 19;
|
kind = 18;
|
||||||
jjCheckNAddStates(3, 7);
|
jjCheckNAddTwoStates(20, 21);
|
||||||
}
|
}
|
||||||
else if (curChar == 92)
|
|
||||||
jjCheckNAddStates(13, 15);
|
|
||||||
else if (curChar == 126)
|
else if (curChar == 126)
|
||||||
{
|
{
|
||||||
if (kind > 20)
|
if (kind > 19)
|
||||||
kind = 20;
|
kind = 19;
|
||||||
jjstateSet[jjnewStateCnt++] = 20;
|
jjstateSet[jjnewStateCnt++] = 25;
|
||||||
}
|
|
||||||
if ((0x97ffffff87ffffffL & l) != 0L)
|
|
||||||
{
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
}
|
}
|
||||||
|
else if (curChar == 92)
|
||||||
|
jjCheckNAdd(22);
|
||||||
if (curChar == 78)
|
if (curChar == 78)
|
||||||
jjstateSet[jjnewStateCnt++] = 11;
|
jjstateSet[jjnewStateCnt++] = 11;
|
||||||
else if (curChar == 124)
|
else if (curChar == 124)
|
||||||
|
@ -368,72 +271,32 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
jjCheckNAddStates(0, 2);
|
jjCheckNAddStates(0, 2);
|
||||||
break;
|
break;
|
||||||
case 19:
|
case 19:
|
||||||
if (curChar != 126)
|
case 20:
|
||||||
|
if ((0x97ffffff87ffffffL & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 20)
|
if (kind > 18)
|
||||||
kind = 20;
|
kind = 18;
|
||||||
jjstateSet[jjnewStateCnt++] = 20;
|
jjCheckNAddTwoStates(20, 21);
|
||||||
|
break;
|
||||||
|
case 21:
|
||||||
|
if (curChar == 92)
|
||||||
|
jjCheckNAddTwoStates(22, 22);
|
||||||
|
break;
|
||||||
|
case 22:
|
||||||
|
if (kind > 18)
|
||||||
|
kind = 18;
|
||||||
|
jjCheckNAddTwoStates(20, 21);
|
||||||
|
break;
|
||||||
|
case 23:
|
||||||
|
if (curChar == 92)
|
||||||
|
jjCheckNAdd(22);
|
||||||
break;
|
break;
|
||||||
case 24:
|
case 24:
|
||||||
if ((0x97ffffff87ffffffL & l) == 0L)
|
if (curChar != 126)
|
||||||
break;
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
break;
|
|
||||||
case 25:
|
|
||||||
if ((0x97ffffff87ffffffL & l) == 0L)
|
|
||||||
break;
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
break;
|
|
||||||
case 26:
|
|
||||||
if (curChar == 92)
|
|
||||||
jjCheckNAddTwoStates(27, 27);
|
|
||||||
break;
|
|
||||||
case 27:
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
break;
|
|
||||||
case 28:
|
|
||||||
if ((0x97ffffff87ffffffL & l) == 0L)
|
|
||||||
break;
|
break;
|
||||||
if (kind > 19)
|
if (kind > 19)
|
||||||
kind = 19;
|
kind = 19;
|
||||||
jjCheckNAddStates(3, 7);
|
jjstateSet[jjnewStateCnt++] = 25;
|
||||||
break;
|
|
||||||
case 29:
|
|
||||||
if ((0x97ffffff87ffffffL & l) == 0L)
|
|
||||||
break;
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddTwoStates(29, 30);
|
|
||||||
break;
|
|
||||||
case 30:
|
|
||||||
if (curChar == 92)
|
|
||||||
jjCheckNAddTwoStates(31, 31);
|
|
||||||
break;
|
|
||||||
case 31:
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddTwoStates(29, 30);
|
|
||||||
break;
|
|
||||||
case 32:
|
|
||||||
if ((0x97ffffff87ffffffL & l) != 0L)
|
|
||||||
jjCheckNAddStates(10, 12);
|
|
||||||
break;
|
|
||||||
case 33:
|
|
||||||
if (curChar == 92)
|
|
||||||
jjCheckNAddTwoStates(34, 34);
|
|
||||||
break;
|
|
||||||
case 34:
|
|
||||||
jjCheckNAddStates(10, 12);
|
|
||||||
break;
|
|
||||||
case 35:
|
|
||||||
if (curChar == 92)
|
|
||||||
jjCheckNAddStates(13, 15);
|
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
}
|
}
|
||||||
|
@ -450,14 +313,6 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
{
|
{
|
||||||
switch(jjstateSet[--i])
|
switch(jjstateSet[--i])
|
||||||
{
|
{
|
||||||
case 36:
|
|
||||||
case 25:
|
|
||||||
if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
|
|
||||||
break;
|
|
||||||
if (kind > 22)
|
|
||||||
kind = 22;
|
|
||||||
jjCheckNAddTwoStates(25, 26);
|
|
||||||
break;
|
|
||||||
case 0:
|
case 0:
|
||||||
if (jjCanMove_0(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_0(hiByte, i1, i2, l1, l2))
|
||||||
{
|
{
|
||||||
|
@ -466,15 +321,9 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
}
|
}
|
||||||
if (jjCanMove_2(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_2(hiByte, i1, i2, l1, l2))
|
||||||
{
|
{
|
||||||
if (kind > 22)
|
if (kind > 18)
|
||||||
kind = 22;
|
kind = 18;
|
||||||
jjCheckNAddTwoStates(25, 26);
|
jjCheckNAddTwoStates(20, 21);
|
||||||
}
|
|
||||||
if (jjCanMove_2(hiByte, i1, i2, l1, l2))
|
|
||||||
{
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddStates(3, 7);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 15:
|
case 15:
|
||||||
|
@ -482,48 +331,20 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
jjCheckNAddStates(0, 2);
|
jjCheckNAddStates(0, 2);
|
||||||
break;
|
break;
|
||||||
case 24:
|
case 19:
|
||||||
|
case 20:
|
||||||
if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
|
if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
|
||||||
break;
|
break;
|
||||||
if (kind > 22)
|
if (kind > 18)
|
||||||
kind = 22;
|
kind = 18;
|
||||||
jjCheckNAddTwoStates(25, 26);
|
jjCheckNAddTwoStates(20, 21);
|
||||||
break;
|
break;
|
||||||
case 27:
|
case 22:
|
||||||
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
break;
|
break;
|
||||||
if (kind > 22)
|
if (kind > 18)
|
||||||
kind = 22;
|
kind = 18;
|
||||||
jjCheckNAddTwoStates(25, 26);
|
jjCheckNAddTwoStates(20, 21);
|
||||||
break;
|
|
||||||
case 28:
|
|
||||||
if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
|
|
||||||
break;
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddStates(3, 7);
|
|
||||||
break;
|
|
||||||
case 29:
|
|
||||||
if (!jjCanMove_2(hiByte, i1, i2, l1, l2))
|
|
||||||
break;
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddTwoStates(29, 30);
|
|
||||||
break;
|
|
||||||
case 31:
|
|
||||||
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
|
||||||
break;
|
|
||||||
if (kind > 19)
|
|
||||||
kind = 19;
|
|
||||||
jjCheckNAddTwoStates(29, 30);
|
|
||||||
break;
|
|
||||||
case 32:
|
|
||||||
if (jjCanMove_2(hiByte, i1, i2, l1, l2))
|
|
||||||
jjCheckNAddStates(10, 12);
|
|
||||||
break;
|
|
||||||
case 34:
|
|
||||||
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
|
||||||
jjCheckNAddStates(10, 12);
|
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
}
|
}
|
||||||
|
@ -536,7 +357,7 @@ private int jjMoveNfa_3(int startState, int curPos)
|
||||||
kind = 0x7fffffff;
|
kind = 0x7fffffff;
|
||||||
}
|
}
|
||||||
++curPos;
|
++curPos;
|
||||||
if ((i = jjnewStateCnt) == (startsAt = 36 - (jjnewStateCnt = startsAt)))
|
if ((i = jjnewStateCnt) == (startsAt = 28 - (jjnewStateCnt = startsAt)))
|
||||||
return curPos;
|
return curPos;
|
||||||
try { curChar = input_stream.readChar(); }
|
try { curChar = input_stream.readChar(); }
|
||||||
catch(java.io.IOException e) { return curPos; }
|
catch(java.io.IOException e) { return curPos; }
|
||||||
|
@ -547,9 +368,9 @@ private final int jjStopStringLiteralDfa_1(int pos, long active0)
|
||||||
switch (pos)
|
switch (pos)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
if ((active0 & 0x40000000L) != 0L)
|
if ((active0 & 0x8000000L) != 0L)
|
||||||
{
|
{
|
||||||
jjmatchedKind = 33;
|
jjmatchedKind = 30;
|
||||||
return 6;
|
return 6;
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -566,9 +387,9 @@ private int jjMoveStringLiteralDfa0_1()
|
||||||
switch(curChar)
|
switch(curChar)
|
||||||
{
|
{
|
||||||
case 84:
|
case 84:
|
||||||
return jjMoveStringLiteralDfa1_1(0x40000000L);
|
return jjMoveStringLiteralDfa1_1(0x8000000L);
|
||||||
case 125:
|
case 125:
|
||||||
return jjStopAtPos(0, 31);
|
return jjStopAtPos(0, 28);
|
||||||
default :
|
default :
|
||||||
return jjMoveNfa_1(0, 0);
|
return jjMoveNfa_1(0, 0);
|
||||||
}
|
}
|
||||||
|
@ -583,8 +404,8 @@ private int jjMoveStringLiteralDfa1_1(long active0)
|
||||||
switch(curChar)
|
switch(curChar)
|
||||||
{
|
{
|
||||||
case 79:
|
case 79:
|
||||||
if ((active0 & 0x40000000L) != 0L)
|
if ((active0 & 0x8000000L) != 0L)
|
||||||
return jjStartNfaWithStates_1(1, 30, 6);
|
return jjStartNfaWithStates_1(1, 27, 6);
|
||||||
break;
|
break;
|
||||||
default :
|
default :
|
||||||
break;
|
break;
|
||||||
|
@ -620,8 +441,8 @@ private int jjMoveNfa_1(int startState, int curPos)
|
||||||
case 0:
|
case 0:
|
||||||
if ((0xfffffffeffffffffL & l) != 0L)
|
if ((0xfffffffeffffffffL & l) != 0L)
|
||||||
{
|
{
|
||||||
if (kind > 33)
|
if (kind > 30)
|
||||||
kind = 33;
|
kind = 30;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
}
|
}
|
||||||
if ((0x100002600L & l) != 0L)
|
if ((0x100002600L & l) != 0L)
|
||||||
|
@ -638,21 +459,21 @@ private int jjMoveNfa_1(int startState, int curPos)
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if ((0xfffffffbffffffffL & l) != 0L)
|
if ((0xfffffffbffffffffL & l) != 0L)
|
||||||
jjCheckNAddStates(16, 18);
|
jjCheckNAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
if (curChar == 34)
|
if (curChar == 34)
|
||||||
jjCheckNAddStates(16, 18);
|
jjCheckNAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
if (curChar == 34 && kind > 32)
|
if (curChar == 34 && kind > 29)
|
||||||
kind = 32;
|
kind = 29;
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
if ((0xfffffffeffffffffL & l) == 0L)
|
if ((0xfffffffeffffffffL & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 33)
|
if (kind > 30)
|
||||||
kind = 33;
|
kind = 30;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
|
@ -670,12 +491,12 @@ private int jjMoveNfa_1(int startState, int curPos)
|
||||||
case 6:
|
case 6:
|
||||||
if ((0xdfffffffffffffffL & l) == 0L)
|
if ((0xdfffffffffffffffL & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 33)
|
if (kind > 30)
|
||||||
kind = 33;
|
kind = 30;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
jjAddStates(16, 18);
|
jjAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
if (curChar == 92)
|
if (curChar == 92)
|
||||||
|
@ -704,20 +525,20 @@ private int jjMoveNfa_1(int startState, int curPos)
|
||||||
}
|
}
|
||||||
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
{
|
{
|
||||||
if (kind > 33)
|
if (kind > 30)
|
||||||
kind = 33;
|
kind = 30;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
jjAddStates(16, 18);
|
jjAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
break;
|
break;
|
||||||
if (kind > 33)
|
if (kind > 30)
|
||||||
kind = 33;
|
kind = 30;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
|
@ -762,9 +583,9 @@ private int jjMoveNfa_0(int startState, int curPos)
|
||||||
case 0:
|
case 0:
|
||||||
if ((0x3ff000000000000L & l) == 0L)
|
if ((0x3ff000000000000L & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 25)
|
if (kind > 22)
|
||||||
kind = 25;
|
kind = 22;
|
||||||
jjAddStates(19, 20);
|
jjAddStates(8, 9);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if (curChar == 46)
|
if (curChar == 46)
|
||||||
|
@ -773,8 +594,8 @@ private int jjMoveNfa_0(int startState, int curPos)
|
||||||
case 2:
|
case 2:
|
||||||
if ((0x3ff000000000000L & l) == 0L)
|
if ((0x3ff000000000000L & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 25)
|
if (kind > 22)
|
||||||
kind = 25;
|
kind = 22;
|
||||||
jjCheckNAdd(2);
|
jjCheckNAdd(2);
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
|
@ -825,9 +646,9 @@ private final int jjStopStringLiteralDfa_2(int pos, long active0)
|
||||||
switch (pos)
|
switch (pos)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
if ((active0 & 0x4000000L) != 0L)
|
if ((active0 & 0x800000L) != 0L)
|
||||||
{
|
{
|
||||||
jjmatchedKind = 29;
|
jjmatchedKind = 26;
|
||||||
return 6;
|
return 6;
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -844,9 +665,9 @@ private int jjMoveStringLiteralDfa0_2()
|
||||||
switch(curChar)
|
switch(curChar)
|
||||||
{
|
{
|
||||||
case 84:
|
case 84:
|
||||||
return jjMoveStringLiteralDfa1_2(0x4000000L);
|
return jjMoveStringLiteralDfa1_2(0x800000L);
|
||||||
case 93:
|
case 93:
|
||||||
return jjStopAtPos(0, 27);
|
return jjStopAtPos(0, 24);
|
||||||
default :
|
default :
|
||||||
return jjMoveNfa_2(0, 0);
|
return jjMoveNfa_2(0, 0);
|
||||||
}
|
}
|
||||||
|
@ -861,8 +682,8 @@ private int jjMoveStringLiteralDfa1_2(long active0)
|
||||||
switch(curChar)
|
switch(curChar)
|
||||||
{
|
{
|
||||||
case 79:
|
case 79:
|
||||||
if ((active0 & 0x4000000L) != 0L)
|
if ((active0 & 0x800000L) != 0L)
|
||||||
return jjStartNfaWithStates_2(1, 26, 6);
|
return jjStartNfaWithStates_2(1, 23, 6);
|
||||||
break;
|
break;
|
||||||
default :
|
default :
|
||||||
break;
|
break;
|
||||||
|
@ -898,8 +719,8 @@ private int jjMoveNfa_2(int startState, int curPos)
|
||||||
case 0:
|
case 0:
|
||||||
if ((0xfffffffeffffffffL & l) != 0L)
|
if ((0xfffffffeffffffffL & l) != 0L)
|
||||||
{
|
{
|
||||||
if (kind > 29)
|
if (kind > 26)
|
||||||
kind = 29;
|
kind = 26;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
}
|
}
|
||||||
if ((0x100002600L & l) != 0L)
|
if ((0x100002600L & l) != 0L)
|
||||||
|
@ -916,21 +737,21 @@ private int jjMoveNfa_2(int startState, int curPos)
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if ((0xfffffffbffffffffL & l) != 0L)
|
if ((0xfffffffbffffffffL & l) != 0L)
|
||||||
jjCheckNAddStates(16, 18);
|
jjCheckNAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
if (curChar == 34)
|
if (curChar == 34)
|
||||||
jjCheckNAddStates(16, 18);
|
jjCheckNAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
if (curChar == 34 && kind > 28)
|
if (curChar == 34 && kind > 25)
|
||||||
kind = 28;
|
kind = 25;
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
if ((0xfffffffeffffffffL & l) == 0L)
|
if ((0xfffffffeffffffffL & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 29)
|
if (kind > 26)
|
||||||
kind = 29;
|
kind = 26;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
|
@ -948,12 +769,12 @@ private int jjMoveNfa_2(int startState, int curPos)
|
||||||
case 6:
|
case 6:
|
||||||
if ((0xffffffffdfffffffL & l) == 0L)
|
if ((0xffffffffdfffffffL & l) == 0L)
|
||||||
break;
|
break;
|
||||||
if (kind > 29)
|
if (kind > 26)
|
||||||
kind = 29;
|
kind = 26;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
jjAddStates(16, 18);
|
jjAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
if (curChar == 92)
|
if (curChar == 92)
|
||||||
|
@ -982,20 +803,20 @@ private int jjMoveNfa_2(int startState, int curPos)
|
||||||
}
|
}
|
||||||
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
{
|
{
|
||||||
if (kind > 29)
|
if (kind > 26)
|
||||||
kind = 29;
|
kind = 26;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
jjAddStates(16, 18);
|
jjAddStates(5, 7);
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
if (!jjCanMove_1(hiByte, i1, i2, l1, l2))
|
||||||
break;
|
break;
|
||||||
if (kind > 29)
|
if (kind > 26)
|
||||||
kind = 29;
|
kind = 26;
|
||||||
jjCheckNAdd(6);
|
jjCheckNAdd(6);
|
||||||
break;
|
break;
|
||||||
default : break;
|
default : break;
|
||||||
|
@ -1016,8 +837,7 @@ private int jjMoveNfa_2(int startState, int curPos)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static final int[] jjnextStates = {
|
static final int[] jjnextStates = {
|
||||||
15, 16, 18, 29, 32, 23, 33, 30, 20, 21, 32, 23, 33, 31, 34, 27,
|
15, 16, 18, 25, 26, 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)
|
||||||
{
|
{
|
||||||
|
@ -1059,8 +879,8 @@ private static final boolean jjCanMove_2(int hiByte, int i1, int i2, long l1, lo
|
||||||
/** Token literal values. */
|
/** Token literal values. */
|
||||||
public static final String[] jjstrLiteralImages = {
|
public static final String[] jjstrLiteralImages = {
|
||||||
"", null, null, null, null, null, null, null, null, null, null, "\53", "\55",
|
"", null, null, null, null, null, null, null, null, null, null, "\53", "\55",
|
||||||
"\50", "\51", "\72", "\52", "\136", null, null, null, null, null, "\133", "\173",
|
"\50", "\51", "\72", "\136", null, null, null, "\133", "\173", null, "\124\117",
|
||||||
null, "\124\117", "\135", null, null, "\124\117", "\175", null, null, };
|
"\135", null, null, "\124\117", "\175", null, null, };
|
||||||
|
|
||||||
/** Lexer state names. */
|
/** Lexer state names. */
|
||||||
public static final String[] lexStateNames = {
|
public static final String[] lexStateNames = {
|
||||||
|
@ -1072,18 +892,18 @@ public static final String[] lexStateNames = {
|
||||||
|
|
||||||
/** Lex State array. */
|
/** Lex State array. */
|
||||||
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, -1, 0, -1, -1, -1, -1, -1, 2, 1,
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, -1, -1, -1, 2, 1, 3, -1, 3,
|
||||||
3, -1, 3, -1, -1, -1, 3, -1, -1,
|
-1, -1, -1, 3, -1, -1,
|
||||||
};
|
};
|
||||||
static final long[] jjtoToken = {
|
static final long[] jjtoToken = {
|
||||||
0x3ffffff01L,
|
0x7fffff01L,
|
||||||
};
|
};
|
||||||
static final long[] jjtoSkip = {
|
static final long[] jjtoSkip = {
|
||||||
0x80L,
|
0x80L,
|
||||||
};
|
};
|
||||||
protected JavaCharStream input_stream;
|
protected JavaCharStream input_stream;
|
||||||
private final int[] jjrounds = new int[36];
|
private final int[] jjrounds = new int[28];
|
||||||
private final int[] jjstateSet = new int[72];
|
private final int[] jjstateSet = new int[56];
|
||||||
protected char curChar;
|
protected char curChar;
|
||||||
/** Constructor. */
|
/** Constructor. */
|
||||||
public StandardSyntaxParserTokenManager(JavaCharStream stream){
|
public StandardSyntaxParserTokenManager(JavaCharStream stream){
|
||||||
|
@ -1110,7 +930,7 @@ private void ReInitRounds()
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
jjround = 0x80000001;
|
jjround = 0x80000001;
|
||||||
for (i = 36; i-- > 0;)
|
for (i = 28; i-- > 0;)
|
||||||
jjrounds[i] = 0x80000000;
|
jjrounds[i] = 0x80000000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -128,4 +128,4 @@ public class Token implements java.io.Serializable {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
/* JavaCC - StandardChecksum=f9eb36a076cde62bf39ccbf828bc2117 (do not edit this line) */
|
/* JavaCC - OriginalChecksum=75998e81abbed08b0922a65bec11680d (do not edit this line) */
|
||||||
|
|
|
@ -144,4 +144,4 @@ public class TokenMgrError extends Error
|
||||||
this(LexicalError(EOFSeen, lexState, errorLine, errorColumn, errorAfter, curChar), reason);
|
this(LexicalError(EOFSeen, lexState, errorLine, errorColumn, errorAfter, curChar), reason);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* JavaCC - StandardChecksum=91ba9c9f5e0e552a815530d639ce15ed (do not edit this line) */
|
/* JavaCC - OriginalChecksum=9672a6de7ecf4f5789a473d7dd40f6fb (do not edit this line) */
|
||||||
|
|
|
@ -24,9 +24,10 @@ import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryParser.core.config.QueryConfigHandler;
|
import org.apache.lucene.queryParser.core.config.QueryConfigHandler;
|
||||||
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
|
import org.apache.lucene.queryParser.core.util.UnescapedCharSequence;
|
||||||
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
|
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
import org.apache.lucene.queryParser.standard.parser.EscapeQuerySyntaxImpl;
|
import org.apache.lucene.queryParser.standard.parser.EscapeQuerySyntaxImpl;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -46,19 +47,16 @@ public class AllowLeadingWildcardProcessor extends QueryNodeProcessorImpl {
|
||||||
|
|
||||||
public QueryNode process(QueryNode queryTree) throws QueryNodeException {
|
public QueryNode process(QueryNode queryTree) throws QueryNodeException {
|
||||||
|
|
||||||
if (getQueryConfigHandler().hasAttribute(
|
if (getQueryConfigHandler().hasAttribute(AllowLeadingWildcardAttribute.class)) {
|
||||||
AllowLeadingWildcardAttribute.class)) {
|
|
||||||
|
|
||||||
if (!((AllowLeadingWildcardAttribute) getQueryConfigHandler()
|
AllowLeadingWildcardAttribute alwAttr= (AllowLeadingWildcardAttribute) getQueryConfigHandler().getAttribute(AllowLeadingWildcardAttribute.class);
|
||||||
.getAttribute(AllowLeadingWildcardAttribute.class))
|
if (!alwAttr.isAllowLeadingWildcard()) {
|
||||||
.isAllowLeadingWildcard()) {
|
|
||||||
return super.process(queryTree);
|
return super.process(queryTree);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return queryTree;
|
return queryTree;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException {
|
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException {
|
||||||
|
@ -66,14 +64,19 @@ public class AllowLeadingWildcardProcessor extends QueryNodeProcessorImpl {
|
||||||
if (node instanceof WildcardQueryNode) {
|
if (node instanceof WildcardQueryNode) {
|
||||||
WildcardQueryNode wildcardNode = (WildcardQueryNode) node;
|
WildcardQueryNode wildcardNode = (WildcardQueryNode) node;
|
||||||
|
|
||||||
switch (wildcardNode.getText().charAt(0)) {
|
if (wildcardNode.getText().length() > 0) {
|
||||||
|
|
||||||
|
// Validate if the wildcard was escaped
|
||||||
|
if (UnescapedCharSequence.wasEscaped(wildcardNode.getText(), 0))
|
||||||
|
return node;
|
||||||
|
|
||||||
|
switch (wildcardNode.getText().charAt(0)) {
|
||||||
case '*':
|
case '*':
|
||||||
case '?':
|
case '?':
|
||||||
throw new QueryNodeException(new MessageImpl(
|
throw new QueryNodeException(new MessageImpl(
|
||||||
QueryParserMessages.LEADING_WILDCARD_NOT_ALLOWED, node
|
QueryParserMessages.LEADING_WILDCARD_NOT_ALLOWED, node
|
||||||
.toQueryString(new EscapeQuerySyntaxImpl())));
|
.toQueryString(new EscapeQuerySyntaxImpl())));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,12 +38,12 @@ import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.TextableQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.TextableQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.TokenizedPhraseQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.TokenizedPhraseQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
|
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
|
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.nodes.StandardBooleanQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.standard.nodes.MultiPhraseQueryNode;
|
import org.apache.lucene.queryParser.standard.nodes.MultiPhraseQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.StandardBooleanQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This processor verifies if the attribute {@link AnalyzerQueryNodeProcessor}
|
* This processor verifies if the attribute {@link AnalyzerQueryNodeProcessor}
|
||||||
|
|
|
@ -25,9 +25,10 @@ import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
|
import org.apache.lucene.queryParser.core.util.UnescapedCharSequence;
|
||||||
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
|
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This processor verifies if the attribute
|
* This processor verifies if the attribute
|
||||||
|
@ -69,8 +70,7 @@ public class LowercaseExpandedTermsQueryNodeProcessor extends
|
||||||
|| node instanceof ParametricQueryNode) {
|
|| node instanceof ParametricQueryNode) {
|
||||||
|
|
||||||
FieldQueryNode fieldNode = (FieldQueryNode) node;
|
FieldQueryNode fieldNode = (FieldQueryNode) node;
|
||||||
fieldNode.setText(fieldNode.getText().toString().toLowerCase());
|
fieldNode.setText(UnescapedCharSequence.toLowerCase(fieldNode.getText()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return node;
|
return node;
|
||||||
|
|
|
@ -20,10 +20,11 @@ package org.apache.lucene.queryParser.standard.processors;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeException;
|
import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.MatchAllDocsQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.MatchAllDocsQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
import org.apache.lucene.search.MatchAllDocsQuery;
|
import org.apache.lucene.search.MatchAllDocsQuery;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -41,11 +42,11 @@ public class MatchAllDocsQueryNodeProcessor extends QueryNodeProcessorImpl {
|
||||||
|
|
||||||
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException {
|
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException {
|
||||||
|
|
||||||
if (node instanceof WildcardQueryNode) {
|
if (node instanceof FieldQueryNode) {
|
||||||
WildcardQueryNode wildcardNode = (WildcardQueryNode) node;
|
FieldQueryNode fqn = (FieldQueryNode) node;
|
||||||
|
|
||||||
if (wildcardNode.getField().toString().equals("*")
|
if (fqn.getField().toString().equals("*")
|
||||||
&& wildcardNode.getText().toString().equals("*")) {
|
&& fqn.getText().toString().equals("*")) {
|
||||||
|
|
||||||
return new MatchAllDocsQueryNode();
|
return new MatchAllDocsQueryNode();
|
||||||
|
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
package org.apache.lucene.queryParser.standard.processors;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
|
||||||
import org.apache.lucene.search.MultiTermQuery;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This processor instates the default {@link
|
|
||||||
* MultiTermQuery.RewriteMethod}, {@link
|
|
||||||
* MultiTermQuery#CONSTANT_SCORE_AUTO_REWRITE_DEFAULT}, for
|
|
||||||
* multi-term query nodes.
|
|
||||||
*/
|
|
||||||
public class MultiTermRewriteDefaultProcessor extends QueryNodeProcessorImpl {
|
|
||||||
|
|
||||||
protected QueryNode postProcessNode(QueryNode node) {
|
|
||||||
if (node instanceof WildcardQueryNode) {
|
|
||||||
((WildcardQueryNode) node).setMultiTermRewriteMethod(MultiTermQuery.CONSTANT_SCORE_AUTO_REWRITE_DEFAULT);
|
|
||||||
} else if (node instanceof PrefixWildcardQueryNode) {
|
|
||||||
((PrefixWildcardQueryNode) node).setMultiTermRewriteMethod(MultiTermQuery.CONSTANT_SCORE_AUTO_REWRITE_DEFAULT);
|
|
||||||
}
|
|
||||||
|
|
||||||
return node;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected QueryNode preProcessNode(QueryNode node) {
|
|
||||||
return node;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected List<QueryNode> setChildrenOrder(List<QueryNode> children) {
|
|
||||||
return children;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,66 @@
|
||||||
|
package org.apache.lucene.queryParser.standard.processors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
|
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This processor instates the default {@link
|
||||||
|
* MultiTermQuery.RewriteMethod}, {@link
|
||||||
|
* MultiTermQuery#CONSTANT_SCORE_AUTO_REWRITE_DEFAULT}, for
|
||||||
|
* multi-term query nodes.
|
||||||
|
*/
|
||||||
|
public class MultiTermRewriteMethodProcessor extends QueryNodeProcessorImpl {
|
||||||
|
|
||||||
|
protected QueryNode postProcessNode(QueryNode node) {
|
||||||
|
|
||||||
|
// set setMultiTermRewriteMethod for WildcardQueryNode and PrefixWildcardQueryNode
|
||||||
|
if (node instanceof WildcardQueryNode || node instanceof ParametricRangeQueryNode
|
||||||
|
|| node instanceof ParametricRangeQueryNode) {
|
||||||
|
|
||||||
|
if (!getQueryConfigHandler().hasAttribute(MultiTermRewriteMethodAttribute.class)) {
|
||||||
|
// This should not happen, this attribute is created in the StandardQueryConfigHandler
|
||||||
|
throw new IllegalArgumentException("MultiTermRewriteMethodAttribute should be set on the QueryConfigHandler");
|
||||||
|
}
|
||||||
|
|
||||||
|
//read the attribute value and use a TAG to take the value to the Builder
|
||||||
|
MultiTermQuery.RewriteMethod rewriteMethod = ((MultiTermRewriteMethodAttribute) getQueryConfigHandler()
|
||||||
|
.getAttribute(MultiTermRewriteMethodAttribute.class))
|
||||||
|
.getMultiTermRewriteMethod();
|
||||||
|
|
||||||
|
node.setTag(MultiTermRewriteMethodAttribute.TAG_ID, rewriteMethod);
|
||||||
|
}
|
||||||
|
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected QueryNode preProcessNode(QueryNode node) {
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected List<QueryNode> setChildrenOrder(List<QueryNode> children) {
|
||||||
|
return children;
|
||||||
|
}
|
||||||
|
}
|
|
@ -35,12 +35,10 @@ import org.apache.lucene.queryParser.core.nodes.ParametricRangeQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode.CompareOperator;
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode.CompareOperator;
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
|
|
||||||
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
|
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
|
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
|
||||||
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
import org.apache.lucene.queryParser.standard.nodes.RangeQueryNode;
|
||||||
import org.apache.lucene.search.MultiTermQuery;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This processor converts {@link ParametricRangeQueryNode} objects to
|
* This processor converts {@link ParametricRangeQueryNode} objects to
|
||||||
|
@ -85,16 +83,6 @@ public class ParametricRangeQueryNodeProcessor extends QueryNodeProcessorImpl {
|
||||||
DateTools.Resolution dateRes = null;
|
DateTools.Resolution dateRes = null;
|
||||||
boolean inclusive = false;
|
boolean inclusive = false;
|
||||||
|
|
||||||
if (!getQueryConfigHandler().hasAttribute(
|
|
||||||
MultiTermRewriteMethodAttribute.class)) {
|
|
||||||
throw new IllegalArgumentException(
|
|
||||||
"MultiTermRewriteMethodAttribute should be set on the QueryConfigHandler");
|
|
||||||
}
|
|
||||||
|
|
||||||
MultiTermQuery.RewriteMethod rewriteMethod = ((MultiTermRewriteMethodAttribute) getQueryConfigHandler()
|
|
||||||
.getAttribute(MultiTermRewriteMethodAttribute.class))
|
|
||||||
.getMultiTermRewriteMethod();
|
|
||||||
|
|
||||||
if (getQueryConfigHandler().hasAttribute(RangeCollatorAttribute.class)) {
|
if (getQueryConfigHandler().hasAttribute(RangeCollatorAttribute.class)) {
|
||||||
collator = ((RangeCollatorAttribute) getQueryConfigHandler()
|
collator = ((RangeCollatorAttribute) getQueryConfigHandler()
|
||||||
.getAttribute(RangeCollatorAttribute.class)).getRangeCollator();
|
.getAttribute(RangeCollatorAttribute.class)).getRangeCollator();
|
||||||
|
@ -164,7 +152,7 @@ public class ParametricRangeQueryNodeProcessor extends QueryNodeProcessorImpl {
|
||||||
lower.setText(part1);
|
lower.setText(part1);
|
||||||
upper.setText(part2);
|
upper.setText(part2);
|
||||||
|
|
||||||
return new RangeQueryNode(lower, upper, collator, rewriteMethod);
|
return new RangeQueryNode(lower, upper, collator);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,72 +0,0 @@
|
||||||
package org.apache.lucene.queryParser.standard.processors;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.apache.lucene.queryParser.core.QueryNodeException;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.PrefixWildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
|
||||||
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
|
||||||
import org.apache.lucene.search.PrefixQuery;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The {@link StandardSyntaxParser} creates {@link PrefixWildcardQueryNode} nodes which
|
|
||||||
* have values containing the prefixed wildcard. However, Lucene
|
|
||||||
* {@link PrefixQuery} cannot contain the prefixed wildcard. So, this processor
|
|
||||||
* basically removed the prefixed wildcard from the
|
|
||||||
* {@link PrefixWildcardQueryNode} value. <br/>
|
|
||||||
*
|
|
||||||
* @see PrefixQuery
|
|
||||||
* @see PrefixWildcardQueryNode
|
|
||||||
*/
|
|
||||||
public class PrefixWildcardQueryNodeProcessor extends QueryNodeProcessorImpl {
|
|
||||||
|
|
||||||
public PrefixWildcardQueryNodeProcessor() {
|
|
||||||
// empty constructor
|
|
||||||
}
|
|
||||||
|
|
||||||
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException {
|
|
||||||
|
|
||||||
if (node instanceof PrefixWildcardQueryNode) {
|
|
||||||
PrefixWildcardQueryNode prefixWildcardNode = (PrefixWildcardQueryNode) node;
|
|
||||||
CharSequence text = prefixWildcardNode.getText();
|
|
||||||
|
|
||||||
prefixWildcardNode.setText(text.subSequence(0, text.length() - 1));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return node;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
protected QueryNode preProcessNode(QueryNode node) throws QueryNodeException {
|
|
||||||
|
|
||||||
return node;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
protected List<QueryNode> setChildrenOrder(List<QueryNode> children)
|
|
||||||
throws QueryNodeException {
|
|
||||||
|
|
||||||
return children;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -48,13 +48,13 @@ public class StandardQueryNodeProcessorPipeline extends
|
||||||
public StandardQueryNodeProcessorPipeline(QueryConfigHandler queryConfig) {
|
public StandardQueryNodeProcessorPipeline(QueryConfigHandler queryConfig) {
|
||||||
super(queryConfig);
|
super(queryConfig);
|
||||||
|
|
||||||
|
addProcessor(new WildcardQueryNodeProcessor());
|
||||||
addProcessor(new MultiFieldQueryNodeProcessor());
|
addProcessor(new MultiFieldQueryNodeProcessor());
|
||||||
addProcessor(new FuzzyQueryNodeProcessor());
|
addProcessor(new FuzzyQueryNodeProcessor());
|
||||||
addProcessor(new MatchAllDocsQueryNodeProcessor());
|
addProcessor(new MatchAllDocsQueryNodeProcessor());
|
||||||
addProcessor(new LowercaseExpandedTermsQueryNodeProcessor());
|
addProcessor(new LowercaseExpandedTermsQueryNodeProcessor());
|
||||||
addProcessor(new ParametricRangeQueryNodeProcessor());
|
addProcessor(new ParametricRangeQueryNodeProcessor());
|
||||||
addProcessor(new AllowLeadingWildcardProcessor());
|
addProcessor(new AllowLeadingWildcardProcessor());
|
||||||
addProcessor(new PrefixWildcardQueryNodeProcessor());
|
|
||||||
addProcessor(new AnalyzerQueryNodeProcessor());
|
addProcessor(new AnalyzerQueryNodeProcessor());
|
||||||
addProcessor(new PhraseSlopQueryNodeProcessor());
|
addProcessor(new PhraseSlopQueryNodeProcessor());
|
||||||
addProcessor(new GroupQueryNodeProcessor());
|
addProcessor(new GroupQueryNodeProcessor());
|
||||||
|
@ -64,8 +64,7 @@ public class StandardQueryNodeProcessorPipeline extends
|
||||||
addProcessor(new BooleanSingleChildOptimizationQueryNodeProcessor());
|
addProcessor(new BooleanSingleChildOptimizationQueryNodeProcessor());
|
||||||
addProcessor(new DefaultPhraseSlopQueryNodeProcessor());
|
addProcessor(new DefaultPhraseSlopQueryNodeProcessor());
|
||||||
addProcessor(new BoostQueryNodeProcessor());
|
addProcessor(new BoostQueryNodeProcessor());
|
||||||
addProcessor(new MultiTermRewriteDefaultProcessor());
|
addProcessor(new MultiTermRewriteMethodProcessor());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,136 @@
|
||||||
|
package org.apache.lucene.queryParser.standard.processors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.nodes.QuotedFieldQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
|
import org.apache.lucene.queryParser.core.util.UnescapedCharSequence;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.PrefixWildcardQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
||||||
|
import org.apache.lucene.search.PrefixQuery;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The {@link StandardSyntaxParser} creates {@link PrefixWildcardQueryNode} nodes which
|
||||||
|
* have values containing the prefixed wildcard. However, Lucene
|
||||||
|
* {@link PrefixQuery} cannot contain the prefixed wildcard. So, this processor
|
||||||
|
* basically removed the prefixed wildcard from the
|
||||||
|
* {@link PrefixWildcardQueryNode} value. <br/>
|
||||||
|
*
|
||||||
|
* @see PrefixQuery
|
||||||
|
* @see PrefixWildcardQueryNode
|
||||||
|
*/
|
||||||
|
public class WildcardQueryNodeProcessor extends QueryNodeProcessorImpl {
|
||||||
|
|
||||||
|
public WildcardQueryNodeProcessor() {
|
||||||
|
// empty constructor
|
||||||
|
}
|
||||||
|
|
||||||
|
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException {
|
||||||
|
|
||||||
|
// the old Lucene Parser ignores FuzzyQueryNode that are also PrefixWildcardQueryNode or WildcardQueryNode
|
||||||
|
// we do the same here, also ignore empty terms
|
||||||
|
if (node instanceof FieldQueryNode || node instanceof FuzzyQueryNode) {
|
||||||
|
FieldQueryNode fqn = (FieldQueryNode) node;
|
||||||
|
CharSequence text = fqn.getText();
|
||||||
|
|
||||||
|
// do not process wildcards for ParametricQueryNode and
|
||||||
|
// QuotedFieldQueryNode to reproduce the old parser behavior
|
||||||
|
if (fqn instanceof ParametricQueryNode
|
||||||
|
|| fqn instanceof QuotedFieldQueryNode
|
||||||
|
|| text.length() <= 0){
|
||||||
|
// Ignore empty terms
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Code below simulates the old lucene parser behavior for wildcards
|
||||||
|
|
||||||
|
if (isPrefixWildcard(text)) {
|
||||||
|
PrefixWildcardQueryNode prefixWildcardQN = new PrefixWildcardQueryNode(fqn);
|
||||||
|
return prefixWildcardQN;
|
||||||
|
|
||||||
|
} else if (isWildcard(text)){
|
||||||
|
WildcardQueryNode wildcardQN = new WildcardQueryNode(fqn);
|
||||||
|
return wildcardQN;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return node;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isWildcard(CharSequence text) {
|
||||||
|
if (text ==null || text.length() <= 0) return false;
|
||||||
|
|
||||||
|
// If a un-escaped '*' or '?' if found return true
|
||||||
|
// start at the end since it's more common to put wildcards at the end
|
||||||
|
for(int i=text.length()-1; i>=0; i--){
|
||||||
|
if ((text.charAt(i) == '*' || text.charAt(i) == '?') && !UnescapedCharSequence.wasEscaped(text, i)){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isPrefixWildcard(CharSequence text) {
|
||||||
|
if (text == null || text.length() <= 0 || !isWildcard(text)) return false;
|
||||||
|
|
||||||
|
// Validate last character is a '*' and was not escaped
|
||||||
|
// If single '*' is is a wildcard not prefix to simulate old queryparser
|
||||||
|
if (text.charAt(text.length()-1) != '*') return false;
|
||||||
|
if (UnescapedCharSequence.wasEscaped(text, text.length()-1)) return false;
|
||||||
|
if (text.length() == 1) return false;
|
||||||
|
|
||||||
|
// Only make a prefix if there is only one single star at the end and no '?' or '*' characters
|
||||||
|
// If single wildcard return false to mimic old queryparser
|
||||||
|
for(int i=0; i<text.length(); i++){
|
||||||
|
if (text.charAt(i) == '?') return false;
|
||||||
|
if (text.charAt(i) == '*' && !UnescapedCharSequence.wasEscaped(text, i)){
|
||||||
|
if (i == text.length()-1)
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected QueryNode preProcessNode(QueryNode node) throws QueryNodeException {
|
||||||
|
|
||||||
|
return node;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected List<QueryNode> setChildrenOrder(List<QueryNode> children)
|
||||||
|
throws QueryNodeException {
|
||||||
|
|
||||||
|
return children;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -27,6 +27,7 @@ import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorPipeline;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorPipeline;
|
||||||
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
|
||||||
|
import org.apache.lucene.queryParser.standard.processors.WildcardQueryNodeProcessor;
|
||||||
import org.apache.lucene.search.spans.SpanOrQuery;
|
import org.apache.lucene.search.spans.SpanOrQuery;
|
||||||
import org.apache.lucene.search.spans.SpanQuery;
|
import org.apache.lucene.search.spans.SpanQuery;
|
||||||
import org.apache.lucene.search.spans.SpanTermQuery;
|
import org.apache.lucene.search.spans.SpanTermQuery;
|
||||||
|
@ -115,13 +116,11 @@ public class TestSpanQueryParser extends TestCase {
|
||||||
this.spansQueryTreeBuilder = new SpansQueryTreeBuilder();
|
this.spansQueryTreeBuilder = new SpansQueryTreeBuilder();
|
||||||
|
|
||||||
// set up the processor pipeline
|
// set up the processor pipeline
|
||||||
this.spanProcessorPipeline
|
this.spanProcessorPipeline.setQueryConfigHandler(this.spanQueryConfigHandler);
|
||||||
.setQueryConfigHandler(this.spanQueryConfigHandler);
|
|
||||||
|
|
||||||
this.spanProcessorPipeline
|
this.spanProcessorPipeline.addProcessor(new WildcardQueryNodeProcessor());
|
||||||
.addProcessor(new SpansValidatorQueryNodeProcessor());
|
this.spanProcessorPipeline.addProcessor(new SpansValidatorQueryNodeProcessor());
|
||||||
this.spanProcessorPipeline
|
this.spanProcessorPipeline.addProcessor(new UniqueFieldQueryNodeProcessor());
|
||||||
.addProcessor(new UniqueFieldQueryNodeProcessor());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -54,10 +54,10 @@ import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
||||||
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorPipeline;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorPipeline;
|
||||||
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator;
|
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.search.FuzzyQuery;
|
import org.apache.lucene.search.FuzzyQuery;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
@ -759,6 +759,8 @@ public class TestQPHelper extends LuceneTestCase {
|
||||||
* "foo \\AND bar");
|
* "foo \\AND bar");
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
assertQueryEquals("\\*", a, "*");
|
||||||
|
|
||||||
assertQueryEquals("\\a", a, "a");
|
assertQueryEquals("\\a", a, "a");
|
||||||
|
|
||||||
assertQueryEquals("a\\-b:c", a, "a-b:c");
|
assertQueryEquals("a\\-b:c", a, "a-b:c");
|
||||||
|
@ -938,13 +940,13 @@ public class TestQPHelper extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testException() throws Exception {
|
public void testException() throws Exception {
|
||||||
|
assertQueryNodeException("*leadingWildcard"); // disallowed by default
|
||||||
assertQueryNodeException("\"some phrase");
|
assertQueryNodeException("\"some phrase");
|
||||||
assertQueryNodeException("(foo bar");
|
assertQueryNodeException("(foo bar");
|
||||||
assertQueryNodeException("foo bar))");
|
assertQueryNodeException("foo bar))");
|
||||||
assertQueryNodeException("field:term:with:colon some more terms");
|
assertQueryNodeException("field:term:with:colon some more terms");
|
||||||
assertQueryNodeException("(sub query)^5.0^2.0 plus more");
|
assertQueryNodeException("(sub query)^5.0^2.0 plus more");
|
||||||
assertQueryNodeException("secret AND illegal) AND access:confidential");
|
assertQueryNodeException("secret AND illegal) AND access:confidential");
|
||||||
assertQueryNodeException("*leadingWildcard"); // disallowed by default
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCustomQueryParserWildcard() {
|
public void testCustomQueryParserWildcard() {
|
||||||
|
|
|
@ -51,9 +51,10 @@ import org.apache.lucene.queryParser.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
import org.apache.lucene.queryParser.core.messages.QueryParserMessages;
|
||||||
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
import org.apache.lucene.queryParser.core.nodes.FuzzyQueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
import org.apache.lucene.queryParser.core.nodes.QueryNode;
|
||||||
import org.apache.lucene.queryParser.core.nodes.WildcardQueryNode;
|
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorImpl;
|
||||||
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorPipeline;
|
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessorPipeline;
|
||||||
|
import org.apache.lucene.queryParser.standard.nodes.WildcardQueryNode;
|
||||||
|
import org.apache.lucene.queryParser.standard.processors.WildcardQueryNodeProcessor;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.search.FuzzyQuery;
|
import org.apache.lucene.search.FuzzyQuery;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
@ -159,6 +160,7 @@ public class TestQueryParserWrapper extends LuceneTestCase {
|
||||||
|
|
||||||
QueryNodeProcessorPipeline newProcessorPipeline = new QueryNodeProcessorPipeline(
|
QueryNodeProcessorPipeline newProcessorPipeline = new QueryNodeProcessorPipeline(
|
||||||
getQueryProcessor().getQueryConfigHandler());
|
getQueryProcessor().getQueryConfigHandler());
|
||||||
|
newProcessorPipeline.addProcessor(new WildcardQueryNodeProcessor());
|
||||||
newProcessorPipeline.addProcessor(new QPTestParserQueryNodeProcessor());
|
newProcessorPipeline.addProcessor(new QPTestParserQueryNodeProcessor());
|
||||||
newProcessorPipeline.addProcessor(getQueryProcessor());
|
newProcessorPipeline.addProcessor(getQueryProcessor());
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue