Package org.eclipse.net4j.signal
Class SignalProtocol<INFRA_STRUCTURE>
java.lang.Object
org.eclipse.net4j.util.event.Notifier
org.eclipse.net4j.util.lifecycle.Lifecycle
org.eclipse.spi.net4j.Protocol<INFRA_STRUCTURE>
org.eclipse.net4j.signal.SignalProtocol<INFRA_STRUCTURE>
- All Implemented Interfaces:
- IBufferHandler,- ILocationAware,- IProtocol<INFRA_STRUCTURE>,- IProtocol2<INFRA_STRUCTURE>,- IProtocol3<INFRA_STRUCTURE>,- ISignalProtocol<INFRA_STRUCTURE>,- ISignalProtocol.WithSignalCounters<INFRA_STRUCTURE>,- org.eclipse.net4j.util.collection.Entity.Store.Provider,- org.eclipse.net4j.util.concurrent.IExecutorServiceProvider,- org.eclipse.net4j.util.container.IManagedContainerProvider,- org.eclipse.net4j.util.event.INotifier,- org.eclipse.net4j.util.event.INotifier.INotifier2,- org.eclipse.net4j.util.lifecycle.IDeactivateable,- org.eclipse.net4j.util.lifecycle.ILifecycle,- org.eclipse.net4j.util.lifecycle.ILifecycle.DeferrableActivation,- org.eclipse.net4j.util.security.IUserAware
- Direct Known Subclasses:
- AuthenticatingSignalProtocol,- HeartBeatProtocol,- HeartBeatProtocol.Server
public class SignalProtocol<INFRA_STRUCTURE>
extends Protocol<INFRA_STRUCTURE>
implements ISignalProtocol.WithSignalCounters<INFRA_STRUCTURE>, org.eclipse.net4j.util.collection.Entity.Store.Provider
The default implementation of a 
signal protocol.
 
 On the receiver side(s) of protocol the
 createSignalReactor() method has to be overridden to
 create appropriate peer instances for incoming signals.
- Author:
- Eike Stepper
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic final classstatic final classNested classes/interfaces inherited from class org.eclipse.spi.net4j.ProtocolProtocol.InfraStructureChangedEventNested classes/interfaces inherited from interface org.eclipse.net4j.util.lifecycle.ILifecycleorg.eclipse.net4j.util.lifecycle.ILifecycle.DeferrableActivationNested classes/interfaces inherited from interface org.eclipse.net4j.ILocationAwareILocationAware.LocationNested classes/interfaces inherited from interface org.eclipse.net4j.util.event.INotifierorg.eclipse.net4j.util.event.INotifier.INotifier2Nested classes/interfaces inherited from interface org.eclipse.net4j.signal.ISignalProtocolISignalProtocol.WithSignalCounters<INFRA_STRUCTURE>
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final longstatic final shortstatic final shortstatic final shortstatic final shortstatic final shortstatic final shortFields inherited from class org.eclipse.net4j.util.lifecycle.LifecycleUSE_LABELFields inherited from interface org.eclipse.net4j.protocol.IProtocol2UNSPECIFIED_VERSIONFields inherited from interface org.eclipse.net4j.signal.ISignalProtocolDEFAULT_TIMEOUT, NO_TIMEOUT
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddStreamWrapper(org.eclipse.net4j.util.io.IStreamWrapper streamWrapper) voidclose()protected SignalReactorcreateSignalReactor(short signalID) Returns a new signal instance to serve the given signal ID ornullif the signal ID is invalid/unknown for this protocol.protected voidprotected voidorg.eclipse.net4j.util.collection.Entity.Storelonglongorg.eclipse.net4j.util.io.IStreamWrapperprotected org.eclipse.net4j.util.io.StringCompressorlongvoidhandleBuffer(IBuffer buffer) Handles a given (incoming) buffer.protected voidprotected booleanReturnstrueby default, override to change this behavior.open(IConnector connector) protected final SignalReactorprovideSignalReactor(short signalID) voidsetStreamWrapper(org.eclipse.net4j.util.io.IStreamWrapper streamWrapper) voidsetTimeout(long timeout) Equivalent to calling SignalProtocol.setTimeout(timeout, false).booleansetTimeout(long timeout, boolean useOldTimeoutToSendNewOne) Update the timeout used for signal end of stream waiting time.toString()booleanwaitForSignals(long timeout) Methods inherited from class org.eclipse.spi.net4j.ProtocoldoBeforeActivate, getBufferProvider, getChannel, getContainer, getExecutorService, getInfraStructure, getLocation, getType, getUserID, getVersion, isClient, isServer, setChannel, setExecutorService, setInfraStructure, setUserIDMethods inherited from class org.eclipse.net4j.util.lifecycle.Lifecycleactivate, checkActive, checkArg, checkArg, checkInactive, checkNull, checkState, checkState, deactivate, deferredActivate, doActivate, doAfterActivate, dump, getLifecycleState, isActive, isDeferredActivationMethods inherited from class org.eclipse.net4j.util.event.NotifieraddListener, addUniqueListener, fireEvent, fireEvent, fireEvent, fireThrowable, firstListenerAdded, getListeners, getNotificationService, hasListener, hasListeners, lastListenerRemoved, listenerAdded, listenerRemoved, removeListenerMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.net4j.ILocationAwaregetLocation, isClient, isServerMethods inherited from interface org.eclipse.net4j.util.event.INotifieraddListener, getListeners, hasListeners, removeListenerMethods inherited from interface org.eclipse.net4j.protocol.IProtocolgetBufferProvider, getChannel, getExecutorService, getInfraStructure, getType, setChannel, setExecutorService, setInfraStructureMethods inherited from interface org.eclipse.net4j.protocol.IProtocol3doWhenFullyConnectedMethods inherited from interface org.eclipse.net4j.util.security.IUserAwaregetUserID
- 
Field Details- 
COMPRESSED_STRINGS_ACKNOWLEDGE_TIMEOUTpublic static final long COMPRESSED_STRINGS_ACKNOWLEDGE_TIMEOUT- Since:
- 4.7
 
- 
SIGNAL_REMOTE_EXCEPTIONpublic static final short SIGNAL_REMOTE_EXCEPTION- Since:
- 2.0
- See Also:
 
- 
SIGNAL_MONITOR_CANCELEDpublic static final short SIGNAL_MONITOR_CANCELED- Since:
- 2.0
- See Also:
 
- 
SIGNAL_MONITOR_PROGRESSpublic static final short SIGNAL_MONITOR_PROGRESS- Since:
- 2.0
- See Also:
 
- 
SIGNAL_SET_TIMEOUTpublic static final short SIGNAL_SET_TIMEOUT- Since:
- 4.1
- See Also:
 
- 
SIGNAL_ACKNOWLEDGE_COMPRESSED_STRINGSpublic static final short SIGNAL_ACKNOWLEDGE_COMPRESSED_STRINGS- Since:
- 4.7
- See Also:
 
- 
SIGNAL_ENTITYpublic static final short SIGNAL_ENTITY- Since:
- 4.20
- See Also:
 
 
- 
- 
Constructor Details- 
SignalProtocol- Since:
- 2.0
 
 
- 
- 
Method Details- 
getTimeoutpublic long getTimeout()- Specified by:
- getTimeoutin interface- ISignalProtocol<INFRA_STRUCTURE>
- Since:
- 2.0
 
- 
setTimeoutpublic void setTimeout(long timeout) Equivalent to calling SignalProtocol.setTimeout(timeout, false).- Specified by:
- setTimeoutin interface- ISignalProtocol<INFRA_STRUCTURE>
- Since:
- 2.0
 
- 
setTimeoutpublic boolean setTimeout(long timeout, boolean useOldTimeoutToSendNewOne) Update the timeout used for signal end of stream waiting time.- Parameters:
- timeout- the new timeout
- useOldTimeoutToSendNewOne-- trueto use the old timeout,- falseto use the new specified one to sent to server side the new specified timeout
- Returns:
- trueif the new specified timeout has correctly been sent NOTE: this second parameter is useful mostly for test to be able to set a to small timeout
- Since:
- 4.4
 
- 
getStreamWrapperpublic org.eclipse.net4j.util.io.IStreamWrapper getStreamWrapper()- Specified by:
- getStreamWrapperin interface- ISignalProtocol<INFRA_STRUCTURE>
 
- 
setStreamWrapperpublic void setStreamWrapper(org.eclipse.net4j.util.io.IStreamWrapper streamWrapper) - Specified by:
- setStreamWrapperin interface- ISignalProtocol<INFRA_STRUCTURE>
 
- 
addStreamWrapperpublic void addStreamWrapper(org.eclipse.net4j.util.io.IStreamWrapper streamWrapper) - Specified by:
- addStreamWrapperin interface- ISignalProtocol<INFRA_STRUCTURE>
 
- 
getEntityStorepublic org.eclipse.net4j.util.collection.Entity.Store getEntityStore()- Specified by:
- getEntityStorein interface- org.eclipse.net4j.util.collection.Entity.Store.Provider
 
- 
getSentSignalspublic long getSentSignals()- Specified by:
- getSentSignalsin interface- ISignalProtocol.WithSignalCounters<INFRA_STRUCTURE>
- Since:
- 4.13
 
- 
getReceivedSignalspublic long getReceivedSignals()- Specified by:
- getReceivedSignalsin interface- ISignalProtocol.WithSignalCounters<INFRA_STRUCTURE>
 
- 
open- Specified by:
- openin interface- ISignalProtocol<INFRA_STRUCTURE>
- Since:
- 2.0
 
- 
closepublic void close()- Specified by:
- closein interface- ISignalProtocol<INFRA_STRUCTURE>
- Since:
- 2.0
 
- 
waitForSignalspublic boolean waitForSignals(long timeout) 
- 
handleBufferHandles a given (incoming) buffer. Creates a signal to act upon the given buffer or uses a previously created signal.- Specified by:
- handleBufferin interface- IBufferHandler
- Parameters:
- buffer- The buffer to be handled.
 
- 
toString- Overrides:
- toStringin class- org.eclipse.net4j.util.lifecycle.Lifecycle
 
- 
doBeforeDeactivate- Overrides:
- doBeforeDeactivatein class- org.eclipse.net4j.util.lifecycle.Lifecycle
- Throws:
- Exception
 
- 
doDeactivate- Overrides:
- doDeactivatein class- Protocol<INFRA_STRUCTURE>
- Throws:
- Exception
 
- 
handleChannelDeactivationprotected void handleChannelDeactivation()- Overrides:
- handleChannelDeactivationin class- Protocol<INFRA_STRUCTURE>
 
- 
provideSignalReactor
- 
createSignalReactorReturns a new signal instance to serve the given signal ID ornullif the signal ID is invalid/unknown for this protocol.
- 
isSendingTimeoutChangesprotected boolean isSendingTimeoutChanges()Returnstrueby default, override to change this behavior.- Since:
- 4.1
 
- 
getStringCompressorprotected org.eclipse.net4j.util.io.StringCompressor getStringCompressor()- Since:
- 4.7
 
 
-