Class BaseTable.ShiftAwareListenerImpl
- All Implemented Interfaces:
com.fishlib.base.log.LogOutputAppendable,NotificationQueue.Dependency,LivenessManager,LivenessNode,LivenessReferent,ListenerBase,ShiftAwareListener,Serializable
- Direct Known Subclasses:
AppendOnlyAssertionInstrumentedListenerAdapter,ListenerRecorder,SnapshotInternalListener,SortedAssertionInstrumentedListenerAdapter,SortListener
- Enclosing class:
- BaseTable
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class com.illumon.iris.db.v2.InstrumentedShiftAwareListener
InstrumentedShiftAwareListener.NotificationNested classes/interfaces inherited from class com.illumon.iris.db.v2.InstrumentedListenerBase
InstrumentedListenerBase.ErrorNotification, InstrumentedListenerBase.NotificationBaseNested classes/interfaces inherited from interface com.illumon.iris.db.v2.ShiftAwareListener
ShiftAwareListener.Update -
Constructor Summary
ConstructorsConstructorDescriptionShiftAwareListenerImpl(String description, DynamicTable parent, DynamicTable dependent) -
Method Summary
Modifier and TypeMethodDescriptionbooleancanExecute(long step) Check if this listener is ready to execute.protected voiddestroy()Attempt to release (destructively when necessary) resources held by this object.protected DynamicTablevoidonFailureInternal(Throwable originalException, UpdatePerformanceTracker.Entry sourceEntry) voidonUpdate(ShiftAwareListener.Update upstream) Process notification of table changes.Methods inherited from class com.illumon.iris.db.v2.InstrumentedShiftAwareListener
getNotificationMethods inherited from class com.illumon.iris.db.v2.InstrumentedListenerBase
append, getEntry, getErrorNotification, onFailure, onFailureInternalWithDependent, satisfied, setVerboseLogging, toStringMethods inherited from class com.illumon.iris.db.util.liveness.LivenessArtifact
manageWithCurrentScope, unmanage, unmanageMethods inherited from class com.illumon.iris.db.util.liveness.ReferenceCountedLivenessNode
dropReference, getWeakReference, initializeTransientFieldsForLiveness, onReferenceCountAtZero, tryManage, tryRetainReferenceMethods inherited from class com.illumon.util.referencecounting.ReferenceCounted
decrementReferenceCount, incrementReferenceCount, resetReferenceCount, tryDecrementReferenceCount, tryIncrementReferenceCountMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface com.illumon.iris.db.v2.ListenerBase
getErrorNotification, onFailureMethods inherited from interface com.illumon.iris.db.util.liveness.LivenessManager
manage, tryManageMethods inherited from interface com.illumon.iris.db.util.liveness.LivenessReferent
dropReference, getReferentDescription, getWeakReference, retainReference, tryRetainReference
-
Constructor Details
-
ShiftAwareListenerImpl
-
-
Method Details
-
onUpdate
Description copied from interface:ShiftAwareListenerProcess notification of table changes.The Listener onUpdate call executes within the
LiveTableMonitorrefresh loop. Any tables used within the listener's onUpdate call must have already been refreshed. Using the typical pattern of a Listener that is listening to a single table, withDynamicTable.listenForUpdates(Listener), this is trivially true.When the listener must reference more than just one parent, the tables (or other objects) it references, must be made a
NotificationQueue.Dependencyof the listener. For listeners that reference multiple ticking tables, a common pattern is to use aMergedListenerand collection ofListenerRecorders.- Parameters:
upstream- The set of upstream table updates.
-
onFailureInternal
public void onFailureInternal(Throwable originalException, UpdatePerformanceTracker.Entry sourceEntry) - Specified by:
onFailureInternalin classInstrumentedListenerBase
-
canExecute
public boolean canExecute(long step) Description copied from class:InstrumentedListenerBaseCheck if this listener is ready to execute.- Overrides:
canExecutein classInstrumentedListenerBase- Returns:
- if this listener is ready to execute
-
destroy
protected void destroy()Description copied from class:ReferenceCountedLivenessNodeAttempt to release (destructively when necessary) resources held by this object. This may render the object unusable for subsequent operations. Implementations should be sure to call super.destroy().
This is intended to only ever be used as a side effect of decreasing the reference count to 0.
- Overrides:
destroyin classReferenceCountedLivenessNode
-
getParent
-