/* * ************************************************************************************* * 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.agg.service; import com.espertech.esper.core.context.util.AgentInstanceContext; import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; import com.espertech.esper.epl.core.MethodResolutionService; /** * Aggregation service for use when only first/last/window aggregation functions are used an none other. */ public class AggSvcGroupByAccessOnlyFactory implements AggregationServiceFactory { private final AggregationAccessorSlotPair[] accessors; private final int[] streams; private final boolean isJoin; /** * Ctor. * @param accessors accessor definitions * @param streams streams in join * @param isJoin true for join, false for single-stream */ public AggSvcGroupByAccessOnlyFactory(AggregationAccessorSlotPair[] accessors, int[] streams, boolean isJoin) { this.accessors = accessors; this.streams = streams; this.isJoin = isJoin; } public AggregationService makeService(AgentInstanceContext agentInstanceContext, MethodResolutionService methodResolutionService) { return new AggSvcGroupByAccessOnlyImpl(methodResolutionService, accessors, streams, isJoin); } }