mirror of https://github.com/grpc/grpc.git
Merge branch 'master' of https://github.com/grpc/grpc into gpr_malloc_is_all
commit
bdf80ac31f
972 changed files with 29607 additions and 8835 deletions
@ -0,0 +1,57 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, 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. |
||||
* |
||||
*/ |
||||
|
||||
#include "src/core/ext/client_config/client_channel_factory.h" |
||||
|
||||
void grpc_client_channel_factory_ref(grpc_client_channel_factory* factory) { |
||||
factory->vtable->ref(factory); |
||||
} |
||||
|
||||
void grpc_client_channel_factory_unref(grpc_exec_ctx* exec_ctx, |
||||
grpc_client_channel_factory* factory) { |
||||
factory->vtable->unref(exec_ctx, factory); |
||||
} |
||||
|
||||
grpc_subchannel* grpc_client_channel_factory_create_subchannel( |
||||
grpc_exec_ctx* exec_ctx, grpc_client_channel_factory* factory, |
||||
grpc_subchannel_args* args) { |
||||
return factory->vtable->create_subchannel(exec_ctx, factory, args); |
||||
} |
||||
|
||||
grpc_channel* grpc_client_channel_factory_create_channel( |
||||
grpc_exec_ctx* exec_ctx, grpc_client_channel_factory* factory, |
||||
const char* target, grpc_client_channel_type type, |
||||
grpc_channel_args* args) { |
||||
return factory->vtable->create_client_channel(exec_ctx, factory, target, type, |
||||
args); |
||||
} |
@ -0,0 +1,85 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, 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_CORE_EXT_CLIENT_CONFIG_CLIENT_CHANNEL_FACTORY_H |
||||
#define GRPC_CORE_EXT_CLIENT_CONFIG_CLIENT_CHANNEL_FACTORY_H |
||||
|
||||
#include <grpc/impl/codegen/grpc_types.h> |
||||
|
||||
#include "src/core/ext/client_config/subchannel.h" |
||||
#include "src/core/lib/channel/channel_stack.h" |
||||
|
||||
typedef struct grpc_client_channel_factory grpc_client_channel_factory; |
||||
typedef struct grpc_client_channel_factory_vtable |
||||
grpc_client_channel_factory_vtable; |
||||
|
||||
typedef enum { |
||||
GRPC_CLIENT_CHANNEL_TYPE_REGULAR, /** for the user-level regular calls */ |
||||
GRPC_CLIENT_CHANNEL_TYPE_LOAD_BALANCING, /** for communication with a load
|
||||
balancing service */ |
||||
} grpc_client_channel_type; |
||||
|
||||
/** Constructor for new configured channels.
|
||||
Creating decorators around this type is encouraged to adapt behavior. */ |
||||
struct grpc_client_channel_factory { |
||||
const grpc_client_channel_factory_vtable *vtable; |
||||
}; |
||||
|
||||
struct grpc_client_channel_factory_vtable { |
||||
void (*ref)(grpc_client_channel_factory *factory); |
||||
void (*unref)(grpc_exec_ctx *exec_ctx, grpc_client_channel_factory *factory); |
||||
grpc_subchannel *(*create_subchannel)(grpc_exec_ctx *exec_ctx, |
||||
grpc_client_channel_factory *factory, |
||||
grpc_subchannel_args *args); |
||||
grpc_channel *(*create_client_channel)(grpc_exec_ctx *exec_ctx, |
||||
grpc_client_channel_factory *factory, |
||||
const char *target, |
||||
grpc_client_channel_type type, |
||||
grpc_channel_args *args); |
||||
}; |
||||
|
||||
void grpc_client_channel_factory_ref(grpc_client_channel_factory *factory); |
||||
void grpc_client_channel_factory_unref(grpc_exec_ctx *exec_ctx, |
||||
grpc_client_channel_factory *factory); |
||||
|
||||
/** Create a new grpc_subchannel */ |
||||
grpc_subchannel *grpc_client_channel_factory_create_subchannel( |
||||
grpc_exec_ctx *exec_ctx, grpc_client_channel_factory *factory, |
||||
grpc_subchannel_args *args); |
||||
|
||||
/** Create a new grpc_channel */ |
||||
grpc_channel *grpc_client_channel_factory_create_channel( |
||||
grpc_exec_ctx *exec_ctx, grpc_client_channel_factory *factory, |
||||
const char *target, grpc_client_channel_type type, grpc_channel_args *args); |
||||
|
||||
#endif /* GRPC_CORE_EXT_CLIENT_CONFIG_CLIENT_CHANNEL_FACTORY_H */ |
@ -0,0 +1,95 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, 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. |
||||
* |
||||
*/ |
||||
|
||||
#include <limits.h> |
||||
#include <stdbool.h> |
||||
#include <string.h> |
||||
|
||||
#include <grpc/support/alloc.h> |
||||
|
||||
#include "src/core/ext/client_config/client_channel.h" |
||||
#include "src/core/ext/client_config/lb_policy_registry.h" |
||||
#include "src/core/ext/client_config/resolver_registry.h" |
||||
#include "src/core/ext/client_config/subchannel_index.h" |
||||
#include "src/core/lib/surface/channel_init.h" |
||||
|
||||
#ifndef GRPC_DEFAULT_NAME_PREFIX |
||||
#define GRPC_DEFAULT_NAME_PREFIX "dns:///"
|
||||
#endif |
||||
|
||||
static bool append_filter(grpc_channel_stack_builder *builder, void *arg) { |
||||
return grpc_channel_stack_builder_append_filter( |
||||
builder, (const grpc_channel_filter *)arg, NULL, NULL); |
||||
} |
||||
|
||||
static bool set_default_host_if_unset(grpc_channel_stack_builder *builder, |
||||
void *unused) { |
||||
const grpc_channel_args *args = |
||||
grpc_channel_stack_builder_get_channel_arguments(builder); |
||||
for (size_t i = 0; i < args->num_args; i++) { |
||||
if (0 == strcmp(args->args[i].key, GRPC_ARG_DEFAULT_AUTHORITY) || |
||||
0 == strcmp(args->args[i].key, GRPC_SSL_TARGET_NAME_OVERRIDE_ARG)) { |
||||
return true; |
||||
} |
||||
} |
||||
char *default_authority = grpc_get_default_authority( |
||||
grpc_channel_stack_builder_get_target(builder)); |
||||
if (default_authority != NULL) { |
||||
grpc_arg arg; |
||||
arg.type = GRPC_ARG_STRING; |
||||
arg.key = GRPC_ARG_DEFAULT_AUTHORITY; |
||||
arg.value.string = default_authority; |
||||
grpc_channel_args *new_args = grpc_channel_args_copy_and_add(args, &arg, 1); |
||||
grpc_channel_stack_builder_set_channel_arguments(builder, new_args); |
||||
gpr_free(default_authority); |
||||
grpc_channel_args_destroy(new_args); |
||||
} |
||||
return true; |
||||
} |
||||
|
||||
void grpc_client_config_init(void) { |
||||
grpc_lb_policy_registry_init(); |
||||
grpc_resolver_registry_init(GRPC_DEFAULT_NAME_PREFIX); |
||||
grpc_subchannel_index_init(); |
||||
grpc_channel_init_register_stage(GRPC_CLIENT_CHANNEL, INT_MIN, |
||||
set_default_host_if_unset, NULL); |
||||
grpc_channel_init_register_stage(GRPC_CLIENT_CHANNEL, INT_MAX, append_filter, |
||||
(void *)&grpc_client_channel_filter); |
||||
} |
||||
|
||||
void grpc_client_config_shutdown(void) { |
||||
grpc_subchannel_index_shutdown(); |
||||
grpc_channel_init_shutdown(); |
||||
grpc_resolver_registry_shutdown(); |
||||
grpc_lb_policy_registry_shutdown(); |
||||
} |
@ -0,0 +1,46 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, 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. |
||||
* |
||||
*/ |
||||
|
||||
#include "src/core/ext/transport/chttp2/transport/bin_encoder.h" |
||||
#include "src/core/ext/transport/chttp2/transport/chttp2_transport.h" |
||||
#include "src/core/lib/debug/trace.h" |
||||
#include "src/core/lib/transport/metadata.h" |
||||
|
||||
void grpc_chttp2_plugin_init(void) { |
||||
grpc_chttp2_base64_encode_and_huffman_compress = |
||||
grpc_chttp2_base64_encode_and_huffman_compress_impl; |
||||
grpc_register_tracer("http", &grpc_http_trace); |
||||
grpc_register_tracer("flowctl", &grpc_flowctl_trace); |
||||
} |
||||
|
||||
void grpc_chttp2_plugin_shutdown(void) {} |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue