Skip to content
Snippets Groups Projects
Commit 90391dbb authored by Przemysław Sobala's avatar Przemysław Sobala
Browse files

Change CallData status before notifying CompletionQueue

parent 7593cff3
No related branches found
No related tags found
No related merge requests found
...@@ -94,6 +94,9 @@ class ServerImpl final { ...@@ -94,6 +94,9 @@ class ServerImpl final {
void Proceed() { void Proceed() {
if (status_ == CREATE) { if (status_ == CREATE) {
// Make this instance progress to the PROCESS state.
status_ = PROCESS;
// As part of the initial CREATE state, we *request* that the system // As part of the initial CREATE state, we *request* that the system
// start processing SayHello requests. In this request, "this" acts are // start processing SayHello requests. In this request, "this" acts are
// the tag uniquely identifying the request (so that different CallData // the tag uniquely identifying the request (so that different CallData
...@@ -101,8 +104,6 @@ class ServerImpl final { ...@@ -101,8 +104,6 @@ class ServerImpl final {
// the memory address of this CallData instance. // the memory address of this CallData instance.
service_->RequestSayHello(&ctx_, &request_, &responder_, cq_, cq_, service_->RequestSayHello(&ctx_, &request_, &responder_, cq_, cq_,
this); this);
// Make this instance progress to the PROCESS state.
status_ = PROCESS;
} else if (status_ == PROCESS) { } else if (status_ == PROCESS) {
// Spawn a new CallData instance to serve new clients while we process // Spawn a new CallData instance to serve new clients while we process
// the one for this CallData. The instance will deallocate itself as // the one for this CallData. The instance will deallocate itself as
...@@ -116,8 +117,8 @@ class ServerImpl final { ...@@ -116,8 +117,8 @@ class ServerImpl final {
// And we are done! Let the gRPC runtime know we've finished, using the // And we are done! Let the gRPC runtime know we've finished, using the
// memory address of this instance as the uniquely identifying tag for // memory address of this instance as the uniquely identifying tag for
// the event. // the event.
responder_.Finish(reply_, Status::OK, this);
status_ = FINISH; status_ = FINISH;
responder_.Finish(reply_, Status::OK, this);
} else { } else {
GPR_ASSERT(status_ == FINISH); GPR_ASSERT(status_ == FINISH);
// Once in the FINISH state, deallocate ourselves (CallData). // Once in the FINISH state, deallocate ourselves (CallData).
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment