diff options
Diffstat (limited to 'include/grpc++')
-rw-r--r-- | include/grpc++/impl/call.h | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/include/grpc++/impl/call.h b/include/grpc++/impl/call.h index eef0e90cc9..94b0f915c6 100644 --- a/include/grpc++/impl/call.h +++ b/include/grpc++/impl/call.h @@ -85,7 +85,7 @@ class CallOpSendInitialMetadata { op->data.send_initial_metadata.metadata = initial_metadata_; } void FinishOp(bool* status, int max_message_size) { - // nothing to do + send_ = false; } bool send_; @@ -109,6 +109,7 @@ class CallOpSendMessage { } void FinishOp(bool* status, int max_message_size) { if (own_buf_) grpc_byte_buffer_destroy(send_buf_); + send_buf_ = nullptr; } private: @@ -154,6 +155,7 @@ class CallOpRecvMessage { got_message = false; *status = false; } + message_ = nullptr; } private: @@ -198,10 +200,12 @@ class CallOpGenericRecvMessage { got_message = false; *status = false; } + deserialize_ = DeserializeFunc(); } private: - std::function<Status(grpc_byte_buffer*, int)> deserialize_; + typedef std::function<Status(grpc_byte_buffer*, int)> DeserializeFunc; + DeserializeFunc deserialize_; grpc_byte_buffer* recv_buf_; }; @@ -217,7 +221,7 @@ class CallOpClientSendClose { ops[(*nops)++].op = GRPC_OP_SEND_CLOSE_FROM_CLIENT; } void FinishOp(bool* status, int max_message_size) { - // nothing to do + send_ = false; } private: @@ -251,7 +255,7 @@ class CallOpServerSendStatus { } void FinishOp(bool* status, int max_message_size) { - // nothing to do + send_status_details_ = false; } private: @@ -281,7 +285,9 @@ class CallOpRecvInitialMetadata { op->data.recv_initial_metadata = &recv_initial_metadata_arr_; } void FinishOp(bool* status, int max_message_size) { + if (recv_initial_metadata_ == nullptr) return; FillMetadataMap(&recv_initial_metadata_arr_, recv_initial_metadata_); + recv_initial_metadata_ = nullptr; } private: @@ -312,10 +318,12 @@ class CallOpClientRecvStatus { } void FinishOp(bool* status, int max_message_size) { + if (recv_status_ == nullptr) return; FillMetadataMap(&recv_trailing_metadata_arr_, recv_trailing_metadata_); *recv_status_ = Status( static_cast<StatusCode>(status_code_), status_details_ ? grpc::string(status_details_) : grpc::string()); + recv_status_ = nullptr; } private: |