com.espertech.esper.epl.join.exec.composite.CompositeIndexQueryRange Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of esper Show documentation
Show all versions of esper Show documentation
Complex event processing and event series analysis component
The newest version!
/*
***************************************************************************************
* Copyright (C) 2006 EsperTech, Inc. All rights reserved. *
* http://www.espertech.com/esper *
* http://www.espertech.com *
* ---------------------------------------------------------------------------------- *
* The software in this package is published under the terms of the GPL license *
* a copy of which has been included with this distribution in the license.txt file. *
***************************************************************************************
*/
package com.espertech.esper.epl.join.exec.composite;
import com.espertech.esper.client.EventBean;
import com.espertech.esper.epl.expression.core.ExprNodeUtilityCore;
import com.espertech.esper.epl.expression.core.ExprEvaluator;
import com.espertech.esper.epl.expression.core.ExprEvaluatorContext;
import com.espertech.esper.epl.join.plan.QueryGraphRangeEnum;
import com.espertech.esper.epl.join.plan.QueryGraphValueEntryRange;
import com.espertech.esper.epl.join.plan.QueryGraphValueEntryRangeIn;
import com.espertech.esper.epl.join.plan.QueryGraphValueEntryRangeRelOp;
import com.espertech.esper.epl.lookup.SubordPropRangeKey;
import java.util.*;
public class CompositeIndexQueryRange implements CompositeIndexQuery {
private final CompositeAccessStrategy strategy;
private CompositeIndexQuery next;
public CompositeIndexQueryRange(boolean isNWOnTrigger, int lookupStream, int numStreams, SubordPropRangeKey subqRangeKey, Class coercionType, List expressionTexts) {
QueryGraphValueEntryRange rangeProp = subqRangeKey.getRangeInfo();
if (rangeProp.getType().isRange()) {
QueryGraphValueEntryRangeIn rangeIn = (QueryGraphValueEntryRangeIn) rangeProp;
ExprEvaluator start = rangeIn.getExprStart().getForge().getExprEvaluator();
expressionTexts.add(ExprNodeUtilityCore.toExpressionStringMinPrecedenceSafe(rangeIn.getExprStart()));
boolean includeStart = rangeProp.getType().isIncludeStart();
ExprEvaluator end = rangeIn.getExprEnd().getForge().getExprEvaluator();
expressionTexts.add(ExprNodeUtilityCore.toExpressionStringMinPrecedenceSafe(rangeIn.getExprEnd()));
boolean includeEnd = rangeProp.getType().isIncludeEnd();
if (!rangeProp.getType().isRangeInverted()) {
strategy = new CompositeAccessStrategyRangeNormal(isNWOnTrigger, lookupStream, numStreams, start, includeStart, end, includeEnd, coercionType, ((QueryGraphValueEntryRangeIn) rangeProp).isAllowRangeReversal());
} else {
strategy = new CompositeAccessStrategyRangeInverted(isNWOnTrigger, lookupStream, numStreams, start, includeStart, end, includeEnd, coercionType);
}
} else {
QueryGraphValueEntryRangeRelOp relOp = (QueryGraphValueEntryRangeRelOp) rangeProp;
ExprEvaluator key = relOp.getExpression().getForge().getExprEvaluator();
expressionTexts.add(ExprNodeUtilityCore.toExpressionStringMinPrecedenceSafe(relOp.getExpression()));
if (rangeProp.getType() == QueryGraphRangeEnum.GREATER_OR_EQUAL) {
strategy = new CompositeAccessStrategyGE(isNWOnTrigger, lookupStream, numStreams, key, coercionType);
} else if (rangeProp.getType() == QueryGraphRangeEnum.GREATER) {
strategy = new CompositeAccessStrategyGT(isNWOnTrigger, lookupStream, numStreams, key, coercionType);
} else if (rangeProp.getType() == QueryGraphRangeEnum.LESS_OR_EQUAL) {
strategy = new CompositeAccessStrategyLE(isNWOnTrigger, lookupStream, numStreams, key, coercionType);
} else if (rangeProp.getType() == QueryGraphRangeEnum.LESS) {
strategy = new CompositeAccessStrategyLT(isNWOnTrigger, lookupStream, numStreams, key, coercionType);
} else {
throw new IllegalArgumentException("Comparison operator " + rangeProp.getType() + " not supported");
}
}
}
public void add(EventBean theEvent, Map parent, Set result, CompositeIndexQueryResultPostProcessor postProcessor) {
strategy.lookup(theEvent, parent, result, next, null, null, postProcessor);
}
public void add(EventBean[] eventsPerStream, Map parent, Collection result, CompositeIndexQueryResultPostProcessor postProcessor) {
strategy.lookup(eventsPerStream, parent, result, next, null, null, postProcessor);
}
public Set get(EventBean theEvent, Map parent, ExprEvaluatorContext context, CompositeIndexQueryResultPostProcessor postProcessor) {
return strategy.lookup(theEvent, parent, null, next, context, null, postProcessor);
}
public Collection get(EventBean[] eventsPerStream, Map parent, ExprEvaluatorContext context, CompositeIndexQueryResultPostProcessor postProcessor) {
return strategy.lookup(eventsPerStream, parent, null, next, context, null, postProcessor);
}
public Set getCollectKeys(EventBean theEvent, Map parent, ExprEvaluatorContext context, ArrayList