Add metadata batch documentation

pull/2170/head
Craig Tiller 10 years ago
parent 096b77dcdf
commit cb89db7312
  1. 58
      src/core/transport/stream_op.c
  2. 47
      src/core/transport/stream_op.h

@ -184,34 +184,34 @@ static void assert_valid_list(grpc_mdelem_list *list) {
} }
#ifndef NDEBUG #ifndef NDEBUG
void grpc_metadata_batch_assert_ok(grpc_metadata_batch *comd) { void grpc_metadata_batch_assert_ok(grpc_metadata_batch *batch) {
assert_valid_list(&comd->list); assert_valid_list(&batch->list);
assert_valid_list(&comd->garbage); assert_valid_list(&batch->garbage);
} }
#endif /* NDEBUG */ #endif /* NDEBUG */
void grpc_metadata_batch_init(grpc_metadata_batch *comd) { void grpc_metadata_batch_init(grpc_metadata_batch *batch) {
comd->list.head = comd->list.tail = comd->garbage.head = comd->garbage.tail = batch->list.head = batch->list.tail = batch->garbage.head = batch->garbage.tail =
NULL; NULL;
comd->deadline = gpr_inf_future; batch->deadline = gpr_inf_future;
} }
void grpc_metadata_batch_destroy(grpc_metadata_batch *comd) { void grpc_metadata_batch_destroy(grpc_metadata_batch *batch) {
grpc_linked_mdelem *l; grpc_linked_mdelem *l;
for (l = comd->list.head; l; l = l->next) { for (l = batch->list.head; l; l = l->next) {
grpc_mdelem_unref(l->md); grpc_mdelem_unref(l->md);
} }
for (l = comd->garbage.head; l; l = l->next) { for (l = batch->garbage.head; l; l = l->next) {
grpc_mdelem_unref(l->md); grpc_mdelem_unref(l->md);
} }
} }
void grpc_metadata_batch_add_head(grpc_metadata_batch *comd, void grpc_metadata_batch_add_head(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage, grpc_linked_mdelem *storage,
grpc_mdelem *elem_to_add) { grpc_mdelem *elem_to_add) {
GPR_ASSERT(elem_to_add); GPR_ASSERT(elem_to_add);
storage->md = elem_to_add; storage->md = elem_to_add;
grpc_metadata_batch_link_head(comd, storage); grpc_metadata_batch_link_head(batch, storage);
} }
static void link_head(grpc_mdelem_list *list, grpc_linked_mdelem *storage) { static void link_head(grpc_mdelem_list *list, grpc_linked_mdelem *storage) {
@ -228,17 +228,17 @@ static void link_head(grpc_mdelem_list *list, grpc_linked_mdelem *storage) {
assert_valid_list(list); assert_valid_list(list);
} }
void grpc_metadata_batch_link_head(grpc_metadata_batch *comd, void grpc_metadata_batch_link_head(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage) { grpc_linked_mdelem *storage) {
link_head(&comd->list, storage); link_head(&batch->list, storage);
} }
void grpc_metadata_batch_add_tail(grpc_metadata_batch *comd, void grpc_metadata_batch_add_tail(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage, grpc_linked_mdelem *storage,
grpc_mdelem *elem_to_add) { grpc_mdelem *elem_to_add) {
GPR_ASSERT(elem_to_add); GPR_ASSERT(elem_to_add);
storage->md = elem_to_add; storage->md = elem_to_add;
grpc_metadata_batch_link_tail(comd, storage); grpc_metadata_batch_link_tail(batch, storage);
} }
static void link_tail(grpc_mdelem_list *list, grpc_linked_mdelem *storage) { static void link_tail(grpc_mdelem_list *list, grpc_linked_mdelem *storage) {
@ -255,9 +255,9 @@ static void link_tail(grpc_mdelem_list *list, grpc_linked_mdelem *storage) {
assert_valid_list(list); assert_valid_list(list);
} }
void grpc_metadata_batch_link_tail(grpc_metadata_batch *comd, void grpc_metadata_batch_link_tail(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage) { grpc_linked_mdelem *storage) {
link_tail(&comd->list, storage); link_tail(&batch->list, storage);
} }
void grpc_metadata_batch_merge(grpc_metadata_batch *target, void grpc_metadata_batch_merge(grpc_metadata_batch *target,
@ -274,16 +274,16 @@ void grpc_metadata_batch_merge(grpc_metadata_batch *target,
} }
} }
void grpc_metadata_batch_filter(grpc_metadata_batch *comd, void grpc_metadata_batch_filter(grpc_metadata_batch *batch,
grpc_mdelem *(*filter)(void *user_data, grpc_mdelem *(*filter)(void *user_data,
grpc_mdelem *elem), grpc_mdelem *elem),
void *user_data) { void *user_data) {
grpc_linked_mdelem *l; grpc_linked_mdelem *l;
grpc_linked_mdelem *next; grpc_linked_mdelem *next;
assert_valid_list(&comd->list); assert_valid_list(&batch->list);
assert_valid_list(&comd->garbage); assert_valid_list(&batch->garbage);
for (l = comd->list.head; l; l = next) { for (l = batch->list.head; l; l = next) {
grpc_mdelem *orig = l->md; grpc_mdelem *orig = l->md;
grpc_mdelem *filt = filter(user_data, orig); grpc_mdelem *filt = filter(user_data, orig);
next = l->next; next = l->next;
@ -294,19 +294,19 @@ void grpc_metadata_batch_filter(grpc_metadata_batch *comd,
if (l->next) { if (l->next) {
l->next->prev = l->prev; l->next->prev = l->prev;
} }
if (comd->list.head == l) { if (batch->list.head == l) {
comd->list.head = l->next; batch->list.head = l->next;
} }
if (comd->list.tail == l) { if (batch->list.tail == l) {
comd->list.tail = l->prev; batch->list.tail = l->prev;
} }
assert_valid_list(&comd->list); assert_valid_list(&batch->list);
link_head(&comd->garbage, l); link_head(&batch->garbage, l);
} else if (filt != orig) { } else if (filt != orig) {
grpc_mdelem_unref(orig); grpc_mdelem_unref(orig);
l->md = filt; l->md = filt;
} }
} }
assert_valid_list(&comd->list); assert_valid_list(&batch->list);
assert_valid_list(&comd->garbage); assert_valid_list(&batch->garbage);
} }

@ -85,29 +85,62 @@ typedef struct grpc_mdelem_list {
} grpc_mdelem_list; } grpc_mdelem_list;
typedef struct grpc_metadata_batch { typedef struct grpc_metadata_batch {
/** Metadata elements in this batch */
grpc_mdelem_list list; grpc_mdelem_list list;
/** Elements that have been removed from the batch, but have
not yet been unreffed - used to allow collecting garbage
under a single metadata context lock */
grpc_mdelem_list garbage; grpc_mdelem_list garbage;
/** Used to calculate grpc-timeout at the point of sending,
or gpr_inf_future if this batch does not need to send a
grpc-timeout */
gpr_timespec deadline; gpr_timespec deadline;
} grpc_metadata_batch; } grpc_metadata_batch;
void grpc_metadata_batch_init(grpc_metadata_batch *comd); void grpc_metadata_batch_init(grpc_metadata_batch *batch);
void grpc_metadata_batch_destroy(grpc_metadata_batch *comd); void grpc_metadata_batch_destroy(grpc_metadata_batch *batch);
void grpc_metadata_batch_merge(grpc_metadata_batch *target, void grpc_metadata_batch_merge(grpc_metadata_batch *target,
grpc_metadata_batch *add); grpc_metadata_batch *add);
void grpc_metadata_batch_link_head(grpc_metadata_batch *comd, /** Add \a storage to the beginning of \a batch. storage->md is
assumed to be valid.
\a storage is owned by the caller and must survive for the
lifetime of batch. This usually means it should be around
for the lifetime of the call. */
void grpc_metadata_batch_link_head(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage); grpc_linked_mdelem *storage);
void grpc_metadata_batch_link_tail(grpc_metadata_batch *comd, /** Add \a storage to the end of \a batch. storage->md is
assumed to be valid.
\a storage is owned by the caller and must survive for the
lifetime of batch. This usually means it should be around
for the lifetime of the call. */
void grpc_metadata_batch_link_tail(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage); grpc_linked_mdelem *storage);
void grpc_metadata_batch_add_head(grpc_metadata_batch *comd, /** Add \a elem_to_add as the first element in \a batch, using
\a storage as backing storage for the linked list element.
\a storage is owned by the caller and must survive for the
lifetime of batch. This usually means it should be around
for the lifetime of the call.
Takes ownership of \a elem_to_add */
void grpc_metadata_batch_add_head(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage, grpc_linked_mdelem *storage,
grpc_mdelem *elem_to_add); grpc_mdelem *elem_to_add);
void grpc_metadata_batch_add_tail(grpc_metadata_batch *comd, /** Add \a elem_to_add as the last element in \a batch, using
\a storage as backing storage for the linked list element.
\a storage is owned by the caller and must survive for the
lifetime of batch. This usually means it should be around
for the lifetime of the call.
Takes ownership of \a elem_to_add */
void grpc_metadata_batch_add_tail(grpc_metadata_batch *batch,
grpc_linked_mdelem *storage, grpc_linked_mdelem *storage,
grpc_mdelem *elem_to_add); grpc_mdelem *elem_to_add);
void grpc_metadata_batch_filter(grpc_metadata_batch *comd, /** For each element in \a batch, execute \a filter.
The return value from \a filter will be substituted for the
grpc_mdelem passed to \a filter. If \a filter returns NULL,
the element will be moved to the garbage list. */
void grpc_metadata_batch_filter(grpc_metadata_batch *batch,
grpc_mdelem *(*filter)(void *user_data, grpc_mdelem *(*filter)(void *user_data,
grpc_mdelem *elem), grpc_mdelem *elem),
void *user_data); void *user_data);

Loading…
Cancel
Save