ViewServiceCreateResult createResult = services.getViewService().createViews(rootView, unmaterializedViewChain.getViewFactoryChain(), viewFactoryChainContext, false);
topView = createResult.getTopViewable();
finalView = createResult.getFinalViewable();
// If this is a virtual data window implementation, bind it to the context for easy lookup
StopCallback envStopCallback = null;
if (finalView instanceof VirtualDWView) {
final String objectName = "/virtualdw/" + windowName;
final VirtualDWView virtualDWView = (VirtualDWView) finalView;
try {
services.getEngineEnvContext().bind(objectName, virtualDWView.getVirtualDataWindow());
}
catch (NamingException e) {
throw new ViewProcessingException("Invalid name for adding to context:" + e.getMessage(), e);
}
envStopCallback = new StopCallback() {
public void stop() {
try {
virtualDWView.destroy();
services.getEngineEnvContext().unbind(objectName);
} catch (NamingException e) {}
}
};
}
final StopCallback environmentStopCallback = envStopCallback;
// create stop method using statement stream specs
StopCallback allInOneStopMethod = new StopCallback()
{
public void stop()
{
String windowName = statementSpec.getCreateWindowDesc().getWindowName();
NamedWindowProcessor processor = services.getNamedWindowService().getProcessor(windowName);
if (processor == null) {
log.warn("Named window processor by name '" + windowName + "' has not been found");
}
else {
NamedWindowProcessorInstance instance = processor.getProcessorInstance(agentInstanceContext);
if (instance != null && instance.getRootViewInstance().isVirtualDataWindow()) {
instance.getRootViewInstance().getVirtualDataWindow().handleStopWindow();
}
if (instance != null) {
processor.removeProcessorInstance(instance);
}
}
if (environmentStopCallback != null) {
environmentStopCallback.stop();
}
}
};
stopCallbacks.add(allInOneStopMethod);
// Attach tail view
NamedWindowTailViewInstance tailView = processorInstance.getTailViewInstance();
finalView.addView(tailView);
finalView = tailView;
// obtain result set processor
ResultSetProcessor resultSetProcessor = EPStatementStartMethodHelperAssignExpr.getAssignResultSetProcessor(agentInstanceContext, resultSetProcessorPrototype);
// Attach output view
View outputView = outputProcessViewFactory.makeView(resultSetProcessor, agentInstanceContext);
finalView.addView(outputView);
finalView = outputView;
// obtain post load
postLoad = processorInstance.getPostLoad();
// Handle insert case
if (statementSpec.getCreateWindowDesc().isInsert() && !isRecoveringStatement)
{
String insertFromWindow = statementSpec.getCreateWindowDesc().getInsertFromWindow();
NamedWindowProcessor namedWindowProcessor = services.getNamedWindowService().getProcessor(insertFromWindow);
NamedWindowProcessorInstance sourceWindowInstances = namedWindowProcessor.getProcessorInstance(agentInstanceContext);
List<EventBean> events = new ArrayList<EventBean>();
if (statementSpec.getCreateWindowDesc().getInsertFilter() != null)
{
EventBean[] eventsPerStream = new EventBean[1];
ExprEvaluator filter = statementSpec.getCreateWindowDesc().getInsertFilter().getExprEvaluator();
for (Iterator<EventBean> it = sourceWindowInstances.getTailViewInstance().iterator(); it.hasNext();)
{
EventBean candidate = it.next();
eventsPerStream[0] = candidate;
Boolean result = (Boolean) filter.evaluate(eventsPerStream, true, agentInstanceContext);
if ((result == null) || (!result))
{
continue;
}
events.add(candidate);
}
}
else
{
for (Iterator<EventBean> it = sourceWindowInstances.getTailViewInstance().iterator(); it.hasNext();)
{
events.add(it.next());
}
}
if (events.size() > 0)
{
EventType rootViewType = rootView.getEventType();
EventBean[] convertedEvents = services.getEventAdapterService().typeCast(events, rootViewType);
rootView.update(convertedEvents, null);
}
}
}
catch (RuntimeException ex) {
StopCallback stopCallback = StatementAgentInstanceUtil.getStopCallback(stopCallbacks, agentInstanceContext);
StatementAgentInstanceUtil.stopSafe(stopCallback, statementContext);
throw ex;
}
log.debug(".start Statement start completed");
StopCallback stopCallback = StatementAgentInstanceUtil.getStopCallback(stopCallbacks, agentInstanceContext);
return new StatementAgentInstanceFactoryCreateWindowResult(finalView, stopCallback, agentInstanceContext, eventStreamParentViewable, postLoad, topView);
}