public class GroupByViewReclaimAged extends ViewSupport implements CloneableView, GroupByView
Modifier and Type | Field and Description |
---|---|
protected AgentInstanceViewFactoryChainContext |
agentInstanceContext |
protected String[] |
propertyNames |
protected Map<Object,GroupByViewAgedEntry> |
subViewsPerKey |
EMPTY_VIEW_ARRAY, parent
Constructor and Description |
---|
GroupByViewReclaimAged(AgentInstanceViewFactoryChainContext agentInstanceContext,
ExprNode[] criteriaExpressions,
ExprEvaluator[] criteriaEvaluators,
double reclaimMaxAgeSeconds,
double reclaimFrequencySeconds)
Constructor.
|
Modifier and Type | Method and Description |
---|---|
View |
cloneView()
Duplicates the view.
|
ExprNode[] |
getCriteriaExpressions()
Returns the field name that provides the key valie by which to group by.
|
EventType |
getEventType()
Provides metadata information about the type of object the event collection contains.
|
Iterator<EventBean> |
iterator()
Allows iteration through all elements in this event collection.
|
boolean |
removeView(View view)
Remove a view.
|
String |
toString() |
void |
update(EventBean[] newData,
EventBean[] oldData)
Notify that data has been added or removed from the Viewable parent.
|
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
forEach, spliterator
protected final AgentInstanceViewFactoryChainContext agentInstanceContext
protected String[] propertyNames
protected final Map<Object,GroupByViewAgedEntry> subViewsPerKey
public GroupByViewReclaimAged(AgentInstanceViewFactoryChainContext agentInstanceContext, ExprNode[] criteriaExpressions, ExprEvaluator[] criteriaEvaluators, double reclaimMaxAgeSeconds, double reclaimFrequencySeconds)
agentInstanceContext
- contains required view servicescriteriaExpressions
- is the fields from which to pull the values to group byreclaimMaxAgeSeconds
- age after which to reclaim groupreclaimFrequencySeconds
- frequency in which to check for groups to reclaimcriteriaEvaluators
- evaluatorspublic View cloneView()
CloneableView
Expected to return a same view in initialized state for grouping.
cloneView
in interface CloneableView
public ExprNode[] getCriteriaExpressions()
getCriteriaExpressions
in interface GroupByView
public final EventType getEventType()
EventCollection
getEventType
in interface EventCollection
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 Iterator<EventBean> iterator()
EventCollection
iterator
in interface EventCollection
iterator
in interface Iterable<EventBean>
public void visitViewContainer(ViewDataVisitorContained viewDataVisitor)
visitViewContainer
in interface ViewDataVisitableContainer
public boolean removeView(View view)
Viewable
removeView
in interface Viewable
removeView
in class ViewSupport
view
- to remove