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.

Files changed (616) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +2106 -2116
  3. data/include/grpc/census.h +1 -432
  4. data/include/grpc/compression.h +9 -9
  5. data/include/grpc/grpc.h +115 -98
  6. data/include/grpc/grpc_cronet.h +3 -3
  7. data/include/grpc/grpc_posix.h +4 -4
  8. data/include/grpc/grpc_security.h +160 -88
  9. data/include/grpc/grpc_security_constants.h +7 -0
  10. data/include/grpc/impl/codegen/atm.h +9 -1
  11. data/include/grpc/impl/codegen/atm_gcc_atomic.h +13 -4
  12. data/include/grpc/impl/codegen/atm_gcc_sync.h +6 -5
  13. data/include/grpc/impl/codegen/atm_windows.h +23 -22
  14. data/include/grpc/impl/codegen/byte_buffer.h +14 -14
  15. data/include/grpc/impl/codegen/byte_buffer_reader.h +2 -2
  16. data/include/grpc/impl/codegen/connectivity_state.h +0 -2
  17. data/include/grpc/impl/codegen/grpc_types.h +32 -28
  18. data/include/grpc/impl/codegen/port_platform.h +48 -0
  19. data/include/grpc/impl/codegen/slice.h +10 -10
  20. data/include/grpc/impl/codegen/sync_generic.h +9 -3
  21. data/include/grpc/slice.h +16 -17
  22. data/include/grpc/slice_buffer.h +22 -22
  23. data/include/grpc/support/alloc.h +11 -11
  24. data/include/grpc/support/avl.h +28 -20
  25. data/include/grpc/support/cmdline.h +13 -13
  26. data/include/grpc/support/histogram.h +17 -17
  27. data/include/grpc/support/host_port.h +2 -2
  28. data/include/grpc/support/log.h +9 -9
  29. data/include/grpc/support/log_windows.h +1 -1
  30. data/include/grpc/support/string_util.h +2 -2
  31. data/include/grpc/support/subprocess.h +5 -5
  32. data/include/grpc/support/sync.h +43 -27
  33. data/include/grpc/support/thd.h +6 -6
  34. data/include/grpc/support/tls_gcc.h +1 -1
  35. data/include/grpc/support/tls_pthread.h +1 -1
  36. data/src/core/ext/census/{grpc_context.c → grpc_context.cc} +5 -8
  37. data/src/core/ext/filters/client_channel/backup_poller.cc +165 -0
  38. data/src/core/ext/{census/grpc_filter.h → filters/client_channel/backup_poller.h} +12 -7
  39. data/src/core/ext/filters/client_channel/{channel_connectivity.c → channel_connectivity.cc} +45 -42
  40. data/src/core/ext/filters/client_channel/{client_channel.c → client_channel.cc} +452 -417
  41. data/src/core/ext/filters/client_channel/client_channel.h +16 -8
  42. data/src/core/ext/filters/client_channel/{client_channel_factory.c → client_channel_factory.cc} +0 -0
  43. data/src/core/ext/filters/client_channel/client_channel_factory.h +29 -21
  44. data/src/core/ext/filters/client_channel/{client_channel_plugin.c → client_channel_plugin.cc} +15 -19
  45. data/src/core/ext/filters/client_channel/{connector.c → connector.cc} +0 -0
  46. data/src/core/ext/filters/client_channel/connector.h +29 -21
  47. data/src/core/ext/filters/client_channel/{http_connect_handshaker.c → http_connect_handshaker.cc} +10 -10
  48. data/src/core/ext/filters/client_channel/http_connect_handshaker.h +8 -0
  49. data/src/core/ext/filters/client_channel/{http_proxy.c → http_proxy.cc} +14 -14
  50. data/src/core/ext/filters/client_channel/http_proxy.h +8 -0
  51. data/src/core/ext/filters/client_channel/{lb_policy.c → lb_policy.cc} +47 -48
  52. data/src/core/ext/filters/client_channel/lb_policy.h +76 -70
  53. data/src/core/ext/filters/client_channel/lb_policy/grpclb/{client_load_reporting_filter.c → client_load_reporting_filter.cc} +28 -29
  54. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +9 -1
  55. data/src/core/ext/filters/client_channel/lb_policy/grpclb/{grpclb.c → grpclb.cc} +554 -563
  56. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.h +9 -1
  57. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel.h +17 -9
  58. data/src/core/ext/filters/client_channel/lb_policy/grpclb/{grpclb_channel_secure.c → grpclb_channel_secure.cc} +17 -17
  59. data/src/core/ext/filters/client_channel/lb_policy/grpclb/{grpclb_client_stats.c → grpclb_client_stats.cc} +3 -3
  60. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +9 -1
  61. data/src/core/ext/filters/client_channel/lb_policy/grpclb/{load_balancer_api.c → load_balancer_api.cc} +64 -67
  62. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +20 -21
  63. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +599 -0
  64. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +695 -0
  65. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.cc +270 -0
  66. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +153 -0
  67. data/src/core/ext/filters/client_channel/{lb_policy_factory.c → lb_policy_factory.cc} +10 -10
  68. data/src/core/ext/filters/client_channel/lb_policy_factory.h +48 -40
  69. data/src/core/ext/filters/client_channel/{lb_policy_registry.c → lb_policy_registry.cc} +9 -9
  70. data/src/core/ext/filters/client_channel/lb_policy_registry.h +11 -3
  71. data/src/core/ext/filters/client_channel/{parse_address.c → parse_address.cc} +24 -24
  72. data/src/core/ext/filters/client_channel/parse_address.h +14 -6
  73. data/src/core/ext/filters/client_channel/{proxy_mapper.c → proxy_mapper.cc} +0 -0
  74. data/src/core/ext/filters/client_channel/proxy_mapper.h +8 -0
  75. data/src/core/ext/filters/client_channel/{proxy_mapper_registry.c → proxy_mapper_registry.cc} +0 -0
  76. data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +8 -0
  77. data/src/core/ext/filters/client_channel/{resolver.c → resolver.cc} +21 -23
  78. data/src/core/ext/filters/client_channel/resolver.h +33 -27
  79. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/{dns_resolver_ares.c → dns_resolver_ares.cc} +133 -133
  80. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +18 -9
  81. 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
  82. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/{grpc_ares_wrapper.c → grpc_ares_wrapper.cc} +118 -115
  83. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +23 -15
  84. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.cc +60 -0
  85. data/src/core/ext/filters/client_channel/resolver/dns/native/{dns_resolver.c → dns_resolver.cc} +100 -94
  86. data/src/core/ext/filters/client_channel/resolver/fake/{fake_resolver.c → fake_resolver.cc} +14 -14
  87. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +9 -1
  88. data/src/core/ext/filters/client_channel/resolver/sockaddr/{sockaddr_resolver.c → sockaddr_resolver.cc} +60 -60
  89. data/src/core/ext/filters/client_channel/{resolver_factory.c → resolver_factory.cc} +2 -2
  90. data/src/core/ext/filters/client_channel/resolver_factory.h +27 -19
  91. data/src/core/ext/filters/client_channel/{resolver_registry.c → resolver_registry.cc} +35 -35
  92. data/src/core/ext/filters/client_channel/resolver_registry.h +18 -10
  93. data/src/core/ext/filters/client_channel/{retry_throttle.c → retry_throttle.cc} +10 -10
  94. data/src/core/ext/filters/client_channel/retry_throttle.h +8 -0
  95. data/src/core/ext/filters/client_channel/{subchannel.c → subchannel.cc} +210 -213
  96. data/src/core/ext/filters/client_channel/subchannel.h +68 -60
  97. data/src/core/ext/filters/client_channel/{subchannel_index.c → subchannel_index.cc} +52 -52
  98. data/src/core/ext/filters/client_channel/subchannel_index.h +22 -14
  99. data/src/core/ext/filters/client_channel/{uri_parser.c → uri_parser.cc} +29 -27
  100. data/src/core/ext/filters/client_channel/uri_parser.h +18 -10
  101. data/src/core/ext/filters/deadline/{deadline_filter.c → deadline_filter.cc} +12 -15
  102. data/src/core/ext/filters/deadline/deadline_filter.h +11 -2
  103. data/src/core/ext/filters/http/client/{http_client_filter.c → http_client_filter.cc} +83 -83
  104. data/src/core/ext/filters/http/client/http_client_filter.h +8 -0
  105. data/src/core/ext/filters/http/{http_filters_plugin.c → http_filters_plugin.cc} +20 -21
  106. data/src/core/ext/filters/http/message_compress/{message_compress_filter.c → message_compress_filter.cc} +84 -83
  107. data/src/core/ext/filters/http/message_compress/message_compress_filter.h +9 -1
  108. data/src/core/ext/filters/http/server/{http_server_filter.c → http_server_filter.cc} +80 -78
  109. data/src/core/ext/filters/http/server/http_server_filter.h +8 -0
  110. data/src/core/ext/filters/load_reporting/{server_load_reporting_filter.c → server_load_reporting_filter.cc} +29 -29
  111. data/src/core/ext/filters/load_reporting/server_load_reporting_filter.h +9 -1
  112. data/src/core/ext/filters/load_reporting/{server_load_reporting_plugin.c → server_load_reporting_plugin.cc} +11 -11
  113. data/src/core/ext/filters/load_reporting/server_load_reporting_plugin.h +13 -5
  114. data/src/core/ext/filters/max_age/{max_age_filter.c → max_age_filter.cc} +46 -56
  115. data/src/core/ext/filters/max_age/max_age_filter.h +8 -0
  116. data/src/core/ext/filters/message_size/{message_size_filter.c → message_size_filter.cc} +62 -40
  117. data/src/core/ext/filters/message_size/message_size_filter.h +8 -0
  118. data/src/core/ext/filters/workarounds/{workaround_cronet_compression_filter.c → workaround_cronet_compression_filter.cc} +11 -11
  119. data/src/core/ext/filters/workarounds/workaround_cronet_compression_filter.h +8 -0
  120. data/src/core/ext/filters/workarounds/{workaround_utils.c → workaround_utils.cc} +7 -7
  121. data/src/core/ext/filters/workarounds/workaround_utils.h +9 -1
  122. data/src/core/ext/transport/chttp2/alpn/{alpn.c → alpn.cc} +3 -3
  123. data/src/core/ext/transport/chttp2/alpn/alpn.h +10 -2
  124. data/src/core/ext/transport/chttp2/client/{chttp2_connector.c → chttp2_connector.cc} +49 -45
  125. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +8 -0
  126. data/src/core/ext/transport/chttp2/client/insecure/{channel_create.c → channel_create.cc} +28 -27
  127. data/src/core/ext/transport/chttp2/client/insecure/{channel_create_posix.c → channel_create_posix.cc} +14 -13
  128. data/src/core/ext/transport/chttp2/client/secure/{secure_channel_create.c → secure_channel_create.cc} +68 -66
  129. data/src/core/ext/transport/chttp2/server/{chttp2_server.c → chttp2_server.cc} +76 -77
  130. data/src/core/ext/transport/chttp2/server/chttp2_server.h +11 -3
  131. data/src/core/ext/transport/chttp2/server/insecure/{server_chttp2.c → server_chttp2.cc} +3 -3
  132. data/src/core/ext/transport/chttp2/server/insecure/{server_chttp2_posix.c → server_chttp2_posix.cc} +13 -12
  133. data/src/core/ext/transport/chttp2/server/secure/{server_secure_chttp2.c → server_secure_chttp2.cc} +12 -10
  134. data/src/core/ext/transport/chttp2/transport/{bin_decoder.c → bin_decoder.cc} +7 -7
  135. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +15 -7
  136. data/src/core/ext/transport/chttp2/transport/{bin_encoder.c → bin_encoder.cc} +11 -11
  137. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +8 -0
  138. data/src/core/ext/transport/chttp2/transport/{chttp2_plugin.c → chttp2_plugin.cc} +2 -9
  139. data/src/core/ext/transport/chttp2/transport/{chttp2_transport.c → chttp2_transport.cc} +778 -778
  140. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +14 -10
  141. data/src/core/ext/transport/chttp2/transport/flow_control.cc +385 -0
  142. data/src/core/ext/transport/chttp2/transport/flow_control.h +337 -0
  143. data/src/core/ext/transport/chttp2/transport/frame.h +8 -0
  144. data/src/core/ext/transport/chttp2/transport/{frame_data.c → frame_data.cc} +34 -34
  145. data/src/core/ext/transport/chttp2/transport/frame_data.h +25 -17
  146. data/src/core/ext/transport/chttp2/transport/{frame_goaway.c → frame_goaway.cc} +18 -18
  147. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +18 -10
  148. data/src/core/ext/transport/chttp2/transport/{frame_ping.c → frame_ping.cc} +18 -19
  149. data/src/core/ext/transport/chttp2/transport/frame_ping.h +12 -4
  150. data/src/core/ext/transport/chttp2/transport/{frame_rst_stream.c → frame_rst_stream.cc} +16 -16
  151. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +16 -8
  152. data/src/core/ext/transport/chttp2/transport/{frame_settings.c → frame_settings.cc} +23 -24
  153. data/src/core/ext/transport/chttp2/transport/frame_settings.h +17 -9
  154. data/src/core/ext/transport/chttp2/transport/{frame_window_update.c → frame_window_update.cc} +22 -24
  155. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +14 -6
  156. data/src/core/ext/transport/chttp2/transport/{hpack_encoder.c → hpack_encoder.cc} +206 -161
  157. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +23 -13
  158. data/src/core/ext/transport/chttp2/transport/{hpack_parser.c → hpack_parser.cc} +340 -334
  159. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +30 -22
  160. data/src/core/ext/transport/chttp2/transport/{hpack_table.c → hpack_table.cc} +25 -25
  161. data/src/core/ext/transport/chttp2/transport/hpack_table.h +19 -11
  162. data/src/core/ext/transport/chttp2/transport/{http2_settings.c → http2_settings.cc} +1 -1
  163. data/src/core/ext/transport/chttp2/transport/http2_settings.h +10 -2
  164. data/src/core/ext/transport/chttp2/transport/{huffsyms.c → huffsyms.cc} +0 -0
  165. data/src/core/ext/transport/chttp2/transport/huffsyms.h +8 -0
  166. data/src/core/ext/transport/chttp2/transport/{incoming_metadata.c → incoming_metadata.cc} +14 -13
  167. data/src/core/ext/transport/chttp2/transport/incoming_metadata.h +18 -10
  168. data/src/core/ext/transport/chttp2/transport/internal.h +214 -340
  169. data/src/core/ext/transport/chttp2/transport/{parsing.c → parsing.cc} +152 -141
  170. data/src/core/ext/transport/chttp2/transport/{stream_lists.c → stream_lists.cc} +53 -53
  171. data/src/core/ext/transport/chttp2/transport/{stream_map.c → stream_map.cc} +35 -34
  172. data/src/core/ext/transport/chttp2/transport/stream_map.h +22 -14
  173. data/src/core/ext/transport/chttp2/transport/{varint.c → varint.cc} +0 -0
  174. data/src/core/ext/transport/chttp2/transport/varint.h +8 -0
  175. data/src/core/ext/transport/chttp2/transport/writing.cc +636 -0
  176. data/src/core/ext/transport/inproc/{inproc_plugin.c → inproc_plugin.cc} +5 -6
  177. data/src/core/ext/transport/inproc/{inproc_transport.c → inproc_transport.cc} +479 -544
  178. data/src/core/ext/transport/inproc/inproc_transport.h +4 -4
  179. data/src/core/lib/backoff/backoff.cc +80 -0
  180. data/src/core/lib/backoff/backoff.h +83 -0
  181. data/src/core/lib/channel/{channel_args.c → channel_args.cc} +92 -92
  182. data/src/core/lib/channel/channel_args.h +45 -37
  183. data/src/core/lib/channel/{channel_stack.c → channel_stack.cc} +67 -68
  184. data/src/core/lib/channel/channel_stack.h +76 -75
  185. data/src/core/lib/channel/{channel_stack_builder.c → channel_stack_builder.cc} +91 -91
  186. data/src/core/lib/channel/channel_stack_builder.h +45 -45
  187. data/src/core/lib/channel/{connected_channel.c → connected_channel.cc} +70 -70
  188. data/src/core/lib/channel/connected_channel.h +12 -4
  189. data/src/core/lib/channel/context.h +2 -2
  190. data/src/core/lib/channel/{handshaker.c → handshaker.cc} +7 -9
  191. data/src/core/lib/channel/handshaker.h +9 -1
  192. data/src/core/lib/channel/{handshaker_factory.c → handshaker_factory.cc} +7 -7
  193. data/src/core/lib/channel/handshaker_factory.h +18 -10
  194. data/src/core/lib/channel/{handshaker_registry.c → handshaker_registry.cc} +0 -0
  195. data/src/core/lib/channel/handshaker_registry.h +8 -0
  196. data/src/core/lib/compression/algorithm_metadata.h +8 -0
  197. data/src/core/lib/compression/{compression.c → compression.cc} +9 -9
  198. data/src/core/lib/compression/{message_compress.c → message_compress.cc} +0 -0
  199. data/src/core/lib/compression/message_compress.h +8 -0
  200. data/src/core/lib/compression/{stream_compression.c → stream_compression.cc} +12 -12
  201. data/src/core/lib/compression/stream_compression.h +27 -19
  202. data/src/core/lib/compression/{stream_compression_gzip.c → stream_compression_gzip.cc} +35 -36
  203. data/src/core/lib/compression/stream_compression_gzip.h +8 -0
  204. data/src/core/lib/compression/{stream_compression_identity.c → stream_compression_identity.cc} +19 -20
  205. data/src/core/lib/compression/stream_compression_identity.h +8 -0
  206. data/src/core/lib/debug/{stats.c → stats.cc} +19 -19
  207. data/src/core/lib/debug/stats.h +17 -9
  208. data/src/core/lib/debug/{stats_data.c → stats_data.cc} +45 -22
  209. data/src/core/lib/debug/stats_data.h +58 -19
  210. data/src/core/lib/debug/trace.cc +142 -0
  211. data/src/core/lib/debug/trace.h +74 -14
  212. data/src/core/lib/http/{format_request.c → format_request.cc} +10 -10
  213. data/src/core/lib/http/format_request.h +12 -4
  214. data/src/core/lib/http/{httpcli.c → httpcli.cc} +80 -80
  215. data/src/core/lib/http/httpcli.h +41 -33
  216. data/src/core/lib/http/{httpcli_security_connector.c → httpcli_security_connector.cc} +69 -55
  217. data/src/core/lib/http/{parser.c → parser.cc} +42 -42
  218. data/src/core/lib/http/parser.h +28 -20
  219. data/src/core/lib/{support → iomgr}/block_annotate.h +17 -8
  220. data/src/core/lib/iomgr/{call_combiner.c → call_combiner.cc} +29 -17
  221. data/src/core/lib/iomgr/call_combiner.h +9 -1
  222. data/src/core/lib/iomgr/closure.h +220 -62
  223. data/src/core/lib/iomgr/{combiner.c → combiner.cc} +63 -62
  224. data/src/core/lib/iomgr/combiner.h +16 -8
  225. data/src/core/lib/iomgr/{endpoint.c → endpoint.cc} +6 -0
  226. data/src/core/lib/iomgr/endpoint.h +47 -32
  227. data/src/core/lib/iomgr/endpoint_pair.h +12 -4
  228. data/src/core/lib/iomgr/{endpoint_pair_posix.c → endpoint_pair_posix.cc} +3 -3
  229. data/src/core/lib/iomgr/{endpoint_pair_uv.c → endpoint_pair_uv.cc} +2 -2
  230. data/src/core/lib/iomgr/{endpoint_pair_windows.c → endpoint_pair_windows.cc} +6 -6
  231. data/src/core/lib/iomgr/{error.c → error.cc} +125 -124
  232. data/src/core/lib/iomgr/error.h +32 -27
  233. data/src/core/lib/iomgr/error_internal.h +11 -2
  234. data/src/core/lib/iomgr/{ev_epoll1_linux.c → ev_epoll1_linux.cc} +214 -215
  235. data/src/core/lib/iomgr/ev_epoll1_linux.h +9 -1
  236. data/src/core/lib/iomgr/ev_epollex_linux.cc +1488 -0
  237. data/src/core/lib/iomgr/ev_epollex_linux.h +9 -1
  238. data/src/core/lib/iomgr/{ev_epollsig_linux.c → ev_epollsig_linux.cc} +304 -305
  239. data/src/core/lib/iomgr/ev_epollsig_linux.h +12 -4
  240. data/src/core/lib/iomgr/{ev_poll_posix.c → ev_poll_posix.cc} +272 -283
  241. data/src/core/lib/iomgr/ev_poll_posix.h +10 -2
  242. data/src/core/lib/iomgr/ev_posix.cc +288 -0
  243. data/src/core/lib/iomgr/ev_posix.h +75 -67
  244. data/src/core/lib/iomgr/{ev_windows.c → ev_windows.cc} +2 -2
  245. data/src/core/lib/iomgr/exec_ctx.cc +177 -0
  246. data/src/core/lib/iomgr/exec_ctx.h +35 -13
  247. data/src/core/lib/iomgr/{executor.c → executor.cc} +34 -35
  248. data/src/core/lib/iomgr/executor.h +12 -4
  249. data/src/core/lib/iomgr/{fork_posix.c → fork_posix.cc} +0 -0
  250. data/src/core/lib/iomgr/{fork_windows.c → fork_windows.cc} +0 -0
  251. data/src/core/lib/iomgr/gethostname.h +9 -1
  252. data/src/core/lib/iomgr/{gethostname_fallback.c → gethostname_fallback.cc} +2 -1
  253. data/src/core/lib/iomgr/{gethostname_host_name_max.c → gethostname_host_name_max.cc} +4 -3
  254. data/src/core/lib/iomgr/{gethostname_sysconf.c → gethostname_sysconf.cc} +3 -2
  255. data/src/core/lib/iomgr/{iocp_windows.c → iocp_windows.cc} +23 -25
  256. data/src/core/lib/iomgr/iocp_windows.h +17 -3
  257. data/src/core/lib/iomgr/{iomgr.c → iomgr.cc} +25 -19
  258. data/src/core/lib/iomgr/iomgr.h +11 -3
  259. data/src/core/lib/iomgr/iomgr_internal.h +13 -5
  260. data/src/core/lib/iomgr/{iomgr_posix.c → iomgr_posix.cc} +0 -1
  261. data/src/core/lib/iomgr/{iomgr_uv.c → iomgr_uv.cc} +1 -1
  262. data/src/core/lib/iomgr/iomgr_uv.h +8 -0
  263. data/src/core/lib/iomgr/{iomgr_windows.c → iomgr_windows.cc} +0 -0
  264. data/src/core/lib/iomgr/{is_epollexclusive_available.c → is_epollexclusive_available.cc} +1 -1
  265. data/src/core/lib/iomgr/is_epollexclusive_available.h +8 -0
  266. data/src/core/lib/iomgr/{load_file.c → load_file.cc} +12 -12
  267. data/src/core/lib/iomgr/load_file.h +2 -2
  268. data/src/core/lib/iomgr/{lockfree_event.c → lockfree_event.cc} +76 -68
  269. data/src/core/lib/iomgr/lockfree_event.h +30 -11
  270. data/src/core/lib/iomgr/{network_status_tracker.c → network_status_tracker.cc} +3 -2
  271. data/src/core/lib/iomgr/network_status_tracker.h +2 -2
  272. data/src/core/lib/iomgr/{polling_entity.c → polling_entity.cc} +18 -18
  273. data/src/core/lib/iomgr/polling_entity.h +21 -13
  274. data/src/core/lib/iomgr/pollset.h +17 -11
  275. data/src/core/lib/iomgr/pollset_set.h +23 -15
  276. data/src/core/lib/iomgr/{pollset_set_uv.c → pollset_set_uv.cc} +0 -0
  277. data/src/core/lib/iomgr/{pollset_set_windows.c → pollset_set_windows.cc} +0 -0
  278. data/src/core/lib/iomgr/{pollset_uv.c → pollset_uv.cc} +31 -29
  279. data/src/core/lib/iomgr/pollset_uv.h +8 -0
  280. data/src/core/lib/iomgr/{pollset_windows.c → pollset_windows.cc} +24 -24
  281. data/src/core/lib/iomgr/pollset_windows.h +17 -4
  282. data/src/core/lib/iomgr/port.h +10 -0
  283. data/src/core/lib/iomgr/resolve_address.h +18 -10
  284. data/src/core/lib/iomgr/{resolve_address_posix.c → resolve_address_posix.cc} +40 -40
  285. data/src/core/lib/iomgr/{resolve_address_uv.c → resolve_address_uv.cc} +61 -56
  286. data/src/core/lib/iomgr/{resolve_address_windows.c → resolve_address_windows.cc} +36 -34
  287. data/src/core/lib/iomgr/{resource_quota.c → resource_quota.cc} +209 -180
  288. data/src/core/lib/iomgr/resource_quota.h +45 -37
  289. data/src/core/lib/iomgr/{sockaddr_utils.c → sockaddr_utils.cc} +61 -61
  290. data/src/core/lib/iomgr/sockaddr_utils.h +23 -15
  291. data/src/core/lib/iomgr/sockaddr_windows.h +6 -0
  292. data/src/core/lib/iomgr/{socket_factory_posix.c → socket_factory_posix.cc} +20 -20
  293. data/src/core/lib/iomgr/socket_factory_posix.h +15 -15
  294. data/src/core/lib/iomgr/{socket_mutator.c → socket_mutator.cc} +18 -18
  295. data/src/core/lib/iomgr/socket_mutator.h +11 -11
  296. data/src/core/lib/iomgr/socket_utils.h +9 -1
  297. data/src/core/lib/iomgr/{socket_utils_common_posix.c → socket_utils_common_posix.cc} +28 -28
  298. data/src/core/lib/iomgr/{socket_utils_linux.c → socket_utils_linux.cc} +3 -3
  299. data/src/core/lib/iomgr/{socket_utils_posix.c → socket_utils_posix.cc} +3 -3
  300. data/src/core/lib/iomgr/socket_utils_posix.h +26 -18
  301. data/src/core/lib/iomgr/{socket_utils_uv.c → socket_utils_uv.cc} +1 -1
  302. data/src/core/lib/iomgr/{socket_utils_windows.c → socket_utils_windows.cc} +2 -2
  303. data/src/core/lib/iomgr/{socket_windows.c → socket_windows.cc} +18 -18
  304. data/src/core/lib/iomgr/socket_windows.h +26 -13
  305. data/src/core/lib/iomgr/tcp_client.h +14 -6
  306. data/src/core/lib/iomgr/{tcp_client_posix.c → tcp_client_posix.cc} +69 -70
  307. data/src/core/lib/iomgr/tcp_client_posix.h +11 -3
  308. data/src/core/lib/iomgr/{tcp_client_uv.c → tcp_client_uv.cc} +47 -48
  309. data/src/core/lib/iomgr/{tcp_client_windows.c → tcp_client_windows.cc} +46 -44
  310. data/src/core/lib/iomgr/{tcp_posix.c → tcp_posix.cc} +198 -175
  311. data/src/core/lib/iomgr/tcp_posix.h +15 -7
  312. data/src/core/lib/iomgr/tcp_server.h +31 -23
  313. data/src/core/lib/iomgr/{tcp_server_posix.c → tcp_server_posix.cc} +78 -77
  314. data/src/core/lib/iomgr/tcp_server_utils_posix.h +27 -19
  315. data/src/core/lib/iomgr/{tcp_server_utils_posix_common.c → tcp_server_utils_posix_common.cc} +27 -27
  316. data/src/core/lib/iomgr/{tcp_server_utils_posix_ifaddrs.c → tcp_server_utils_posix_ifaddrs.cc} +25 -25
  317. data/src/core/lib/iomgr/{tcp_server_utils_posix_noifaddrs.c → tcp_server_utils_posix_noifaddrs.cc} +2 -2
  318. data/src/core/lib/iomgr/{tcp_server_uv.c → tcp_server_uv.cc} +133 -105
  319. data/src/core/lib/iomgr/{tcp_server_windows.c → tcp_server_windows.cc} +81 -77
  320. data/src/core/lib/iomgr/tcp_uv.cc +420 -0
  321. data/src/core/lib/iomgr/tcp_uv.h +18 -4
  322. data/src/core/lib/iomgr/{tcp_windows.c → tcp_windows.cc} +90 -79
  323. data/src/core/lib/iomgr/tcp_windows.h +17 -4
  324. data/src/core/lib/iomgr/{time_averaged_stats.c → time_averaged_stats.cc} +0 -0
  325. data/src/core/lib/iomgr/time_averaged_stats.h +8 -0
  326. data/src/core/lib/iomgr/timer.h +16 -9
  327. data/src/core/lib/iomgr/{timer_generic.c → timer_generic.cc} +130 -171
  328. data/src/core/lib/iomgr/timer_generic.h +4 -4
  329. data/src/core/lib/iomgr/{timer_heap.c → timer_heap.cc} +20 -21
  330. data/src/core/lib/iomgr/timer_heap.h +16 -8
  331. data/src/core/lib/iomgr/{timer_manager.c → timer_manager.cc} +54 -52
  332. data/src/core/lib/iomgr/timer_manager.h +8 -0
  333. data/src/core/lib/iomgr/{timer_uv.c → timer_uv.cc} +22 -24
  334. data/src/core/lib/iomgr/timer_uv.h +2 -2
  335. data/src/core/lib/iomgr/{udp_server.c → udp_server.cc} +75 -75
  336. data/src/core/lib/iomgr/udp_server.h +25 -17
  337. data/src/core/lib/iomgr/{unix_sockets_posix.c → unix_sockets_posix.cc} +22 -21
  338. data/src/core/lib/iomgr/unix_sockets_posix.h +14 -6
  339. data/src/core/lib/iomgr/{unix_sockets_posix_noop.c → unix_sockets_posix_noop.cc} +5 -5
  340. data/src/core/lib/iomgr/{wakeup_fd_cv.c → wakeup_fd_cv.cc} +2 -2
  341. data/src/core/lib/iomgr/wakeup_fd_cv.h +10 -0
  342. data/src/core/lib/iomgr/{wakeup_fd_eventfd.c → wakeup_fd_eventfd.cc} +0 -0
  343. data/src/core/lib/iomgr/{wakeup_fd_nospecial.c → wakeup_fd_nospecial.cc} +0 -0
  344. data/src/core/lib/iomgr/{wakeup_fd_pipe.c → wakeup_fd_pipe.cc} +1 -0
  345. data/src/core/lib/iomgr/wakeup_fd_pipe.h +9 -1
  346. data/src/core/lib/iomgr/{wakeup_fd_posix.c → wakeup_fd_posix.cc} +6 -7
  347. data/src/core/lib/iomgr/wakeup_fd_posix.h +8 -0
  348. data/src/core/lib/json/{json.c → json.cc} +0 -0
  349. data/src/core/lib/json/json.h +8 -0
  350. data/src/core/lib/json/{json_reader.c → json_reader.cc} +18 -18
  351. data/src/core/lib/json/json_reader.h +26 -18
  352. data/src/core/lib/json/{json_string.c → json_string.cc} +57 -57
  353. data/src/core/lib/json/{json_writer.c → json_writer.cc} +20 -20
  354. data/src/core/lib/json/json_writer.h +23 -15
  355. data/src/core/lib/profiling/{basic_timers.c → basic_timers.cc} +34 -34
  356. data/src/core/lib/profiling/{stap_timers.c → stap_timers.cc} +5 -5
  357. data/src/core/lib/profiling/timers.h +6 -6
  358. data/src/core/lib/security/context/{security_context.c → security_context.cc} +98 -95
  359. data/src/core/lib/security/context/security_context.h +27 -29
  360. data/src/core/lib/security/credentials/composite/{composite_credentials.c → composite_credentials.cc} +79 -73
  361. data/src/core/lib/security/credentials/composite/composite_credentials.h +17 -9
  362. data/src/core/lib/security/credentials/{credentials.c → credentials.cc} +97 -92
  363. data/src/core/lib/security/credentials/credentials.h +83 -75
  364. data/src/core/lib/security/credentials/{credentials_metadata.c → credentials_metadata.cc} +7 -6
  365. data/src/core/lib/security/credentials/fake/{fake_credentials.c → fake_credentials.cc} +39 -36
  366. data/src/core/lib/security/credentials/fake/fake_credentials.h +13 -5
  367. data/src/core/lib/security/credentials/google_default/{credentials_generic.c → credentials_generic.cc} +5 -5
  368. data/src/core/lib/security/credentials/google_default/{google_default_credentials.c → google_default_credentials.cc} +55 -55
  369. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +9 -1
  370. data/src/core/lib/security/credentials/iam/{iam_credentials.c → iam_credentials.cc} +19 -18
  371. data/src/core/lib/security/credentials/jwt/{json_token.c → json_token.cc} +80 -75
  372. data/src/core/lib/security/credentials/jwt/json_token.h +23 -15
  373. data/src/core/lib/security/credentials/jwt/{jwt_credentials.c → jwt_credentials.cc} +45 -41
  374. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +11 -3
  375. data/src/core/lib/security/credentials/jwt/{jwt_verifier.c → jwt_verifier.cc} +262 -252
  376. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +38 -30
  377. data/src/core/lib/security/credentials/oauth2/{oauth2_credentials.c → oauth2_credentials.cc} +138 -141
  378. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +30 -22
  379. data/src/core/lib/security/credentials/plugin/{plugin_credentials.c → plugin_credentials.cc} +52 -53
  380. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +7 -7
  381. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +344 -0
  382. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +27 -0
  383. data/src/core/lib/security/transport/auth_filters.h +16 -0
  384. data/src/core/lib/security/transport/{client_auth_filter.c → client_auth_filter.cc} +127 -115
  385. data/src/core/lib/security/transport/{lb_targets_info.c → lb_targets_info.cc} +16 -13
  386. data/src/core/lib/security/transport/lb_targets_info.h +11 -3
  387. data/src/core/lib/security/transport/{secure_endpoint.c → secure_endpoint.cc} +84 -76
  388. data/src/core/lib/security/transport/secure_endpoint.h +13 -5
  389. data/src/core/lib/security/transport/security_connector.cc +1121 -0
  390. data/src/core/lib/security/transport/security_connector.h +97 -79
  391. data/src/core/lib/security/transport/{security_handshaker.c → security_handshaker.cc} +139 -132
  392. data/src/core/lib/security/transport/security_handshaker.h +11 -3
  393. data/src/core/lib/security/transport/{server_auth_filter.c → server_auth_filter.cc} +68 -68
  394. data/src/core/lib/security/transport/{tsi_error.c → tsi_error.cc} +1 -1
  395. data/src/core/lib/security/transport/tsi_error.h +9 -1
  396. data/src/core/lib/security/util/{json_util.c → json_util.cc} +11 -11
  397. data/src/core/lib/security/util/json_util.h +12 -4
  398. data/src/core/lib/slice/{b64.c → b64.cc} +15 -15
  399. data/src/core/lib/slice/b64.h +12 -4
  400. data/src/core/lib/slice/{percent_encoding.c → percent_encoding.cc} +15 -15
  401. data/src/core/lib/slice/percent_encoding.h +11 -3
  402. data/src/core/lib/slice/{slice.c → slice.cc} +64 -64
  403. data/src/core/lib/slice/{slice_buffer.c → slice_buffer.cc} +38 -38
  404. data/src/core/lib/slice/{slice_hash_table.c → slice_hash_table.cc} +7 -7
  405. data/src/core/lib/slice/slice_hash_table.h +19 -11
  406. data/src/core/lib/slice/{slice_intern.c → slice_intern.cc} +35 -34
  407. data/src/core/lib/slice/slice_internal.h +17 -6
  408. data/src/core/lib/slice/{slice_string_helpers.c → slice_string_helpers.cc} +9 -9
  409. data/src/core/lib/slice/slice_string_helpers.h +3 -3
  410. data/src/core/lib/support/abstract.h +29 -0
  411. data/src/core/lib/support/{alloc.c → alloc.cc} +22 -22
  412. data/src/core/lib/support/{arena.c → arena.cc} +12 -12
  413. data/src/core/lib/support/arena.h +11 -3
  414. data/src/core/lib/support/{atm.c → atm.cc} +1 -1
  415. data/src/core/lib/support/{avl.c → avl.cc} +71 -70
  416. data/src/core/lib/support/{cmdline.c → cmdline.cc} +62 -62
  417. data/src/core/lib/support/{cpu_iphone.c → cpu_iphone.cc} +2 -0
  418. data/src/core/lib/support/{cpu_linux.c → cpu_linux.cc} +10 -0
  419. data/src/core/lib/support/{cpu_posix.c → cpu_posix.cc} +27 -4
  420. data/src/core/lib/support/{cpu_windows.c → cpu_windows.cc} +1 -0
  421. data/src/core/lib/support/env.h +3 -3
  422. data/src/core/lib/support/{env_linux.c → env_linux.cc} +11 -11
  423. data/src/core/lib/support/{env_posix.c → env_posix.cc} +4 -4
  424. data/src/core/lib/support/{env_windows.c → env_windows.cc} +5 -5
  425. data/src/core/lib/support/{fork.c → fork.cc} +2 -2
  426. data/src/core/lib/support/{histogram.c → histogram.cc} +25 -26
  427. data/src/core/lib/support/{host_port.c → host_port.cc} +16 -16
  428. data/src/core/lib/support/{log.c → log.cc} +8 -8
  429. data/src/core/lib/support/{log_android.c → log_android.cc} +7 -7
  430. data/src/core/lib/support/{log_linux.c → log_linux.cc} +8 -8
  431. data/src/core/lib/support/{log_posix.c → log_posix.cc} +9 -10
  432. data/src/core/lib/support/{log_windows.c → log_windows.cc} +7 -7
  433. data/src/core/lib/support/manual_constructor.h +211 -0
  434. data/src/core/lib/support/memory.h +41 -0
  435. data/src/core/lib/support/mpscq.cc +114 -0
  436. data/src/core/lib/support/mpscq.h +45 -7
  437. data/src/core/lib/support/{murmur_hash.c → murmur_hash.cc} +9 -12
  438. data/src/core/lib/support/murmur_hash.h +9 -1
  439. data/src/core/lib/support/spinlock.h +8 -1
  440. data/src/core/lib/support/{string.c → string.cc} +56 -55
  441. data/src/core/lib/support/string.h +21 -21
  442. data/src/core/lib/support/{string_posix.c → string_posix.cc} +5 -4
  443. data/src/core/lib/support/{string_util_windows.c → string_util_windows.cc} +9 -6
  444. data/src/core/lib/support/{string_windows.c → string_windows.cc} +3 -2
  445. data/src/core/lib/support/string_windows.h +8 -0
  446. data/src/core/lib/support/{subprocess_posix.c → subprocess_posix.cc} +13 -13
  447. data/src/core/lib/support/{subprocess_windows.c → subprocess_windows.cc} +9 -9
  448. data/src/core/lib/support/{sync.c → sync.cc} +22 -22
  449. data/src/core/lib/support/{sync_posix.c → sync_posix.cc} +6 -2
  450. data/src/core/lib/support/{sync_windows.c → sync_windows.cc} +14 -14
  451. data/src/core/lib/support/{thd.c → thd.cc} +0 -0
  452. data/src/core/lib/support/{thd_posix.c → thd_posix.cc} +10 -10
  453. data/src/core/lib/support/{thd_windows.c → thd_windows.cc} +10 -10
  454. data/src/core/lib/support/{time.c → time.cc} +0 -0
  455. data/src/core/lib/support/{time_posix.c → time_posix.cc} +5 -6
  456. data/src/core/lib/support/{time_precise.c → time_precise.cc} +6 -4
  457. data/src/core/lib/support/time_precise.h +9 -1
  458. data/src/core/lib/support/{time_windows.c → time_windows.cc} +2 -3
  459. data/src/core/lib/support/{tls_pthread.c → tls_pthread.cc} +2 -2
  460. data/src/core/lib/support/tmpfile.h +1 -1
  461. data/src/core/lib/support/{tmpfile_msys.c → tmpfile_msys.cc} +2 -2
  462. data/src/core/lib/support/{tmpfile_posix.c → tmpfile_posix.cc} +7 -7
  463. data/src/core/lib/support/{tmpfile_windows.c → tmpfile_windows.cc} +2 -2
  464. data/src/core/lib/support/{wrap_memcpy.c → wrap_memcpy.cc} +4 -2
  465. data/src/core/lib/surface/{alarm.c → alarm.cc} +32 -31
  466. data/src/core/lib/surface/alarm_internal.h +10 -2
  467. data/src/core/lib/surface/{api_trace.c → api_trace.cc} +1 -1
  468. data/src/core/lib/surface/api_trace.h +2 -2
  469. data/src/core/lib/surface/{byte_buffer.c → byte_buffer.cc} +13 -13
  470. data/src/core/lib/surface/{byte_buffer_reader.c → byte_buffer_reader.cc} +9 -9
  471. data/src/core/lib/surface/{call.c → call.cc} +379 -372
  472. data/src/core/lib/surface/call.h +37 -38
  473. data/src/core/lib/surface/{call_details.c → call_details.cc} +0 -0
  474. data/src/core/lib/surface/{call_log_batch.c → call_log_batch.cc} +13 -11
  475. data/src/core/lib/surface/call_test_only.h +5 -5
  476. data/src/core/lib/surface/{channel.c → channel.cc} +94 -95
  477. data/src/core/lib/surface/channel.h +29 -21
  478. data/src/core/lib/surface/{channel_init.c → channel_init.cc} +13 -13
  479. data/src/core/lib/surface/channel_init.h +6 -6
  480. data/src/core/lib/surface/{channel_ping.c → channel_ping.cc} +12 -12
  481. data/src/core/lib/surface/{channel_stack_type.c → channel_stack_type.cc} +1 -1
  482. data/src/core/lib/surface/channel_stack_type.h +9 -1
  483. data/src/core/lib/surface/{completion_queue.c → completion_queue.cc} +416 -379
  484. data/src/core/lib/surface/completion_queue.h +29 -29
  485. data/src/core/lib/surface/{completion_queue_factory.c → completion_queue_factory.cc} +1 -1
  486. data/src/core/lib/surface/completion_queue_factory.h +8 -0
  487. data/src/core/lib/surface/{event_string.c → event_string.cc} +9 -9
  488. data/src/core/lib/surface/event_string.h +9 -1
  489. data/src/core/lib/surface/{init.c → init.cc} +16 -39
  490. data/src/core/lib/surface/init.h +8 -0
  491. data/src/core/lib/surface/{init_secure.c → init_secure.cc} +12 -25
  492. data/src/core/lib/surface/lame_client.cc +38 -40
  493. data/src/core/lib/surface/lame_client.h +8 -0
  494. data/src/core/lib/surface/{metadata_array.c → metadata_array.cc} +0 -0
  495. data/src/core/lib/surface/{server.c → server.cc} +340 -404
  496. data/src/core/lib/surface/server.h +22 -14
  497. data/src/core/lib/surface/{validate_metadata.c → validate_metadata.cc} +10 -9
  498. data/src/core/lib/surface/validate_metadata.h +10 -2
  499. data/src/core/lib/surface/{version.c → version.cc} +2 -2
  500. data/src/core/lib/transport/bdp_estimator.cc +84 -0
  501. data/src/core/lib/transport/bdp_estimator.h +67 -42
  502. data/src/core/lib/transport/{byte_stream.c → byte_stream.cc} +51 -51
  503. data/src/core/lib/transport/byte_stream.h +41 -33
  504. data/src/core/lib/transport/{connectivity_state.c → connectivity_state.cc} +36 -40
  505. data/src/core/lib/transport/connectivity_state.h +29 -21
  506. data/src/core/lib/transport/{error_utils.c → error_utils.cc} +26 -22
  507. data/src/core/lib/transport/error_utils.h +18 -6
  508. data/src/core/lib/transport/{metadata.c → metadata.cc} +92 -88
  509. data/src/core/lib/transport/metadata.h +22 -20
  510. data/src/core/lib/transport/{metadata_batch.c → metadata_batch.cc} +78 -79
  511. data/src/core/lib/transport/metadata_batch.h +46 -45
  512. data/src/core/lib/transport/pid_controller.cc +48 -0
  513. data/src/core/lib/transport/pid_controller.h +84 -32
  514. data/src/core/lib/transport/{service_config.c → service_config.cc} +66 -48
  515. data/src/core/lib/transport/service_config.h +11 -2
  516. data/src/core/lib/transport/{static_metadata.c → static_metadata.cc} +2 -2
  517. data/src/core/lib/transport/static_metadata.h +30 -23
  518. data/src/core/lib/transport/{status_conversion.c → status_conversion.cc} +4 -3
  519. data/src/core/lib/transport/status_conversion.h +12 -2
  520. data/src/core/lib/transport/{timeout_encoding.c → timeout_encoding.cc} +28 -61
  521. data/src/core/lib/transport/timeout_encoding.h +11 -2
  522. data/src/core/lib/transport/{transport.c → transport.cc} +79 -79
  523. data/src/core/lib/transport/transport.h +78 -80
  524. data/src/core/lib/transport/transport_impl.h +27 -19
  525. data/src/core/lib/transport/{transport_op_string.c → transport_op_string.cc} +32 -30
  526. data/src/core/plugin_registry/{grpc_plugin_registry.c → grpc_plugin_registry.cc} +34 -38
  527. data/src/core/tsi/{fake_transport_security.c → fake_transport_security.cc} +141 -132
  528. data/src/core/tsi/fake_transport_security.h +5 -5
  529. data/src/core/tsi/{gts_transport_security.c → gts_transport_security.cc} +4 -4
  530. data/src/core/tsi/gts_transport_security.h +11 -3
  531. data/src/core/tsi/{ssl_transport_security.c → ssl_transport_security.cc} +309 -300
  532. data/src/core/tsi/ssl_transport_security.h +25 -25
  533. data/src/core/tsi/ssl_types.h +8 -0
  534. data/src/core/tsi/{transport_security.c → transport_security.cc} +94 -87
  535. data/src/core/tsi/transport_security.h +55 -55
  536. data/src/core/tsi/{transport_security_adapter.c → transport_security_adapter.cc} +58 -55
  537. data/src/core/tsi/transport_security_adapter.h +2 -2
  538. data/src/core/tsi/{transport_security_grpc.c → transport_security_grpc.cc} +21 -21
  539. data/src/core/tsi/transport_security_grpc.h +19 -19
  540. data/src/core/tsi/transport_security_interface.h +41 -41
  541. data/src/ruby/ext/grpc/extconf.rb +4 -2
  542. data/src/ruby/ext/grpc/rb_byte_buffer.c +5 -5
  543. data/src/ruby/ext/grpc/rb_byte_buffer.h +2 -2
  544. data/src/ruby/ext/grpc/rb_call.c +41 -42
  545. data/src/ruby/ext/grpc/rb_call.h +6 -6
  546. data/src/ruby/ext/grpc/rb_call_credentials.c +30 -30
  547. data/src/ruby/ext/grpc/rb_channel.c +87 -87
  548. data/src/ruby/ext/grpc/rb_channel_credentials.c +23 -23
  549. data/src/ruby/ext/grpc/rb_completion_queue.c +11 -11
  550. data/src/ruby/ext/grpc/rb_completion_queue.h +3 -3
  551. data/src/ruby/ext/grpc/rb_compression_options.c +20 -20
  552. data/src/ruby/ext/grpc/rb_event_thread.c +14 -14
  553. data/src/ruby/ext/grpc/rb_event_thread.h +1 -1
  554. data/src/ruby/ext/grpc/rb_grpc.c +8 -8
  555. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +16 -58
  556. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +242 -306
  557. data/src/ruby/ext/grpc/rb_server.c +23 -23
  558. data/src/ruby/ext/grpc/rb_server_credentials.c +13 -13
  559. data/src/ruby/lib/grpc/generic/rpc_server.rb +25 -12
  560. data/src/ruby/lib/grpc/version.rb +1 -1
  561. data/src/ruby/pb/grpc/health/checker.rb +14 -0
  562. data/src/ruby/spec/pb/health/checker_spec.rb +29 -0
  563. data/third_party/cares/config_freebsd/ares_config.h +502 -0
  564. data/third_party/cares/config_openbsd/ares_config.h +502 -0
  565. metadata +302 -328
  566. data/src/core/ext/census/aggregation.h +0 -51
  567. data/src/core/ext/census/base_resources.c +0 -56
  568. data/src/core/ext/census/base_resources.h +0 -24
  569. data/src/core/ext/census/census_interface.h +0 -61
  570. data/src/core/ext/census/census_rpc_stats.h +0 -86
  571. data/src/core/ext/census/context.c +0 -496
  572. data/src/core/ext/census/gen/census.pb.c +0 -161
  573. data/src/core/ext/census/gen/census.pb.h +0 -280
  574. data/src/core/ext/census/gen/trace_context.pb.c +0 -39
  575. data/src/core/ext/census/gen/trace_context.pb.h +0 -78
  576. data/src/core/ext/census/grpc_filter.c +0 -196
  577. data/src/core/ext/census/grpc_plugin.c +0 -70
  578. data/src/core/ext/census/initialize.c +0 -51
  579. data/src/core/ext/census/intrusive_hash_map.c +0 -305
  580. data/src/core/ext/census/intrusive_hash_map.h +0 -152
  581. data/src/core/ext/census/intrusive_hash_map_internal.h +0 -48
  582. data/src/core/ext/census/mlog.c +0 -586
  583. data/src/core/ext/census/mlog.h +0 -80
  584. data/src/core/ext/census/operation.c +0 -48
  585. data/src/core/ext/census/placeholders.c +0 -49
  586. data/src/core/ext/census/resource.c +0 -303
  587. data/src/core/ext/census/resource.h +0 -48
  588. data/src/core/ext/census/rpc_metric_id.h +0 -36
  589. data/src/core/ext/census/trace_context.c +0 -71
  590. data/src/core/ext/census/trace_context.h +0 -56
  591. data/src/core/ext/census/trace_label.h +0 -46
  592. data/src/core/ext/census/trace_propagation.h +0 -48
  593. data/src/core/ext/census/trace_status.h +0 -30
  594. data/src/core/ext/census/trace_string.h +0 -35
  595. data/src/core/ext/census/tracing.c +0 -55
  596. data/src/core/ext/census/tracing.h +0 -109
  597. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.c +0 -714
  598. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.c +0 -924
  599. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.c +0 -60
  600. data/src/core/ext/transport/chttp2/transport/flow_control.c +0 -502
  601. data/src/core/ext/transport/chttp2/transport/writing.c +0 -534
  602. data/src/core/lib/debug/trace.c +0 -146
  603. data/src/core/lib/iomgr/closure.c +0 -219
  604. data/src/core/lib/iomgr/ev_epollex_linux.c +0 -1461
  605. data/src/core/lib/iomgr/ev_posix.c +0 -266
  606. data/src/core/lib/iomgr/exec_ctx.c +0 -113
  607. data/src/core/lib/iomgr/tcp_uv.c +0 -381
  608. data/src/core/lib/security/credentials/ssl/ssl_credentials.c +0 -194
  609. data/src/core/lib/security/transport/security_connector.c +0 -914
  610. data/src/core/lib/support/backoff.c +0 -72
  611. data/src/core/lib/support/backoff.h +0 -56
  612. data/src/core/lib/support/mpscq.c +0 -79
  613. data/src/core/lib/support/stack_lockfree.c +0 -137
  614. data/src/core/lib/support/stack_lockfree.h +0 -38
  615. data/src/core/lib/transport/bdp_estimator.c +0 -110
  616. data/src/core/lib/transport/pid_controller.c +0 -63
@@ -35,42 +35,43 @@
35
35
  #include "src/core/lib/surface/channel.h"
36
36
  #include "src/core/lib/transport/transport.h"
37
37
 
38
- grpc_channel *grpc_insecure_channel_create_from_fd(
39
- const char *target, int fd, const grpc_channel_args *args) {
38
+ grpc_channel* grpc_insecure_channel_create_from_fd(
39
+ const char* target, int fd, const grpc_channel_args* args) {
40
40
  grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
41
41
  GRPC_API_TRACE("grpc_insecure_channel_create(target=%p, fd=%d, args=%p)", 3,
42
42
  (target, fd, args));
43
43
 
44
44
  grpc_arg default_authority_arg = grpc_channel_arg_string_create(
45
- (char *)GRPC_ARG_DEFAULT_AUTHORITY, (char *)"test.authority");
46
- grpc_channel_args *final_args =
45
+ (char*)GRPC_ARG_DEFAULT_AUTHORITY, (char*)"test.authority");
46
+ grpc_channel_args* final_args =
47
47
  grpc_channel_args_copy_and_add(args, &default_authority_arg, 1);
48
48
 
49
49
  int flags = fcntl(fd, F_GETFL, 0);
50
50
  GPR_ASSERT(fcntl(fd, F_SETFL, flags | O_NONBLOCK) == 0);
51
51
 
52
- grpc_endpoint *client = grpc_tcp_client_create_from_fd(
52
+ grpc_endpoint* client = grpc_tcp_client_create_from_fd(
53
53
  &exec_ctx, grpc_fd_create(fd, "client"), args, "fd-client");
54
54
 
55
- grpc_transport *transport =
55
+ grpc_transport* transport =
56
56
  grpc_create_chttp2_transport(&exec_ctx, final_args, client, true);
57
57
  GPR_ASSERT(transport);
58
- grpc_channel *channel = grpc_channel_create(
58
+ grpc_channel* channel = grpc_channel_create(
59
59
  &exec_ctx, target, final_args, GRPC_CLIENT_DIRECT_CHANNEL, transport);
60
60
  grpc_channel_args_destroy(&exec_ctx, final_args);
61
- grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, NULL);
61
+ grpc_chttp2_transport_start_reading(&exec_ctx, transport, nullptr, nullptr);
62
62
 
63
63
  grpc_exec_ctx_finish(&exec_ctx);
64
64
 
65
- return channel != NULL ? channel : grpc_lame_client_channel_create(
66
- target, GRPC_STATUS_INTERNAL,
67
- "Failed to create client channel");
65
+ return channel != nullptr ? channel
66
+ : grpc_lame_client_channel_create(
67
+ target, GRPC_STATUS_INTERNAL,
68
+ "Failed to create client channel");
68
69
  }
69
70
 
70
71
  #else // !GPR_SUPPORT_CHANNELS_FROM_FD
71
72
 
72
- grpc_channel *grpc_insecure_channel_create_from_fd(
73
- const char *target, int fd, const grpc_channel_args *args) {
73
+ grpc_channel* grpc_insecure_channel_create_from_fd(
74
+ const char* target, int fd, const grpc_channel_args* args) {
74
75
  GPR_ASSERT(0);
75
76
  return NULL;
76
77
  }
@@ -38,59 +38,60 @@
38
38
  #include "src/core/lib/surface/channel.h"
39
39
 
40
40
  static void client_channel_factory_ref(
41
- grpc_client_channel_factory *cc_factory) {}
41
+ grpc_client_channel_factory* cc_factory) {}
42
42
 
43
43
  static void client_channel_factory_unref(
44
- grpc_exec_ctx *exec_ctx, grpc_client_channel_factory *cc_factory) {}
44
+ grpc_exec_ctx* exec_ctx, grpc_client_channel_factory* cc_factory) {}
45
45
 
46
- static grpc_subchannel_args *get_secure_naming_subchannel_args(
47
- grpc_exec_ctx *exec_ctx, const grpc_subchannel_args *args) {
48
- grpc_channel_credentials *channel_credentials =
46
+ static grpc_subchannel_args* get_secure_naming_subchannel_args(
47
+ grpc_exec_ctx* exec_ctx, const grpc_subchannel_args* args) {
48
+ grpc_channel_credentials* channel_credentials =
49
49
  grpc_channel_credentials_find_in_args(args->args);
50
- if (channel_credentials == NULL) {
50
+ if (channel_credentials == nullptr) {
51
51
  gpr_log(GPR_ERROR,
52
52
  "Can't create subchannel: channel credentials missing for secure "
53
53
  "channel.");
54
- return NULL;
54
+ return nullptr;
55
55
  }
56
56
  // Make sure security connector does not already exist in args.
57
- if (grpc_security_connector_find_in_args(args->args) != NULL) {
57
+ if (grpc_security_connector_find_in_args(args->args) != nullptr) {
58
58
  gpr_log(GPR_ERROR,
59
59
  "Can't create subchannel: security connector already present in "
60
60
  "channel args.");
61
- return NULL;
61
+ return nullptr;
62
62
  }
63
63
  // To which address are we connecting? By default, use the server URI.
64
- const grpc_arg *server_uri_arg =
64
+ const grpc_arg* server_uri_arg =
65
65
  grpc_channel_args_find(args->args, GRPC_ARG_SERVER_URI);
66
- GPR_ASSERT(server_uri_arg != NULL);
66
+ GPR_ASSERT(server_uri_arg != nullptr);
67
67
  GPR_ASSERT(server_uri_arg->type == GRPC_ARG_STRING);
68
- const char *server_uri_str = server_uri_arg->value.string;
69
- GPR_ASSERT(server_uri_str != NULL);
70
- grpc_uri *server_uri =
68
+ const char* server_uri_str = server_uri_arg->value.string;
69
+ GPR_ASSERT(server_uri_str != nullptr);
70
+ grpc_uri* server_uri =
71
71
  grpc_uri_parse(exec_ctx, server_uri_str, true /* supress errors */);
72
- GPR_ASSERT(server_uri != NULL);
73
- const char *server_uri_path;
72
+ GPR_ASSERT(server_uri != nullptr);
73
+ const char* server_uri_path;
74
74
  server_uri_path =
75
75
  server_uri->path[0] == '/' ? server_uri->path + 1 : server_uri->path;
76
- const grpc_slice_hash_table *targets_info =
76
+ const grpc_slice_hash_table* targets_info =
77
77
  grpc_lb_targets_info_find_in_args(args->args);
78
- char *target_name_to_check = NULL;
79
- if (targets_info != NULL) { // LB channel
78
+ char* target_name_to_check = nullptr;
79
+ if (targets_info != nullptr) { // LB channel
80
80
  // Find the balancer name for the target.
81
- const char *target_uri_str =
81
+ const char* target_uri_str =
82
82
  grpc_get_subchannel_address_uri_arg(args->args);
83
- grpc_uri *target_uri =
83
+ grpc_uri* target_uri =
84
84
  grpc_uri_parse(exec_ctx, target_uri_str, false /* suppress errors */);
85
- GPR_ASSERT(target_uri != NULL);
85
+ GPR_ASSERT(target_uri != nullptr);
86
86
  if (target_uri->path[0] != '\0') { // "path" may be empty
87
87
  const grpc_slice key = grpc_slice_from_static_string(
88
88
  target_uri->path[0] == '/' ? target_uri->path + 1 : target_uri->path);
89
- const char *value = grpc_slice_hash_table_get(targets_info, key);
90
- if (value != NULL) target_name_to_check = gpr_strdup(value);
89
+ const char* value =
90
+ (const char*)grpc_slice_hash_table_get(targets_info, key);
91
+ if (value != nullptr) target_name_to_check = gpr_strdup(value);
91
92
  grpc_slice_unref_internal(exec_ctx, key);
92
93
  }
93
- if (target_name_to_check == NULL) {
94
+ if (target_name_to_check == nullptr) {
94
95
  // If the target name to check hasn't already been set, fall back to using
95
96
  // SERVER_URI
96
97
  target_name_to_check = gpr_strdup(server_uri_path);
@@ -100,10 +101,10 @@ static grpc_subchannel_args *get_secure_naming_subchannel_args(
100
101
  target_name_to_check = gpr_strdup(server_uri_path);
101
102
  }
102
103
  grpc_uri_destroy(server_uri);
103
- GPR_ASSERT(target_name_to_check != NULL);
104
- grpc_channel_security_connector *subchannel_security_connector = NULL;
104
+ GPR_ASSERT(target_name_to_check != nullptr);
105
+ grpc_channel_security_connector* subchannel_security_connector = nullptr;
105
106
  // Create the security connector using the credentials and target name.
106
- grpc_channel_args *new_args_from_connector = NULL;
107
+ grpc_channel_args* new_args_from_connector = nullptr;
107
108
  const grpc_security_status security_status =
108
109
  grpc_channel_credentials_create_security_connector(
109
110
  exec_ctx, channel_credentials, target_name_to_check, args->args,
@@ -113,65 +114,66 @@ static grpc_subchannel_args *get_secure_naming_subchannel_args(
113
114
  "Failed to create secure subchannel for secure name '%s'",
114
115
  target_name_to_check);
115
116
  gpr_free(target_name_to_check);
116
- return NULL;
117
+ return nullptr;
117
118
  }
118
119
  gpr_free(target_name_to_check);
119
120
  grpc_arg new_security_connector_arg =
120
121
  grpc_security_connector_to_arg(&subchannel_security_connector->base);
121
122
 
122
- grpc_channel_args *new_args = grpc_channel_args_copy_and_add(
123
- new_args_from_connector != NULL ? new_args_from_connector : args->args,
123
+ grpc_channel_args* new_args = grpc_channel_args_copy_and_add(
124
+ new_args_from_connector != nullptr ? new_args_from_connector : args->args,
124
125
  &new_security_connector_arg, 1);
125
126
  GRPC_SECURITY_CONNECTOR_UNREF(exec_ctx, &subchannel_security_connector->base,
126
127
  "lb_channel_create");
127
- if (new_args_from_connector != NULL) {
128
+ if (new_args_from_connector != nullptr) {
128
129
  grpc_channel_args_destroy(exec_ctx, new_args_from_connector);
129
130
  }
130
- grpc_subchannel_args *final_sc_args = gpr_malloc(sizeof(*final_sc_args));
131
+ grpc_subchannel_args* final_sc_args =
132
+ (grpc_subchannel_args*)gpr_malloc(sizeof(*final_sc_args));
131
133
  memcpy(final_sc_args, args, sizeof(*args));
132
134
  final_sc_args->args = new_args;
133
135
  return final_sc_args;
134
136
  }
135
137
 
136
- static grpc_subchannel *client_channel_factory_create_subchannel(
137
- grpc_exec_ctx *exec_ctx, grpc_client_channel_factory *cc_factory,
138
- const grpc_subchannel_args *args) {
139
- grpc_subchannel_args *subchannel_args =
138
+ static grpc_subchannel* client_channel_factory_create_subchannel(
139
+ grpc_exec_ctx* exec_ctx, grpc_client_channel_factory* cc_factory,
140
+ const grpc_subchannel_args* args) {
141
+ grpc_subchannel_args* subchannel_args =
140
142
  get_secure_naming_subchannel_args(exec_ctx, args);
141
- if (subchannel_args == NULL) {
143
+ if (subchannel_args == nullptr) {
142
144
  gpr_log(
143
145
  GPR_ERROR,
144
146
  "Failed to create subchannel arguments during subchannel creation.");
145
- return NULL;
147
+ return nullptr;
146
148
  }
147
- grpc_connector *connector = grpc_chttp2_connector_create();
148
- grpc_subchannel *s =
149
+ grpc_connector* connector = grpc_chttp2_connector_create();
150
+ grpc_subchannel* s =
149
151
  grpc_subchannel_create(exec_ctx, connector, subchannel_args);
150
152
  grpc_connector_unref(exec_ctx, connector);
151
153
  grpc_channel_args_destroy(exec_ctx,
152
- (grpc_channel_args *)subchannel_args->args);
154
+ (grpc_channel_args*)subchannel_args->args);
153
155
  gpr_free(subchannel_args);
154
156
  return s;
155
157
  }
156
158
 
157
- static grpc_channel *client_channel_factory_create_channel(
158
- grpc_exec_ctx *exec_ctx, grpc_client_channel_factory *cc_factory,
159
- const char *target, grpc_client_channel_type type,
160
- const grpc_channel_args *args) {
161
- if (target == NULL) {
159
+ static grpc_channel* client_channel_factory_create_channel(
160
+ grpc_exec_ctx* exec_ctx, grpc_client_channel_factory* cc_factory,
161
+ const char* target, grpc_client_channel_type type,
162
+ const grpc_channel_args* args) {
163
+ if (target == nullptr) {
162
164
  gpr_log(GPR_ERROR, "cannot create channel with NULL target name");
163
- return NULL;
165
+ return nullptr;
164
166
  }
165
167
  // Add channel arg containing the server URI.
166
168
  grpc_arg arg = grpc_channel_arg_string_create(
167
- GRPC_ARG_SERVER_URI,
169
+ (char*)GRPC_ARG_SERVER_URI,
168
170
  grpc_resolver_factory_add_default_prefix_if_needed(exec_ctx, target));
169
- const char *to_remove[] = {GRPC_ARG_SERVER_URI};
170
- grpc_channel_args *new_args =
171
+ const char* to_remove[] = {GRPC_ARG_SERVER_URI};
172
+ grpc_channel_args* new_args =
171
173
  grpc_channel_args_copy_and_add_and_remove(args, to_remove, 1, &arg, 1);
172
174
  gpr_free(arg.value.string);
173
- grpc_channel *channel = grpc_channel_create(exec_ctx, target, new_args,
174
- GRPC_CLIENT_CHANNEL, NULL);
175
+ grpc_channel* channel = grpc_channel_create(exec_ctx, target, new_args,
176
+ GRPC_CLIENT_CHANNEL, nullptr);
175
177
  grpc_channel_args_destroy(exec_ctx, new_args);
176
178
  return channel;
177
179
  }
@@ -188,24 +190,24 @@ static grpc_client_channel_factory client_channel_factory = {
188
190
  // Asynchronously: - resolve target
189
191
  // - connect to it (trying alternatives as presented)
190
192
  // - perform handshakes
191
- grpc_channel *grpc_secure_channel_create(grpc_channel_credentials *creds,
192
- const char *target,
193
- const grpc_channel_args *args,
194
- void *reserved) {
193
+ grpc_channel* grpc_secure_channel_create(grpc_channel_credentials* creds,
194
+ const char* target,
195
+ const grpc_channel_args* args,
196
+ void* reserved) {
195
197
  grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
196
198
  GRPC_API_TRACE(
197
199
  "grpc_secure_channel_create(creds=%p, target=%s, args=%p, "
198
200
  "reserved=%p)",
199
- 4, ((void *)creds, target, (void *)args, (void *)reserved));
200
- GPR_ASSERT(reserved == NULL);
201
- grpc_channel *channel = NULL;
202
- if (creds != NULL) {
201
+ 4, ((void*)creds, target, (void*)args, (void*)reserved));
202
+ GPR_ASSERT(reserved == nullptr);
203
+ grpc_channel* channel = nullptr;
204
+ if (creds != nullptr) {
203
205
  // Add channel args containing the client channel factory and channel
204
206
  // credentials.
205
207
  grpc_arg args_to_add[] = {
206
208
  grpc_client_channel_factory_create_channel_arg(&client_channel_factory),
207
209
  grpc_channel_credentials_to_arg(creds)};
208
- grpc_channel_args *new_args = grpc_channel_args_copy_and_add(
210
+ grpc_channel_args* new_args = grpc_channel_args_copy_and_add(
209
211
  args, args_to_add, GPR_ARRAY_SIZE(args_to_add));
210
212
  // Create channel.
211
213
  channel = client_channel_factory_create_channel(
@@ -215,8 +217,8 @@ grpc_channel *grpc_secure_channel_create(grpc_channel_credentials *creds,
215
217
  grpc_channel_args_destroy(&exec_ctx, new_args);
216
218
  grpc_exec_ctx_finish(&exec_ctx);
217
219
  }
218
- return channel != NULL ? channel
219
- : grpc_lame_client_channel_create(
220
- target, GRPC_STATUS_INTERNAL,
221
- "Failed to create secure client channel");
220
+ return channel != nullptr ? channel
221
+ : grpc_lame_client_channel_create(
222
+ target, GRPC_STATUS_INTERNAL,
223
+ "Failed to create secure client channel");
222
224
  }
@@ -20,6 +20,7 @@
20
20
 
21
21
  #include <grpc/grpc.h>
22
22
 
23
+ #include <inttypes.h>
23
24
  #include <limits.h>
24
25
  #include <string.h>
25
26
 
@@ -43,34 +44,34 @@
43
44
  #include "src/core/lib/surface/server.h"
44
45
 
45
46
  typedef struct {
46
- grpc_server *server;
47
- grpc_tcp_server *tcp_server;
48
- grpc_channel_args *args;
47
+ grpc_server* server;
48
+ grpc_tcp_server* tcp_server;
49
+ grpc_channel_args* args;
49
50
  gpr_mu mu;
50
51
  bool shutdown;
51
52
  grpc_closure tcp_server_shutdown_complete;
52
- grpc_closure *server_destroy_listener_done;
53
- grpc_handshake_manager *pending_handshake_mgrs;
53
+ grpc_closure* server_destroy_listener_done;
54
+ grpc_handshake_manager* pending_handshake_mgrs;
54
55
  } server_state;
55
56
 
56
57
  typedef struct {
57
58
  gpr_refcount refs;
58
- server_state *svr_state;
59
- grpc_pollset *accepting_pollset;
60
- grpc_tcp_server_acceptor *acceptor;
61
- grpc_handshake_manager *handshake_mgr;
59
+ server_state* svr_state;
60
+ grpc_pollset* accepting_pollset;
61
+ grpc_tcp_server_acceptor* acceptor;
62
+ grpc_handshake_manager* handshake_mgr;
62
63
  // State for enforcing handshake timeout on receiving HTTP/2 settings.
63
- grpc_chttp2_transport *transport;
64
- gpr_timespec deadline;
64
+ grpc_chttp2_transport* transport;
65
+ grpc_millis deadline;
65
66
  grpc_timer timer;
66
67
  grpc_closure on_timeout;
67
68
  grpc_closure on_receive_settings;
68
69
  } server_connection_state;
69
70
 
70
71
  static void server_connection_state_unref(
71
- grpc_exec_ctx *exec_ctx, server_connection_state *connection_state) {
72
+ grpc_exec_ctx* exec_ctx, server_connection_state* connection_state) {
72
73
  if (gpr_unref(&connection_state->refs)) {
73
- if (connection_state->transport != NULL) {
74
+ if (connection_state->transport != nullptr) {
74
75
  GRPC_CHTTP2_UNREF_TRANSPORT(exec_ctx, connection_state->transport,
75
76
  "receive settings timeout");
76
77
  }
@@ -78,12 +79,12 @@ static void server_connection_state_unref(
78
79
  }
79
80
  }
80
81
 
81
- static void on_timeout(grpc_exec_ctx *exec_ctx, void *arg, grpc_error *error) {
82
- server_connection_state *connection_state = (server_connection_state *)arg;
82
+ static void on_timeout(grpc_exec_ctx* exec_ctx, void* arg, grpc_error* error) {
83
+ server_connection_state* connection_state = (server_connection_state*)arg;
83
84
  // Note that we may be called with GRPC_ERROR_NONE when the timer fires
84
85
  // or with an error indicating that the timer system is being shut down.
85
86
  if (error != GRPC_ERROR_CANCELLED) {
86
- grpc_transport_op *op = grpc_make_transport_op(NULL);
87
+ grpc_transport_op* op = grpc_make_transport_op(nullptr);
87
88
  op->disconnect_with_error = GRPC_ERROR_CREATE_FROM_STATIC_STRING(
88
89
  "Did not receive HTTP/2 settings before handshake timeout");
89
90
  grpc_transport_perform_op(exec_ctx, &connection_state->transport->base, op);
@@ -91,25 +92,25 @@ static void on_timeout(grpc_exec_ctx *exec_ctx, void *arg, grpc_error *error) {
91
92
  server_connection_state_unref(exec_ctx, connection_state);
92
93
  }
93
94
 
94
- static void on_receive_settings(grpc_exec_ctx *exec_ctx, void *arg,
95
- grpc_error *error) {
96
- server_connection_state *connection_state = (server_connection_state *)arg;
95
+ static void on_receive_settings(grpc_exec_ctx* exec_ctx, void* arg,
96
+ grpc_error* error) {
97
+ server_connection_state* connection_state = (server_connection_state*)arg;
97
98
  if (error == GRPC_ERROR_NONE) {
98
99
  grpc_timer_cancel(exec_ctx, &connection_state->timer);
99
100
  }
100
101
  server_connection_state_unref(exec_ctx, connection_state);
101
102
  }
102
103
 
103
- static void on_handshake_done(grpc_exec_ctx *exec_ctx, void *arg,
104
- grpc_error *error) {
105
- grpc_handshaker_args *args = (grpc_handshaker_args *)arg;
106
- server_connection_state *connection_state =
107
- (server_connection_state *)args->user_data;
104
+ static void on_handshake_done(grpc_exec_ctx* exec_ctx, void* arg,
105
+ grpc_error* error) {
106
+ grpc_handshaker_args* args = (grpc_handshaker_args*)arg;
107
+ server_connection_state* connection_state =
108
+ (server_connection_state*)args->user_data;
108
109
  gpr_mu_lock(&connection_state->svr_state->mu);
109
110
  if (error != GRPC_ERROR_NONE || connection_state->svr_state->shutdown) {
110
- const char *error_str = grpc_error_string(error);
111
+ const char* error_str = grpc_error_string(error);
111
112
  gpr_log(GPR_DEBUG, "Handshaking failed: %s", error_str);
112
- if (error == GRPC_ERROR_NONE && args->endpoint != NULL) {
113
+ if (error == GRPC_ERROR_NONE && args->endpoint != nullptr) {
113
114
  // We were shut down after handshaking completed successfully, so
114
115
  // destroy the endpoint here.
115
116
  // TODO(ctiller): It is currently necessary to shutdown endpoints
@@ -126,15 +127,15 @@ static void on_handshake_done(grpc_exec_ctx *exec_ctx, void *arg,
126
127
  // If the handshaking succeeded but there is no endpoint, then the
127
128
  // handshaker may have handed off the connection to some external
128
129
  // code, so we can just clean up here without creating a transport.
129
- if (args->endpoint != NULL) {
130
- grpc_transport *transport = grpc_create_chttp2_transport(
130
+ if (args->endpoint != nullptr) {
131
+ grpc_transport* transport = grpc_create_chttp2_transport(
131
132
  exec_ctx, args->args, args->endpoint, false);
132
133
  grpc_server_setup_transport(
133
134
  exec_ctx, connection_state->svr_state->server, transport,
134
135
  connection_state->accepting_pollset, args->args);
135
136
  // Use notify_on_receive_settings callback to enforce the
136
137
  // handshake deadline.
137
- connection_state->transport = (grpc_chttp2_transport *)transport;
138
+ connection_state->transport = (grpc_chttp2_transport*)transport;
138
139
  gpr_ref(&connection_state->refs);
139
140
  GRPC_CLOSURE_INIT(&connection_state->on_receive_settings,
140
141
  on_receive_settings, connection_state,
@@ -144,13 +145,13 @@ static void on_handshake_done(grpc_exec_ctx *exec_ctx, void *arg,
144
145
  &connection_state->on_receive_settings);
145
146
  grpc_channel_args_destroy(exec_ctx, args->args);
146
147
  gpr_ref(&connection_state->refs);
147
- GRPC_CHTTP2_REF_TRANSPORT((grpc_chttp2_transport *)transport,
148
+ GRPC_CHTTP2_REF_TRANSPORT((grpc_chttp2_transport*)transport,
148
149
  "receive settings timeout");
149
150
  GRPC_CLOSURE_INIT(&connection_state->on_timeout, on_timeout,
150
151
  connection_state, grpc_schedule_on_exec_ctx);
151
152
  grpc_timer_init(exec_ctx, &connection_state->timer,
152
- connection_state->deadline, &connection_state->on_timeout,
153
- gpr_now(GPR_CLOCK_MONOTONIC));
153
+ connection_state->deadline,
154
+ &connection_state->on_timeout);
154
155
  }
155
156
  }
156
157
  grpc_handshake_manager_pending_list_remove(
@@ -163,10 +164,10 @@ static void on_handshake_done(grpc_exec_ctx *exec_ctx, void *arg,
163
164
  server_connection_state_unref(exec_ctx, connection_state);
164
165
  }
165
166
 
166
- static void on_accept(grpc_exec_ctx *exec_ctx, void *arg, grpc_endpoint *tcp,
167
- grpc_pollset *accepting_pollset,
168
- grpc_tcp_server_acceptor *acceptor) {
169
- server_state *state = (server_state *)arg;
167
+ static void on_accept(grpc_exec_ctx* exec_ctx, void* arg, grpc_endpoint* tcp,
168
+ grpc_pollset* accepting_pollset,
169
+ grpc_tcp_server_acceptor* acceptor) {
170
+ server_state* state = (server_state*)arg;
170
171
  gpr_mu_lock(&state->mu);
171
172
  if (state->shutdown) {
172
173
  gpr_mu_unlock(&state->mu);
@@ -175,13 +176,13 @@ static void on_accept(grpc_exec_ctx *exec_ctx, void *arg, grpc_endpoint *tcp,
175
176
  gpr_free(acceptor);
176
177
  return;
177
178
  }
178
- grpc_handshake_manager *handshake_mgr = grpc_handshake_manager_create();
179
+ grpc_handshake_manager* handshake_mgr = grpc_handshake_manager_create();
179
180
  grpc_handshake_manager_pending_list_add(&state->pending_handshake_mgrs,
180
181
  handshake_mgr);
181
182
  gpr_mu_unlock(&state->mu);
182
183
  grpc_tcp_server_ref(state->tcp_server);
183
- server_connection_state *connection_state =
184
- (server_connection_state *)gpr_zalloc(sizeof(*connection_state));
184
+ server_connection_state* connection_state =
185
+ (server_connection_state*)gpr_zalloc(sizeof(*connection_state));
185
186
  gpr_ref_init(&connection_state->refs, 1);
186
187
  connection_state->svr_state = state;
187
188
  connection_state->accepting_pollset = accepting_pollset;
@@ -189,15 +190,12 @@ static void on_accept(grpc_exec_ctx *exec_ctx, void *arg, grpc_endpoint *tcp,
189
190
  connection_state->handshake_mgr = handshake_mgr;
190
191
  grpc_handshakers_add(exec_ctx, HANDSHAKER_SERVER, state->args,
191
192
  connection_state->handshake_mgr);
192
- const grpc_arg *timeout_arg =
193
+ const grpc_arg* timeout_arg =
193
194
  grpc_channel_args_find(state->args, GRPC_ARG_SERVER_HANDSHAKE_TIMEOUT_MS);
194
- connection_state->deadline = gpr_time_add(
195
- gpr_now(GPR_CLOCK_MONOTONIC),
196
- gpr_time_from_millis(
197
- grpc_channel_arg_get_integer(
198
- timeout_arg,
199
- (grpc_integer_options){120 * GPR_MS_PER_SEC, 1, INT_MAX}),
200
- GPR_TIMESPAN));
195
+ connection_state->deadline =
196
+ grpc_exec_ctx_now(exec_ctx) +
197
+ grpc_channel_arg_get_integer(timeout_arg,
198
+ {120 * GPR_MS_PER_SEC, 1, INT_MAX});
201
199
  grpc_handshake_manager_do_handshake(exec_ctx, connection_state->handshake_mgr,
202
200
  tcp, state->args,
203
201
  connection_state->deadline, acceptor,
@@ -205,10 +203,10 @@ static void on_accept(grpc_exec_ctx *exec_ctx, void *arg, grpc_endpoint *tcp,
205
203
  }
206
204
 
207
205
  /* Server callback: start listening on our ports */
208
- static void server_start_listener(grpc_exec_ctx *exec_ctx, grpc_server *server,
209
- void *arg, grpc_pollset **pollsets,
206
+ static void server_start_listener(grpc_exec_ctx* exec_ctx, grpc_server* server,
207
+ void* arg, grpc_pollset** pollsets,
210
208
  size_t pollset_count) {
211
- server_state *state = (server_state *)arg;
209
+ server_state* state = (server_state*)arg;
212
210
  gpr_mu_lock(&state->mu);
213
211
  state->shutdown = false;
214
212
  gpr_mu_unlock(&state->mu);
@@ -216,12 +214,12 @@ static void server_start_listener(grpc_exec_ctx *exec_ctx, grpc_server *server,
216
214
  on_accept, state);
217
215
  }
218
216
 
219
- static void tcp_server_shutdown_complete(grpc_exec_ctx *exec_ctx, void *arg,
220
- grpc_error *error) {
221
- server_state *state = (server_state *)arg;
217
+ static void tcp_server_shutdown_complete(grpc_exec_ctx* exec_ctx, void* arg,
218
+ grpc_error* error) {
219
+ server_state* state = (server_state*)arg;
222
220
  /* ensure all threads have unlocked */
223
221
  gpr_mu_lock(&state->mu);
224
- grpc_closure *destroy_done = state->server_destroy_listener_done;
222
+ grpc_closure* destroy_done = state->server_destroy_listener_done;
225
223
  GPR_ASSERT(state->shutdown);
226
224
  grpc_handshake_manager_pending_list_shutdown_all(
227
225
  exec_ctx, state->pending_handshake_mgrs, GRPC_ERROR_REF(error));
@@ -229,7 +227,7 @@ static void tcp_server_shutdown_complete(grpc_exec_ctx *exec_ctx, void *arg,
229
227
  // Flush queued work before destroying handshaker factory, since that
230
228
  // may do a synchronous unref.
231
229
  grpc_exec_ctx_flush(exec_ctx);
232
- if (destroy_done != NULL) {
230
+ if (destroy_done != nullptr) {
233
231
  destroy_done->cb(exec_ctx, destroy_done->cb_arg, GRPC_ERROR_REF(error));
234
232
  grpc_exec_ctx_flush(exec_ctx);
235
233
  }
@@ -240,31 +238,31 @@ static void tcp_server_shutdown_complete(grpc_exec_ctx *exec_ctx, void *arg,
240
238
 
241
239
  /* Server callback: destroy the tcp listener (so we don't generate further
242
240
  callbacks) */
243
- static void server_destroy_listener(grpc_exec_ctx *exec_ctx,
244
- grpc_server *server, void *arg,
245
- grpc_closure *destroy_done) {
246
- server_state *state = (server_state *)arg;
241
+ static void server_destroy_listener(grpc_exec_ctx* exec_ctx,
242
+ grpc_server* server, void* arg,
243
+ grpc_closure* destroy_done) {
244
+ server_state* state = (server_state*)arg;
247
245
  gpr_mu_lock(&state->mu);
248
246
  state->shutdown = true;
249
247
  state->server_destroy_listener_done = destroy_done;
250
- grpc_tcp_server *tcp_server = state->tcp_server;
248
+ grpc_tcp_server* tcp_server = state->tcp_server;
251
249
  gpr_mu_unlock(&state->mu);
252
250
  grpc_tcp_server_shutdown_listeners(exec_ctx, tcp_server);
253
251
  grpc_tcp_server_unref(exec_ctx, tcp_server);
254
252
  }
255
253
 
256
- grpc_error *grpc_chttp2_server_add_port(grpc_exec_ctx *exec_ctx,
257
- grpc_server *server, const char *addr,
258
- grpc_channel_args *args,
259
- int *port_num) {
260
- grpc_resolved_addresses *resolved = NULL;
261
- grpc_tcp_server *tcp_server = NULL;
254
+ grpc_error* grpc_chttp2_server_add_port(grpc_exec_ctx* exec_ctx,
255
+ grpc_server* server, const char* addr,
256
+ grpc_channel_args* args,
257
+ int* port_num) {
258
+ grpc_resolved_addresses* resolved = nullptr;
259
+ grpc_tcp_server* tcp_server = nullptr;
262
260
  size_t i;
263
261
  size_t count = 0;
264
262
  int port_temp;
265
- grpc_error *err = GRPC_ERROR_NONE;
266
- server_state *state = NULL;
267
- grpc_error **errors = NULL;
263
+ grpc_error* err = GRPC_ERROR_NONE;
264
+ server_state* state = nullptr;
265
+ grpc_error** errors = nullptr;
268
266
  size_t naddrs = 0;
269
267
 
270
268
  *port_num = -1;
@@ -274,7 +272,7 @@ grpc_error *grpc_chttp2_server_add_port(grpc_exec_ctx *exec_ctx,
274
272
  if (err != GRPC_ERROR_NONE) {
275
273
  goto error;
276
274
  }
277
- state = (server_state *)gpr_zalloc(sizeof(*state));
275
+ state = (server_state*)gpr_zalloc(sizeof(*state));
278
276
  GRPC_CLOSURE_INIT(&state->tcp_server_shutdown_complete,
279
277
  tcp_server_shutdown_complete, state,
280
278
  grpc_schedule_on_exec_ctx);
@@ -291,7 +289,7 @@ grpc_error *grpc_chttp2_server_add_port(grpc_exec_ctx *exec_ctx,
291
289
  gpr_mu_init(&state->mu);
292
290
 
293
291
  naddrs = resolved->naddrs;
294
- errors = (grpc_error **)gpr_malloc(sizeof(*errors) * naddrs);
292
+ errors = (grpc_error**)gpr_malloc(sizeof(*errors) * naddrs);
295
293
  for (i = 0; i < naddrs; i++) {
296
294
  errors[i] =
297
295
  grpc_tcp_server_add_port(tcp_server, &resolved->addrs[i], &port_temp);
@@ -305,21 +303,22 @@ grpc_error *grpc_chttp2_server_add_port(grpc_exec_ctx *exec_ctx,
305
303
  }
306
304
  }
307
305
  if (count == 0) {
308
- char *msg;
306
+ char* msg;
309
307
  gpr_asprintf(&msg, "No address added out of total %" PRIuPTR " resolved",
310
308
  naddrs);
311
309
  err = GRPC_ERROR_CREATE_REFERENCING_FROM_COPIED_STRING(msg, errors, naddrs);
312
310
  gpr_free(msg);
313
311
  goto error;
314
312
  } else if (count != naddrs) {
315
- char *msg;
316
- gpr_asprintf(&msg, "Only %" PRIuPTR
317
- " addresses added out of total %" PRIuPTR " resolved",
313
+ char* msg;
314
+ gpr_asprintf(&msg,
315
+ "Only %" PRIuPTR " addresses added out of total %" PRIuPTR
316
+ " resolved",
318
317
  count, naddrs);
319
318
  err = GRPC_ERROR_CREATE_REFERENCING_FROM_COPIED_STRING(msg, errors, naddrs);
320
319
  gpr_free(msg);
321
320
 
322
- const char *warning_message = grpc_error_string(err);
321
+ const char* warning_message = grpc_error_string(err);
323
322
  gpr_log(GPR_INFO, "WARNING: %s", warning_message);
324
323
 
325
324
  /* we managed to bind some addresses: continue */
@@ -346,7 +345,7 @@ error:
346
345
  *port_num = 0;
347
346
 
348
347
  done:
349
- if (errors != NULL) {
348
+ if (errors != nullptr) {
350
349
  for (i = 0; i < naddrs; i++) {
351
350
  GRPC_ERROR_UNREF(errors[i]);
352
351
  }