Class DefaultPhraseSlopQueryNodeProcessor
- java.lang.Object
-
- org.apache.lucene.queryparser.flexible.core.processors.QueryNodeProcessorImpl
-
- org.apache.lucene.queryparser.flexible.standard.processors.DefaultPhraseSlopQueryNodeProcessor
-
- All Implemented Interfaces:
QueryNodeProcessor
public class DefaultPhraseSlopQueryNodeProcessor extends QueryNodeProcessorImpl
This processor verifies ifStandardQueryConfigHandler.ConfigurationKeys.PHRASE_SLOPis defined in theQueryConfigHandler. If it is, it looks for everyTokenizedPhraseQueryNodeandMultiPhraseQueryNodethat does not have anySlopQueryNodeapplied to it and creates anSlopQueryNodeand apply to it. The newSlopQueryNodehas the same slop value defined in the configuration.
-
-
Constructor Summary
Constructors Constructor Description DefaultPhraseSlopQueryNodeProcessor()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected QueryNodepostProcessNode(QueryNode node)This method is invoked for every node when walking up the tree.protected QueryNodepreProcessNode(QueryNode node)This method is invoked for every node when walking down the tree.QueryNodeprocess(QueryNode queryTree)Processes a query node tree.protected voidprocessChildren(QueryNode queryTree)This method is called every time a child is processed.protected List<QueryNode>setChildrenOrder(List<QueryNode> children)This method is invoked for every node that has at least on child.-
Methods inherited from class org.apache.lucene.queryparser.flexible.core.processors.QueryNodeProcessorImpl
getQueryConfigHandler, setQueryConfigHandler
-
-
-
-
Method Detail
-
process
public QueryNode process(QueryNode queryTree) throws QueryNodeException
Description copied from interface:QueryNodeProcessorProcesses a query node tree. It may return the same or another query tree. I should never returnnull.- Specified by:
processin interfaceQueryNodeProcessor- Overrides:
processin classQueryNodeProcessorImpl- Parameters:
queryTree- tree root node- Returns:
- the processed query tree
- Throws:
QueryNodeException
-
postProcessNode
protected QueryNode postProcessNode(QueryNode node) throws QueryNodeException
Description copied from class:QueryNodeProcessorImplThis method is invoked for every node when walking up the tree.- Specified by:
postProcessNodein classQueryNodeProcessorImpl- Parameters:
node- node the query node to be post-processed- Returns:
- a query node
- Throws:
QueryNodeException- if something goes wrong during the query node processing
-
preProcessNode
protected QueryNode preProcessNode(QueryNode node) throws QueryNodeException
Description copied from class:QueryNodeProcessorImplThis method is invoked for every node when walking down the tree.- Specified by:
preProcessNodein classQueryNodeProcessorImpl- Parameters:
node- the query node to be pre-processed- Returns:
- a query node
- Throws:
QueryNodeException- if something goes wrong during the query node processing
-
processChildren
protected void processChildren(QueryNode queryTree) throws QueryNodeException
Description copied from class:QueryNodeProcessorImplThis method is called every time a child is processed.- Overrides:
processChildrenin classQueryNodeProcessorImpl- Parameters:
queryTree- the query node child to be processed- Throws:
QueryNodeException- if something goes wrong during the query node processing
-
setChildrenOrder
protected List<QueryNode> setChildrenOrder(List<QueryNode> children) throws QueryNodeException
Description copied from class:QueryNodeProcessorImplThis method is invoked for every node that has at least on child. It's invoked right beforeQueryNodeProcessorImpl.postProcessNode(QueryNode)is invoked.- Specified by:
setChildrenOrderin classQueryNodeProcessorImpl- Parameters:
children- the list containing all current node's children- Returns:
- a new list containing all children that should be set to the current node
- Throws:
QueryNodeException- if something goes wrong during the query node processing
-
-