Index: third_party/grpc/src/core/transport/metadata.h |
diff --git a/third_party/grpc/src/core/transport/metadata.h b/third_party/grpc/src/core/transport/metadata.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8742846be7e6250d7987b196bb7e4e2b500e6055 |
--- /dev/null |
+++ b/third_party/grpc/src/core/transport/metadata.h |
@@ -0,0 +1,156 @@ |
+/* |
+ * |
+ * Copyright 2015-2016, Google Inc. |
+ * All rights reserved. |
+ * |
+ * Redistribution and use in source and binary forms, with or without |
+ * modification, are permitted provided that the following conditions are |
+ * met: |
+ * |
+ * * Redistributions of source code must retain the above copyright |
+ * notice, this list of conditions and the following disclaimer. |
+ * * Redistributions in binary form must reproduce the above |
+ * copyright notice, this list of conditions and the following disclaimer |
+ * in the documentation and/or other materials provided with the |
+ * distribution. |
+ * * Neither the name of Google Inc. nor the names of its |
+ * contributors may be used to endorse or promote products derived from |
+ * this software without specific prior written permission. |
+ * |
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
+ * |
+ */ |
+ |
+#ifndef GRPC_INTERNAL_CORE_TRANSPORT_METADATA_H |
+#define GRPC_INTERNAL_CORE_TRANSPORT_METADATA_H |
+ |
+#include <grpc/support/slice.h> |
+#include <grpc/support/useful.h> |
+ |
+/* This file provides a mechanism for tracking metadata through the grpc stack. |
+ It's not intended for consumption outside of the library. |
+ |
+ Metadata is tracked in the context of a grpc_mdctx. For the time being there |
+ is one of these per-channel, avoiding cross channel interference with memory |
+ use and lock contention. |
+ |
+ The context tracks unique strings (grpc_mdstr) and pairs of strings |
+ (grpc_mdelem). Any of these objects can be checked for equality by comparing |
+ their pointers. These objects are reference counted. |
+ |
+ grpc_mdelem can additionally store a (non-NULL) user data pointer. This |
+ pointer is intended to be used to cache semantic meaning of a metadata |
+ element. For example, an OAuth token may cache the credentials it represents |
+ and the time at which it expires in the mdelem user data. |
+ |
+ Combining this metadata cache and the hpack compression table allows us to |
+ simply lookup complete preparsed objects quickly, incurring a few atomic |
+ ops per metadata element on the fast path. |
+ |
+ grpc_mdelem instances MAY live longer than their refcount implies, and are |
+ garbage collected periodically, meaning cached data can easily outlive a |
+ single request. |
+ |
+ STATIC METADATA: in static_metadata.h we declare a set of static metadata. |
+ These mdelems and mdstrs are available via pre-declared code generated macros |
+ and are available to code anywhere between grpc_init() and grpc_shutdown(). |
+ They are not refcounted, but can be passed to _ref and _unref functions |
+ declared here - in which case those functions are effectively no-ops. */ |
+ |
+/* Forward declarations */ |
+typedef struct grpc_mdstr grpc_mdstr; |
+typedef struct grpc_mdelem grpc_mdelem; |
+ |
+/* if changing this, make identical changes in internal_string in metadata.c */ |
+struct grpc_mdstr { |
+ const gpr_slice slice; |
+ const uint32_t hash; |
+ /* there is a private part to this in metadata.c */ |
+}; |
+ |
+/* if changing this, make identical changes in internal_metadata in |
+ metadata.c */ |
+struct grpc_mdelem { |
+ grpc_mdstr *const key; |
+ grpc_mdstr *const value; |
+ /* there is a private part to this in metadata.c */ |
+}; |
+ |
+void grpc_test_only_set_metadata_hash_seed(uint32_t seed); |
+ |
+/* Constructors for grpc_mdstr instances; take a variety of data types that |
+ clients may have handy */ |
+grpc_mdstr *grpc_mdstr_from_string(const char *str); |
+/* Unrefs the slice. */ |
+grpc_mdstr *grpc_mdstr_from_slice(gpr_slice slice); |
+grpc_mdstr *grpc_mdstr_from_buffer(const uint8_t *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_mdstr *key, |
+ grpc_mdstr *value); |
+grpc_mdelem *grpc_mdelem_from_strings(const char *key, const char *value); |
+/* Unrefs the slices. */ |
+grpc_mdelem *grpc_mdelem_from_slices(gpr_slice key, gpr_slice value); |
+grpc_mdelem *grpc_mdelem_from_string_and_buffer(const char *key, |
+ const uint8_t *value, |
+ size_t value_length); |
+ |
+/* Mutator and accessor for grpc_mdelem user data. The destructor function |
+ is used as a type tag and is checked during user_data fetch. */ |
+void *grpc_mdelem_get_user_data(grpc_mdelem *md, |
+ void (*if_destroy_func)(void *)); |
+void grpc_mdelem_set_user_data(grpc_mdelem *md, void (*destroy_func)(void *), |
+ void *user_data); |
+ |
+/* Reference counting */ |
+#ifdef GRPC_METADATA_REFCOUNT_DEBUG |
+#define GRPC_MDSTR_REF(s) grpc_mdstr_ref((s), __FILE__, __LINE__) |
+#define GRPC_MDSTR_UNREF(s) grpc_mdstr_unref((s), __FILE__, __LINE__) |
+#define GRPC_MDELEM_REF(s) grpc_mdelem_ref((s), __FILE__, __LINE__) |
+#define GRPC_MDELEM_UNREF(s) grpc_mdelem_unref((s), __FILE__, __LINE__) |
+grpc_mdstr *grpc_mdstr_ref(grpc_mdstr *s, const char *file, int line); |
+void grpc_mdstr_unref(grpc_mdstr *s, const char *file, int line); |
+grpc_mdelem *grpc_mdelem_ref(grpc_mdelem *md, const char *file, int line); |
+void grpc_mdelem_unref(grpc_mdelem *md, const char *file, int line); |
+#else |
+#define GRPC_MDSTR_REF(s) grpc_mdstr_ref((s)) |
+#define GRPC_MDSTR_UNREF(s) grpc_mdstr_unref((s)) |
+#define GRPC_MDELEM_REF(s) grpc_mdelem_ref((s)) |
+#define GRPC_MDELEM_UNREF(s) grpc_mdelem_unref((s)) |
+grpc_mdstr *grpc_mdstr_ref(grpc_mdstr *s); |
+void grpc_mdstr_unref(grpc_mdstr *s); |
+grpc_mdelem *grpc_mdelem_ref(grpc_mdelem *md); |
+void grpc_mdelem_unref(grpc_mdelem *md); |
+#endif |
+ |
+/* Recover a char* from a grpc_mdstr. The returned string is null terminated. |
+ Does not promise that the returned string has no embedded nulls however. */ |
+const char *grpc_mdstr_as_c_string(grpc_mdstr *s); |
+ |
+#define GRPC_MDSTR_LENGTH(s) (GPR_SLICE_LENGTH(s->slice)) |
+ |
+int grpc_mdstr_is_legal_header(grpc_mdstr *s); |
+int grpc_mdstr_is_legal_nonbin_header(grpc_mdstr *s); |
+int grpc_mdstr_is_bin_suffixed(grpc_mdstr *s); |
+ |
+#define GRPC_MDSTR_KV_HASH(k_hash, v_hash) (GPR_ROTL((k_hash), 2) ^ (v_hash)) |
+ |
+void grpc_mdctx_global_init(void); |
+void grpc_mdctx_global_shutdown(void); |
+ |
+#endif /* GRPC_INTERNAL_CORE_TRANSPORT_METADATA_H */ |