Package hudson.remoting
Class AbstractSynchronousByteArrayCommandTransport
java.lang.Object
hudson.remoting.CommandTransport
hudson.remoting.SynchronousCommandTransport
hudson.remoting.AbstractSynchronousByteArrayCommandTransport
public abstract class AbstractSynchronousByteArrayCommandTransport
extends SynchronousCommandTransport
SynchronousCommandTransport that works with byte[] instead of command object.
 This base class hides away some of the Command serialization details. One less thing
 for transport implementers to worry about.- Since:
- 2.13
- Author:
- Kohsuke Kawaguchi
- 
Nested Class SummaryNested classes/interfaces inherited from class hudson.remoting.CommandTransportCommandTransport.CommandReceiver
- 
Field SummaryFields inherited from class hudson.remoting.SynchronousCommandTransportchannel
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionread()Called byChannelto read the next command to arrive from the stream.abstract byte[]Read a byte[] from the underlying transport for the given channel.voidCalled byChannelto send one command to the other side.abstract voidwriteBlock(Channel channel, byte[] payload) Writes a byte[] to the transport.Methods inherited from class hudson.remoting.SynchronousCommandTransportsetupMethods inherited from class hudson.remoting.CommandTransportcloseRead, closeWrite, getRemoteCapability
- 
Constructor Details- 
AbstractSynchronousByteArrayCommandTransportpublic AbstractSynchronousByteArrayCommandTransport()
 
- 
- 
Method Details- 
readBlockRead a byte[] from the underlying transport for the given channel.- Throws:
- IOException
- ClassNotFoundException
 
- 
writeBlockWrites a byte[] to the transport. The block boundary is significant. A transport needs to ensure that that the same byte[] is read by the peer throughreadBlock(Channel)(unlike TCP, where a single write can be split into multiple read()s on the other side.)- Throws:
- IOException
 
- 
readDescription copied from class:SynchronousCommandTransportCalled byChannelto read the next command to arrive from the stream.- Specified by:
- readin class- SynchronousCommandTransport
- Throws:
- IOException
- ClassNotFoundException
 
- 
writeDescription copied from class:CommandTransportCalled byChannelto send one command to the other side.Channelserializes the invocation of this method for ordering. That is, at any given point in time only one thread executes this method.Asynchronous transport must serialize the given command object before returning from this method, as its content can be modified by the calling thread as soon as this method returns. Also, if an asynchronous transport chooses to return from this method without committing data to the network, then it is also responsible for a flow control (by blocking this method if too many commands are queueing up waiting for the network to unclog.) - Specified by:
- writein class- CommandTransport
- Parameters:
- cmd- The command object that needs to be sent. Never null. This must be serialized via- Command.writeTo(Channel, ObjectOutputStream)
- last- Informational flag that indicates that this is the last call of the- CommandTransport.write(Command, boolean).
- Throws:
- IOException
 
 
-