grpc 1.7.3 → 1.8.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of grpc might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Makefile +2106 -2116
- data/include/grpc/census.h +1 -432
- data/include/grpc/compression.h +9 -9
- data/include/grpc/grpc.h +115 -98
- data/include/grpc/grpc_cronet.h +3 -3
- data/include/grpc/grpc_posix.h +4 -4
- data/include/grpc/grpc_security.h +160 -88
- data/include/grpc/grpc_security_constants.h +7 -0
- data/include/grpc/impl/codegen/atm.h +9 -1
- data/include/grpc/impl/codegen/atm_gcc_atomic.h +13 -4
- data/include/grpc/impl/codegen/atm_gcc_sync.h +6 -5
- data/include/grpc/impl/codegen/atm_windows.h +23 -22
- data/include/grpc/impl/codegen/byte_buffer.h +14 -14
- data/include/grpc/impl/codegen/byte_buffer_reader.h +2 -2
- data/include/grpc/impl/codegen/connectivity_state.h +0 -2
- data/include/grpc/impl/codegen/grpc_types.h +32 -28
- data/include/grpc/impl/codegen/port_platform.h +48 -0
- data/include/grpc/impl/codegen/slice.h +10 -10
- data/include/grpc/impl/codegen/sync_generic.h +9 -3
- data/include/grpc/slice.h +16 -17
- data/include/grpc/slice_buffer.h +22 -22
- data/include/grpc/support/alloc.h +11 -11
- data/include/grpc/support/avl.h +28 -20
- data/include/grpc/support/cmdline.h +13 -13
- data/include/grpc/support/histogram.h +17 -17
- data/include/grpc/support/host_port.h +2 -2
- data/include/grpc/support/log.h +9 -9
- data/include/grpc/support/log_windows.h +1 -1
- data/include/grpc/support/string_util.h +2 -2
- data/include/grpc/support/subprocess.h +5 -5
- data/include/grpc/support/sync.h +43 -27
- data/include/grpc/support/thd.h +6 -6
- data/include/grpc/support/tls_gcc.h +1 -1
- data/include/grpc/support/tls_pthread.h +1 -1
- data/src/core/ext/census/{grpc_context.c → grpc_context.cc} +5 -8
- data/src/core/ext/filters/client_channel/backup_poller.cc +165 -0
- data/src/core/ext/{census/grpc_filter.h → filters/client_channel/backup_poller.h} +12 -7
- data/src/core/ext/filters/client_channel/{channel_connectivity.c → channel_connectivity.cc} +45 -42
- data/src/core/ext/filters/client_channel/{client_channel.c → client_channel.cc} +452 -417
- data/src/core/ext/filters/client_channel/client_channel.h +16 -8
- data/src/core/ext/filters/client_channel/{client_channel_factory.c → client_channel_factory.cc} +0 -0
- data/src/core/ext/filters/client_channel/client_channel_factory.h +29 -21
- data/src/core/ext/filters/client_channel/{client_channel_plugin.c → client_channel_plugin.cc} +15 -19
- data/src/core/ext/filters/client_channel/{connector.c → connector.cc} +0 -0
- data/src/core/ext/filters/client_channel/connector.h +29 -21
- data/src/core/ext/filters/client_channel/{http_connect_handshaker.c → http_connect_handshaker.cc} +10 -10
- data/src/core/ext/filters/client_channel/http_connect_handshaker.h +8 -0
- data/src/core/ext/filters/client_channel/{http_proxy.c → http_proxy.cc} +14 -14
- data/src/core/ext/filters/client_channel/http_proxy.h +8 -0
- data/src/core/ext/filters/client_channel/{lb_policy.c → lb_policy.cc} +47 -48
- data/src/core/ext/filters/client_channel/lb_policy.h +76 -70
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/{client_load_reporting_filter.c → client_load_reporting_filter.cc} +28 -29
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +9 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/{grpclb.c → grpclb.cc} +554 -563
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.h +9 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel.h +17 -9
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/{grpclb_channel_secure.c → grpclb_channel_secure.cc} +17 -17
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/{grpclb_client_stats.c → grpclb_client_stats.cc} +3 -3
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +9 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/{load_balancer_api.c → load_balancer_api.cc} +64 -67
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +20 -21
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +599 -0
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +695 -0
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.cc +270 -0
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +153 -0
- data/src/core/ext/filters/client_channel/{lb_policy_factory.c → lb_policy_factory.cc} +10 -10
- data/src/core/ext/filters/client_channel/lb_policy_factory.h +48 -40
- data/src/core/ext/filters/client_channel/{lb_policy_registry.c → lb_policy_registry.cc} +9 -9
- data/src/core/ext/filters/client_channel/lb_policy_registry.h +11 -3
- data/src/core/ext/filters/client_channel/{parse_address.c → parse_address.cc} +24 -24
- data/src/core/ext/filters/client_channel/parse_address.h +14 -6
- data/src/core/ext/filters/client_channel/{proxy_mapper.c → proxy_mapper.cc} +0 -0
- data/src/core/ext/filters/client_channel/proxy_mapper.h +8 -0
- data/src/core/ext/filters/client_channel/{proxy_mapper_registry.c → proxy_mapper_registry.cc} +0 -0
- data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +8 -0
- data/src/core/ext/filters/client_channel/{resolver.c → resolver.cc} +21 -23
- data/src/core/ext/filters/client_channel/resolver.h +33 -27
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/{dns_resolver_ares.c → dns_resolver_ares.cc} +133 -133
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +18 -9
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/{grpc_ares_ev_driver_posix.c → grpc_ares_ev_driver_posix.cc} +58 -56
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/{grpc_ares_wrapper.c → grpc_ares_wrapper.cc} +118 -115
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +23 -15
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.cc +60 -0
- data/src/core/ext/filters/client_channel/resolver/dns/native/{dns_resolver.c → dns_resolver.cc} +100 -94
- data/src/core/ext/filters/client_channel/resolver/fake/{fake_resolver.c → fake_resolver.cc} +14 -14
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +9 -1
- data/src/core/ext/filters/client_channel/resolver/sockaddr/{sockaddr_resolver.c → sockaddr_resolver.cc} +60 -60
- data/src/core/ext/filters/client_channel/{resolver_factory.c → resolver_factory.cc} +2 -2
- data/src/core/ext/filters/client_channel/resolver_factory.h +27 -19
- data/src/core/ext/filters/client_channel/{resolver_registry.c → resolver_registry.cc} +35 -35
- data/src/core/ext/filters/client_channel/resolver_registry.h +18 -10
- data/src/core/ext/filters/client_channel/{retry_throttle.c → retry_throttle.cc} +10 -10
- data/src/core/ext/filters/client_channel/retry_throttle.h +8 -0
- data/src/core/ext/filters/client_channel/{subchannel.c → subchannel.cc} +210 -213
- data/src/core/ext/filters/client_channel/subchannel.h +68 -60
- data/src/core/ext/filters/client_channel/{subchannel_index.c → subchannel_index.cc} +52 -52
- data/src/core/ext/filters/client_channel/subchannel_index.h +22 -14
- data/src/core/ext/filters/client_channel/{uri_parser.c → uri_parser.cc} +29 -27
- data/src/core/ext/filters/client_channel/uri_parser.h +18 -10
- data/src/core/ext/filters/deadline/{deadline_filter.c → deadline_filter.cc} +12 -15
- data/src/core/ext/filters/deadline/deadline_filter.h +11 -2
- data/src/core/ext/filters/http/client/{http_client_filter.c → http_client_filter.cc} +83 -83
- data/src/core/ext/filters/http/client/http_client_filter.h +8 -0
- data/src/core/ext/filters/http/{http_filters_plugin.c → http_filters_plugin.cc} +20 -21
- data/src/core/ext/filters/http/message_compress/{message_compress_filter.c → message_compress_filter.cc} +84 -83
- data/src/core/ext/filters/http/message_compress/message_compress_filter.h +9 -1
- data/src/core/ext/filters/http/server/{http_server_filter.c → http_server_filter.cc} +80 -78
- data/src/core/ext/filters/http/server/http_server_filter.h +8 -0
- data/src/core/ext/filters/load_reporting/{server_load_reporting_filter.c → server_load_reporting_filter.cc} +29 -29
- data/src/core/ext/filters/load_reporting/server_load_reporting_filter.h +9 -1
- data/src/core/ext/filters/load_reporting/{server_load_reporting_plugin.c → server_load_reporting_plugin.cc} +11 -11
- data/src/core/ext/filters/load_reporting/server_load_reporting_plugin.h +13 -5
- data/src/core/ext/filters/max_age/{max_age_filter.c → max_age_filter.cc} +46 -56
- data/src/core/ext/filters/max_age/max_age_filter.h +8 -0
- data/src/core/ext/filters/message_size/{message_size_filter.c → message_size_filter.cc} +62 -40
- data/src/core/ext/filters/message_size/message_size_filter.h +8 -0
- data/src/core/ext/filters/workarounds/{workaround_cronet_compression_filter.c → workaround_cronet_compression_filter.cc} +11 -11
- data/src/core/ext/filters/workarounds/workaround_cronet_compression_filter.h +8 -0
- data/src/core/ext/filters/workarounds/{workaround_utils.c → workaround_utils.cc} +7 -7
- data/src/core/ext/filters/workarounds/workaround_utils.h +9 -1
- data/src/core/ext/transport/chttp2/alpn/{alpn.c → alpn.cc} +3 -3
- data/src/core/ext/transport/chttp2/alpn/alpn.h +10 -2
- data/src/core/ext/transport/chttp2/client/{chttp2_connector.c → chttp2_connector.cc} +49 -45
- data/src/core/ext/transport/chttp2/client/chttp2_connector.h +8 -0
- data/src/core/ext/transport/chttp2/client/insecure/{channel_create.c → channel_create.cc} +28 -27
- data/src/core/ext/transport/chttp2/client/insecure/{channel_create_posix.c → channel_create_posix.cc} +14 -13
- data/src/core/ext/transport/chttp2/client/secure/{secure_channel_create.c → secure_channel_create.cc} +68 -66
- data/src/core/ext/transport/chttp2/server/{chttp2_server.c → chttp2_server.cc} +76 -77
- data/src/core/ext/transport/chttp2/server/chttp2_server.h +11 -3
- data/src/core/ext/transport/chttp2/server/insecure/{server_chttp2.c → server_chttp2.cc} +3 -3
- data/src/core/ext/transport/chttp2/server/insecure/{server_chttp2_posix.c → server_chttp2_posix.cc} +13 -12
- data/src/core/ext/transport/chttp2/server/secure/{server_secure_chttp2.c → server_secure_chttp2.cc} +12 -10
- data/src/core/ext/transport/chttp2/transport/{bin_decoder.c → bin_decoder.cc} +7 -7
- data/src/core/ext/transport/chttp2/transport/bin_decoder.h +15 -7
- data/src/core/ext/transport/chttp2/transport/{bin_encoder.c → bin_encoder.cc} +11 -11
- data/src/core/ext/transport/chttp2/transport/bin_encoder.h +8 -0
- data/src/core/ext/transport/chttp2/transport/{chttp2_plugin.c → chttp2_plugin.cc} +2 -9
- data/src/core/ext/transport/chttp2/transport/{chttp2_transport.c → chttp2_transport.cc} +778 -778
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +14 -10
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +385 -0
- data/src/core/ext/transport/chttp2/transport/flow_control.h +337 -0
- data/src/core/ext/transport/chttp2/transport/frame.h +8 -0
- data/src/core/ext/transport/chttp2/transport/{frame_data.c → frame_data.cc} +34 -34
- data/src/core/ext/transport/chttp2/transport/frame_data.h +25 -17
- data/src/core/ext/transport/chttp2/transport/{frame_goaway.c → frame_goaway.cc} +18 -18
- data/src/core/ext/transport/chttp2/transport/frame_goaway.h +18 -10
- data/src/core/ext/transport/chttp2/transport/{frame_ping.c → frame_ping.cc} +18 -19
- data/src/core/ext/transport/chttp2/transport/frame_ping.h +12 -4
- data/src/core/ext/transport/chttp2/transport/{frame_rst_stream.c → frame_rst_stream.cc} +16 -16
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +16 -8
- data/src/core/ext/transport/chttp2/transport/{frame_settings.c → frame_settings.cc} +23 -24
- data/src/core/ext/transport/chttp2/transport/frame_settings.h +17 -9
- data/src/core/ext/transport/chttp2/transport/{frame_window_update.c → frame_window_update.cc} +22 -24
- data/src/core/ext/transport/chttp2/transport/frame_window_update.h +14 -6
- data/src/core/ext/transport/chttp2/transport/{hpack_encoder.c → hpack_encoder.cc} +206 -161
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +23 -13
- data/src/core/ext/transport/chttp2/transport/{hpack_parser.c → hpack_parser.cc} +340 -334
- data/src/core/ext/transport/chttp2/transport/hpack_parser.h +30 -22
- data/src/core/ext/transport/chttp2/transport/{hpack_table.c → hpack_table.cc} +25 -25
- data/src/core/ext/transport/chttp2/transport/hpack_table.h +19 -11
- data/src/core/ext/transport/chttp2/transport/{http2_settings.c → http2_settings.cc} +1 -1
- data/src/core/ext/transport/chttp2/transport/http2_settings.h +10 -2
- data/src/core/ext/transport/chttp2/transport/{huffsyms.c → huffsyms.cc} +0 -0
- data/src/core/ext/transport/chttp2/transport/huffsyms.h +8 -0
- data/src/core/ext/transport/chttp2/transport/{incoming_metadata.c → incoming_metadata.cc} +14 -13
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.h +18 -10
- data/src/core/ext/transport/chttp2/transport/internal.h +214 -340
- data/src/core/ext/transport/chttp2/transport/{parsing.c → parsing.cc} +152 -141
- data/src/core/ext/transport/chttp2/transport/{stream_lists.c → stream_lists.cc} +53 -53
- data/src/core/ext/transport/chttp2/transport/{stream_map.c → stream_map.cc} +35 -34
- data/src/core/ext/transport/chttp2/transport/stream_map.h +22 -14
- data/src/core/ext/transport/chttp2/transport/{varint.c → varint.cc} +0 -0
- data/src/core/ext/transport/chttp2/transport/varint.h +8 -0
- data/src/core/ext/transport/chttp2/transport/writing.cc +636 -0
- data/src/core/ext/transport/inproc/{inproc_plugin.c → inproc_plugin.cc} +5 -6
- data/src/core/ext/transport/inproc/{inproc_transport.c → inproc_transport.cc} +479 -544
- data/src/core/ext/transport/inproc/inproc_transport.h +4 -4
- data/src/core/lib/backoff/backoff.cc +80 -0
- data/src/core/lib/backoff/backoff.h +83 -0
- data/src/core/lib/channel/{channel_args.c → channel_args.cc} +92 -92
- data/src/core/lib/channel/channel_args.h +45 -37
- data/src/core/lib/channel/{channel_stack.c → channel_stack.cc} +67 -68
- data/src/core/lib/channel/channel_stack.h +76 -75
- data/src/core/lib/channel/{channel_stack_builder.c → channel_stack_builder.cc} +91 -91
- data/src/core/lib/channel/channel_stack_builder.h +45 -45
- data/src/core/lib/channel/{connected_channel.c → connected_channel.cc} +70 -70
- data/src/core/lib/channel/connected_channel.h +12 -4
- data/src/core/lib/channel/context.h +2 -2
- data/src/core/lib/channel/{handshaker.c → handshaker.cc} +7 -9
- data/src/core/lib/channel/handshaker.h +9 -1
- data/src/core/lib/channel/{handshaker_factory.c → handshaker_factory.cc} +7 -7
- data/src/core/lib/channel/handshaker_factory.h +18 -10
- data/src/core/lib/channel/{handshaker_registry.c → handshaker_registry.cc} +0 -0
- data/src/core/lib/channel/handshaker_registry.h +8 -0
- data/src/core/lib/compression/algorithm_metadata.h +8 -0
- data/src/core/lib/compression/{compression.c → compression.cc} +9 -9
- data/src/core/lib/compression/{message_compress.c → message_compress.cc} +0 -0
- data/src/core/lib/compression/message_compress.h +8 -0
- data/src/core/lib/compression/{stream_compression.c → stream_compression.cc} +12 -12
- data/src/core/lib/compression/stream_compression.h +27 -19
- data/src/core/lib/compression/{stream_compression_gzip.c → stream_compression_gzip.cc} +35 -36
- data/src/core/lib/compression/stream_compression_gzip.h +8 -0
- data/src/core/lib/compression/{stream_compression_identity.c → stream_compression_identity.cc} +19 -20
- data/src/core/lib/compression/stream_compression_identity.h +8 -0
- data/src/core/lib/debug/{stats.c → stats.cc} +19 -19
- data/src/core/lib/debug/stats.h +17 -9
- data/src/core/lib/debug/{stats_data.c → stats_data.cc} +45 -22
- data/src/core/lib/debug/stats_data.h +58 -19
- data/src/core/lib/debug/trace.cc +142 -0
- data/src/core/lib/debug/trace.h +74 -14
- data/src/core/lib/http/{format_request.c → format_request.cc} +10 -10
- data/src/core/lib/http/format_request.h +12 -4
- data/src/core/lib/http/{httpcli.c → httpcli.cc} +80 -80
- data/src/core/lib/http/httpcli.h +41 -33
- data/src/core/lib/http/{httpcli_security_connector.c → httpcli_security_connector.cc} +69 -55
- data/src/core/lib/http/{parser.c → parser.cc} +42 -42
- data/src/core/lib/http/parser.h +28 -20
- data/src/core/lib/{support → iomgr}/block_annotate.h +17 -8
- data/src/core/lib/iomgr/{call_combiner.c → call_combiner.cc} +29 -17
- data/src/core/lib/iomgr/call_combiner.h +9 -1
- data/src/core/lib/iomgr/closure.h +220 -62
- data/src/core/lib/iomgr/{combiner.c → combiner.cc} +63 -62
- data/src/core/lib/iomgr/combiner.h +16 -8
- data/src/core/lib/iomgr/{endpoint.c → endpoint.cc} +6 -0
- data/src/core/lib/iomgr/endpoint.h +47 -32
- data/src/core/lib/iomgr/endpoint_pair.h +12 -4
- data/src/core/lib/iomgr/{endpoint_pair_posix.c → endpoint_pair_posix.cc} +3 -3
- data/src/core/lib/iomgr/{endpoint_pair_uv.c → endpoint_pair_uv.cc} +2 -2
- data/src/core/lib/iomgr/{endpoint_pair_windows.c → endpoint_pair_windows.cc} +6 -6
- data/src/core/lib/iomgr/{error.c → error.cc} +125 -124
- data/src/core/lib/iomgr/error.h +32 -27
- data/src/core/lib/iomgr/error_internal.h +11 -2
- data/src/core/lib/iomgr/{ev_epoll1_linux.c → ev_epoll1_linux.cc} +214 -215
- data/src/core/lib/iomgr/ev_epoll1_linux.h +9 -1
- data/src/core/lib/iomgr/ev_epollex_linux.cc +1488 -0
- data/src/core/lib/iomgr/ev_epollex_linux.h +9 -1
- data/src/core/lib/iomgr/{ev_epollsig_linux.c → ev_epollsig_linux.cc} +304 -305
- data/src/core/lib/iomgr/ev_epollsig_linux.h +12 -4
- data/src/core/lib/iomgr/{ev_poll_posix.c → ev_poll_posix.cc} +272 -283
- data/src/core/lib/iomgr/ev_poll_posix.h +10 -2
- data/src/core/lib/iomgr/ev_posix.cc +288 -0
- data/src/core/lib/iomgr/ev_posix.h +75 -67
- data/src/core/lib/iomgr/{ev_windows.c → ev_windows.cc} +2 -2
- data/src/core/lib/iomgr/exec_ctx.cc +177 -0
- data/src/core/lib/iomgr/exec_ctx.h +35 -13
- data/src/core/lib/iomgr/{executor.c → executor.cc} +34 -35
- data/src/core/lib/iomgr/executor.h +12 -4
- data/src/core/lib/iomgr/{fork_posix.c → fork_posix.cc} +0 -0
- data/src/core/lib/iomgr/{fork_windows.c → fork_windows.cc} +0 -0
- data/src/core/lib/iomgr/gethostname.h +9 -1
- data/src/core/lib/iomgr/{gethostname_fallback.c → gethostname_fallback.cc} +2 -1
- data/src/core/lib/iomgr/{gethostname_host_name_max.c → gethostname_host_name_max.cc} +4 -3
- data/src/core/lib/iomgr/{gethostname_sysconf.c → gethostname_sysconf.cc} +3 -2
- data/src/core/lib/iomgr/{iocp_windows.c → iocp_windows.cc} +23 -25
- data/src/core/lib/iomgr/iocp_windows.h +17 -3
- data/src/core/lib/iomgr/{iomgr.c → iomgr.cc} +25 -19
- data/src/core/lib/iomgr/iomgr.h +11 -3
- data/src/core/lib/iomgr/iomgr_internal.h +13 -5
- data/src/core/lib/iomgr/{iomgr_posix.c → iomgr_posix.cc} +0 -1
- data/src/core/lib/iomgr/{iomgr_uv.c → iomgr_uv.cc} +1 -1
- data/src/core/lib/iomgr/iomgr_uv.h +8 -0
- data/src/core/lib/iomgr/{iomgr_windows.c → iomgr_windows.cc} +0 -0
- data/src/core/lib/iomgr/{is_epollexclusive_available.c → is_epollexclusive_available.cc} +1 -1
- data/src/core/lib/iomgr/is_epollexclusive_available.h +8 -0
- data/src/core/lib/iomgr/{load_file.c → load_file.cc} +12 -12
- data/src/core/lib/iomgr/load_file.h +2 -2
- data/src/core/lib/iomgr/{lockfree_event.c → lockfree_event.cc} +76 -68
- data/src/core/lib/iomgr/lockfree_event.h +30 -11
- data/src/core/lib/iomgr/{network_status_tracker.c → network_status_tracker.cc} +3 -2
- data/src/core/lib/iomgr/network_status_tracker.h +2 -2
- data/src/core/lib/iomgr/{polling_entity.c → polling_entity.cc} +18 -18
- data/src/core/lib/iomgr/polling_entity.h +21 -13
- data/src/core/lib/iomgr/pollset.h +17 -11
- data/src/core/lib/iomgr/pollset_set.h +23 -15
- data/src/core/lib/iomgr/{pollset_set_uv.c → pollset_set_uv.cc} +0 -0
- data/src/core/lib/iomgr/{pollset_set_windows.c → pollset_set_windows.cc} +0 -0
- data/src/core/lib/iomgr/{pollset_uv.c → pollset_uv.cc} +31 -29
- data/src/core/lib/iomgr/pollset_uv.h +8 -0
- data/src/core/lib/iomgr/{pollset_windows.c → pollset_windows.cc} +24 -24
- data/src/core/lib/iomgr/pollset_windows.h +17 -4
- data/src/core/lib/iomgr/port.h +10 -0
- data/src/core/lib/iomgr/resolve_address.h +18 -10
- data/src/core/lib/iomgr/{resolve_address_posix.c → resolve_address_posix.cc} +40 -40
- data/src/core/lib/iomgr/{resolve_address_uv.c → resolve_address_uv.cc} +61 -56
- data/src/core/lib/iomgr/{resolve_address_windows.c → resolve_address_windows.cc} +36 -34
- data/src/core/lib/iomgr/{resource_quota.c → resource_quota.cc} +209 -180
- data/src/core/lib/iomgr/resource_quota.h +45 -37
- data/src/core/lib/iomgr/{sockaddr_utils.c → sockaddr_utils.cc} +61 -61
- data/src/core/lib/iomgr/sockaddr_utils.h +23 -15
- data/src/core/lib/iomgr/sockaddr_windows.h +6 -0
- data/src/core/lib/iomgr/{socket_factory_posix.c → socket_factory_posix.cc} +20 -20
- data/src/core/lib/iomgr/socket_factory_posix.h +15 -15
- data/src/core/lib/iomgr/{socket_mutator.c → socket_mutator.cc} +18 -18
- data/src/core/lib/iomgr/socket_mutator.h +11 -11
- data/src/core/lib/iomgr/socket_utils.h +9 -1
- data/src/core/lib/iomgr/{socket_utils_common_posix.c → socket_utils_common_posix.cc} +28 -28
- data/src/core/lib/iomgr/{socket_utils_linux.c → socket_utils_linux.cc} +3 -3
- data/src/core/lib/iomgr/{socket_utils_posix.c → socket_utils_posix.cc} +3 -3
- data/src/core/lib/iomgr/socket_utils_posix.h +26 -18
- data/src/core/lib/iomgr/{socket_utils_uv.c → socket_utils_uv.cc} +1 -1
- data/src/core/lib/iomgr/{socket_utils_windows.c → socket_utils_windows.cc} +2 -2
- data/src/core/lib/iomgr/{socket_windows.c → socket_windows.cc} +18 -18
- data/src/core/lib/iomgr/socket_windows.h +26 -13
- data/src/core/lib/iomgr/tcp_client.h +14 -6
- data/src/core/lib/iomgr/{tcp_client_posix.c → tcp_client_posix.cc} +69 -70
- data/src/core/lib/iomgr/tcp_client_posix.h +11 -3
- data/src/core/lib/iomgr/{tcp_client_uv.c → tcp_client_uv.cc} +47 -48
- data/src/core/lib/iomgr/{tcp_client_windows.c → tcp_client_windows.cc} +46 -44
- data/src/core/lib/iomgr/{tcp_posix.c → tcp_posix.cc} +198 -175
- data/src/core/lib/iomgr/tcp_posix.h +15 -7
- data/src/core/lib/iomgr/tcp_server.h +31 -23
- data/src/core/lib/iomgr/{tcp_server_posix.c → tcp_server_posix.cc} +78 -77
- data/src/core/lib/iomgr/tcp_server_utils_posix.h +27 -19
- data/src/core/lib/iomgr/{tcp_server_utils_posix_common.c → tcp_server_utils_posix_common.cc} +27 -27
- data/src/core/lib/iomgr/{tcp_server_utils_posix_ifaddrs.c → tcp_server_utils_posix_ifaddrs.cc} +25 -25
- data/src/core/lib/iomgr/{tcp_server_utils_posix_noifaddrs.c → tcp_server_utils_posix_noifaddrs.cc} +2 -2
- data/src/core/lib/iomgr/{tcp_server_uv.c → tcp_server_uv.cc} +133 -105
- data/src/core/lib/iomgr/{tcp_server_windows.c → tcp_server_windows.cc} +81 -77
- data/src/core/lib/iomgr/tcp_uv.cc +420 -0
- data/src/core/lib/iomgr/tcp_uv.h +18 -4
- data/src/core/lib/iomgr/{tcp_windows.c → tcp_windows.cc} +90 -79
- data/src/core/lib/iomgr/tcp_windows.h +17 -4
- data/src/core/lib/iomgr/{time_averaged_stats.c → time_averaged_stats.cc} +0 -0
- data/src/core/lib/iomgr/time_averaged_stats.h +8 -0
- data/src/core/lib/iomgr/timer.h +16 -9
- data/src/core/lib/iomgr/{timer_generic.c → timer_generic.cc} +130 -171
- data/src/core/lib/iomgr/timer_generic.h +4 -4
- data/src/core/lib/iomgr/{timer_heap.c → timer_heap.cc} +20 -21
- data/src/core/lib/iomgr/timer_heap.h +16 -8
- data/src/core/lib/iomgr/{timer_manager.c → timer_manager.cc} +54 -52
- data/src/core/lib/iomgr/timer_manager.h +8 -0
- data/src/core/lib/iomgr/{timer_uv.c → timer_uv.cc} +22 -24
- data/src/core/lib/iomgr/timer_uv.h +2 -2
- data/src/core/lib/iomgr/{udp_server.c → udp_server.cc} +75 -75
- data/src/core/lib/iomgr/udp_server.h +25 -17
- data/src/core/lib/iomgr/{unix_sockets_posix.c → unix_sockets_posix.cc} +22 -21
- data/src/core/lib/iomgr/unix_sockets_posix.h +14 -6
- data/src/core/lib/iomgr/{unix_sockets_posix_noop.c → unix_sockets_posix_noop.cc} +5 -5
- data/src/core/lib/iomgr/{wakeup_fd_cv.c → wakeup_fd_cv.cc} +2 -2
- data/src/core/lib/iomgr/wakeup_fd_cv.h +10 -0
- data/src/core/lib/iomgr/{wakeup_fd_eventfd.c → wakeup_fd_eventfd.cc} +0 -0
- data/src/core/lib/iomgr/{wakeup_fd_nospecial.c → wakeup_fd_nospecial.cc} +0 -0
- data/src/core/lib/iomgr/{wakeup_fd_pipe.c → wakeup_fd_pipe.cc} +1 -0
- data/src/core/lib/iomgr/wakeup_fd_pipe.h +9 -1
- data/src/core/lib/iomgr/{wakeup_fd_posix.c → wakeup_fd_posix.cc} +6 -7
- data/src/core/lib/iomgr/wakeup_fd_posix.h +8 -0
- data/src/core/lib/json/{json.c → json.cc} +0 -0
- data/src/core/lib/json/json.h +8 -0
- data/src/core/lib/json/{json_reader.c → json_reader.cc} +18 -18
- data/src/core/lib/json/json_reader.h +26 -18
- data/src/core/lib/json/{json_string.c → json_string.cc} +57 -57
- data/src/core/lib/json/{json_writer.c → json_writer.cc} +20 -20
- data/src/core/lib/json/json_writer.h +23 -15
- data/src/core/lib/profiling/{basic_timers.c → basic_timers.cc} +34 -34
- data/src/core/lib/profiling/{stap_timers.c → stap_timers.cc} +5 -5
- data/src/core/lib/profiling/timers.h +6 -6
- data/src/core/lib/security/context/{security_context.c → security_context.cc} +98 -95
- data/src/core/lib/security/context/security_context.h +27 -29
- data/src/core/lib/security/credentials/composite/{composite_credentials.c → composite_credentials.cc} +79 -73
- data/src/core/lib/security/credentials/composite/composite_credentials.h +17 -9
- data/src/core/lib/security/credentials/{credentials.c → credentials.cc} +97 -92
- data/src/core/lib/security/credentials/credentials.h +83 -75
- data/src/core/lib/security/credentials/{credentials_metadata.c → credentials_metadata.cc} +7 -6
- data/src/core/lib/security/credentials/fake/{fake_credentials.c → fake_credentials.cc} +39 -36
- data/src/core/lib/security/credentials/fake/fake_credentials.h +13 -5
- data/src/core/lib/security/credentials/google_default/{credentials_generic.c → credentials_generic.cc} +5 -5
- data/src/core/lib/security/credentials/google_default/{google_default_credentials.c → google_default_credentials.cc} +55 -55
- data/src/core/lib/security/credentials/google_default/google_default_credentials.h +9 -1
- data/src/core/lib/security/credentials/iam/{iam_credentials.c → iam_credentials.cc} +19 -18
- data/src/core/lib/security/credentials/jwt/{json_token.c → json_token.cc} +80 -75
- data/src/core/lib/security/credentials/jwt/json_token.h +23 -15
- data/src/core/lib/security/credentials/jwt/{jwt_credentials.c → jwt_credentials.cc} +45 -41
- data/src/core/lib/security/credentials/jwt/jwt_credentials.h +11 -3
- data/src/core/lib/security/credentials/jwt/{jwt_verifier.c → jwt_verifier.cc} +262 -252
- data/src/core/lib/security/credentials/jwt/jwt_verifier.h +38 -30
- data/src/core/lib/security/credentials/oauth2/{oauth2_credentials.c → oauth2_credentials.cc} +138 -141
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +30 -22
- data/src/core/lib/security/credentials/plugin/{plugin_credentials.c → plugin_credentials.cc} +52 -53
- data/src/core/lib/security/credentials/plugin/plugin_credentials.h +7 -7
- data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +344 -0
- data/src/core/lib/security/credentials/ssl/ssl_credentials.h +27 -0
- data/src/core/lib/security/transport/auth_filters.h +16 -0
- data/src/core/lib/security/transport/{client_auth_filter.c → client_auth_filter.cc} +127 -115
- data/src/core/lib/security/transport/{lb_targets_info.c → lb_targets_info.cc} +16 -13
- data/src/core/lib/security/transport/lb_targets_info.h +11 -3
- data/src/core/lib/security/transport/{secure_endpoint.c → secure_endpoint.cc} +84 -76
- data/src/core/lib/security/transport/secure_endpoint.h +13 -5
- data/src/core/lib/security/transport/security_connector.cc +1121 -0
- data/src/core/lib/security/transport/security_connector.h +97 -79
- data/src/core/lib/security/transport/{security_handshaker.c → security_handshaker.cc} +139 -132
- data/src/core/lib/security/transport/security_handshaker.h +11 -3
- data/src/core/lib/security/transport/{server_auth_filter.c → server_auth_filter.cc} +68 -68
- data/src/core/lib/security/transport/{tsi_error.c → tsi_error.cc} +1 -1
- data/src/core/lib/security/transport/tsi_error.h +9 -1
- data/src/core/lib/security/util/{json_util.c → json_util.cc} +11 -11
- data/src/core/lib/security/util/json_util.h +12 -4
- data/src/core/lib/slice/{b64.c → b64.cc} +15 -15
- data/src/core/lib/slice/b64.h +12 -4
- data/src/core/lib/slice/{percent_encoding.c → percent_encoding.cc} +15 -15
- data/src/core/lib/slice/percent_encoding.h +11 -3
- data/src/core/lib/slice/{slice.c → slice.cc} +64 -64
- data/src/core/lib/slice/{slice_buffer.c → slice_buffer.cc} +38 -38
- data/src/core/lib/slice/{slice_hash_table.c → slice_hash_table.cc} +7 -7
- data/src/core/lib/slice/slice_hash_table.h +19 -11
- data/src/core/lib/slice/{slice_intern.c → slice_intern.cc} +35 -34
- data/src/core/lib/slice/slice_internal.h +17 -6
- data/src/core/lib/slice/{slice_string_helpers.c → slice_string_helpers.cc} +9 -9
- data/src/core/lib/slice/slice_string_helpers.h +3 -3
- data/src/core/lib/support/abstract.h +29 -0
- data/src/core/lib/support/{alloc.c → alloc.cc} +22 -22
- data/src/core/lib/support/{arena.c → arena.cc} +12 -12
- data/src/core/lib/support/arena.h +11 -3
- data/src/core/lib/support/{atm.c → atm.cc} +1 -1
- data/src/core/lib/support/{avl.c → avl.cc} +71 -70
- data/src/core/lib/support/{cmdline.c → cmdline.cc} +62 -62
- data/src/core/lib/support/{cpu_iphone.c → cpu_iphone.cc} +2 -0
- data/src/core/lib/support/{cpu_linux.c → cpu_linux.cc} +10 -0
- data/src/core/lib/support/{cpu_posix.c → cpu_posix.cc} +27 -4
- data/src/core/lib/support/{cpu_windows.c → cpu_windows.cc} +1 -0
- data/src/core/lib/support/env.h +3 -3
- data/src/core/lib/support/{env_linux.c → env_linux.cc} +11 -11
- data/src/core/lib/support/{env_posix.c → env_posix.cc} +4 -4
- data/src/core/lib/support/{env_windows.c → env_windows.cc} +5 -5
- data/src/core/lib/support/{fork.c → fork.cc} +2 -2
- data/src/core/lib/support/{histogram.c → histogram.cc} +25 -26
- data/src/core/lib/support/{host_port.c → host_port.cc} +16 -16
- data/src/core/lib/support/{log.c → log.cc} +8 -8
- data/src/core/lib/support/{log_android.c → log_android.cc} +7 -7
- data/src/core/lib/support/{log_linux.c → log_linux.cc} +8 -8
- data/src/core/lib/support/{log_posix.c → log_posix.cc} +9 -10
- data/src/core/lib/support/{log_windows.c → log_windows.cc} +7 -7
- data/src/core/lib/support/manual_constructor.h +211 -0
- data/src/core/lib/support/memory.h +41 -0
- data/src/core/lib/support/mpscq.cc +114 -0
- data/src/core/lib/support/mpscq.h +45 -7
- data/src/core/lib/support/{murmur_hash.c → murmur_hash.cc} +9 -12
- data/src/core/lib/support/murmur_hash.h +9 -1
- data/src/core/lib/support/spinlock.h +8 -1
- data/src/core/lib/support/{string.c → string.cc} +56 -55
- data/src/core/lib/support/string.h +21 -21
- data/src/core/lib/support/{string_posix.c → string_posix.cc} +5 -4
- data/src/core/lib/support/{string_util_windows.c → string_util_windows.cc} +9 -6
- data/src/core/lib/support/{string_windows.c → string_windows.cc} +3 -2
- data/src/core/lib/support/string_windows.h +8 -0
- data/src/core/lib/support/{subprocess_posix.c → subprocess_posix.cc} +13 -13
- data/src/core/lib/support/{subprocess_windows.c → subprocess_windows.cc} +9 -9
- data/src/core/lib/support/{sync.c → sync.cc} +22 -22
- data/src/core/lib/support/{sync_posix.c → sync_posix.cc} +6 -2
- data/src/core/lib/support/{sync_windows.c → sync_windows.cc} +14 -14
- data/src/core/lib/support/{thd.c → thd.cc} +0 -0
- data/src/core/lib/support/{thd_posix.c → thd_posix.cc} +10 -10
- data/src/core/lib/support/{thd_windows.c → thd_windows.cc} +10 -10
- data/src/core/lib/support/{time.c → time.cc} +0 -0
- data/src/core/lib/support/{time_posix.c → time_posix.cc} +5 -6
- data/src/core/lib/support/{time_precise.c → time_precise.cc} +6 -4
- data/src/core/lib/support/time_precise.h +9 -1
- data/src/core/lib/support/{time_windows.c → time_windows.cc} +2 -3
- data/src/core/lib/support/{tls_pthread.c → tls_pthread.cc} +2 -2
- data/src/core/lib/support/tmpfile.h +1 -1
- data/src/core/lib/support/{tmpfile_msys.c → tmpfile_msys.cc} +2 -2
- data/src/core/lib/support/{tmpfile_posix.c → tmpfile_posix.cc} +7 -7
- data/src/core/lib/support/{tmpfile_windows.c → tmpfile_windows.cc} +2 -2
- data/src/core/lib/support/{wrap_memcpy.c → wrap_memcpy.cc} +4 -2
- data/src/core/lib/surface/{alarm.c → alarm.cc} +32 -31
- data/src/core/lib/surface/alarm_internal.h +10 -2
- data/src/core/lib/surface/{api_trace.c → api_trace.cc} +1 -1
- data/src/core/lib/surface/api_trace.h +2 -2
- data/src/core/lib/surface/{byte_buffer.c → byte_buffer.cc} +13 -13
- data/src/core/lib/surface/{byte_buffer_reader.c → byte_buffer_reader.cc} +9 -9
- data/src/core/lib/surface/{call.c → call.cc} +379 -372
- data/src/core/lib/surface/call.h +37 -38
- data/src/core/lib/surface/{call_details.c → call_details.cc} +0 -0
- data/src/core/lib/surface/{call_log_batch.c → call_log_batch.cc} +13 -11
- data/src/core/lib/surface/call_test_only.h +5 -5
- data/src/core/lib/surface/{channel.c → channel.cc} +94 -95
- data/src/core/lib/surface/channel.h +29 -21
- data/src/core/lib/surface/{channel_init.c → channel_init.cc} +13 -13
- data/src/core/lib/surface/channel_init.h +6 -6
- data/src/core/lib/surface/{channel_ping.c → channel_ping.cc} +12 -12
- data/src/core/lib/surface/{channel_stack_type.c → channel_stack_type.cc} +1 -1
- data/src/core/lib/surface/channel_stack_type.h +9 -1
- data/src/core/lib/surface/{completion_queue.c → completion_queue.cc} +416 -379
- data/src/core/lib/surface/completion_queue.h +29 -29
- data/src/core/lib/surface/{completion_queue_factory.c → completion_queue_factory.cc} +1 -1
- data/src/core/lib/surface/completion_queue_factory.h +8 -0
- data/src/core/lib/surface/{event_string.c → event_string.cc} +9 -9
- data/src/core/lib/surface/event_string.h +9 -1
- data/src/core/lib/surface/{init.c → init.cc} +16 -39
- data/src/core/lib/surface/init.h +8 -0
- data/src/core/lib/surface/{init_secure.c → init_secure.cc} +12 -25
- data/src/core/lib/surface/lame_client.cc +38 -40
- data/src/core/lib/surface/lame_client.h +8 -0
- data/src/core/lib/surface/{metadata_array.c → metadata_array.cc} +0 -0
- data/src/core/lib/surface/{server.c → server.cc} +340 -404
- data/src/core/lib/surface/server.h +22 -14
- data/src/core/lib/surface/{validate_metadata.c → validate_metadata.cc} +10 -9
- data/src/core/lib/surface/validate_metadata.h +10 -2
- data/src/core/lib/surface/{version.c → version.cc} +2 -2
- data/src/core/lib/transport/bdp_estimator.cc +84 -0
- data/src/core/lib/transport/bdp_estimator.h +67 -42
- data/src/core/lib/transport/{byte_stream.c → byte_stream.cc} +51 -51
- data/src/core/lib/transport/byte_stream.h +41 -33
- data/src/core/lib/transport/{connectivity_state.c → connectivity_state.cc} +36 -40
- data/src/core/lib/transport/connectivity_state.h +29 -21
- data/src/core/lib/transport/{error_utils.c → error_utils.cc} +26 -22
- data/src/core/lib/transport/error_utils.h +18 -6
- data/src/core/lib/transport/{metadata.c → metadata.cc} +92 -88
- data/src/core/lib/transport/metadata.h +22 -20
- data/src/core/lib/transport/{metadata_batch.c → metadata_batch.cc} +78 -79
- data/src/core/lib/transport/metadata_batch.h +46 -45
- data/src/core/lib/transport/pid_controller.cc +48 -0
- data/src/core/lib/transport/pid_controller.h +84 -32
- data/src/core/lib/transport/{service_config.c → service_config.cc} +66 -48
- data/src/core/lib/transport/service_config.h +11 -2
- data/src/core/lib/transport/{static_metadata.c → static_metadata.cc} +2 -2
- data/src/core/lib/transport/static_metadata.h +30 -23
- data/src/core/lib/transport/{status_conversion.c → status_conversion.cc} +4 -3
- data/src/core/lib/transport/status_conversion.h +12 -2
- data/src/core/lib/transport/{timeout_encoding.c → timeout_encoding.cc} +28 -61
- data/src/core/lib/transport/timeout_encoding.h +11 -2
- data/src/core/lib/transport/{transport.c → transport.cc} +79 -79
- data/src/core/lib/transport/transport.h +78 -80
- data/src/core/lib/transport/transport_impl.h +27 -19
- data/src/core/lib/transport/{transport_op_string.c → transport_op_string.cc} +32 -30
- data/src/core/plugin_registry/{grpc_plugin_registry.c → grpc_plugin_registry.cc} +34 -38
- data/src/core/tsi/{fake_transport_security.c → fake_transport_security.cc} +141 -132
- data/src/core/tsi/fake_transport_security.h +5 -5
- data/src/core/tsi/{gts_transport_security.c → gts_transport_security.cc} +4 -4
- data/src/core/tsi/gts_transport_security.h +11 -3
- data/src/core/tsi/{ssl_transport_security.c → ssl_transport_security.cc} +309 -300
- data/src/core/tsi/ssl_transport_security.h +25 -25
- data/src/core/tsi/ssl_types.h +8 -0
- data/src/core/tsi/{transport_security.c → transport_security.cc} +94 -87
- data/src/core/tsi/transport_security.h +55 -55
- data/src/core/tsi/{transport_security_adapter.c → transport_security_adapter.cc} +58 -55
- data/src/core/tsi/transport_security_adapter.h +2 -2
- data/src/core/tsi/{transport_security_grpc.c → transport_security_grpc.cc} +21 -21
- data/src/core/tsi/transport_security_grpc.h +19 -19
- data/src/core/tsi/transport_security_interface.h +41 -41
- data/src/ruby/ext/grpc/extconf.rb +4 -2
- data/src/ruby/ext/grpc/rb_byte_buffer.c +5 -5
- data/src/ruby/ext/grpc/rb_byte_buffer.h +2 -2
- data/src/ruby/ext/grpc/rb_call.c +41 -42
- data/src/ruby/ext/grpc/rb_call.h +6 -6
- data/src/ruby/ext/grpc/rb_call_credentials.c +30 -30
- data/src/ruby/ext/grpc/rb_channel.c +87 -87
- data/src/ruby/ext/grpc/rb_channel_credentials.c +23 -23
- data/src/ruby/ext/grpc/rb_completion_queue.c +11 -11
- data/src/ruby/ext/grpc/rb_completion_queue.h +3 -3
- data/src/ruby/ext/grpc/rb_compression_options.c +20 -20
- data/src/ruby/ext/grpc/rb_event_thread.c +14 -14
- data/src/ruby/ext/grpc/rb_event_thread.h +1 -1
- data/src/ruby/ext/grpc/rb_grpc.c +8 -8
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +16 -58
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +242 -306
- data/src/ruby/ext/grpc/rb_server.c +23 -23
- data/src/ruby/ext/grpc/rb_server_credentials.c +13 -13
- data/src/ruby/lib/grpc/generic/rpc_server.rb +25 -12
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/checker.rb +14 -0
- data/src/ruby/spec/pb/health/checker_spec.rb +29 -0
- data/third_party/cares/config_freebsd/ares_config.h +502 -0
- data/third_party/cares/config_openbsd/ares_config.h +502 -0
- metadata +302 -328
- data/src/core/ext/census/aggregation.h +0 -51
- data/src/core/ext/census/base_resources.c +0 -56
- data/src/core/ext/census/base_resources.h +0 -24
- data/src/core/ext/census/census_interface.h +0 -61
- data/src/core/ext/census/census_rpc_stats.h +0 -86
- data/src/core/ext/census/context.c +0 -496
- data/src/core/ext/census/gen/census.pb.c +0 -161
- data/src/core/ext/census/gen/census.pb.h +0 -280
- data/src/core/ext/census/gen/trace_context.pb.c +0 -39
- data/src/core/ext/census/gen/trace_context.pb.h +0 -78
- data/src/core/ext/census/grpc_filter.c +0 -196
- data/src/core/ext/census/grpc_plugin.c +0 -70
- data/src/core/ext/census/initialize.c +0 -51
- data/src/core/ext/census/intrusive_hash_map.c +0 -305
- data/src/core/ext/census/intrusive_hash_map.h +0 -152
- data/src/core/ext/census/intrusive_hash_map_internal.h +0 -48
- data/src/core/ext/census/mlog.c +0 -586
- data/src/core/ext/census/mlog.h +0 -80
- data/src/core/ext/census/operation.c +0 -48
- data/src/core/ext/census/placeholders.c +0 -49
- data/src/core/ext/census/resource.c +0 -303
- data/src/core/ext/census/resource.h +0 -48
- data/src/core/ext/census/rpc_metric_id.h +0 -36
- data/src/core/ext/census/trace_context.c +0 -71
- data/src/core/ext/census/trace_context.h +0 -56
- data/src/core/ext/census/trace_label.h +0 -46
- data/src/core/ext/census/trace_propagation.h +0 -48
- data/src/core/ext/census/trace_status.h +0 -30
- data/src/core/ext/census/trace_string.h +0 -35
- data/src/core/ext/census/tracing.c +0 -55
- data/src/core/ext/census/tracing.h +0 -109
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.c +0 -714
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.c +0 -924
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.c +0 -60
- data/src/core/ext/transport/chttp2/transport/flow_control.c +0 -502
- data/src/core/ext/transport/chttp2/transport/writing.c +0 -534
- data/src/core/lib/debug/trace.c +0 -146
- data/src/core/lib/iomgr/closure.c +0 -219
- data/src/core/lib/iomgr/ev_epollex_linux.c +0 -1461
- data/src/core/lib/iomgr/ev_posix.c +0 -266
- data/src/core/lib/iomgr/exec_ctx.c +0 -113
- data/src/core/lib/iomgr/tcp_uv.c +0 -381
- data/src/core/lib/security/credentials/ssl/ssl_credentials.c +0 -194
- data/src/core/lib/security/transport/security_connector.c +0 -914
- data/src/core/lib/support/backoff.c +0 -72
- data/src/core/lib/support/backoff.h +0 -56
- data/src/core/lib/support/mpscq.c +0 -79
- data/src/core/lib/support/stack_lockfree.c +0 -137
- data/src/core/lib/support/stack_lockfree.h +0 -38
- data/src/core/lib/transport/bdp_estimator.c +0 -110
- data/src/core/lib/transport/pid_controller.c +0 -63
@@ -22,6 +22,10 @@
|
|
22
22
|
#include <grpc/support/port_platform.h>
|
23
23
|
#include "src/core/lib/json/json_common.h"
|
24
24
|
|
25
|
+
#ifdef __cplusplus
|
26
|
+
extern "C" {
|
27
|
+
#endif
|
28
|
+
|
25
29
|
typedef enum {
|
26
30
|
GRPC_JSON_STATE_OBJECT_KEY_BEGIN,
|
27
31
|
GRPC_JSON_STATE_OBJECT_KEY_STRING,
|
@@ -67,27 +71,27 @@ struct grpc_json_reader;
|
|
67
71
|
|
68
72
|
typedef struct grpc_json_reader_vtable {
|
69
73
|
/* Clears your internal string scratchpad. */
|
70
|
-
void (*string_clear)(void
|
74
|
+
void (*string_clear)(void* userdata);
|
71
75
|
/* Adds a char to the string scratchpad. */
|
72
|
-
void (*string_add_char)(void
|
76
|
+
void (*string_add_char)(void* userdata, uint32_t c);
|
73
77
|
/* Adds a utf32 char to the string scratchpad. */
|
74
|
-
void (*string_add_utf32)(void
|
78
|
+
void (*string_add_utf32)(void* userdata, uint32_t c);
|
75
79
|
/* Reads a character from your input. May be utf-8, 16 or 32. */
|
76
|
-
uint32_t (*read_char)(void
|
80
|
+
uint32_t (*read_char)(void* userdata);
|
77
81
|
/* Starts a container of type GRPC_JSON_ARRAY or GRPC_JSON_OBJECT. */
|
78
|
-
void (*container_begins)(void
|
82
|
+
void (*container_begins)(void* userdata, grpc_json_type type);
|
79
83
|
/* Ends the current container. Must return the type of its parent. */
|
80
|
-
grpc_json_type (*container_ends)(void
|
84
|
+
grpc_json_type (*container_ends)(void* userdata);
|
81
85
|
/* Your internal string scratchpad is an object's key. */
|
82
|
-
void (*set_key)(void
|
86
|
+
void (*set_key)(void* userdata);
|
83
87
|
/* Your internal string scratchpad is a string value. */
|
84
|
-
void (*set_string)(void
|
88
|
+
void (*set_string)(void* userdata);
|
85
89
|
/* Your internal string scratchpad is a numerical value. Return 1 if valid. */
|
86
|
-
int (*set_number)(void
|
90
|
+
int (*set_number)(void* userdata);
|
87
91
|
/* Sets the values true, false or null. */
|
88
|
-
void (*set_true)(void
|
89
|
-
void (*set_false)(void
|
90
|
-
void (*set_null)(void
|
92
|
+
void (*set_true)(void* userdata);
|
93
|
+
void (*set_false)(void* userdata);
|
94
|
+
void (*set_null)(void* userdata);
|
91
95
|
} grpc_json_reader_vtable;
|
92
96
|
|
93
97
|
typedef struct grpc_json_reader {
|
@@ -95,8 +99,8 @@ typedef struct grpc_json_reader {
|
|
95
99
|
* The definition is public so you can put it on your stack.
|
96
100
|
*/
|
97
101
|
|
98
|
-
void
|
99
|
-
grpc_json_reader_vtable
|
102
|
+
void* userdata;
|
103
|
+
grpc_json_reader_vtable* vtable;
|
100
104
|
int depth;
|
101
105
|
int in_object;
|
102
106
|
int in_array;
|
@@ -129,17 +133,21 @@ typedef enum {
|
|
129
133
|
* . GRPC_JSON_INTERNAL_ERROR if the parser somehow ended into an invalid
|
130
134
|
* internal state.
|
131
135
|
*/
|
132
|
-
grpc_json_reader_status grpc_json_reader_run(grpc_json_reader
|
136
|
+
grpc_json_reader_status grpc_json_reader_run(grpc_json_reader* reader);
|
133
137
|
|
134
138
|
/* Call this function to initialize the reader structure. */
|
135
|
-
void grpc_json_reader_init(grpc_json_reader
|
136
|
-
grpc_json_reader_vtable
|
139
|
+
void grpc_json_reader_init(grpc_json_reader* reader,
|
140
|
+
grpc_json_reader_vtable* vtable, void* userdata);
|
137
141
|
|
138
142
|
/* You may call this from the read_char callback if you don't know where is the
|
139
143
|
* end of your input stream, and you'd like the json reader to hint you that it
|
140
144
|
* has completed reading its input, so you can return an EOF to it. Note that
|
141
145
|
* there might still be trailing whitespaces after that point.
|
142
146
|
*/
|
143
|
-
int grpc_json_reader_is_complete(grpc_json_reader
|
147
|
+
int grpc_json_reader_is_complete(grpc_json_reader* reader);
|
148
|
+
|
149
|
+
#ifdef __cplusplus
|
150
|
+
}
|
151
|
+
#endif
|
144
152
|
|
145
153
|
#endif /* GRPC_CORE_LIB_JSON_JSON_READER_H */
|
@@ -38,13 +38,13 @@
|
|
38
38
|
* input size, and never expands it.
|
39
39
|
*/
|
40
40
|
typedef struct {
|
41
|
-
grpc_json
|
42
|
-
grpc_json
|
43
|
-
grpc_json
|
44
|
-
uint8_t
|
45
|
-
uint8_t
|
46
|
-
uint8_t
|
47
|
-
uint8_t
|
41
|
+
grpc_json* top;
|
42
|
+
grpc_json* current_container;
|
43
|
+
grpc_json* current_value;
|
44
|
+
uint8_t* input;
|
45
|
+
uint8_t* key;
|
46
|
+
uint8_t* string;
|
47
|
+
uint8_t* string_ptr;
|
48
48
|
size_t remaining_input;
|
49
49
|
} json_reader_userdata;
|
50
50
|
|
@@ -52,7 +52,7 @@ typedef struct {
|
|
52
52
|
* The point is that we allocate that string in chunks of 256 bytes.
|
53
53
|
*/
|
54
54
|
typedef struct {
|
55
|
-
char
|
55
|
+
char* output;
|
56
56
|
size_t free_space;
|
57
57
|
size_t string_len;
|
58
58
|
size_t allocated;
|
@@ -62,35 +62,35 @@ typedef struct {
|
|
62
62
|
* and will enlarge it if necessary. We're only allocating chunks of 256
|
63
63
|
* bytes at a time (or multiples thereof).
|
64
64
|
*/
|
65
|
-
static void json_writer_output_check(void
|
66
|
-
json_writer_userdata
|
65
|
+
static void json_writer_output_check(void* userdata, size_t needed) {
|
66
|
+
json_writer_userdata* state = (json_writer_userdata*)userdata;
|
67
67
|
if (state->free_space >= needed) return;
|
68
68
|
needed -= state->free_space;
|
69
69
|
/* Round up by 256 bytes. */
|
70
70
|
needed = (needed + 0xff) & ~0xffU;
|
71
|
-
state->output = (char
|
71
|
+
state->output = (char*)gpr_realloc(state->output, state->allocated + needed);
|
72
72
|
state->free_space += needed;
|
73
73
|
state->allocated += needed;
|
74
74
|
}
|
75
75
|
|
76
76
|
/* These are needed by the writer's implementation. */
|
77
|
-
static void json_writer_output_char(void
|
78
|
-
json_writer_userdata
|
77
|
+
static void json_writer_output_char(void* userdata, char c) {
|
78
|
+
json_writer_userdata* state = (json_writer_userdata*)userdata;
|
79
79
|
json_writer_output_check(userdata, 1);
|
80
80
|
state->output[state->string_len++] = c;
|
81
81
|
state->free_space--;
|
82
82
|
}
|
83
83
|
|
84
|
-
static void json_writer_output_string_with_len(void
|
84
|
+
static void json_writer_output_string_with_len(void* userdata, const char* str,
|
85
85
|
size_t len) {
|
86
|
-
json_writer_userdata
|
86
|
+
json_writer_userdata* state = (json_writer_userdata*)userdata;
|
87
87
|
json_writer_output_check(userdata, len);
|
88
88
|
memcpy(state->output + state->string_len, str, len);
|
89
89
|
state->string_len += len;
|
90
90
|
state->free_space -= len;
|
91
91
|
}
|
92
92
|
|
93
|
-
static void json_writer_output_string(void
|
93
|
+
static void json_writer_output_string(void* userdata, const char* str) {
|
94
94
|
size_t len = strlen(str);
|
95
95
|
json_writer_output_string_with_len(userdata, str, len);
|
96
96
|
}
|
@@ -98,8 +98,8 @@ static void json_writer_output_string(void *userdata, const char *str) {
|
|
98
98
|
/* The reader asks us to clear our scratchpad. In our case, we'll simply mark
|
99
99
|
* the end of the current string, and advance our output pointer.
|
100
100
|
*/
|
101
|
-
static void json_reader_string_clear(void
|
102
|
-
json_reader_userdata
|
101
|
+
static void json_reader_string_clear(void* userdata) {
|
102
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
103
103
|
if (state->string) {
|
104
104
|
GPR_ASSERT(state->string_ptr < state->input);
|
105
105
|
*state->string_ptr++ = 0;
|
@@ -107,8 +107,8 @@ static void json_reader_string_clear(void *userdata) {
|
|
107
107
|
state->string = state->string_ptr;
|
108
108
|
}
|
109
109
|
|
110
|
-
static void json_reader_string_add_char(void
|
111
|
-
json_reader_userdata
|
110
|
+
static void json_reader_string_add_char(void* userdata, uint32_t c) {
|
111
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
112
112
|
GPR_ASSERT(state->string_ptr < state->input);
|
113
113
|
GPR_ASSERT(c <= 0xff);
|
114
114
|
*state->string_ptr++ = (uint8_t)c;
|
@@ -117,7 +117,7 @@ static void json_reader_string_add_char(void *userdata, uint32_t c) {
|
|
117
117
|
/* We are converting a UTF-32 character into UTF-8 here,
|
118
118
|
* as described by RFC3629.
|
119
119
|
*/
|
120
|
-
static void json_reader_string_add_utf32(void
|
120
|
+
static void json_reader_string_add_utf32(void* userdata, uint32_t c) {
|
121
121
|
if (c <= 0x7f) {
|
122
122
|
json_reader_string_add_char(userdata, c);
|
123
123
|
} else if (c <= 0x7ff) {
|
@@ -147,9 +147,9 @@ static void json_reader_string_add_utf32(void *userdata, uint32_t c) {
|
|
147
147
|
/* We consider that the input may be a zero-terminated string. So we
|
148
148
|
* can end up hitting eof before the end of the alleged string length.
|
149
149
|
*/
|
150
|
-
static uint32_t json_reader_read_char(void
|
150
|
+
static uint32_t json_reader_read_char(void* userdata) {
|
151
151
|
uint32_t r;
|
152
|
-
json_reader_userdata
|
152
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
153
153
|
|
154
154
|
if (state->remaining_input == 0) return GRPC_JSON_READ_CHAR_EOF;
|
155
155
|
|
@@ -167,9 +167,9 @@ static uint32_t json_reader_read_char(void *userdata) {
|
|
167
167
|
/* Helper function to create a new grpc_json object and link it into
|
168
168
|
* our tree-in-progress inside our opaque structure.
|
169
169
|
*/
|
170
|
-
static grpc_json
|
171
|
-
json_reader_userdata
|
172
|
-
grpc_json
|
170
|
+
static grpc_json* json_create_and_link(void* userdata, grpc_json_type type) {
|
171
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
172
|
+
grpc_json* json = grpc_json_create(type);
|
173
173
|
|
174
174
|
json->parent = state->current_container;
|
175
175
|
json->prev = state->current_value;
|
@@ -183,7 +183,7 @@ static grpc_json *json_create_and_link(void *userdata, grpc_json_type type) {
|
|
183
183
|
json->parent->child = json;
|
184
184
|
}
|
185
185
|
if (json->parent->type == GRPC_JSON_OBJECT) {
|
186
|
-
json->key = (char
|
186
|
+
json->key = (char*)state->key;
|
187
187
|
}
|
188
188
|
}
|
189
189
|
if (!state->top) {
|
@@ -193,15 +193,15 @@ static grpc_json *json_create_and_link(void *userdata, grpc_json_type type) {
|
|
193
193
|
return json;
|
194
194
|
}
|
195
195
|
|
196
|
-
static void json_reader_container_begins(void
|
197
|
-
json_reader_userdata
|
198
|
-
grpc_json
|
196
|
+
static void json_reader_container_begins(void* userdata, grpc_json_type type) {
|
197
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
198
|
+
grpc_json* container;
|
199
199
|
|
200
200
|
GPR_ASSERT(type == GRPC_JSON_ARRAY || type == GRPC_JSON_OBJECT);
|
201
201
|
|
202
202
|
container = json_create_and_link(userdata, type);
|
203
203
|
state->current_container = container;
|
204
|
-
state->current_value =
|
204
|
+
state->current_value = nullptr;
|
205
205
|
}
|
206
206
|
|
207
207
|
/* It's important to remember that the reader is mostly stateless, so it
|
@@ -213,9 +213,9 @@ static void json_reader_container_begins(void *userdata, grpc_json_type type) {
|
|
213
213
|
* Also note that if we're at the top of the tree, and the last container
|
214
214
|
* ends, we have to return GRPC_JSON_TOP_LEVEL.
|
215
215
|
*/
|
216
|
-
static grpc_json_type json_reader_container_ends(void
|
216
|
+
static grpc_json_type json_reader_container_ends(void* userdata) {
|
217
217
|
grpc_json_type container_type = GRPC_JSON_TOP_LEVEL;
|
218
|
-
json_reader_userdata
|
218
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
219
219
|
|
220
220
|
GPR_ASSERT(state->current_container);
|
221
221
|
|
@@ -235,36 +235,36 @@ static grpc_json_type json_reader_container_ends(void *userdata) {
|
|
235
235
|
* Note that in the set_number case, we're not going to try interpreting it.
|
236
236
|
* We'll keep it as a string, and leave it to the caller to evaluate it.
|
237
237
|
*/
|
238
|
-
static void json_reader_set_key(void
|
239
|
-
json_reader_userdata
|
238
|
+
static void json_reader_set_key(void* userdata) {
|
239
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
240
240
|
state->key = state->string;
|
241
241
|
}
|
242
242
|
|
243
|
-
static void json_reader_set_string(void
|
244
|
-
json_reader_userdata
|
245
|
-
grpc_json
|
246
|
-
json->value = (char
|
243
|
+
static void json_reader_set_string(void* userdata) {
|
244
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
245
|
+
grpc_json* json = json_create_and_link(userdata, GRPC_JSON_STRING);
|
246
|
+
json->value = (char*)state->string;
|
247
247
|
}
|
248
248
|
|
249
|
-
static int json_reader_set_number(void
|
250
|
-
json_reader_userdata
|
251
|
-
grpc_json
|
252
|
-
json->value = (char
|
249
|
+
static int json_reader_set_number(void* userdata) {
|
250
|
+
json_reader_userdata* state = (json_reader_userdata*)userdata;
|
251
|
+
grpc_json* json = json_create_and_link(userdata, GRPC_JSON_NUMBER);
|
252
|
+
json->value = (char*)state->string;
|
253
253
|
return 1;
|
254
254
|
}
|
255
255
|
|
256
256
|
/* The object types true, false and null are self-sufficient, and don't need
|
257
257
|
* any more information beside their type.
|
258
258
|
*/
|
259
|
-
static void json_reader_set_true(void
|
259
|
+
static void json_reader_set_true(void* userdata) {
|
260
260
|
json_create_and_link(userdata, GRPC_JSON_TRUE);
|
261
261
|
}
|
262
262
|
|
263
|
-
static void json_reader_set_false(void
|
263
|
+
static void json_reader_set_false(void* userdata) {
|
264
264
|
json_create_and_link(userdata, GRPC_JSON_FALSE);
|
265
265
|
}
|
266
266
|
|
267
|
-
static void json_reader_set_null(void
|
267
|
+
static void json_reader_set_null(void* userdata) {
|
268
268
|
json_create_and_link(userdata, GRPC_JSON_NULL);
|
269
269
|
}
|
270
270
|
|
@@ -277,17 +277,17 @@ static grpc_json_reader_vtable reader_vtable = {
|
|
277
277
|
json_reader_set_false, json_reader_set_null};
|
278
278
|
|
279
279
|
/* And finally, let's define our public API. */
|
280
|
-
grpc_json
|
280
|
+
grpc_json* grpc_json_parse_string_with_len(char* input, size_t size) {
|
281
281
|
grpc_json_reader reader;
|
282
282
|
json_reader_userdata state;
|
283
|
-
grpc_json
|
283
|
+
grpc_json* json = nullptr;
|
284
284
|
grpc_json_reader_status status;
|
285
285
|
|
286
|
-
if (!input) return
|
286
|
+
if (!input) return nullptr;
|
287
287
|
|
288
|
-
state.top = state.current_container = state.current_value =
|
289
|
-
state.string = state.key =
|
290
|
-
state.string_ptr = state.input = (uint8_t
|
288
|
+
state.top = state.current_container = state.current_value = nullptr;
|
289
|
+
state.string = state.key = nullptr;
|
290
|
+
state.string_ptr = state.input = (uint8_t*)input;
|
291
291
|
state.remaining_input = size;
|
292
292
|
grpc_json_reader_init(&reader, &reader_vtable, &state);
|
293
293
|
|
@@ -296,7 +296,7 @@ grpc_json *grpc_json_parse_string_with_len(char *input, size_t size) {
|
|
296
296
|
|
297
297
|
if ((status != GRPC_JSON_DONE) && json) {
|
298
298
|
grpc_json_destroy(json);
|
299
|
-
json =
|
299
|
+
json = nullptr;
|
300
300
|
}
|
301
301
|
|
302
302
|
return json;
|
@@ -304,11 +304,11 @@ grpc_json *grpc_json_parse_string_with_len(char *input, size_t size) {
|
|
304
304
|
|
305
305
|
#define UNBOUND_JSON_STRING_LENGTH 0x7fffffff
|
306
306
|
|
307
|
-
grpc_json
|
307
|
+
grpc_json* grpc_json_parse_string(char* input) {
|
308
308
|
return grpc_json_parse_string_with_len(input, UNBOUND_JSON_STRING_LENGTH);
|
309
309
|
}
|
310
310
|
|
311
|
-
static void json_dump_recursive(grpc_json_writer
|
311
|
+
static void json_dump_recursive(grpc_json_writer* writer, grpc_json* json,
|
312
312
|
int in_object) {
|
313
313
|
while (json) {
|
314
314
|
if (in_object) grpc_json_writer_object_key(writer, json->key);
|
@@ -348,11 +348,11 @@ static grpc_json_writer_vtable writer_vtable = {
|
|
348
348
|
json_writer_output_char, json_writer_output_string,
|
349
349
|
json_writer_output_string_with_len};
|
350
350
|
|
351
|
-
char
|
351
|
+
char* grpc_json_dump_to_string(grpc_json* json, int indent) {
|
352
352
|
grpc_json_writer writer;
|
353
353
|
json_writer_userdata state;
|
354
354
|
|
355
|
-
state.output =
|
355
|
+
state.output = nullptr;
|
356
356
|
state.free_space = state.string_len = state.allocated = 0;
|
357
357
|
grpc_json_writer_init(&writer, indent, &writer_vtable, &state);
|
358
358
|
|
@@ -22,22 +22,22 @@
|
|
22
22
|
|
23
23
|
#include "src/core/lib/json/json_writer.h"
|
24
24
|
|
25
|
-
static void json_writer_output_char(grpc_json_writer
|
25
|
+
static void json_writer_output_char(grpc_json_writer* writer, char c) {
|
26
26
|
writer->vtable->output_char(writer->userdata, c);
|
27
27
|
}
|
28
28
|
|
29
|
-
static void json_writer_output_string(grpc_json_writer
|
30
|
-
const char
|
29
|
+
static void json_writer_output_string(grpc_json_writer* writer,
|
30
|
+
const char* str) {
|
31
31
|
writer->vtable->output_string(writer->userdata, str);
|
32
32
|
}
|
33
33
|
|
34
|
-
static void json_writer_output_string_with_len(grpc_json_writer
|
35
|
-
const char
|
34
|
+
static void json_writer_output_string_with_len(grpc_json_writer* writer,
|
35
|
+
const char* str, size_t len) {
|
36
36
|
writer->vtable->output_string_with_len(writer->userdata, str, len);
|
37
37
|
}
|
38
38
|
|
39
|
-
void grpc_json_writer_init(grpc_json_writer
|
40
|
-
grpc_json_writer_vtable
|
39
|
+
void grpc_json_writer_init(grpc_json_writer* writer, int indent,
|
40
|
+
grpc_json_writer_vtable* vtable, void* userdata) {
|
41
41
|
memset(writer, 0, sizeof(*writer));
|
42
42
|
writer->container_empty = 1;
|
43
43
|
writer->indent = indent;
|
@@ -45,7 +45,7 @@ void grpc_json_writer_init(grpc_json_writer *writer, int indent,
|
|
45
45
|
writer->userdata = userdata;
|
46
46
|
}
|
47
47
|
|
48
|
-
static void json_writer_output_indent(grpc_json_writer
|
48
|
+
static void json_writer_output_indent(grpc_json_writer* writer) {
|
49
49
|
static const char spacesstr[] =
|
50
50
|
" "
|
51
51
|
" "
|
@@ -73,7 +73,7 @@ static void json_writer_output_indent(grpc_json_writer *writer) {
|
|
73
73
|
writer, spacesstr + sizeof(spacesstr) - 1 - spaces, spaces);
|
74
74
|
}
|
75
75
|
|
76
|
-
static void json_writer_value_end(grpc_json_writer
|
76
|
+
static void json_writer_value_end(grpc_json_writer* writer) {
|
77
77
|
if (writer->container_empty) {
|
78
78
|
writer->container_empty = 0;
|
79
79
|
if ((writer->indent == 0) || (writer->depth == 0)) return;
|
@@ -85,7 +85,7 @@ static void json_writer_value_end(grpc_json_writer *writer) {
|
|
85
85
|
}
|
86
86
|
}
|
87
87
|
|
88
|
-
static void json_writer_escape_utf16(grpc_json_writer
|
88
|
+
static void json_writer_escape_utf16(grpc_json_writer* writer, uint16_t utf16) {
|
89
89
|
static const char hex[] = "0123456789abcdef";
|
90
90
|
|
91
91
|
json_writer_output_string_with_len(writer, "\\u", 2);
|
@@ -95,8 +95,8 @@ static void json_writer_escape_utf16(grpc_json_writer *writer, uint16_t utf16) {
|
|
95
95
|
json_writer_output_char(writer, hex[(utf16)&0x0f]);
|
96
96
|
}
|
97
97
|
|
98
|
-
static void json_writer_escape_string(grpc_json_writer
|
99
|
-
const char
|
98
|
+
static void json_writer_escape_string(grpc_json_writer* writer,
|
99
|
+
const char* string) {
|
100
100
|
json_writer_output_char(writer, '"');
|
101
101
|
|
102
102
|
for (;;) {
|
@@ -190,7 +190,7 @@ static void json_writer_escape_string(grpc_json_writer *writer,
|
|
190
190
|
json_writer_output_char(writer, '"');
|
191
191
|
}
|
192
192
|
|
193
|
-
void grpc_json_writer_container_begins(grpc_json_writer
|
193
|
+
void grpc_json_writer_container_begins(grpc_json_writer* writer,
|
194
194
|
grpc_json_type type) {
|
195
195
|
if (!writer->got_key) json_writer_value_end(writer);
|
196
196
|
json_writer_output_indent(writer);
|
@@ -200,7 +200,7 @@ void grpc_json_writer_container_begins(grpc_json_writer *writer,
|
|
200
200
|
writer->depth++;
|
201
201
|
}
|
202
202
|
|
203
|
-
void grpc_json_writer_container_ends(grpc_json_writer
|
203
|
+
void grpc_json_writer_container_ends(grpc_json_writer* writer,
|
204
204
|
grpc_json_type type) {
|
205
205
|
if (writer->indent && !writer->container_empty)
|
206
206
|
json_writer_output_char(writer, '\n');
|
@@ -211,7 +211,7 @@ void grpc_json_writer_container_ends(grpc_json_writer *writer,
|
|
211
211
|
writer->got_key = 0;
|
212
212
|
}
|
213
213
|
|
214
|
-
void grpc_json_writer_object_key(grpc_json_writer
|
214
|
+
void grpc_json_writer_object_key(grpc_json_writer* writer, const char* string) {
|
215
215
|
json_writer_value_end(writer);
|
216
216
|
json_writer_output_indent(writer);
|
217
217
|
json_writer_escape_string(writer, string);
|
@@ -219,23 +219,23 @@ void grpc_json_writer_object_key(grpc_json_writer *writer, const char *string) {
|
|
219
219
|
writer->got_key = 1;
|
220
220
|
}
|
221
221
|
|
222
|
-
void grpc_json_writer_value_raw(grpc_json_writer
|
222
|
+
void grpc_json_writer_value_raw(grpc_json_writer* writer, const char* string) {
|
223
223
|
if (!writer->got_key) json_writer_value_end(writer);
|
224
224
|
json_writer_output_indent(writer);
|
225
225
|
json_writer_output_string(writer, string);
|
226
226
|
writer->got_key = 0;
|
227
227
|
}
|
228
228
|
|
229
|
-
void grpc_json_writer_value_raw_with_len(grpc_json_writer
|
230
|
-
const char
|
229
|
+
void grpc_json_writer_value_raw_with_len(grpc_json_writer* writer,
|
230
|
+
const char* string, size_t len) {
|
231
231
|
if (!writer->got_key) json_writer_value_end(writer);
|
232
232
|
json_writer_output_indent(writer);
|
233
233
|
json_writer_output_string_with_len(writer, string, len);
|
234
234
|
writer->got_key = 0;
|
235
235
|
}
|
236
236
|
|
237
|
-
void grpc_json_writer_value_string(grpc_json_writer
|
238
|
-
const char
|
237
|
+
void grpc_json_writer_value_string(grpc_json_writer* writer,
|
238
|
+
const char* string) {
|
239
239
|
if (!writer->got_key) json_writer_value_end(writer);
|
240
240
|
json_writer_output_indent(writer);
|
241
241
|
json_writer_escape_string(writer, string);
|