com.espertech.esper.runtime.internal.subscriber.ResultDeliveryStrategyMap Maven / Gradle / Ivy
/*
***************************************************************************************
* 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.runtime.internal.subscriber;
import com.espertech.esper.common.client.EventBean;
import com.espertech.esper.common.internal.collection.UniformPair;
import com.espertech.esper.common.internal.event.core.NaturalEventBean;
import com.espertech.esper.common.internal.settings.ClasspathImportService;
import com.espertech.esper.runtime.client.EPStatement;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.Map;
/**
* A result delivery strategy that uses an "update" method that accepts a pair of map array.
*/
public class ResultDeliveryStrategyMap implements ResultDeliveryStrategy {
private final static Logger log = LoggerFactory.getLogger(ResultDeliveryStrategyMap.class);
protected final EPStatement statement;
protected final Object subscriber;
protected final Method method;
protected final String[] columnNames;
/**
* Ctor.
*
* @param subscriber the object to deliver to
* @param method the delivery method
* @param columnNames the column names for the map
* @param statement statement
* @param classpathImportService runtime imports
*/
public ResultDeliveryStrategyMap(EPStatement statement, Object subscriber, Method method, String[] columnNames, ClasspathImportService classpathImportService) {
this.statement = statement;
this.subscriber = subscriber;
this.method = method;
this.columnNames = columnNames;
}
public void execute(UniformPair result) {
Map[] newData;
Map[] oldData;
if (result == null) {
newData = null;
oldData = null;
} else {
newData = convert(result.getFirst());
oldData = convert(result.getSecond());
}
Object[] parameters = new Object[]{newData, oldData};
try {
method.invoke(subscriber, parameters);
} catch (InvocationTargetException | IllegalAccessException e) {
ResultDeliveryStrategyImpl.handle(statement.getName(), log, e, parameters, subscriber, method);
}
}
protected Map[] convert(EventBean[] events) {
if ((events == null) || (events.length == 0)) {
return null;
}
Map[] result = new Map[events.length];
int length = 0;
for (int i = 0; i < result.length; i++) {
if (events[i] instanceof NaturalEventBean) {
NaturalEventBean natural = (NaturalEventBean) events[i];
result[length] = convert(natural);
length++;
}
}
if (length == 0) {
return null;
}
if (length != events.length) {
Map[] reduced = new Map[length];
System.arraycopy(result, 0, reduced, 0, length);
result = reduced;
}
return result;
}
private Map convert(NaturalEventBean natural) {
Map map = new HashMap();
Object[] columns = natural.getNatural();
for (int i = 0; i < columns.length; i++) {
map.put(columnNames[i], columns[i]);
}
return map;
}
}