Package io.grpc
Class ForwardingServerCallListener<ReqT>
java.lang.Object
io.grpc.ServerCall.Listener<ReqT>
io.grpc.ForwardingServerCallListener<ReqT>
- Direct Known Subclasses:
ForwardingServerCallListener.SimpleForwardingServerCallListener
A
ServerCall.Listener
which forwards all of its methods to another ServerCall.Listener
of matching parameterized types.-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic class
A simplified version ofForwardingServerCallListener
where subclasses can pass in aServerCall.Listener
as the delegate. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected abstract ServerCall.Listener
<ReqT> delegate()
Returns the delegatedServerCall.Listener
.void
onCancel()
The call was cancelled and the server is encouraged to abort processing to save resources, since the client will not process any further messages.void
The call is considered complete andServerCall.Listener.onCancel()
is guaranteed not to be called.void
The client completed all message sending.void
A request message has been received.void
onReady()
This indicates that the call may now be capable of sending additional messages (viaServerCall.sendMessage(RespT)
) without requiring excessive buffering internally.toString()
-
Constructor Details
-
ForwardingServerCallListener
public ForwardingServerCallListener()
-
-
Method Details
-
delegate
Returns the delegatedServerCall.Listener
. -
onMessage
Description copied from class:ServerCall.Listener
A request message has been received. For streaming calls, there may be zero or more request messages.- Overrides:
onMessage
in classServerCall.Listener<ReqT>
- Parameters:
message
- a received request message.
-
onHalfClose
public void onHalfClose()Description copied from class:ServerCall.Listener
The client completed all message sending. However, the call may still be cancelled.- Overrides:
onHalfClose
in classServerCall.Listener<ReqT>
-
onCancel
public void onCancel()Description copied from class:ServerCall.Listener
The call was cancelled and the server is encouraged to abort processing to save resources, since the client will not process any further messages. Cancellations can be caused by timeouts, explicit cancellation by the client, network errors, etc.There will be no further callbacks for the call.
- Overrides:
onCancel
in classServerCall.Listener<ReqT>
-
onComplete
public void onComplete()Description copied from class:ServerCall.Listener
The call is considered complete andServerCall.Listener.onCancel()
is guaranteed not to be called. However, the client is not guaranteed to have received all messages.There will be no further callbacks for the call.
- Overrides:
onComplete
in classServerCall.Listener<ReqT>
-
onReady
public void onReady()Description copied from class:ServerCall.Listener
This indicates that the call may now be capable of sending additional messages (viaServerCall.sendMessage(RespT)
) without requiring excessive buffering internally. This event is just a suggestion and the application is free to ignore it, however doing so may result in excessive buffering within the call.Because there is a processing delay to deliver this notification, it is possible for concurrent writes to cause
isReady() == false
within this callback. Handle "spurious" notifications by checkingisReady()
's current value instead of assuming it is nowtrue
. IfisReady() == false
the normal expectations apply, so there would be anotheronReady()
callback.- Overrides:
onReady
in classServerCall.Listener<ReqT>
-
toString
-