Documentation ¶
Overview ¶
Package drpcstream sends protobufs using the dprc wire protocol.
![Stream state machine diagram](./state.png)
Index ¶
- type Options
- type Stream
- func (s *Stream) Cancel(err error) bool
- func (s *Stream) Close() (err error)
- func (s *Stream) CloseSend() (err error)
- func (s *Stream) Context() context.Context
- func (s *Stream) Finished() <-chan struct{}
- func (s *Stream) HandlePacket(pkt drpcwire.Packet) (err error)
- func (s *Stream) ID() uint64
- func (s *Stream) IsFinished() bool
- func (s *Stream) IsTerminated() bool
- func (s *Stream) MsgRecv(msg drpc.Message, enc drpc.Encoding) (err error)
- func (s *Stream) MsgSend(msg drpc.Message, enc drpc.Encoding) (err error)
- func (s *Stream) RawFlush() (err error)
- func (s *Stream) RawRecv() (data []byte, err error)
- func (s *Stream) RawWrite(kind drpcwire.Kind, data []byte) (err error)
- func (s *Stream) SendCancel(err error) (bool, error)
- func (s *Stream) SendError(serr error) (err error)
- func (s *Stream) SetManualFlush(mf bool)
- func (s *Stream) String() string
- func (s *Stream) Terminated() <-chan struct{}
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Options ¶ added in v0.0.7
type Options struct { // SplitSize controls the default size we split packets into frames. SplitSize int // ManualFlush controls if the stream will automatically flush after every // message send. Note that flushing is not part of the drpc.Stream // interface, so if you use this you must be ready to type assert and // call RawFlush dynamically. ManualFlush bool // MaximumBufferSize causes the Stream to drop any internal buffers that // are larger than this amount to control maximum memory usage at the // expense of more allocations. 0 is unlimited. MaximumBufferSize int // Internal contains options that are for internal use only. Internal drpcopts.Stream }
Options controls configuration settings for a stream.
type Stream ¶
type Stream struct {
// contains filtered or unexported fields
}
Stream represents an rpc actively happening on a transport.
func New ¶
New returns a new stream bound to the context with the given stream id and will use the writer to write messages on. It is important use monotonically increasing stream ids within a single transport.
func NewWithOptions ¶ added in v0.0.7
NewWithOptions returns a new stream bound to the context with the given stream id and will use the writer to write messages on. It is important use monotonically increasing stream ids within a single transport. The options are used to control details of how the Stream operates.
func (*Stream) Cancel ¶ added in v0.0.7
Cancel transitions the stream into a state where all writes to the transport will return the provided error, and terminates the stream. It is a no-op if the stream is already finished, and returns a boolean indicating if that was the case.
func (*Stream) Close ¶
Close terminates the stream and sends that the stream has been closed to the remote. It is a no-op if the stream is already terminated.
func (*Stream) CloseSend ¶
CloseSend informs the remote that no more messages will be sent. If the remote has also already issued a CloseSend, the stream is terminated. It is a no-op if the stream already has sent a CloseSend or if it is terminated.
func (*Stream) Context ¶
Context returns the context associated with the stream. It is closed when the Stream will no longer issue any writes or reads.
func (*Stream) Finished ¶ added in v0.0.7
func (s *Stream) Finished() <-chan struct{}
Finished returns a channel that is closed when the stream is fully finished and will no longer issue any writes or reads.
func (*Stream) HandlePacket ¶ added in v0.0.5
HandlePacket advances the stream state machine by inspecting the packet. It returns any major errors that should terminate the transport the stream is operating on as well as a boolean indicating if the stream expects more packets.
func (*Stream) IsFinished ¶ added in v0.0.16
IsFinished returns true if the stream is fully finished and will no longer issue any writes or reads.
func (*Stream) IsTerminated ¶ added in v0.0.24
IsTerminated returns true if the stream has been terminated.
func (*Stream) SendCancel ¶
SendCancel transitions the stream into the canceled state with context.Canceled and sends a cancel error to the remote side for a soft cancel. It is a no-op if the stream is already terminated. It returns true for busy if writes are already blocked and a hard cancel is required.
func (*Stream) SendError ¶
SendError terminates the stream and sends the error to the remote. It is a no-op if the stream is already terminated.
func (*Stream) SetManualFlush ¶ added in v0.0.33
SetManualFlush sets the ManualFlush option. It cannot be called concurrently with any sends or receives on the stream. Example use case:
flusher := stream.(interface{ GetStream() drpc.Stream }).GetStream().(interface{ SetManualFlush(bool) }) flusher.SetManualFlush(true) err = stream.Send(&pb.Message{Request: "hello, "}) flusher.SetManualFlush(false) if err != nil { return err } // the next send will send both messages in the same write // to the underlying connection. err = stream.Send(&pb.Message{Request: "world!"}) if err != nil { return err }
func (*Stream) Terminated ¶ added in v0.0.5
func (s *Stream) Terminated() <-chan struct{}
Terminated returns a channel that is closed when the stream has been terminated.