public class GroupByViewImpl extends ViewSupport implements GroupByView
The view takes a single parameter which is the field name returning the key value to group.
This view can, for example, be used to calculate the average price per symbol for a list of symbols.
The view treats its child views and their child views as prototypes. It dynamically instantiates copies of each child view and their child views, and the child view's child views as so on. When there are no more child views or the special merge view is encountered, it ends. The view installs a special merge view unto each leaf child view that merges the value key that was grouped by back into the stream using the group-by field name.
Modifier and Type | Field and Description |
---|---|
protected AgentInstanceViewFactoryChainContext |
agentInstanceContext |
protected java.util.Map<java.lang.Object,View> |
subViewPerKey |
static java.lang.String |
VIEWNAME |
EMPTY_VIEW_ARRAY, parent
Constructor and Description |
---|
GroupByViewImpl(GroupByViewFactory groupByViewFactory,
AgentInstanceViewFactoryChainContext agentInstanceContext)
Constructor.
|
Modifier and Type | Method and Description |
---|---|
protected static java.lang.Object |
addUpgradeToDequeIfPopulated(java.lang.Object holder,
EventBean theEvent) |
protected static EventBean[] |
convertToArray(java.lang.Object eventOrDeque) |
EventType |
getEventType()
Provides metadata information about the type of object the event collection contains.
|
GroupByViewFactory |
getViewFactory() |
java.util.Iterator<EventBean> |
iterator()
Allows iteration through all elements in this event collection.
|
boolean |
removeView(View view)
Remove a view.
|
java.lang.String |
toString() |
void |
update(EventBean[] newData,
EventBean[] oldData)
Notify that data has been added or removed from the Viewable parent.
|
static void |
visitView(ViewDataVisitorContained viewDataVisitor,
java.lang.Object groupkey,
View view) |
void |
visitViewContainer(ViewDataVisitorContained viewDataVisitor) |
addView, addView, dumpChildViews, dumpUpdateParams, dumpUpdateParams, findDescendent, findViewIndex, getParent, getViews, hasViews, removeAllViews, removeView, setParent, updateChildren, updateChildren
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
addView, getViews, hasViews, removeAllViews
public static final java.lang.String VIEWNAME
protected final AgentInstanceViewFactoryChainContext agentInstanceContext
protected final java.util.Map<java.lang.Object,View> subViewPerKey
public GroupByViewImpl(GroupByViewFactory groupByViewFactory, AgentInstanceViewFactoryChainContext agentInstanceContext)
groupByViewFactory
- view factoryagentInstanceContext
- contains required view servicespublic final EventType getEventType()
EventCollection
getEventType
in interface EventCollection
public GroupByViewFactory getViewFactory()
getViewFactory
in interface GroupByView
public final void update(EventBean[] newData, EventBean[] oldData)
View
If the call to update contains new (inserted) data, then the first argument will be a non-empty list and the second will be empty. Similarly, if the call is a notification of deleted data, then the first argument will be empty and the second will be non-empty. Either the newData or oldData will be non-null. This method won't be called with both arguments being null, but either one could be null. The same is true for zero-length arrays. Either newData or oldData will be non-empty. If both are non-empty, then the update is a modification notification.
When update() is called on a view by the parent object, the data in newData will be in the collection of the parent, and its data structures will be arranged to reflect that. The data in oldData will not be in the parent's data structures, and any access to the parent will indicate that that data is no longer there.
public final java.util.Iterator<EventBean> iterator()
EventCollection
iterator
in interface EventCollection
iterator
in interface java.lang.Iterable<EventBean>
public final java.lang.String toString()
toString
in class java.lang.Object
public void visitViewContainer(ViewDataVisitorContained viewDataVisitor)
visitViewContainer
in interface ViewDataVisitableContainer
public static void visitView(ViewDataVisitorContained viewDataVisitor, java.lang.Object groupkey, View view)
public boolean removeView(View view)
Viewable
removeView
in interface Viewable
removeView
in class ViewSupport
view
- to removeprotected static java.lang.Object addUpgradeToDequeIfPopulated(java.lang.Object holder, EventBean theEvent)
protected static EventBean[] convertToArray(java.lang.Object eventOrDeque)