/************************************************************************************** * Copyright (C) 2008 EsperTech, Inc. All rights reserved. * * http://esper.codehaus.org * * 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.core; import com.espertech.esper.client.EventBean; import com.espertech.esper.collection.UniformPair; import com.espertech.esper.core.context.util.AgentInstanceContext; import com.espertech.esper.epl.agg.service.AggregationRowRemovedCallback; import com.espertech.esper.epl.agg.service.AggregationService; import com.espertech.esper.view.Viewable; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import java.util.HashMap; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; public class ResultSetProcessorRowPerGroupSpecial extends ResultSetProcessorRowPerGroup implements AggregationRowRemovedCallback { private static final Log log = LogFactory.getLog(ResultSetProcessorRowPerGroupSpecial.class); protected final Map<Object, EventBean> groupReps = new LinkedHashMap<Object, EventBean>(); public ResultSetProcessorRowPerGroupSpecial(ResultSetProcessorRowPerGroupFactory prototype, SelectExprProcessor selectExprProcessor, OrderByProcessor orderByProcessor, AggregationService aggregationService, AgentInstanceContext agentInstanceContext) { super(prototype, selectExprProcessor, orderByProcessor, aggregationService, agentInstanceContext); aggregationService.setRemovedCallback(this); } @Override public UniformPair<EventBean[]> processViewResult(EventBean[] newData, EventBean[] oldData, boolean isSynthesize) { // Generate group-by keys for all events, collect all keys in a set for later event generation Map<Object, EventBean> keysAndEvents = new HashMap<Object, EventBean>(); Object[] newDataMultiKey = generateGroupKeys(newData, keysAndEvents, true); Object[] oldDataMultiKey = generateGroupKeys(oldData, keysAndEvents, false); EventBean[] selectOldEvents = null; if (prototype.isSelectRStream()) { selectOldEvents = generateOutputEventsView(keysAndEvents, false, isSynthesize); } // update aggregates EventBean[] eventsPerStream = new EventBean[1]; if (newData != null) { // apply new data to aggregates for (int i = 0; i < newData.length; i++) { eventsPerStream[0] = newData[i]; groupReps.put(newDataMultiKey[i], eventsPerStream[0]); aggregationService.applyEnter(eventsPerStream, newDataMultiKey[i], agentInstanceContext); } } if (oldData != null) { // apply old data to aggregates for (int i = 0; i < oldData.length; i++) { eventsPerStream[0] = oldData[i]; aggregationService.applyLeave(eventsPerStream, oldDataMultiKey[i], agentInstanceContext); } } // generate new events using select expressions EventBean[] selectNewEvents = generateOutputEventsView(keysAndEvents, true, isSynthesize); if ((selectNewEvents != null) || (selectOldEvents != null)) { return new UniformPair<EventBean[]>(selectNewEvents, selectOldEvents); } return null; } @Override public Iterator<EventBean> getIterator(Viewable parent) { if (orderByProcessor == null) { Iterator<EventBean> it = groupReps.values().iterator(); return new ResultSetRowPerGroupIterator(it, this, aggregationService, agentInstanceContext); } return getIteratorSorted(groupReps.values().iterator()); } public void removed(Object optionalGroupKeyPerRow) { groupReps.remove(optionalGroupKeyPerRow); } }