mirror of https://github.com/apache/lucene.git
SOLR-2444: implement parsing only of augmenters (localParams syntax but using [])
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1133457 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e934e3849f
commit
d8928bb3c7
|
@ -88,11 +88,16 @@ public class QueryParsing {
|
||||||
|
|
||||||
|
|
||||||
// note to self: something needs to detect infinite recursion when parsing queries
|
// note to self: something needs to detect infinite recursion when parsing queries
|
||||||
static int parseLocalParams(String txt, int start, Map<String, String> target, SolrParams params) throws ParseException {
|
public static int parseLocalParams(String txt, int start, Map<String, String> target, SolrParams params) throws ParseException {
|
||||||
|
return parseLocalParams(txt, start, target, params, LOCALPARAM_START, LOCALPARAM_END);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static int parseLocalParams(String txt, int start, Map<String, String> target, SolrParams params, String startString, char endChar) throws ParseException {
|
||||||
int off = start;
|
int off = start;
|
||||||
if (!txt.startsWith(LOCALPARAM_START, off)) return start;
|
if (!txt.startsWith(startString, off)) return start;
|
||||||
StrParser p = new StrParser(txt, start, txt.length());
|
StrParser p = new StrParser(txt, start, txt.length());
|
||||||
p.pos += 2; // skip over "{!"
|
p.pos += startString.length(); // skip over "{!"
|
||||||
|
|
||||||
for (; ;) {
|
for (; ;) {
|
||||||
/*
|
/*
|
||||||
|
@ -101,13 +106,13 @@ public class QueryParsing {
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
char ch = p.peek();
|
char ch = p.peek();
|
||||||
if (ch == LOCALPARAM_END) {
|
if (ch == endChar) {
|
||||||
return p.pos + 1;
|
return p.pos + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
String id = p.getId();
|
String id = p.getId();
|
||||||
if (id.length() == 0) {
|
if (id.length() == 0) {
|
||||||
throw new ParseException("Expected identifier '}' parsing local params '" + txt + '"');
|
throw new ParseException("Expected ending character '" + endChar + "' parsing local params '" + txt + '"');
|
||||||
|
|
||||||
}
|
}
|
||||||
String val = null;
|
String val = null;
|
||||||
|
@ -131,7 +136,7 @@ public class QueryParsing {
|
||||||
if (ch == '\"' || ch == '\'') {
|
if (ch == '\"' || ch == '\'') {
|
||||||
val = p.getQuotedString();
|
val = p.getQuotedString();
|
||||||
} else {
|
} else {
|
||||||
// read unquoted literal ended by whitespace or '}'
|
// read unquoted literal ended by whitespace or endChar (normally '}')
|
||||||
// there is no escaping.
|
// there is no escaping.
|
||||||
int valStart = p.pos;
|
int valStart = p.pos;
|
||||||
for (; ;) {
|
for (; ;) {
|
||||||
|
@ -139,7 +144,7 @@ public class QueryParsing {
|
||||||
throw new ParseException("Missing end to unquoted value starting at " + valStart + " str='" + txt + "'");
|
throw new ParseException("Missing end to unquoted value starting at " + valStart + " str='" + txt + "'");
|
||||||
}
|
}
|
||||||
char c = p.val.charAt(p.pos);
|
char c = p.val.charAt(p.pos);
|
||||||
if (c == LOCALPARAM_END || Character.isWhitespace(c)) {
|
if (c == endChar || Character.isWhitespace(c)) {
|
||||||
val = p.val.substring(valStart, p.pos);
|
val = p.val.substring(valStart, p.pos);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -157,6 +162,7 @@ public class QueryParsing {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static String encodeLocalParamVal(String val) {
|
public static String encodeLocalParamVal(String val) {
|
||||||
int len = val.length();
|
int len = val.length();
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
|
@ -16,17 +16,14 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.search;
|
package org.apache.solr.search;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.LinkedHashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.apache.commons.io.FilenameUtils;
|
import org.apache.commons.io.FilenameUtils;
|
||||||
import org.apache.lucene.queryParser.ParseException;
|
import org.apache.lucene.queryParser.ParseException;
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.params.CommonParams;
|
import org.apache.solr.common.params.CommonParams;
|
||||||
|
import org.apache.solr.common.params.MapSolrParams;
|
||||||
import org.apache.solr.common.params.SolrParams;
|
import org.apache.solr.common.params.SolrParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
import org.apache.solr.core.SolrCore;
|
import org.apache.solr.core.SolrCore;
|
||||||
|
@ -211,9 +208,24 @@ public class ReturnFields
|
||||||
sp.pos = start;
|
sp.pos = start;
|
||||||
}
|
}
|
||||||
|
|
||||||
// let's try it as a function instead
|
|
||||||
String funcStr = sp.val.substring(start);
|
String funcStr = sp.val.substring(start);
|
||||||
|
|
||||||
|
// Is it an augmenter of the form [augmenter_name foo=1 bar=myfield]?
|
||||||
|
// This is identical to localParams syntax except it uses [] instead of {!}
|
||||||
|
|
||||||
|
if (funcStr.startsWith("[")) {
|
||||||
|
Map<String,String> augmenterArgs = new HashMap<String,String>();
|
||||||
|
int end = QueryParsing.parseLocalParams(funcStr, 0, augmenterArgs, req.getParams(), "[", ']');
|
||||||
|
sp.pos += end;
|
||||||
|
String augmenterName = augmenterArgs.get("type"); // [foo] is short for [type=foo] in localParams syntax
|
||||||
|
// TODO: look up and add the augmenter. If the form was myalias:[myaugmenter], then "key" will be myalias
|
||||||
|
SolrParams augmenterParams = new MapSolrParams(augmenterArgs);
|
||||||
|
log.info("Parsed augmenter " + augmenterParams + " with alias " + key); // TODO: remove log statement after augmenter works
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// let's try it as a function instead
|
||||||
QParser parser = QParser.getParser(funcStr, FunctionQParserPlugin.NAME, req);
|
QParser parser = QParser.getParser(funcStr, FunctionQParserPlugin.NAME, req);
|
||||||
Query q = null;
|
Query q = null;
|
||||||
ValueSource vs = null;
|
ValueSource vs = null;
|
||||||
|
|
Loading…
Reference in New Issue