diff options
author | jboeuf <jboeuf@users.noreply.github.com> | 2015-05-05 08:46:02 -0700 |
---|---|---|
committer | jboeuf <jboeuf@users.noreply.github.com> | 2015-05-05 08:46:02 -0700 |
commit | a0e14540210d856c09da184ecd5da7b414056cc9 (patch) | |
tree | 26129af00450d0d969fc0eb473752045f3311038 /src/core/surface | |
parent | d53d87cbd3a93fa90ac1363fd5dc3b27dbb31cae (diff) | |
parent | 935cf42396d78cad859f25ed1e8cf7f440b06edc (diff) |
Merge pull request #1447 from ctiller/magical-void-pointers
Add per-call context pointer API
Diffstat (limited to 'src/core/surface')
-rw-r--r-- | src/core/surface/call.c | 23 | ||||
-rw-r--r-- | src/core/surface/call.h | 8 |
2 files changed, 31 insertions, 0 deletions
diff --git a/src/core/surface/call.c b/src/core/surface/call.c index fc8f5083fd..0782a58fda 100644 --- a/src/core/surface/call.c +++ b/src/core/surface/call.c @@ -205,6 +205,9 @@ struct grpc_call { /* Received call statuses from various sources */ received_status status[STATUS_SOURCE_COUNT]; + void *context[GRPC_CONTEXT_COUNT]; + void (*destroy_context[GRPC_CONTEXT_COUNT])(void *); + /* Deadline alarm - if have_alarm is non-zero */ grpc_alarm alarm; @@ -295,6 +298,7 @@ grpc_call *grpc_call_create(grpc_channel *channel, grpc_completion_queue *cq, initial_op.recv_state = &call->recv_state; initial_op.on_done_recv = call_on_done_recv; initial_op.recv_user_data = call; + initial_op.context = call->context; call->receiving = 1; GRPC_CALL_INTERNAL_REF(call, "receiving"); initial_op_ptr = &initial_op; @@ -347,6 +351,11 @@ static void destroy_call(void *call, int ignored_success) { for (i = 0; i < c->send_initial_metadata_count; i++) { grpc_mdelem_unref(c->send_initial_metadata[i].md); } + for (i = 0; i < GRPC_CONTEXT_COUNT; i++) { + if (c->destroy_context[i]) { + c->destroy_context[i](c->context[i]); + } + } grpc_sopb_destroy(&c->send_ops); grpc_sopb_destroy(&c->recv_ops); grpc_bbq_destroy(&c->incoming_queue); @@ -1032,6 +1041,7 @@ static grpc_call_error cancel_with_status( static void execute_op(grpc_call *call, grpc_transport_op *op) { grpc_call_element *elem; elem = CALL_ELEM_FROM_CALL(call, 0); + op->context = call->context; elem->filter->start_transport_op(elem, op); } @@ -1269,3 +1279,16 @@ grpc_call_error grpc_call_start_batch(grpc_call *call, const grpc_op *ops, return grpc_call_start_ioreq_and_call_back(call, reqs, out, finish_batch, tag); } + +void grpc_call_context_set(grpc_call *call, grpc_context_index elem, void *value, + void (*destroy)(void *value)) { + if (call->destroy_context[elem]) { + call->destroy_context[elem](value); + } + call->context[elem] = value; + call->destroy_context[elem] = destroy; +} + +void *grpc_call_context_get(grpc_call *call, grpc_context_index elem) { + return call->context[elem]; +} diff --git a/src/core/surface/call.h b/src/core/surface/call.h index 2d4c7f61e3..18a77babac 100644 --- a/src/core/surface/call.h +++ b/src/core/surface/call.h @@ -35,6 +35,7 @@ #define GRPC_INTERNAL_CORE_SURFACE_CALL_H #include "src/core/channel/channel_stack.h" +#include "src/core/channel/context.h" #include <grpc/grpc.h> /* Primitive operation types - grpc_op's get rewritten into these */ @@ -120,6 +121,13 @@ void grpc_call_log_batch(char *file, int line, gpr_log_severity severity, grpc_call *call, const grpc_op *ops, size_t nops, void *tag); +/* Set a context pointer. + No thread safety guarantees are made wrt this value. */ +void grpc_call_context_set(grpc_call *call, grpc_context_index elem, void *value, + void (*destroy)(void *value)); +/* Get a context pointer. */ +void *grpc_call_context_get(grpc_call *call, grpc_context_index elem); + #define GRPC_CALL_LOG_BATCH(sev, call, ops, nops, tag) \ if (grpc_trace_batch) grpc_call_log_batch(sev, call, ops, nops, tag) |