aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/ext
diff options
context:
space:
mode:
authorGravatar Muxi Yan <mxyan@google.com>2016-09-30 16:51:58 -0700
committerGravatar Muxi Yan <mxyan@google.com>2016-09-30 16:52:07 -0700
commit20f49619ad4fc1f7ca25e72f4ff5527971186e68 (patch)
treeb8561efdaf34a50e79ef340659483b5a3b34641d /src/core/ext
parent461fed13cbc581e5593830b228a45e656163b012 (diff)
Simplify the changes using macro
Diffstat (limited to 'src/core/ext')
-rw-r--r--src/core/ext/transport/cronet/transport/cronet_transport.c32
1 files changed, 12 insertions, 20 deletions
diff --git a/src/core/ext/transport/cronet/transport/cronet_transport.c b/src/core/ext/transport/cronet/transport/cronet_transport.c
index 1a731f5885..90f18e413d 100644
--- a/src/core/ext/transport/cronet/transport/cronet_transport.c
+++ b/src/core/ext/transport/cronet/transport/cronet_transport.c
@@ -57,6 +57,14 @@
if (grpc_cronet_trace) gpr_log(__VA_ARGS__); \
} while (0)
+#define free_read_buffer(state_rs) \
+ if ((state_rs).read_buffer && \
+ (state_rs).read_buffer != (state_rs).grpc_header_bytes) { \
+ gpr_free((state_rs).read_buffer); \
+ (state_rs).read_buffer = NULL; \
+ }
+
+
/* TODO (makdharma): Hook up into the wider tracing mechanism */
int grpc_cronet_trace = 0;
@@ -341,11 +349,7 @@ static void on_failed(cronet_bidirectional_stream *stream, int net_error) {
gpr_free(s->state.ws.write_buffer);
s->state.ws.write_buffer = NULL;
}
- if (s->state.rs.read_buffer &&
- s->state.rs.read_buffer != s->state.rs.grpc_header_bytes) {
- gpr_free(s->state.rs.read_buffer);
- s->state.rs.read_buffer = NULL;
- }
+ free_read_buffer(s->state.rs);
gpr_mu_unlock(&s->mu);
execute_from_storage(s);
}
@@ -368,11 +372,7 @@ static void on_canceled(cronet_bidirectional_stream *stream) {
gpr_free(s->state.ws.write_buffer);
s->state.ws.write_buffer = NULL;
}
- if (s->state.rs.read_buffer &&
- s->state.rs.read_buffer != s->state.rs.grpc_header_bytes) {
- gpr_free(s->state.rs.read_buffer);
- s->state.rs.read_buffer = NULL;
- }
+ free_read_buffer(s->state.rs);
gpr_mu_unlock(&s->mu);
execute_from_storage(s);
}
@@ -387,11 +387,7 @@ static void on_succeeded(cronet_bidirectional_stream *stream) {
cronet_bidirectional_stream_destroy(s->cbs);
s->state.state_callback_received[OP_SUCCEEDED] = true;
s->cbs = NULL;
- if (s->state.rs.read_buffer &&
- s->state.rs.read_buffer != s->state.rs.grpc_header_bytes) {
- gpr_free(s->state.rs.read_buffer);
- s->state.rs.read_buffer = NULL;
- }
+ free_read_buffer(s->state.rs);
gpr_mu_unlock(&s->mu);
execute_from_storage(s);
}
@@ -916,11 +912,7 @@ static enum e_op_result execute_stream_op(grpc_exec_ctx *exec_ctx,
uint8_t *dst_p = GPR_SLICE_START_PTR(read_data_slice);
memcpy(dst_p, stream_state->rs.read_buffer,
(size_t)stream_state->rs.length_field);
- if (stream_state.rs.read_buffer &&
- stream_state.rs.read_buffer != stream_state.rs.grpc_header_bytes) {
- gpr_free(stream_state.rs.read_buffer);
- stream_state.rs.read_buffer = NULL;
- }
+ free_read_buffer(stream_state->rs);
gpr_slice_buffer_init(&stream_state->rs.read_slice_buffer);
gpr_slice_buffer_add(&stream_state->rs.read_slice_buffer,
read_data_slice);