aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorGravatar ctiller <ctiller@google.com>2014-12-11 09:15:41 -0800
committerGravatar Jan Tattermusch <jtattermusch@google.com>2014-12-11 15:11:44 -0800
commit430c4996e80b60c7a0dac760e224fb9ea0128690 (patch)
treea0ce34bec8ece128a6d03eb64758c8aa9b69a742 /src
parentccd27fd9b2cc3c2f83dc9a7632f6a2d5f0438c45 (diff)
Cache encoded binary data on the metadata string object.
Change on 2014/12/11 by ctiller <ctiller@google.com> ------------- Created by MOE: http://code.google.com/p/moe-java MOE_MIGRATED_REVID=81882793
Diffstat (limited to 'src')
-rw-r--r--src/core/transport/metadata.c22
-rw-r--r--src/core/transport/metadata.h4
2 files changed, 26 insertions, 0 deletions
diff --git a/src/core/transport/metadata.c b/src/core/transport/metadata.c
index ceb77df34d..9edfd5bfd1 100644
--- a/src/core/transport/metadata.c
+++ b/src/core/transport/metadata.c
@@ -39,6 +39,7 @@
#include <grpc/support/alloc.h>
#include <grpc/support/log.h>
#include "src/core/support/murmur_hash.h"
+#include "src/core/transport/chttp2/bin_encoder.h"
#include <grpc/support/time.h>
#define INITIAL_STRTAB_CAPACITY 4
@@ -53,8 +54,11 @@ typedef struct internal_string {
/* private only data */
gpr_uint32 refs;
+ gpr_uint8 has_base64_and_huffman_encoded;
gpr_slice_refcount refcount;
+ gpr_slice base64_and_huffman;
+
grpc_mdctx *context;
struct internal_string *bucket_next;
@@ -225,6 +229,9 @@ static void internal_destroy_string(internal_string *is) {
internal_string **prev_next;
internal_string *cur;
grpc_mdctx *ctx = is->context;
+ if (is->has_base64_and_huffman_encoded) {
+ gpr_slice_unref(is->base64_and_huffman);
+ }
for (prev_next = &ctx->strtab[is->hash % ctx->strtab_capacity],
cur = *prev_next;
cur != is; prev_next = &cur->bucket_next, cur = cur->bucket_next)
@@ -312,6 +319,7 @@ grpc_mdstr *grpc_mdstr_from_buffer(grpc_mdctx *ctx, const gpr_uint8 *buf,
/* add a null terminator for cheap c string conversion when desired */
s->slice.data.refcounted.bytes[length] = 0;
}
+ s->has_base64_and_huffman_encoded = 0;
s->hash = hash;
s->context = ctx;
s->bucket_next = ctx->strtab[hash % ctx->strtab_capacity];
@@ -523,3 +531,17 @@ void grpc_mdelem_set_user_data(grpc_mdelem *md, void (*destroy_func)(void *),
im->destroy_user_data = destroy_func;
im->user_data = user_data;
}
+
+gpr_slice grpc_mdstr_as_base64_encoded_and_huffman_compressed(grpc_mdstr *gs) {
+ internal_string *s = (internal_string *)gs;
+ gpr_slice slice;
+ grpc_mdctx *ctx = s->context;
+ lock(ctx);
+ if (!s->has_base64_and_huffman_encoded) {
+ s->base64_and_huffman =
+ grpc_chttp2_base64_encode_and_huffman_compress(s->slice);
+ }
+ slice = s->base64_and_huffman;
+ unlock(ctx);
+ return slice;
+}
diff --git a/src/core/transport/metadata.h b/src/core/transport/metadata.h
index 4b87f70e31..9fca3d4bd5 100644
--- a/src/core/transport/metadata.h
+++ b/src/core/transport/metadata.h
@@ -98,6 +98,10 @@ grpc_mdstr *grpc_mdstr_from_slice(grpc_mdctx *ctx, gpr_slice slice);
grpc_mdstr *grpc_mdstr_from_buffer(grpc_mdctx *ctx, const gpr_uint8 *str,
size_t length);
+/* Returns a borrowed slice from the mdstr with its contents base64 encoded
+ and huffman compressed */
+gpr_slice grpc_mdstr_as_base64_encoded_and_huffman_compressed(grpc_mdstr *str);
+
/* Constructors for grpc_mdelem instances; take a variety of data types that
clients may have handy */
grpc_mdelem *grpc_mdelem_from_metadata_strings(grpc_mdctx *ctx, grpc_mdstr *key,