grpc 1.31.1 → 1.35.0.pre1

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 (1104) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +719 -17819
  3. data/etc/roots.pem +257 -573
  4. data/include/grpc/compression.h +1 -1
  5. data/include/grpc/grpc.h +15 -7
  6. data/include/grpc/grpc_security.h +254 -186
  7. data/include/grpc/impl/codegen/README.md +22 -0
  8. data/include/grpc/impl/codegen/atm_windows.h +4 -0
  9. data/include/grpc/impl/codegen/byte_buffer.h +1 -1
  10. data/include/grpc/impl/codegen/grpc_types.h +10 -8
  11. data/include/grpc/impl/codegen/log.h +0 -2
  12. data/include/grpc/impl/codegen/port_platform.h +28 -56
  13. data/include/grpc/impl/codegen/sync_windows.h +4 -0
  14. data/include/grpc/slice_buffer.h +3 -3
  15. data/include/grpc/support/sync.h +3 -3
  16. data/include/grpc/support/time.h +7 -7
  17. data/src/core/ext/filters/client_channel/backend_metric.cc +2 -4
  18. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -2
  19. data/src/core/ext/filters/client_channel/client_channel.cc +2831 -1540
  20. data/src/core/ext/filters/client_channel/client_channel.h +1 -5
  21. data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -3
  22. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
  23. data/src/core/ext/filters/client_channel/config_selector.cc +0 -4
  24. data/src/core/ext/filters/client_channel/config_selector.h +40 -8
  25. data/src/core/ext/filters/client_channel/dynamic_filters.cc +186 -0
  26. data/src/core/ext/filters/client_channel/dynamic_filters.h +99 -0
  27. data/src/core/ext/filters/client_channel/health/health_check_client.cc +16 -8
  28. data/src/core/ext/filters/client_channel/health/health_check_client.h +4 -4
  29. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +7 -9
  30. data/src/core/ext/filters/client_channel/http_proxy.cc +21 -20
  31. data/src/core/ext/filters/client_channel/lb_policy.cc +6 -2
  32. data/src/core/ext/filters/client_channel/lb_policy.h +8 -7
  33. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +48 -35
  34. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +7 -5
  35. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +10 -7
  36. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +1 -1
  37. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +210 -192
  38. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -13
  39. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -3
  40. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -37
  41. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +3 -1
  42. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +3 -3
  43. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -1
  44. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +23 -17
  45. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +79 -30
  46. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +10 -9
  47. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +14 -34
  48. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +26 -15
  49. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +350 -130
  50. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +52 -24
  51. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +24 -0
  52. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +812 -0
  53. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +722 -0
  54. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +1262 -0
  55. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +8 -1
  56. data/src/core/ext/filters/client_channel/resolver.cc +3 -1
  57. data/src/core/ext/filters/client_channel/resolver.h +4 -1
  58. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +9 -16
  59. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +1 -32
  60. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +3 -3
  61. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +457 -19
  62. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +5 -0
  63. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +1 -1
  64. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  65. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +7 -10
  66. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +4 -4
  67. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +1 -1
  68. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +35 -28
  69. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +664 -63
  70. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +28 -0
  71. data/src/core/ext/filters/client_channel/resolver_factory.h +6 -6
  72. data/src/core/ext/filters/client_channel/resolver_registry.cc +40 -39
  73. data/src/core/ext/filters/client_channel/resolver_registry.h +2 -2
  74. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +29 -74
  75. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +12 -11
  76. data/src/core/ext/filters/client_channel/retry_throttle.cc +5 -3
  77. data/src/core/ext/filters/client_channel/retry_throttle.h +4 -2
  78. data/src/core/ext/filters/client_channel/server_address.cc +120 -7
  79. data/src/core/ext/filters/client_channel/server_address.h +44 -21
  80. data/src/core/ext/filters/client_channel/service_config.cc +18 -13
  81. data/src/core/ext/filters/client_channel/service_config.h +8 -5
  82. data/src/core/ext/filters/client_channel/service_config_call_data.h +19 -1
  83. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -2
  84. data/src/core/ext/filters/client_channel/service_config_parser.cc +8 -6
  85. data/src/core/ext/filters/client_channel/service_config_parser.h +8 -5
  86. data/src/core/ext/filters/client_channel/subchannel.cc +115 -87
  87. data/src/core/ext/filters/client_channel/subchannel.h +30 -24
  88. data/src/core/ext/filters/client_channel/subchannel_interface.h +41 -5
  89. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +6 -2
  90. data/src/core/ext/filters/deadline/deadline_filter.cc +87 -79
  91. data/src/core/ext/filters/deadline/deadline_filter.h +7 -11
  92. data/src/core/ext/filters/http/client/http_client_filter.cc +1 -1
  93. data/src/core/ext/filters/http/client_authority_filter.cc +6 -6
  94. data/src/core/ext/filters/http/http_filters_plugin.cc +6 -3
  95. data/src/core/ext/filters/http/server/http_server_filter.cc +3 -3
  96. data/src/core/ext/filters/max_age/max_age_filter.cc +3 -2
  97. data/src/core/ext/filters/message_size/message_size_filter.cc +3 -2
  98. data/src/core/ext/filters/message_size/message_size_filter.h +2 -1
  99. data/src/core/ext/filters/workarounds/workaround_utils.cc +1 -1
  100. data/src/core/ext/transport/chttp2/client/authority.cc +3 -3
  101. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +87 -31
  102. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +19 -2
  103. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +20 -8
  104. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +21 -10
  105. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +34 -47
  106. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +200 -100
  107. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -1
  108. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +2 -2
  109. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +16 -9
  110. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +3 -2
  111. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +7 -7
  112. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +267 -319
  113. data/src/core/ext/transport/chttp2/transport/flow_control.cc +11 -3
  114. data/src/core/ext/transport/chttp2/transport/flow_control.h +13 -3
  115. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +2 -1
  116. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +2 -2
  117. data/src/core/ext/transport/chttp2/transport/frame_settings.h +2 -1
  118. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +6 -6
  119. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +12 -8
  120. data/src/core/ext/transport/chttp2/transport/internal.h +10 -2
  121. data/src/core/ext/transport/chttp2/transport/parsing.cc +19 -31
  122. data/src/core/ext/transport/chttp2/transport/writing.cc +8 -8
  123. data/src/core/ext/transport/inproc/inproc_transport.cc +52 -18
  124. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +1 -0
  125. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +1 -1
  126. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +7 -0
  127. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +244 -0
  128. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +865 -0
  129. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -0
  130. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +253 -0
  131. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +458 -0
  132. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1818 -0
  133. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +35 -0
  134. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +77 -0
  135. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +55 -0
  136. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +349 -0
  137. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +124 -0
  138. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +428 -0
  139. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +35 -0
  140. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +88 -0
  141. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +310 -0
  142. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +991 -0
  143. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +103 -0
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +388 -0
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +34 -0
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +78 -0
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +53 -0
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +149 -0
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +241 -0
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +839 -0
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +170 -0
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +752 -0
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +36 -0
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +88 -0
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +176 -0
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +730 -0
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +28 -0
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +65 -0
  159. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/socket_option.upb.c +8 -8
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +95 -0
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +36 -0
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +92 -0
  163. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +91 -0
  164. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +243 -0
  165. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +91 -0
  166. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +305 -0
  167. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +112 -0
  168. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +367 -0
  169. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +33 -0
  170. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +73 -0
  171. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +128 -0
  172. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +512 -0
  173. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +155 -0
  174. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +591 -0
  175. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +41 -0
  176. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +107 -0
  177. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +178 -0
  178. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +662 -0
  179. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +63 -0
  180. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +220 -0
  181. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +900 -0
  182. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +3640 -0
  183. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +60 -0
  184. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +159 -0
  185. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +50 -0
  186. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +122 -0
  187. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +364 -0
  188. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1475 -0
  189. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +20 -0
  190. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +35 -0
  191. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +110 -0
  192. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +426 -0
  193. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +76 -0
  194. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +236 -0
  195. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +147 -0
  196. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +621 -0
  197. data/src/core/ext/upb-generated/envoy/{api/v2 → service/cluster/v3}/cds.upb.c +6 -7
  198. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +56 -0
  199. data/src/core/ext/upb-generated/envoy/service/discovery/{v2 → v3}/ads.upb.c +6 -5
  200. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +56 -0
  201. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +139 -0
  202. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +487 -0
  203. data/src/core/ext/upb-generated/envoy/{api/v2 → service/endpoint/v3}/eds.upb.c +6 -7
  204. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +56 -0
  205. data/src/core/ext/upb-generated/envoy/{api/v2 → service/listener/v3}/lds.upb.c +6 -7
  206. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +56 -0
  207. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +55 -0
  208. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +151 -0
  209. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/rds.upb.c +6 -7
  210. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +56 -0
  211. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/srds.upb.c +6 -7
  212. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +56 -0
  213. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +47 -0
  214. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +128 -0
  215. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +35 -0
  216. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +84 -0
  217. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +34 -0
  218. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +78 -0
  219. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +64 -0
  220. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +166 -0
  221. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +54 -0
  222. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +146 -0
  223. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +63 -0
  224. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +207 -0
  225. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +88 -0
  226. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +301 -0
  227. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +90 -0
  228. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +283 -0
  229. data/src/core/ext/upb-generated/envoy/type/{http.upb.c → v3/http.upb.c} +2 -2
  230. data/src/core/ext/upb-generated/envoy/type/{http.upb.h → v3/http.upb.h} +9 -8
  231. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +40 -0
  232. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +99 -0
  233. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +51 -0
  234. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +130 -0
  235. data/src/core/ext/upb-generated/envoy/type/{semantic_version.upb.c → v3/semantic_version.upb.c} +7 -6
  236. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +68 -0
  237. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -0
  238. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +242 -0
  239. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +830 -0
  240. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +234 -0
  241. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +842 -0
  242. data/src/core/ext/upb-generated/google/api/http.upb.c +3 -3
  243. data/src/core/ext/upb-generated/google/api/http.upb.h +25 -6
  244. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +1 -1
  245. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +7 -0
  246. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +103 -103
  247. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +455 -292
  248. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +1 -1
  249. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +7 -0
  250. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -1
  251. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +7 -0
  252. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +4 -4
  253. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +23 -4
  254. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +1 -1
  255. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +7 -0
  256. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +9 -9
  257. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +55 -0
  258. data/src/core/ext/upb-generated/google/rpc/status.upb.c +1 -1
  259. data/src/core/ext/upb-generated/google/rpc/status.upb.h +10 -3
  260. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +4 -4
  261. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +11 -3
  262. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +41 -41
  263. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +149 -76
  264. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +5 -5
  265. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +21 -6
  266. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +2 -2
  267. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +13 -0
  268. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +17 -17
  269. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +82 -25
  270. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +3 -3
  271. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +19 -0
  272. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +31 -0
  273. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +64 -0
  274. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +1 -0
  275. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +2 -2
  276. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +9 -2
  277. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +27 -0
  278. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +60 -0
  279. data/src/core/ext/upb-generated/udpa/core/v1/authority.upb.c +28 -0
  280. data/src/core/ext/upb-generated/udpa/core/v1/authority.upb.h +60 -0
  281. data/src/core/ext/upb-generated/udpa/core/v1/collection_entry.upb.c +52 -0
  282. data/src/core/ext/upb-generated/udpa/core/v1/collection_entry.upb.h +143 -0
  283. data/src/core/ext/upb-generated/udpa/core/v1/context_params.upb.c +42 -0
  284. data/src/core/ext/upb-generated/udpa/core/v1/context_params.upb.h +84 -0
  285. data/src/core/ext/upb-generated/udpa/core/v1/resource.upb.c +36 -0
  286. data/src/core/ext/upb-generated/udpa/core/v1/resource.upb.h +94 -0
  287. data/src/core/ext/upb-generated/udpa/core/v1/resource_locator.upb.c +54 -0
  288. data/src/core/ext/upb-generated/udpa/core/v1/resource_locator.upb.h +173 -0
  289. data/src/core/ext/upb-generated/udpa/core/v1/resource_name.upb.c +36 -0
  290. data/src/core/ext/upb-generated/udpa/core/v1/resource_name.upb.h +92 -0
  291. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.c +3 -3
  292. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.h +7 -0
  293. data/src/core/ext/upb-generated/validate/validate.upb.c +68 -68
  294. data/src/core/ext/upb-generated/validate/validate.upb.h +296 -157
  295. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +38 -0
  296. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +30 -0
  297. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +41 -0
  298. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +35 -0
  299. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +254 -0
  300. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +105 -0
  301. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +100 -0
  302. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +45 -0
  303. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +558 -0
  304. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +145 -0
  305. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +53 -0
  306. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +35 -0
  307. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +133 -0
  308. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +35 -0
  309. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +127 -0
  310. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +65 -0
  311. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +56 -0
  312. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +35 -0
  313. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +266 -0
  314. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +125 -0
  315. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +143 -0
  316. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +55 -0
  317. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +56 -0
  318. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +35 -0
  319. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +66 -0
  320. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +40 -0
  321. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +263 -0
  322. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +100 -0
  323. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +233 -0
  324. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +70 -0
  325. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +56 -0
  326. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +35 -0
  327. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +228 -0
  328. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +80 -0
  329. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +46 -0
  330. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +35 -0
  331. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +59 -0
  332. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +35 -0
  333. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +55 -0
  334. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +35 -0
  335. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +110 -0
  336. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +50 -0
  337. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +113 -0
  338. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +50 -0
  339. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +146 -0
  340. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +55 -0
  341. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +50 -0
  342. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +35 -0
  343. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +190 -0
  344. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +55 -0
  345. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +185 -0
  346. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +65 -0
  347. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +62 -0
  348. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +40 -0
  349. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +97 -0
  350. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +40 -0
  351. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +915 -0
  352. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +280 -0
  353. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +71 -0
  354. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +45 -0
  355. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +64 -0
  356. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +40 -0
  357. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +511 -0
  358. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +115 -0
  359. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +48 -0
  360. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +30 -0
  361. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +166 -0
  362. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +55 -0
  363. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +105 -0
  364. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +45 -0
  365. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +249 -0
  366. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +60 -0
  367. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.c +72 -0
  368. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.h +35 -0
  369. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +60 -0
  370. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +35 -0
  371. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +152 -0
  372. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +60 -0
  373. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.c +83 -0
  374. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.h +35 -0
  375. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.c +82 -0
  376. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.h +35 -0
  377. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +83 -0
  378. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +40 -0
  379. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.c +86 -0
  380. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.h +35 -0
  381. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.c +74 -0
  382. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.h +35 -0
  383. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +64 -0
  384. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +40 -0
  385. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +54 -0
  386. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +35 -0
  387. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +53 -0
  388. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +35 -0
  389. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +73 -0
  390. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +45 -0
  391. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +72 -0
  392. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +40 -0
  393. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +81 -0
  394. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +45 -0
  395. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +92 -0
  396. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +65 -0
  397. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +95 -0
  398. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +55 -0
  399. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +34 -0
  400. data/src/core/ext/{upb-generated/gogoproto/gogo.upb.h → upbdefs-generated/envoy/type/v3/http.upbdefs.h} +10 -9
  401. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +59 -0
  402. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +40 -0
  403. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +54 -0
  404. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +45 -0
  405. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +47 -0
  406. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +35 -0
  407. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +40 -0
  408. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +30 -0
  409. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +61 -0
  410. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +45 -0
  411. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +38 -0
  412. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +35 -0
  413. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +386 -0
  414. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +165 -0
  415. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +39 -0
  416. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +35 -0
  417. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +37 -0
  418. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +35 -0
  419. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +65 -0
  420. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +50 -0
  421. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +39 -0
  422. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +35 -0
  423. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +66 -0
  424. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +75 -0
  425. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +42 -0
  426. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +35 -0
  427. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +70 -0
  428. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +45 -0
  429. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +56 -0
  430. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +35 -0
  431. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +33 -0
  432. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +30 -0
  433. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +49 -0
  434. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +35 -0
  435. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +43 -0
  436. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +35 -0
  437. data/src/core/ext/upbdefs-generated/udpa/core/v1/authority.upbdefs.c +42 -0
  438. data/src/core/ext/upbdefs-generated/udpa/core/v1/authority.upbdefs.h +35 -0
  439. data/src/core/ext/upbdefs-generated/udpa/core/v1/collection_entry.upbdefs.c +62 -0
  440. data/src/core/ext/upbdefs-generated/udpa/core/v1/collection_entry.upbdefs.h +40 -0
  441. data/src/core/ext/upbdefs-generated/udpa/core/v1/context_params.upbdefs.c +45 -0
  442. data/src/core/ext/upbdefs-generated/udpa/core/v1/context_params.upbdefs.h +40 -0
  443. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource.upbdefs.c +49 -0
  444. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource.upbdefs.h +35 -0
  445. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_locator.upbdefs.c +68 -0
  446. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_locator.upbdefs.h +40 -0
  447. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_name.upbdefs.c +51 -0
  448. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_name.upbdefs.h +35 -0
  449. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +307 -0
  450. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +145 -0
  451. data/src/core/ext/xds/certificate_provider_factory.h +61 -0
  452. data/src/core/ext/xds/certificate_provider_registry.cc +103 -0
  453. data/src/core/ext/xds/certificate_provider_registry.h +57 -0
  454. data/src/core/ext/xds/certificate_provider_store.cc +87 -0
  455. data/src/core/ext/xds/certificate_provider_store.h +112 -0
  456. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +144 -0
  457. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +69 -0
  458. data/src/core/ext/xds/xds_api.cc +2308 -0
  459. data/src/core/ext/xds/xds_api.h +469 -0
  460. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.cc +208 -19
  461. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.h +31 -11
  462. data/src/core/ext/xds/xds_certificate_provider.cc +299 -0
  463. data/src/core/ext/xds/xds_certificate_provider.h +112 -0
  464. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_args.h +9 -6
  465. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.cc +656 -865
  466. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.h +126 -99
  467. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.cc +61 -18
  468. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.h +38 -10
  469. data/src/core/ext/xds/xds_server_config_fetcher.cc +131 -0
  470. data/src/core/lib/channel/channel_args.cc +9 -8
  471. data/src/core/lib/channel/channel_args.h +0 -1
  472. data/src/core/lib/channel/channel_trace.cc +4 -2
  473. data/src/core/lib/channel/channel_trace.h +1 -1
  474. data/src/core/lib/channel/channelz.cc +37 -74
  475. data/src/core/lib/channel/channelz.h +14 -23
  476. data/src/core/lib/channel/channelz_registry.cc +15 -12
  477. data/src/core/lib/channel/channelz_registry.h +3 -1
  478. data/src/core/lib/channel/handshaker.cc +2 -2
  479. data/src/core/lib/channel/handshaker.h +2 -2
  480. data/src/core/lib/compression/compression.cc +8 -4
  481. data/src/core/lib/compression/compression_args.cc +3 -2
  482. data/src/core/lib/compression/compression_internal.cc +10 -5
  483. data/src/core/lib/compression/compression_internal.h +2 -1
  484. data/src/core/lib/compression/stream_compression_identity.cc +1 -3
  485. data/src/core/lib/debug/stats.h +2 -2
  486. data/src/core/lib/debug/stats_data.cc +1 -0
  487. data/src/core/lib/debug/stats_data.h +13 -13
  488. data/src/core/lib/gpr/alloc.cc +3 -2
  489. data/src/core/lib/gpr/cpu_iphone.cc +10 -2
  490. data/src/core/lib/gpr/log.cc +53 -16
  491. data/src/core/lib/gpr/log_linux.cc +19 -3
  492. data/src/core/lib/gpr/log_posix.cc +15 -1
  493. data/src/core/lib/gpr/log_windows.cc +18 -4
  494. data/src/core/lib/gpr/murmur_hash.cc +1 -1
  495. data/src/core/lib/gpr/spinlock.h +10 -2
  496. data/src/core/lib/gpr/string.cc +23 -22
  497. data/src/core/lib/gpr/string.h +5 -6
  498. data/src/core/lib/gpr/sync.cc +4 -4
  499. data/src/core/lib/gpr/sync_posix.cc +2 -8
  500. data/src/core/lib/gpr/time.cc +12 -12
  501. data/src/core/lib/gpr/time_precise.cc +5 -2
  502. data/src/core/lib/gpr/time_precise.h +6 -2
  503. data/src/core/lib/gpr/tls.h +4 -0
  504. data/src/core/lib/gpr/tls_msvc.h +2 -0
  505. data/src/core/lib/gpr/tls_stdcpp.h +48 -0
  506. data/src/core/lib/gpr/useful.h +5 -4
  507. data/src/core/lib/gprpp/arena.h +3 -2
  508. data/src/core/lib/gprpp/dual_ref_counted.h +331 -0
  509. data/src/core/lib/gprpp/examine_stack.cc +43 -0
  510. data/src/core/lib/gprpp/examine_stack.h +46 -0
  511. data/src/core/lib/gprpp/fork.cc +2 -2
  512. data/src/core/lib/gprpp/manual_constructor.h +1 -1
  513. data/src/core/lib/gprpp/orphanable.h +4 -8
  514. data/src/core/lib/gprpp/ref_counted.h +91 -68
  515. data/src/core/lib/gprpp/ref_counted_ptr.h +166 -7
  516. data/src/core/lib/gprpp/stat.h +38 -0
  517. data/src/core/lib/gprpp/stat_posix.cc +49 -0
  518. data/src/core/lib/gprpp/stat_windows.cc +48 -0
  519. data/src/core/lib/gprpp/thd.h +2 -2
  520. data/src/core/lib/gprpp/thd_posix.cc +42 -37
  521. data/src/core/lib/gprpp/thd_windows.cc +3 -1
  522. data/src/core/lib/http/httpcli.cc +1 -1
  523. data/src/core/lib/http/httpcli.h +2 -3
  524. data/src/core/lib/http/httpcli_security_connector.cc +1 -1
  525. data/src/core/lib/http/parser.cc +47 -27
  526. data/src/core/lib/iomgr/call_combiner.cc +8 -5
  527. data/src/core/lib/iomgr/combiner.cc +2 -1
  528. data/src/core/lib/iomgr/endpoint.cc +5 -1
  529. data/src/core/lib/iomgr/endpoint.h +8 -4
  530. data/src/core/lib/iomgr/endpoint_cfstream.cc +36 -11
  531. data/src/core/lib/iomgr/error.cc +17 -12
  532. data/src/core/lib/iomgr/error_internal.h +1 -1
  533. data/src/core/lib/iomgr/ev_epoll1_linux.cc +20 -13
  534. data/src/core/lib/iomgr/ev_epollex_linux.cc +25 -17
  535. data/src/core/lib/iomgr/ev_poll_posix.cc +9 -7
  536. data/src/core/lib/iomgr/ev_posix.cc +0 -2
  537. data/src/core/lib/iomgr/exec_ctx.cc +1 -1
  538. data/src/core/lib/iomgr/exec_ctx.h +16 -12
  539. data/src/core/lib/iomgr/executor.cc +2 -1
  540. data/src/core/lib/iomgr/executor.h +1 -1
  541. data/src/core/lib/iomgr/executor/mpmcqueue.h +5 -5
  542. data/src/core/lib/iomgr/executor/threadpool.h +4 -4
  543. data/src/core/lib/iomgr/iomgr.cc +1 -11
  544. data/src/core/lib/iomgr/iomgr.h +0 -10
  545. data/src/core/lib/iomgr/load_file.h +1 -1
  546. data/src/core/lib/iomgr/lockfree_event.cc +19 -14
  547. data/src/core/lib/iomgr/lockfree_event.h +2 -2
  548. data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.cc +128 -44
  549. data/src/core/lib/iomgr/parse_address.h +77 -0
  550. data/src/core/lib/iomgr/poller/eventmanager_libuv.cc +2 -1
  551. data/src/core/lib/iomgr/poller/eventmanager_libuv.h +1 -1
  552. data/src/core/lib/iomgr/pollset_set_custom.cc +1 -1
  553. data/src/core/lib/iomgr/python_util.h +4 -4
  554. data/src/core/lib/iomgr/resolve_address.cc +4 -4
  555. data/src/core/lib/iomgr/resolve_address_posix.cc +1 -5
  556. data/src/core/lib/iomgr/resource_quota.cc +4 -4
  557. data/src/core/lib/iomgr/sockaddr_utils.cc +12 -11
  558. data/src/core/lib/iomgr/sockaddr_utils.h +3 -2
  559. data/src/core/lib/iomgr/socket_factory_posix.cc +3 -2
  560. data/src/core/lib/iomgr/socket_mutator.cc +3 -2
  561. data/src/core/lib/iomgr/tcp_client.cc +3 -3
  562. data/src/core/lib/iomgr/tcp_client_custom.cc +7 -6
  563. data/src/core/lib/iomgr/tcp_custom.cc +53 -32
  564. data/src/core/lib/iomgr/tcp_posix.cc +43 -21
  565. data/src/core/lib/iomgr/tcp_server_custom.cc +28 -22
  566. data/src/core/lib/iomgr/tcp_windows.cc +26 -10
  567. data/src/core/lib/iomgr/timer_custom.cc +5 -5
  568. data/src/core/lib/iomgr/timer_generic.cc +3 -3
  569. data/src/core/lib/iomgr/timer_manager.cc +2 -2
  570. data/src/core/lib/iomgr/udp_server.cc +1 -2
  571. data/src/core/lib/iomgr/udp_server.h +1 -2
  572. data/src/core/lib/iomgr/unix_sockets_posix.cc +32 -21
  573. data/src/core/lib/iomgr/unix_sockets_posix.h +5 -0
  574. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +7 -0
  575. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -2
  576. data/src/core/lib/json/json.h +12 -2
  577. data/src/core/lib/json/json_reader.cc +8 -4
  578. data/src/core/lib/json/json_util.cc +58 -0
  579. data/src/core/lib/json/json_util.h +204 -0
  580. data/src/core/lib/json/json_writer.cc +2 -1
  581. data/src/core/lib/security/authorization/authorization_engine.cc +177 -0
  582. data/src/core/lib/security/authorization/authorization_engine.h +84 -0
  583. data/src/core/lib/security/authorization/evaluate_args.cc +148 -0
  584. data/src/core/lib/security/authorization/evaluate_args.h +59 -0
  585. data/src/core/lib/security/authorization/mock_cel/activation.h +57 -0
  586. data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +44 -0
  587. data/src/core/lib/security/authorization/mock_cel/cel_expression.h +69 -0
  588. data/src/core/lib/security/authorization/mock_cel/cel_value.h +97 -0
  589. data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +67 -0
  590. data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +57 -0
  591. data/src/core/lib/security/context/security_context.cc +4 -3
  592. data/src/core/lib/security/context/security_context.h +3 -1
  593. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +1 -1
  594. data/src/core/lib/security/credentials/credentials.cc +7 -7
  595. data/src/core/lib/security/credentials/credentials.h +3 -3
  596. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +413 -0
  597. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +80 -0
  598. data/src/core/lib/security/credentials/external/aws_request_signer.cc +213 -0
  599. data/src/core/lib/security/credentials/external/aws_request_signer.h +72 -0
  600. data/src/core/lib/security/credentials/external/external_account_credentials.cc +497 -0
  601. data/src/core/lib/security/credentials/external/external_account_credentials.h +120 -0
  602. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +135 -0
  603. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +48 -0
  604. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +213 -0
  605. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +58 -0
  606. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -1
  607. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +74 -50
  608. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +64 -0
  609. data/src/core/lib/security/credentials/jwt/json_token.cc +6 -3
  610. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +4 -3
  611. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +8 -4
  612. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +39 -46
  613. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +5 -4
  614. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +1 -1
  615. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +5 -5
  616. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +1 -1
  617. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +346 -0
  618. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +213 -0
  619. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +399 -0
  620. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +138 -0
  621. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +78 -150
  622. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +57 -187
  623. data/src/core/lib/security/credentials/tls/tls_credentials.cc +16 -12
  624. data/src/core/lib/security/credentials/tls/tls_credentials.h +2 -2
  625. data/src/core/lib/security/credentials/tls/tls_utils.cc +91 -0
  626. data/src/core/lib/security/credentials/tls/tls_utils.h +38 -0
  627. data/src/core/lib/security/credentials/xds/xds_credentials.cc +175 -0
  628. data/src/core/lib/security/credentials/xds/xds_credentials.h +69 -0
  629. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +1 -1
  630. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +10 -15
  631. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +121 -0
  632. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +87 -0
  633. data/src/core/lib/security/security_connector/load_system_roots.h +4 -0
  634. data/src/core/lib/security/security_connector/load_system_roots_linux.h +2 -0
  635. data/src/core/lib/security/security_connector/local/local_security_connector.cc +3 -3
  636. data/src/core/lib/security/security_connector/security_connector.cc +4 -3
  637. data/src/core/lib/security/security_connector/security_connector.h +4 -2
  638. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +4 -4
  639. data/src/core/lib/security/security_connector/ssl_utils.cc +2 -2
  640. data/src/core/lib/security/security_connector/ssl_utils.h +19 -19
  641. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +342 -279
  642. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +105 -61
  643. data/src/core/lib/security/transport/secure_endpoint.cc +9 -3
  644. data/src/core/lib/security/transport/security_handshaker.cc +3 -3
  645. data/src/core/lib/security/transport/server_auth_filter.cc +2 -1
  646. data/src/core/lib/security/util/json_util.h +1 -0
  647. data/src/core/lib/slice/slice.cc +7 -4
  648. data/src/core/lib/slice/slice_buffer.cc +2 -1
  649. data/src/core/lib/slice/slice_intern.cc +6 -7
  650. data/src/core/lib/slice/slice_internal.h +2 -2
  651. data/src/core/lib/surface/call.cc +53 -44
  652. data/src/core/lib/surface/call.h +2 -1
  653. data/src/core/lib/surface/call_details.cc +8 -8
  654. data/src/core/lib/surface/channel.cc +53 -61
  655. data/src/core/lib/surface/channel.h +21 -5
  656. data/src/core/lib/surface/channel_init.cc +1 -1
  657. data/src/core/lib/surface/completion_queue.cc +38 -294
  658. data/src/core/lib/surface/completion_queue.h +16 -24
  659. data/src/core/lib/surface/init.cc +32 -16
  660. data/src/core/lib/surface/lame_client.cc +20 -46
  661. data/src/core/lib/surface/lame_client.h +4 -0
  662. data/src/core/lib/surface/server.cc +1107 -1239
  663. data/src/core/lib/surface/server.h +394 -86
  664. data/src/core/lib/surface/validate_metadata.h +3 -0
  665. data/src/core/lib/surface/version.cc +2 -2
  666. data/src/core/lib/transport/authority_override.cc +40 -0
  667. data/src/core/lib/transport/authority_override.h +37 -0
  668. data/src/core/lib/transport/bdp_estimator.cc +1 -1
  669. data/src/core/lib/transport/bdp_estimator.h +2 -1
  670. data/src/core/lib/transport/byte_stream.h +3 -3
  671. data/src/core/lib/transport/connectivity_state.cc +18 -13
  672. data/src/core/lib/transport/connectivity_state.h +26 -12
  673. data/src/core/lib/transport/error_utils.cc +13 -0
  674. data/src/core/lib/transport/error_utils.h +7 -1
  675. data/src/core/lib/transport/metadata.cc +11 -1
  676. data/src/core/lib/transport/metadata.h +2 -2
  677. data/src/core/lib/transport/metadata_batch.h +4 -4
  678. data/src/core/lib/transport/static_metadata.cc +296 -277
  679. data/src/core/lib/transport/static_metadata.h +80 -73
  680. data/src/core/lib/transport/status_metadata.cc +4 -3
  681. data/src/core/lib/transport/timeout_encoding.cc +4 -4
  682. data/src/core/lib/transport/transport.cc +5 -3
  683. data/src/core/lib/transport/transport.h +15 -8
  684. data/src/core/lib/uri/uri_parser.cc +131 -247
  685. data/src/core/lib/uri/uri_parser.h +58 -20
  686. data/src/core/plugin_registry/grpc_plugin_registry.cc +41 -20
  687. data/src/core/tsi/alts/crypt/gsec.cc +5 -4
  688. data/src/core/tsi/alts/frame_protector/frame_handler.cc +8 -6
  689. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +1 -1
  690. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +49 -26
  691. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +8 -6
  692. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +4 -4
  693. data/src/core/tsi/fake_transport_security.cc +6 -3
  694. data/src/core/tsi/local_transport_security.cc +5 -1
  695. data/src/core/tsi/local_transport_security.h +6 -7
  696. data/src/core/tsi/ssl/session_cache/ssl_session.h +3 -0
  697. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +1 -1
  698. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +4 -1
  699. data/src/core/tsi/ssl_transport_security.cc +81 -67
  700. data/src/core/tsi/ssl_transport_security.h +9 -6
  701. data/src/core/tsi/transport_security.cc +10 -8
  702. data/src/core/tsi/transport_security_interface.h +1 -1
  703. data/src/ruby/ext/grpc/extconf.rb +1 -1
  704. data/src/ruby/ext/grpc/rb_channel_credentials.c +9 -0
  705. data/src/ruby/ext/grpc/rb_event_thread.c +2 -0
  706. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +38 -18
  707. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +74 -44
  708. data/src/ruby/lib/grpc/version.rb +1 -1
  709. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +28 -0
  710. data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +18 -0
  711. data/src/ruby/spec/channel_credentials_spec.rb +10 -0
  712. data/src/ruby/spec/generic/active_call_spec.rb +19 -8
  713. data/src/ruby/spec/pb/codegen/package_option_spec.rb +2 -6
  714. data/third_party/abseil-cpp/absl/algorithm/container.h +1764 -0
  715. data/third_party/abseil-cpp/absl/base/attributes.h +99 -38
  716. data/third_party/abseil-cpp/absl/base/call_once.h +1 -1
  717. data/third_party/abseil-cpp/absl/base/casts.h +9 -6
  718. data/third_party/abseil-cpp/absl/base/config.h +60 -17
  719. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +428 -335
  720. data/third_party/abseil-cpp/absl/base/internal/bits.h +17 -16
  721. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +166 -0
  722. data/third_party/abseil-cpp/absl/base/internal/dynamic_annotations.h +398 -0
  723. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.cc +93 -0
  724. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.h +130 -0
  725. data/third_party/abseil-cpp/absl/base/internal/invoke.h +4 -4
  726. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +620 -0
  727. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +126 -0
  728. data/third_party/abseil-cpp/absl/base/internal/low_level_scheduling.h +29 -1
  729. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +2 -2
  730. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +7 -5
  731. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +25 -38
  732. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +19 -25
  733. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +8 -0
  734. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +28 -5
  735. data/third_party/abseil-cpp/absl/base/internal/sysinfo.h +8 -0
  736. data/third_party/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +3 -1
  737. data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +2 -2
  738. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +3 -3
  739. data/third_party/abseil-cpp/absl/base/macros.h +36 -109
  740. data/third_party/abseil-cpp/absl/base/optimization.h +61 -1
  741. data/third_party/abseil-cpp/absl/base/options.h +31 -4
  742. data/third_party/abseil-cpp/absl/base/policy_checks.h +1 -1
  743. data/third_party/abseil-cpp/absl/base/thread_annotations.h +94 -39
  744. data/third_party/abseil-cpp/absl/container/fixed_array.h +532 -0
  745. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +606 -0
  746. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +504 -0
  747. data/third_party/abseil-cpp/absl/container/inlined_vector.h +33 -36
  748. data/third_party/abseil-cpp/absl/container/internal/common.h +206 -0
  749. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +33 -8
  750. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +460 -0
  751. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +161 -0
  752. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +208 -0
  753. data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
  754. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +270 -0
  755. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +321 -0
  756. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +30 -0
  757. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +50 -0
  758. data/third_party/abseil-cpp/absl/container/internal/layout.h +743 -0
  759. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +197 -0
  760. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +48 -0
  761. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1903 -0
  762. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +139 -0
  763. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
  764. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1945 -0
  765. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +71 -0
  766. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +382 -0
  767. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +134 -0
  768. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +196 -0
  769. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +134 -0
  770. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +89 -0
  771. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +108 -0
  772. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +248 -0
  773. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +24 -0
  774. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +93 -0
  775. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +346 -0
  776. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +149 -0
  777. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +173 -0
  778. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
  779. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +140 -0
  780. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +231 -0
  781. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +36 -0
  782. data/third_party/abseil-cpp/absl/debugging/symbolize.h +99 -0
  783. data/third_party/abseil-cpp/absl/debugging/symbolize_darwin.inc +101 -0
  784. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +1560 -0
  785. data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
  786. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +81 -0
  787. data/third_party/abseil-cpp/absl/functional/bind_front.h +184 -0
  788. data/third_party/abseil-cpp/absl/functional/function_ref.h +139 -0
  789. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +95 -0
  790. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +106 -0
  791. data/third_party/abseil-cpp/absl/hash/hash.h +325 -0
  792. data/third_party/abseil-cpp/absl/hash/internal/city.cc +346 -0
  793. data/third_party/abseil-cpp/absl/hash/internal/city.h +96 -0
  794. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +55 -0
  795. data/third_party/abseil-cpp/absl/hash/internal/hash.h +996 -0
  796. data/third_party/abseil-cpp/absl/memory/memory.h +4 -0
  797. data/third_party/abseil-cpp/absl/meta/type_traits.h +2 -8
  798. data/third_party/abseil-cpp/absl/numeric/int128.cc +13 -27
  799. data/third_party/abseil-cpp/absl/numeric/int128.h +16 -15
  800. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +51 -0
  801. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +399 -0
  802. data/third_party/abseil-cpp/absl/status/status.cc +445 -0
  803. data/third_party/abseil-cpp/absl/status/status.h +817 -0
  804. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +38 -0
  805. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +51 -0
  806. data/third_party/abseil-cpp/absl/status/statusor.cc +71 -0
  807. data/third_party/abseil-cpp/absl/status/statusor.h +760 -0
  808. data/third_party/abseil-cpp/absl/strings/charconv.cc +2 -2
  809. data/third_party/abseil-cpp/absl/strings/cord.cc +1998 -0
  810. data/third_party/abseil-cpp/absl/strings/cord.h +1276 -0
  811. data/third_party/abseil-cpp/absl/strings/escaping.cc +9 -9
  812. data/third_party/abseil-cpp/absl/strings/internal/char_map.h +1 -1
  813. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +1 -1
  814. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +2 -2
  815. data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.cc +2 -2
  816. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +173 -0
  817. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +222 -136
  818. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +136 -64
  819. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.cc +1 -1
  820. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +14 -21
  821. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +7 -14
  822. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +31 -7
  823. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +147 -135
  824. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +999 -87
  825. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +3 -3
  826. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +4 -12
  827. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.cc +8 -6
  828. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +13 -11
  829. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +2 -2
  830. data/third_party/abseil-cpp/absl/strings/str_cat.cc +4 -4
  831. data/third_party/abseil-cpp/absl/strings/str_cat.h +1 -1
  832. data/third_party/abseil-cpp/absl/strings/str_format.h +289 -13
  833. data/third_party/abseil-cpp/absl/strings/str_split.cc +2 -2
  834. data/third_party/abseil-cpp/absl/strings/str_split.h +1 -0
  835. data/third_party/abseil-cpp/absl/strings/string_view.h +26 -19
  836. data/third_party/abseil-cpp/absl/strings/substitute.cc +5 -5
  837. data/third_party/abseil-cpp/absl/strings/substitute.h +32 -29
  838. data/third_party/abseil-cpp/absl/synchronization/barrier.cc +52 -0
  839. data/third_party/abseil-cpp/absl/synchronization/barrier.h +79 -0
  840. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +57 -0
  841. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +99 -0
  842. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +140 -0
  843. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +60 -0
  844. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +697 -0
  845. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +141 -0
  846. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +155 -0
  847. data/third_party/abseil-cpp/absl/synchronization/internal/mutex_nonprod.inc +249 -0
  848. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +106 -0
  849. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +115 -0
  850. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +492 -0
  851. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +159 -0
  852. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +2739 -0
  853. data/third_party/abseil-cpp/absl/synchronization/mutex.h +1065 -0
  854. data/third_party/abseil-cpp/absl/synchronization/notification.cc +78 -0
  855. data/third_party/abseil-cpp/absl/synchronization/notification.h +123 -0
  856. data/third_party/abseil-cpp/absl/time/civil_time.cc +9 -9
  857. data/third_party/abseil-cpp/absl/time/clock.cc +3 -3
  858. data/third_party/abseil-cpp/absl/time/duration.cc +90 -59
  859. data/third_party/abseil-cpp/absl/time/format.cc +43 -36
  860. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +26 -16
  861. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +4 -2
  862. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +1 -1
  863. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +136 -29
  864. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +13 -21
  865. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +1 -1
  866. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +136 -129
  867. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +4 -5
  868. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +8 -7
  869. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +6 -6
  870. data/third_party/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +2 -1
  871. data/third_party/abseil-cpp/absl/time/time.h +15 -16
  872. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +64 -0
  873. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +82 -0
  874. data/third_party/abseil-cpp/absl/types/internal/variant.h +1646 -0
  875. data/third_party/abseil-cpp/absl/types/optional.h +9 -9
  876. data/third_party/abseil-cpp/absl/types/span.h +49 -36
  877. data/third_party/abseil-cpp/absl/types/variant.h +861 -0
  878. data/third_party/abseil-cpp/absl/utility/utility.h +2 -2
  879. data/third_party/address_sorting/include/address_sorting/address_sorting.h +2 -0
  880. data/third_party/boringssl-with-bazel/err_data.c +479 -467
  881. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +0 -6
  882. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +2 -0
  883. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +9 -43
  884. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +55 -4
  885. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +34 -0
  886. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +4 -0
  887. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +16 -0
  888. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +6 -2
  889. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +173 -35
  890. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +2 -0
  891. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +4 -0
  892. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +30 -10
  893. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +56 -22
  894. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +8 -2
  895. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +543 -0
  896. data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +237 -0
  897. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +118 -49
  898. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +267 -95
  899. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +210 -34
  900. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +766 -0
  901. data/third_party/boringssl-with-bazel/src/crypto/x509/a_strex.c +3 -3
  902. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +6 -4
  903. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +3 -3
  904. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +1 -1
  905. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +7 -2
  906. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +21 -18
  907. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +1 -1
  908. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +24 -3
  909. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +3 -3
  910. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +67 -67
  911. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +3 -3
  912. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +29 -35
  913. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +13 -2
  914. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +9 -8
  915. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +10 -10
  916. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +2 -2
  917. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +28 -40
  918. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +20 -0
  919. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +3 -1
  920. data/third_party/boringssl-with-bazel/src/crypto/x509v3/ext_dat.h +1 -4
  921. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +5 -3
  922. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +14 -14
  923. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +7 -3
  924. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +2 -2
  925. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +1 -1
  926. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +1 -1
  927. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +55 -8
  928. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +1 -1
  929. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +24 -0
  930. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +54 -0
  931. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +0 -1
  932. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +6 -3
  933. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +4 -0
  934. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +6 -0
  935. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +1 -1
  936. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +6 -0
  937. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +12 -0
  938. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +9 -0
  939. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +4 -1
  940. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +3 -0
  941. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +202 -134
  942. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +103 -10
  943. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +5 -2
  944. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +42 -14
  945. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +199 -78
  946. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +482 -432
  947. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +18 -5
  948. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +35 -0
  949. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +18 -18
  950. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +2 -3
  951. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +1 -1
  952. data/third_party/boringssl-with-bazel/src/ssl/internal.h +49 -10
  953. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +42 -1
  954. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +3 -6
  955. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +8 -9
  956. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +77 -0
  957. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +11 -14
  958. data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +250 -20
  959. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +1 -2
  960. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +57 -19
  961. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +140 -41
  962. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +5 -3
  963. data/third_party/upb/third_party/wyhash/wyhash.h +145 -0
  964. data/third_party/upb/upb/decode.c +275 -145
  965. data/third_party/upb/upb/decode.h +20 -1
  966. data/third_party/upb/upb/decode.int.h +163 -0
  967. data/third_party/upb/upb/decode_fast.c +1040 -0
  968. data/third_party/upb/upb/decode_fast.h +126 -0
  969. data/third_party/upb/upb/def.c +2178 -0
  970. data/third_party/upb/upb/def.h +315 -0
  971. data/third_party/upb/upb/def.hpp +439 -0
  972. data/third_party/upb/upb/encode.c +229 -171
  973. data/third_party/upb/upb/encode.h +27 -2
  974. data/third_party/upb/upb/json_decode.c +1443 -0
  975. data/third_party/upb/upb/json_decode.h +23 -0
  976. data/third_party/upb/upb/json_encode.c +713 -0
  977. data/third_party/upb/upb/json_encode.h +36 -0
  978. data/third_party/upb/upb/msg.c +167 -88
  979. data/third_party/upb/upb/msg.h +175 -35
  980. data/third_party/upb/upb/port_def.inc +75 -62
  981. data/third_party/upb/upb/port_undef.inc +3 -7
  982. data/third_party/upb/upb/reflection.c +408 -0
  983. data/third_party/upb/upb/reflection.h +168 -0
  984. data/third_party/upb/upb/table.c +34 -208
  985. data/third_party/upb/upb/table.int.h +14 -14
  986. data/third_party/upb/upb/text_encode.c +421 -0
  987. data/third_party/upb/upb/text_encode.h +38 -0
  988. data/third_party/upb/upb/upb.c +33 -54
  989. data/third_party/upb/upb/upb.h +56 -1
  990. data/third_party/upb/upb/upb.hpp +6 -4
  991. data/third_party/upb/upb/upb.int.h +29 -0
  992. metadata +508 -172
  993. data/src/core/ext/filters/client_channel/lb_policy/xds/eds.cc +0 -938
  994. data/src/core/ext/filters/client_channel/lb_policy/xds/lrs.cc +0 -528
  995. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_routing.cc +0 -1143
  996. data/src/core/ext/filters/client_channel/parse_address.h +0 -53
  997. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.cc +0 -485
  998. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.cc +0 -68
  999. data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +0 -353
  1000. data/src/core/ext/filters/client_channel/resolving_lb_policy.h +0 -142
  1001. data/src/core/ext/filters/client_channel/xds/xds_api.cc +0 -2110
  1002. data/src/core/ext/filters/client_channel/xds/xds_api.h +0 -345
  1003. data/src/core/ext/filters/client_channel/xds/xds_channel.h +0 -46
  1004. data/src/core/ext/filters/client_channel/xds/xds_channel_secure.cc +0 -106
  1005. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.c +0 -21
  1006. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.h +0 -34
  1007. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.c +0 -114
  1008. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.h +0 -429
  1009. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.c +0 -72
  1010. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.h +0 -198
  1011. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.c +0 -105
  1012. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.h +0 -388
  1013. data/src/core/ext/upb-generated/envoy/api/v2/cds.upb.h +0 -52
  1014. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.c +0 -403
  1015. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.h +0 -1453
  1016. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.c +0 -74
  1017. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.h +0 -226
  1018. data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.c +0 -35
  1019. data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.h +0 -69
  1020. data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.c +0 -55
  1021. data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.h +0 -323
  1022. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.c +0 -112
  1023. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.h +0 -334
  1024. data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.c +0 -35
  1025. data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.h +0 -79
  1026. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.c +0 -313
  1027. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.h +0 -891
  1028. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.c +0 -96
  1029. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.h +0 -328
  1030. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.c +0 -34
  1031. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.h +0 -71
  1032. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.c +0 -197
  1033. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.h +0 -649
  1034. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.c +0 -172
  1035. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.h +0 -693
  1036. data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.c +0 -36
  1037. data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.h +0 -80
  1038. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.c +0 -152
  1039. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.h +0 -536
  1040. data/src/core/ext/upb-generated/envoy/api/v2/core/socket_option.upb.h +0 -88
  1041. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.c +0 -129
  1042. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.h +0 -386
  1043. data/src/core/ext/upb-generated/envoy/api/v2/eds.upb.h +0 -52
  1044. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.c +0 -92
  1045. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.h +0 -224
  1046. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.c +0 -18
  1047. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.h +0 -32
  1048. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.c +0 -91
  1049. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.h +0 -273
  1050. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.c +0 -112
  1051. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.h +0 -332
  1052. data/src/core/ext/upb-generated/envoy/api/v2/lds.upb.h +0 -52
  1053. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.c +0 -109
  1054. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.h +0 -415
  1055. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.c +0 -18
  1056. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.h +0 -32
  1057. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.c +0 -145
  1058. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.h +0 -538
  1059. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.c +0 -43
  1060. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.h +0 -111
  1061. data/src/core/ext/upb-generated/envoy/api/v2/rds.upb.h +0 -52
  1062. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.c +0 -63
  1063. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.h +0 -204
  1064. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.c +0 -18
  1065. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.h +0 -32
  1066. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.c +0 -815
  1067. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.h +0 -2984
  1068. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.c +0 -59
  1069. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.h +0 -135
  1070. data/src/core/ext/upb-generated/envoy/api/v2/srds.upb.h +0 -52
  1071. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.c +0 -228
  1072. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.h +0 -732
  1073. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.c +0 -316
  1074. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.h +0 -1167
  1075. data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.c +0 -33
  1076. data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.h +0 -65
  1077. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.c +0 -51
  1078. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.h +0 -125
  1079. data/src/core/ext/upb-generated/envoy/service/discovery/v2/ads.upb.h +0 -49
  1080. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.c +0 -54
  1081. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.h +0 -136
  1082. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.c +0 -63
  1083. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.h +0 -145
  1084. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.c +0 -53
  1085. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.h +0 -133
  1086. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.c +0 -88
  1087. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.h +0 -258
  1088. data/src/core/ext/upb-generated/envoy/type/percent.upb.c +0 -39
  1089. data/src/core/ext/upb-generated/envoy/type/percent.upb.h +0 -86
  1090. data/src/core/ext/upb-generated/envoy/type/range.upb.c +0 -50
  1091. data/src/core/ext/upb-generated/envoy/type/range.upb.h +0 -111
  1092. data/src/core/ext/upb-generated/envoy/type/semantic_version.upb.h +0 -61
  1093. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.c +0 -89
  1094. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.h +0 -250
  1095. data/src/core/ext/upb-generated/gogoproto/gogo.upb.c +0 -17
  1096. data/src/core/lib/gprpp/map.h +0 -53
  1097. data/src/core/lib/security/transport/target_authority_table.cc +0 -75
  1098. data/src/core/lib/security/transport/target_authority_table.h +0 -40
  1099. data/src/core/lib/slice/slice_hash_table.h +0 -199
  1100. data/src/core/lib/slice/slice_weak_hash_table.h +0 -102
  1101. data/third_party/abseil-cpp/absl/base/dynamic_annotations.cc +0 -129
  1102. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pku.c +0 -110
  1103. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_sxnet.c +0 -274
  1104. data/third_party/upb/upb/port.c +0 -26
@@ -0,0 +1,1276 @@
1
+ // Copyright 2020 The Abseil Authors.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // https://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+ //
15
+ // -----------------------------------------------------------------------------
16
+ // File: cord.h
17
+ // -----------------------------------------------------------------------------
18
+ //
19
+ // This file defines the `absl::Cord` data structure and operations on that data
20
+ // structure. A Cord is a string-like sequence of characters optimized for
21
+ // specific use cases. Unlike a `std::string`, which stores an array of
22
+ // contiguous characters, Cord data is stored in a structure consisting of
23
+ // separate, reference-counted "chunks." (Currently, this implementation is a
24
+ // tree structure, though that implementation may change.)
25
+ //
26
+ // Because a Cord consists of these chunks, data can be added to or removed from
27
+ // a Cord during its lifetime. Chunks may also be shared between Cords. Unlike a
28
+ // `std::string`, a Cord can therefore accomodate data that changes over its
29
+ // lifetime, though it's not quite "mutable"; it can change only in the
30
+ // attachment, detachment, or rearrangement of chunks of its constituent data.
31
+ //
32
+ // A Cord provides some benefit over `std::string` under the following (albeit
33
+ // narrow) circumstances:
34
+ //
35
+ // * Cord data is designed to grow and shrink over a Cord's lifetime. Cord
36
+ // provides efficient insertions and deletions at the start and end of the
37
+ // character sequences, avoiding copies in those cases. Static data should
38
+ // generally be stored as strings.
39
+ // * External memory consisting of string-like data can be directly added to
40
+ // a Cord without requiring copies or allocations.
41
+ // * Cord data may be shared and copied cheaply. Cord provides a copy-on-write
42
+ // implementation and cheap sub-Cord operations. Copying a Cord is an O(1)
43
+ // operation.
44
+ //
45
+ // As a consequence to the above, Cord data is generally large. Small data
46
+ // should generally use strings, as construction of a Cord requires some
47
+ // overhead. Small Cords (<= 15 bytes) are represented inline, but most small
48
+ // Cords are expected to grow over their lifetimes.
49
+ //
50
+ // Note that because a Cord is made up of separate chunked data, random access
51
+ // to character data within a Cord is slower than within a `std::string`.
52
+ //
53
+ // Thread Safety
54
+ //
55
+ // Cord has the same thread-safety properties as many other types like
56
+ // std::string, std::vector<>, int, etc -- it is thread-compatible. In
57
+ // particular, if threads do not call non-const methods, then it is safe to call
58
+ // const methods without synchronization. Copying a Cord produces a new instance
59
+ // that can be used concurrently with the original in arbitrary ways.
60
+
61
+ #ifndef ABSL_STRINGS_CORD_H_
62
+ #define ABSL_STRINGS_CORD_H_
63
+
64
+ #include <algorithm>
65
+ #include <cstddef>
66
+ #include <cstdint>
67
+ #include <cstring>
68
+ #include <iosfwd>
69
+ #include <iterator>
70
+ #include <string>
71
+ #include <type_traits>
72
+
73
+ #include "absl/base/internal/endian.h"
74
+ #include "absl/base/internal/per_thread_tls.h"
75
+ #include "absl/base/macros.h"
76
+ #include "absl/base/port.h"
77
+ #include "absl/container/inlined_vector.h"
78
+ #include "absl/functional/function_ref.h"
79
+ #include "absl/meta/type_traits.h"
80
+ #include "absl/strings/internal/cord_internal.h"
81
+ #include "absl/strings/internal/resize_uninitialized.h"
82
+ #include "absl/strings/string_view.h"
83
+ #include "absl/types/optional.h"
84
+
85
+ namespace absl {
86
+ ABSL_NAMESPACE_BEGIN
87
+ class Cord;
88
+ class CordTestPeer;
89
+ template <typename Releaser>
90
+ Cord MakeCordFromExternal(absl::string_view, Releaser&&);
91
+ void CopyCordToString(const Cord& src, std::string* dst);
92
+
93
+ // Cord
94
+ //
95
+ // A Cord is a sequence of characters, designed to be more efficient than a
96
+ // `std::string` in certain circumstances: namely, large string data that needs
97
+ // to change over its lifetime or shared, especially when such data is shared
98
+ // across API boundaries.
99
+ //
100
+ // A Cord stores its character data in a structure that allows efficient prepend
101
+ // and append operations. This makes a Cord useful for large string data sent
102
+ // over in a wire format that may need to be prepended or appended at some point
103
+ // during the data exchange (e.g. HTTP, protocol buffers). For example, a
104
+ // Cord is useful for storing an HTTP request, and prepending an HTTP header to
105
+ // such a request.
106
+ //
107
+ // Cords should not be used for storing general string data, however. They
108
+ // require overhead to construct and are slower than strings for random access.
109
+ //
110
+ // The Cord API provides the following common API operations:
111
+ //
112
+ // * Create or assign Cords out of existing string data, memory, or other Cords
113
+ // * Append and prepend data to an existing Cord
114
+ // * Create new Sub-Cords from existing Cord data
115
+ // * Swap Cord data and compare Cord equality
116
+ // * Write out Cord data by constructing a `std::string`
117
+ //
118
+ // Additionally, the API provides iterator utilities to iterate through Cord
119
+ // data via chunks or character bytes.
120
+ //
121
+ class Cord {
122
+ private:
123
+ template <typename T>
124
+ using EnableIfString =
125
+ absl::enable_if_t<std::is_same<T, std::string>::value, int>;
126
+
127
+ public:
128
+ // Cord::Cord() Constructors.
129
+
130
+ // Creates an empty Cord.
131
+ constexpr Cord() noexcept;
132
+
133
+ // Creates a Cord from an existing Cord. Cord is copyable and efficiently
134
+ // movable. The moved-from state is valid but unspecified.
135
+ Cord(const Cord& src);
136
+ Cord(Cord&& src) noexcept;
137
+ Cord& operator=(const Cord& x);
138
+ Cord& operator=(Cord&& x) noexcept;
139
+
140
+ // Creates a Cord from a `src` string. This constructor is marked explicit to
141
+ // prevent implicit Cord constructions from arguments convertible to an
142
+ // `absl::string_view`.
143
+ explicit Cord(absl::string_view src);
144
+ Cord& operator=(absl::string_view src);
145
+
146
+ // Creates a Cord from a `std::string&&` rvalue. These constructors are
147
+ // templated to avoid ambiguities for types that are convertible to both
148
+ // `absl::string_view` and `std::string`, such as `const char*`.
149
+ template <typename T, EnableIfString<T> = 0>
150
+ explicit Cord(T&& src);
151
+ template <typename T, EnableIfString<T> = 0>
152
+ Cord& operator=(T&& src);
153
+
154
+ // Cord::~Cord()
155
+ //
156
+ // Destructs the Cord.
157
+ ~Cord() {
158
+ if (contents_.is_tree()) DestroyCordSlow();
159
+ }
160
+
161
+ // MakeCordFromExternal()
162
+ //
163
+ // Creates a Cord that takes ownership of external string memory. The
164
+ // contents of `data` are not copied to the Cord; instead, the external
165
+ // memory is added to the Cord and reference-counted. This data may not be
166
+ // changed for the life of the Cord, though it may be prepended or appended
167
+ // to.
168
+ //
169
+ // `MakeCordFromExternal()` takes a callable "releaser" that is invoked when
170
+ // the reference count for `data` reaches zero. As noted above, this data must
171
+ // remain live until the releaser is invoked. The callable releaser also must:
172
+ //
173
+ // * be move constructible
174
+ // * support `void operator()(absl::string_view) const` or `void operator()`
175
+ //
176
+ // Example:
177
+ //
178
+ // Cord MakeCord(BlockPool* pool) {
179
+ // Block* block = pool->NewBlock();
180
+ // FillBlock(block);
181
+ // return absl::MakeCordFromExternal(
182
+ // block->ToStringView(),
183
+ // [pool, block](absl::string_view v) {
184
+ // pool->FreeBlock(block, v);
185
+ // });
186
+ // }
187
+ //
188
+ // WARNING: Because a Cord can be reference-counted, it's likely a bug if your
189
+ // releaser doesn't do anything. For example, consider the following:
190
+ //
191
+ // void Foo(const char* buffer, int len) {
192
+ // auto c = absl::MakeCordFromExternal(absl::string_view(buffer, len),
193
+ // [](absl::string_view) {});
194
+ //
195
+ // // BUG: If Bar() copies its cord for any reason, including keeping a
196
+ // // substring of it, the lifetime of buffer might be extended beyond
197
+ // // when Foo() returns.
198
+ // Bar(c);
199
+ // }
200
+ template <typename Releaser>
201
+ friend Cord MakeCordFromExternal(absl::string_view data, Releaser&& releaser);
202
+
203
+ // Cord::Clear()
204
+ //
205
+ // Releases the Cord data. Any nodes that share data with other Cords, if
206
+ // applicable, will have their reference counts reduced by 1.
207
+ void Clear();
208
+
209
+ // Cord::Append()
210
+ //
211
+ // Appends data to the Cord, which may come from another Cord or other string
212
+ // data.
213
+ void Append(const Cord& src);
214
+ void Append(Cord&& src);
215
+ void Append(absl::string_view src);
216
+ template <typename T, EnableIfString<T> = 0>
217
+ void Append(T&& src);
218
+
219
+ // Cord::Prepend()
220
+ //
221
+ // Prepends data to the Cord, which may come from another Cord or other string
222
+ // data.
223
+ void Prepend(const Cord& src);
224
+ void Prepend(absl::string_view src);
225
+ template <typename T, EnableIfString<T> = 0>
226
+ void Prepend(T&& src);
227
+
228
+ // Cord::RemovePrefix()
229
+ //
230
+ // Removes the first `n` bytes of a Cord.
231
+ void RemovePrefix(size_t n);
232
+ void RemoveSuffix(size_t n);
233
+
234
+ // Cord::Subcord()
235
+ //
236
+ // Returns a new Cord representing the subrange [pos, pos + new_size) of
237
+ // *this. If pos >= size(), the result is empty(). If
238
+ // (pos + new_size) >= size(), the result is the subrange [pos, size()).
239
+ Cord Subcord(size_t pos, size_t new_size) const;
240
+
241
+ // Cord::swap()
242
+ //
243
+ // Swaps the contents of the Cord with `other`.
244
+ void swap(Cord& other) noexcept;
245
+
246
+ // swap()
247
+ //
248
+ // Swaps the contents of two Cords.
249
+ friend void swap(Cord& x, Cord& y) noexcept {
250
+ x.swap(y);
251
+ }
252
+
253
+ // Cord::size()
254
+ //
255
+ // Returns the size of the Cord.
256
+ size_t size() const;
257
+
258
+ // Cord::empty()
259
+ //
260
+ // Determines whether the given Cord is empty, returning `true` is so.
261
+ bool empty() const;
262
+
263
+ // Cord::EstimatedMemoryUsage()
264
+ //
265
+ // Returns the *approximate* number of bytes held in full or in part by this
266
+ // Cord (which may not remain the same between invocations). Note that Cords
267
+ // that share memory could each be "charged" independently for the same shared
268
+ // memory.
269
+ size_t EstimatedMemoryUsage() const;
270
+
271
+ // Cord::Compare()
272
+ //
273
+ // Compares 'this' Cord with rhs. This function and its relatives treat Cords
274
+ // as sequences of unsigned bytes. The comparison is a straightforward
275
+ // lexicographic comparison. `Cord::Compare()` returns values as follows:
276
+ //
277
+ // -1 'this' Cord is smaller
278
+ // 0 two Cords are equal
279
+ // 1 'this' Cord is larger
280
+ int Compare(absl::string_view rhs) const;
281
+ int Compare(const Cord& rhs) const;
282
+
283
+ // Cord::StartsWith()
284
+ //
285
+ // Determines whether the Cord starts with the passed string data `rhs`.
286
+ bool StartsWith(const Cord& rhs) const;
287
+ bool StartsWith(absl::string_view rhs) const;
288
+
289
+ // Cord::EndsWidth()
290
+ //
291
+ // Determines whether the Cord ends with the passed string data `rhs`.
292
+ bool EndsWith(absl::string_view rhs) const;
293
+ bool EndsWith(const Cord& rhs) const;
294
+
295
+ // Cord::operator std::string()
296
+ //
297
+ // Converts a Cord into a `std::string()`. This operator is marked explicit to
298
+ // prevent unintended Cord usage in functions that take a string.
299
+ explicit operator std::string() const;
300
+
301
+ // CopyCordToString()
302
+ //
303
+ // Copies the contents of a `src` Cord into a `*dst` string.
304
+ //
305
+ // This function optimizes the case of reusing the destination string since it
306
+ // can reuse previously allocated capacity. However, this function does not
307
+ // guarantee that pointers previously returned by `dst->data()` remain valid
308
+ // even if `*dst` had enough capacity to hold `src`. If `*dst` is a new
309
+ // object, prefer to simply use the conversion operator to `std::string`.
310
+ friend void CopyCordToString(const Cord& src, std::string* dst);
311
+
312
+ class CharIterator;
313
+
314
+ //----------------------------------------------------------------------------
315
+ // Cord::ChunkIterator
316
+ //----------------------------------------------------------------------------
317
+ //
318
+ // A `Cord::ChunkIterator` allows iteration over the constituent chunks of its
319
+ // Cord. Such iteration allows you to perform non-const operatons on the data
320
+ // of a Cord without modifying it.
321
+ //
322
+ // Generally, you do not instantiate a `Cord::ChunkIterator` directly;
323
+ // instead, you create one implicitly through use of the `Cord::Chunks()`
324
+ // member function.
325
+ //
326
+ // The `Cord::ChunkIterator` has the following properties:
327
+ //
328
+ // * The iterator is invalidated after any non-const operation on the
329
+ // Cord object over which it iterates.
330
+ // * The `string_view` returned by dereferencing a valid, non-`end()`
331
+ // iterator is guaranteed to be non-empty.
332
+ // * Two `ChunkIterator` objects can be compared equal if and only if they
333
+ // remain valid and iterate over the same Cord.
334
+ // * The iterator in this case is a proxy iterator; the `string_view`
335
+ // returned by the iterator does not live inside the Cord, and its
336
+ // lifetime is limited to the lifetime of the iterator itself. To help
337
+ // prevent lifetime issues, `ChunkIterator::reference` is not a true
338
+ // reference type and is equivalent to `value_type`.
339
+ // * The iterator keeps state that can grow for Cords that contain many
340
+ // nodes and are imbalanced due to sharing. Prefer to pass this type by
341
+ // const reference instead of by value.
342
+ class ChunkIterator {
343
+ public:
344
+ using iterator_category = std::input_iterator_tag;
345
+ using value_type = absl::string_view;
346
+ using difference_type = ptrdiff_t;
347
+ using pointer = const value_type*;
348
+ using reference = value_type;
349
+
350
+ ChunkIterator() = default;
351
+
352
+ ChunkIterator& operator++();
353
+ ChunkIterator operator++(int);
354
+ bool operator==(const ChunkIterator& other) const;
355
+ bool operator!=(const ChunkIterator& other) const;
356
+ reference operator*() const;
357
+ pointer operator->() const;
358
+
359
+ friend class Cord;
360
+ friend class CharIterator;
361
+
362
+ private:
363
+ // Constructs a `begin()` iterator from `cord`.
364
+ explicit ChunkIterator(const Cord* cord);
365
+
366
+ // Removes `n` bytes from `current_chunk_`. Expects `n` to be smaller than
367
+ // `current_chunk_.size()`.
368
+ void RemoveChunkPrefix(size_t n);
369
+ Cord AdvanceAndReadBytes(size_t n);
370
+ void AdvanceBytes(size_t n);
371
+ // Iterates `n` bytes, where `n` is expected to be greater than or equal to
372
+ // `current_chunk_.size()`.
373
+ void AdvanceBytesSlowPath(size_t n);
374
+
375
+ // A view into bytes of the current `CordRep`. It may only be a view to a
376
+ // suffix of bytes if this is being used by `CharIterator`.
377
+ absl::string_view current_chunk_;
378
+ // The current leaf, or `nullptr` if the iterator points to short data.
379
+ // If the current chunk is a substring node, current_leaf_ points to the
380
+ // underlying flat or external node.
381
+ absl::cord_internal::CordRep* current_leaf_ = nullptr;
382
+ // The number of bytes left in the `Cord` over which we are iterating.
383
+ size_t bytes_remaining_ = 0;
384
+ absl::InlinedVector<absl::cord_internal::CordRep*, 4>
385
+ stack_of_right_children_;
386
+ };
387
+
388
+ // Cord::ChunkIterator::chunk_begin()
389
+ //
390
+ // Returns an iterator to the first chunk of the `Cord`.
391
+ //
392
+ // Generally, prefer using `Cord::Chunks()` within a range-based for loop for
393
+ // iterating over the chunks of a Cord. This method may be useful for getting
394
+ // a `ChunkIterator` where range-based for-loops are not useful.
395
+ //
396
+ // Example:
397
+ //
398
+ // absl::Cord::ChunkIterator FindAsChunk(const absl::Cord& c,
399
+ // absl::string_view s) {
400
+ // return std::find(c.chunk_begin(), c.chunk_end(), s);
401
+ // }
402
+ ChunkIterator chunk_begin() const;
403
+
404
+ // Cord::ChunkItertator::chunk_end()
405
+ //
406
+ // Returns an iterator one increment past the last chunk of the `Cord`.
407
+ //
408
+ // Generally, prefer using `Cord::Chunks()` within a range-based for loop for
409
+ // iterating over the chunks of a Cord. This method may be useful for getting
410
+ // a `ChunkIterator` where range-based for-loops may not be available.
411
+ ChunkIterator chunk_end() const;
412
+
413
+ //----------------------------------------------------------------------------
414
+ // Cord::ChunkIterator::ChunkRange
415
+ //----------------------------------------------------------------------------
416
+ //
417
+ // `ChunkRange` is a helper class for iterating over the chunks of the `Cord`,
418
+ // producing an iterator which can be used within a range-based for loop.
419
+ // Construction of a `ChunkRange` will return an iterator pointing to the
420
+ // first chunk of the Cord. Generally, do not construct a `ChunkRange`
421
+ // directly; instead, prefer to use the `Cord::Chunks()` method.
422
+ //
423
+ // Implementation note: `ChunkRange` is simply a convenience wrapper over
424
+ // `Cord::chunk_begin()` and `Cord::chunk_end()`.
425
+ class ChunkRange {
426
+ public:
427
+ explicit ChunkRange(const Cord* cord) : cord_(cord) {}
428
+
429
+ ChunkIterator begin() const;
430
+ ChunkIterator end() const;
431
+
432
+ private:
433
+ const Cord* cord_;
434
+ };
435
+
436
+ // Cord::Chunks()
437
+ //
438
+ // Returns a `Cord::ChunkIterator::ChunkRange` for iterating over the chunks
439
+ // of a `Cord` with a range-based for-loop. For most iteration tasks on a
440
+ // Cord, use `Cord::Chunks()` to retrieve this iterator.
441
+ //
442
+ // Example:
443
+ //
444
+ // void ProcessChunks(const Cord& cord) {
445
+ // for (absl::string_view chunk : cord.Chunks()) { ... }
446
+ // }
447
+ //
448
+ // Note that the ordinary caveats of temporary lifetime extension apply:
449
+ //
450
+ // void Process() {
451
+ // for (absl::string_view chunk : CordFactory().Chunks()) {
452
+ // // The temporary Cord returned by CordFactory has been destroyed!
453
+ // }
454
+ // }
455
+ ChunkRange Chunks() const;
456
+
457
+ //----------------------------------------------------------------------------
458
+ // Cord::CharIterator
459
+ //----------------------------------------------------------------------------
460
+ //
461
+ // A `Cord::CharIterator` allows iteration over the constituent characters of
462
+ // a `Cord`.
463
+ //
464
+ // Generally, you do not instantiate a `Cord::CharIterator` directly; instead,
465
+ // you create one implicitly through use of the `Cord::Chars()` member
466
+ // function.
467
+ //
468
+ // A `Cord::CharIterator` has the following properties:
469
+ //
470
+ // * The iterator is invalidated after any non-const operation on the
471
+ // Cord object over which it iterates.
472
+ // * Two `CharIterator` objects can be compared equal if and only if they
473
+ // remain valid and iterate over the same Cord.
474
+ // * The iterator keeps state that can grow for Cords that contain many
475
+ // nodes and are imbalanced due to sharing. Prefer to pass this type by
476
+ // const reference instead of by value.
477
+ // * This type cannot act as a forward iterator because a `Cord` can reuse
478
+ // sections of memory. This fact violates the requirement for forward
479
+ // iterators to compare equal if dereferencing them returns the same
480
+ // object.
481
+ class CharIterator {
482
+ public:
483
+ using iterator_category = std::input_iterator_tag;
484
+ using value_type = char;
485
+ using difference_type = ptrdiff_t;
486
+ using pointer = const char*;
487
+ using reference = const char&;
488
+
489
+ CharIterator() = default;
490
+
491
+ CharIterator& operator++();
492
+ CharIterator operator++(int);
493
+ bool operator==(const CharIterator& other) const;
494
+ bool operator!=(const CharIterator& other) const;
495
+ reference operator*() const;
496
+ pointer operator->() const;
497
+
498
+ friend Cord;
499
+
500
+ private:
501
+ explicit CharIterator(const Cord* cord) : chunk_iterator_(cord) {}
502
+
503
+ ChunkIterator chunk_iterator_;
504
+ };
505
+
506
+ // Cord::CharIterator::AdvanceAndRead()
507
+ //
508
+ // Advances the `Cord::CharIterator` by `n_bytes` and returns the bytes
509
+ // advanced as a separate `Cord`. `n_bytes` must be less than or equal to the
510
+ // number of bytes within the Cord; otherwise, behavior is undefined. It is
511
+ // valid to pass `char_end()` and `0`.
512
+ static Cord AdvanceAndRead(CharIterator* it, size_t n_bytes);
513
+
514
+ // Cord::CharIterator::Advance()
515
+ //
516
+ // Advances the `Cord::CharIterator` by `n_bytes`. `n_bytes` must be less than
517
+ // or equal to the number of bytes remaining within the Cord; otherwise,
518
+ // behavior is undefined. It is valid to pass `char_end()` and `0`.
519
+ static void Advance(CharIterator* it, size_t n_bytes);
520
+
521
+ // Cord::CharIterator::ChunkRemaining()
522
+ //
523
+ // Returns the longest contiguous view starting at the iterator's position.
524
+ //
525
+ // `it` must be dereferenceable.
526
+ static absl::string_view ChunkRemaining(const CharIterator& it);
527
+
528
+ // Cord::CharIterator::char_begin()
529
+ //
530
+ // Returns an iterator to the first character of the `Cord`.
531
+ //
532
+ // Generally, prefer using `Cord::Chars()` within a range-based for loop for
533
+ // iterating over the chunks of a Cord. This method may be useful for getting
534
+ // a `CharIterator` where range-based for-loops may not be available.
535
+ CharIterator char_begin() const;
536
+
537
+ // Cord::CharIterator::char_end()
538
+ //
539
+ // Returns an iterator to one past the last character of the `Cord`.
540
+ //
541
+ // Generally, prefer using `Cord::Chars()` within a range-based for loop for
542
+ // iterating over the chunks of a Cord. This method may be useful for getting
543
+ // a `CharIterator` where range-based for-loops are not useful.
544
+ CharIterator char_end() const;
545
+
546
+ // Cord::CharIterator::CharRange
547
+ //
548
+ // `CharRange` is a helper class for iterating over the characters of a
549
+ // producing an iterator which can be used within a range-based for loop.
550
+ // Construction of a `CharRange` will return an iterator pointing to the first
551
+ // character of the Cord. Generally, do not construct a `CharRange` directly;
552
+ // instead, prefer to use the `Cord::Chars()` method show below.
553
+ //
554
+ // Implementation note: `CharRange` is simply a convenience wrapper over
555
+ // `Cord::char_begin()` and `Cord::char_end()`.
556
+ class CharRange {
557
+ public:
558
+ explicit CharRange(const Cord* cord) : cord_(cord) {}
559
+
560
+ CharIterator begin() const;
561
+ CharIterator end() const;
562
+
563
+ private:
564
+ const Cord* cord_;
565
+ };
566
+
567
+ // Cord::CharIterator::Chars()
568
+ //
569
+ // Returns a `Cord::CharIterator` for iterating over the characters of a
570
+ // `Cord` with a range-based for-loop. For most character-based iteration
571
+ // tasks on a Cord, use `Cord::Chars()` to retrieve this iterator.
572
+ //
573
+ // Example:
574
+ //
575
+ // void ProcessCord(const Cord& cord) {
576
+ // for (char c : cord.Chars()) { ... }
577
+ // }
578
+ //
579
+ // Note that the ordinary caveats of temporary lifetime extension apply:
580
+ //
581
+ // void Process() {
582
+ // for (char c : CordFactory().Chars()) {
583
+ // // The temporary Cord returned by CordFactory has been destroyed!
584
+ // }
585
+ // }
586
+ CharRange Chars() const;
587
+
588
+ // Cord::operator[]
589
+ //
590
+ // Gets the "i"th character of the Cord and returns it, provided that
591
+ // 0 <= i < Cord.size().
592
+ //
593
+ // NOTE: This routine is reasonably efficient. It is roughly
594
+ // logarithmic based on the number of chunks that make up the cord. Still,
595
+ // if you need to iterate over the contents of a cord, you should
596
+ // use a CharIterator/ChunkIterator rather than call operator[] or Get()
597
+ // repeatedly in a loop.
598
+ char operator[](size_t i) const;
599
+
600
+ // Cord::TryFlat()
601
+ //
602
+ // If this cord's representation is a single flat array, returns a
603
+ // string_view referencing that array. Otherwise returns nullopt.
604
+ absl::optional<absl::string_view> TryFlat() const;
605
+
606
+ // Cord::Flatten()
607
+ //
608
+ // Flattens the cord into a single array and returns a view of the data.
609
+ //
610
+ // If the cord was already flat, the contents are not modified.
611
+ absl::string_view Flatten();
612
+
613
+ // Supports absl::Cord as a sink object for absl::Format().
614
+ friend void AbslFormatFlush(absl::Cord* cord, absl::string_view part) {
615
+ cord->Append(part);
616
+ }
617
+
618
+ template <typename H>
619
+ friend H AbslHashValue(H hash_state, const absl::Cord& c) {
620
+ absl::optional<absl::string_view> maybe_flat = c.TryFlat();
621
+ if (maybe_flat.has_value()) {
622
+ return H::combine(std::move(hash_state), *maybe_flat);
623
+ }
624
+ return c.HashFragmented(std::move(hash_state));
625
+ }
626
+
627
+ private:
628
+ friend class CordTestPeer;
629
+ friend bool operator==(const Cord& lhs, const Cord& rhs);
630
+ friend bool operator==(const Cord& lhs, absl::string_view rhs);
631
+
632
+ // Calls the provided function once for each cord chunk, in order. Unlike
633
+ // Chunks(), this API will not allocate memory.
634
+ void ForEachChunk(absl::FunctionRef<void(absl::string_view)>) const;
635
+
636
+ // Allocates new contiguous storage for the contents of the cord. This is
637
+ // called by Flatten() when the cord was not already flat.
638
+ absl::string_view FlattenSlowPath();
639
+
640
+ // Actual cord contents are hidden inside the following simple
641
+ // class so that we can isolate the bulk of cord.cc from changes
642
+ // to the representation.
643
+ //
644
+ // InlineRep holds either a tree pointer, or an array of kMaxInline bytes.
645
+ class InlineRep {
646
+ public:
647
+ static constexpr unsigned char kMaxInline = 15;
648
+ static_assert(kMaxInline >= sizeof(absl::cord_internal::CordRep*), "");
649
+ // Tag byte & kMaxInline means we are storing a pointer.
650
+ static constexpr unsigned char kTreeFlag = 1 << 4;
651
+ // Tag byte & kProfiledFlag means we are profiling the Cord.
652
+ static constexpr unsigned char kProfiledFlag = 1 << 5;
653
+
654
+ constexpr InlineRep() : data_{} {}
655
+ InlineRep(const InlineRep& src);
656
+ InlineRep(InlineRep&& src);
657
+ InlineRep& operator=(const InlineRep& src);
658
+ InlineRep& operator=(InlineRep&& src) noexcept;
659
+
660
+ void Swap(InlineRep* rhs);
661
+ bool empty() const;
662
+ size_t size() const;
663
+ const char* data() const; // Returns nullptr if holding pointer
664
+ void set_data(const char* data, size_t n,
665
+ bool nullify_tail); // Discards pointer, if any
666
+ char* set_data(size_t n); // Write data to the result
667
+ // Returns nullptr if holding bytes
668
+ absl::cord_internal::CordRep* tree() const;
669
+ // Discards old pointer, if any
670
+ void set_tree(absl::cord_internal::CordRep* rep);
671
+ // Replaces a tree with a new root. This is faster than set_tree, but it
672
+ // should only be used when it's clear that the old rep was a tree.
673
+ void replace_tree(absl::cord_internal::CordRep* rep);
674
+ // Returns non-null iff was holding a pointer
675
+ absl::cord_internal::CordRep* clear();
676
+ // Converts to pointer if necessary.
677
+ absl::cord_internal::CordRep* force_tree(size_t extra_hint);
678
+ void reduce_size(size_t n); // REQUIRES: holding data
679
+ void remove_prefix(size_t n); // REQUIRES: holding data
680
+ void AppendArray(const char* src_data, size_t src_size);
681
+ absl::string_view FindFlatStartPiece() const;
682
+ void AppendTree(absl::cord_internal::CordRep* tree);
683
+ void PrependTree(absl::cord_internal::CordRep* tree);
684
+ void GetAppendRegion(char** region, size_t* size, size_t max_length);
685
+ void GetAppendRegion(char** region, size_t* size);
686
+ bool IsSame(const InlineRep& other) const {
687
+ return memcmp(data_, other.data_, sizeof(data_)) == 0;
688
+ }
689
+ int BitwiseCompare(const InlineRep& other) const {
690
+ uint64_t x, y;
691
+ // Use memcpy to avoid anti-aliasing issues.
692
+ memcpy(&x, data_, sizeof(x));
693
+ memcpy(&y, other.data_, sizeof(y));
694
+ if (x == y) {
695
+ memcpy(&x, data_ + 8, sizeof(x));
696
+ memcpy(&y, other.data_ + 8, sizeof(y));
697
+ if (x == y) return 0;
698
+ }
699
+ return absl::big_endian::FromHost64(x) < absl::big_endian::FromHost64(y)
700
+ ? -1
701
+ : 1;
702
+ }
703
+ void CopyTo(std::string* dst) const {
704
+ // memcpy is much faster when operating on a known size. On most supported
705
+ // platforms, the small string optimization is large enough that resizing
706
+ // to 15 bytes does not cause a memory allocation.
707
+ absl::strings_internal::STLStringResizeUninitialized(dst,
708
+ sizeof(data_) - 1);
709
+ memcpy(&(*dst)[0], data_, sizeof(data_) - 1);
710
+ // erase is faster than resize because the logic for memory allocation is
711
+ // not needed.
712
+ dst->erase(data_[kMaxInline]);
713
+ }
714
+
715
+ // Copies the inline contents into `dst`. Assumes the cord is not empty.
716
+ void CopyToArray(char* dst) const;
717
+
718
+ bool is_tree() const { return data_[kMaxInline] > kMaxInline; }
719
+
720
+ private:
721
+ friend class Cord;
722
+
723
+ void AssignSlow(const InlineRep& src);
724
+ // Unrefs the tree, stops profiling, and zeroes the contents
725
+ void ClearSlow();
726
+
727
+ // If the data has length <= kMaxInline, we store it in data_[0..len-1],
728
+ // and store the length in data_[kMaxInline]. Else we store it in a tree
729
+ // and store a pointer to that tree in data_[0..sizeof(CordRep*)-1].
730
+ alignas(absl::cord_internal::CordRep*) char data_[kMaxInline + 1];
731
+ };
732
+ InlineRep contents_;
733
+
734
+ // Helper for MemoryUsage().
735
+ static size_t MemoryUsageAux(const absl::cord_internal::CordRep* rep);
736
+
737
+ // Helper for GetFlat() and TryFlat().
738
+ static bool GetFlatAux(absl::cord_internal::CordRep* rep,
739
+ absl::string_view* fragment);
740
+
741
+ // Helper for ForEachChunk().
742
+ static void ForEachChunkAux(
743
+ absl::cord_internal::CordRep* rep,
744
+ absl::FunctionRef<void(absl::string_view)> callback);
745
+
746
+ // The destructor for non-empty Cords.
747
+ void DestroyCordSlow();
748
+
749
+ // Out-of-line implementation of slower parts of logic.
750
+ void CopyToArraySlowPath(char* dst) const;
751
+ int CompareSlowPath(absl::string_view rhs, size_t compared_size,
752
+ size_t size_to_compare) const;
753
+ int CompareSlowPath(const Cord& rhs, size_t compared_size,
754
+ size_t size_to_compare) const;
755
+ bool EqualsImpl(absl::string_view rhs, size_t size_to_compare) const;
756
+ bool EqualsImpl(const Cord& rhs, size_t size_to_compare) const;
757
+ int CompareImpl(const Cord& rhs) const;
758
+
759
+ template <typename ResultType, typename RHS>
760
+ friend ResultType GenericCompare(const Cord& lhs, const RHS& rhs,
761
+ size_t size_to_compare);
762
+ static absl::string_view GetFirstChunk(const Cord& c);
763
+ static absl::string_view GetFirstChunk(absl::string_view sv);
764
+
765
+ // Returns a new reference to contents_.tree(), or steals an existing
766
+ // reference if called on an rvalue.
767
+ absl::cord_internal::CordRep* TakeRep() const&;
768
+ absl::cord_internal::CordRep* TakeRep() &&;
769
+
770
+ // Helper for Append().
771
+ template <typename C>
772
+ void AppendImpl(C&& src);
773
+
774
+ // Helper for AbslHashValue().
775
+ template <typename H>
776
+ H HashFragmented(H hash_state) const {
777
+ typename H::AbslInternalPiecewiseCombiner combiner;
778
+ ForEachChunk([&combiner, &hash_state](absl::string_view chunk) {
779
+ hash_state = combiner.add_buffer(std::move(hash_state), chunk.data(),
780
+ chunk.size());
781
+ });
782
+ return H::combine(combiner.finalize(std::move(hash_state)), size());
783
+ }
784
+ };
785
+
786
+ ABSL_NAMESPACE_END
787
+ } // namespace absl
788
+
789
+ namespace absl {
790
+ ABSL_NAMESPACE_BEGIN
791
+
792
+ // allow a Cord to be logged
793
+ extern std::ostream& operator<<(std::ostream& out, const Cord& cord);
794
+
795
+ // ------------------------------------------------------------------
796
+ // Internal details follow. Clients should ignore.
797
+
798
+ namespace cord_internal {
799
+
800
+ // Fast implementation of memmove for up to 15 bytes. This implementation is
801
+ // safe for overlapping regions. If nullify_tail is true, the destination is
802
+ // padded with '\0' up to 16 bytes.
803
+ inline void SmallMemmove(char* dst, const char* src, size_t n,
804
+ bool nullify_tail = false) {
805
+ if (n >= 8) {
806
+ assert(n <= 16);
807
+ uint64_t buf1;
808
+ uint64_t buf2;
809
+ memcpy(&buf1, src, 8);
810
+ memcpy(&buf2, src + n - 8, 8);
811
+ if (nullify_tail) {
812
+ memset(dst + 8, 0, 8);
813
+ }
814
+ memcpy(dst, &buf1, 8);
815
+ memcpy(dst + n - 8, &buf2, 8);
816
+ } else if (n >= 4) {
817
+ uint32_t buf1;
818
+ uint32_t buf2;
819
+ memcpy(&buf1, src, 4);
820
+ memcpy(&buf2, src + n - 4, 4);
821
+ if (nullify_tail) {
822
+ memset(dst + 4, 0, 4);
823
+ memset(dst + 8, 0, 8);
824
+ }
825
+ memcpy(dst, &buf1, 4);
826
+ memcpy(dst + n - 4, &buf2, 4);
827
+ } else {
828
+ if (n != 0) {
829
+ dst[0] = src[0];
830
+ dst[n / 2] = src[n / 2];
831
+ dst[n - 1] = src[n - 1];
832
+ }
833
+ if (nullify_tail) {
834
+ memset(dst + 8, 0, 8);
835
+ memset(dst + n, 0, 8);
836
+ }
837
+ }
838
+ }
839
+
840
+ // Does non-template-specific `CordRepExternal` initialization.
841
+ // Expects `data` to be non-empty.
842
+ void InitializeCordRepExternal(absl::string_view data, CordRepExternal* rep);
843
+
844
+ // Creates a new `CordRep` that owns `data` and `releaser` and returns a pointer
845
+ // to it, or `nullptr` if `data` was empty.
846
+ template <typename Releaser>
847
+ // NOLINTNEXTLINE - suppress clang-tidy raw pointer return.
848
+ CordRep* NewExternalRep(absl::string_view data, Releaser&& releaser) {
849
+ using ReleaserType = absl::decay_t<Releaser>;
850
+ if (data.empty()) {
851
+ // Never create empty external nodes.
852
+ InvokeReleaser(Rank0{}, ReleaserType(std::forward<Releaser>(releaser)),
853
+ data);
854
+ return nullptr;
855
+ }
856
+
857
+ CordRepExternal* rep = new CordRepExternalImpl<ReleaserType>(
858
+ std::forward<Releaser>(releaser), 0);
859
+ InitializeCordRepExternal(data, rep);
860
+ return rep;
861
+ }
862
+
863
+ // Overload for function reference types that dispatches using a function
864
+ // pointer because there are no `alignof()` or `sizeof()` a function reference.
865
+ // NOLINTNEXTLINE - suppress clang-tidy raw pointer return.
866
+ inline CordRep* NewExternalRep(absl::string_view data,
867
+ void (&releaser)(absl::string_view)) {
868
+ return NewExternalRep(data, &releaser);
869
+ }
870
+
871
+ } // namespace cord_internal
872
+
873
+ template <typename Releaser>
874
+ Cord MakeCordFromExternal(absl::string_view data, Releaser&& releaser) {
875
+ Cord cord;
876
+ cord.contents_.set_tree(::absl::cord_internal::NewExternalRep(
877
+ data, std::forward<Releaser>(releaser)));
878
+ return cord;
879
+ }
880
+
881
+ inline Cord::InlineRep::InlineRep(const Cord::InlineRep& src) {
882
+ cord_internal::SmallMemmove(data_, src.data_, sizeof(data_));
883
+ }
884
+
885
+ inline Cord::InlineRep::InlineRep(Cord::InlineRep&& src) {
886
+ memcpy(data_, src.data_, sizeof(data_));
887
+ memset(src.data_, 0, sizeof(data_));
888
+ }
889
+
890
+ inline Cord::InlineRep& Cord::InlineRep::operator=(const Cord::InlineRep& src) {
891
+ if (this == &src) {
892
+ return *this;
893
+ }
894
+ if (!is_tree() && !src.is_tree()) {
895
+ cord_internal::SmallMemmove(data_, src.data_, sizeof(data_));
896
+ return *this;
897
+ }
898
+ AssignSlow(src);
899
+ return *this;
900
+ }
901
+
902
+ inline Cord::InlineRep& Cord::InlineRep::operator=(
903
+ Cord::InlineRep&& src) noexcept {
904
+ if (is_tree()) {
905
+ ClearSlow();
906
+ }
907
+ memcpy(data_, src.data_, sizeof(data_));
908
+ memset(src.data_, 0, sizeof(data_));
909
+ return *this;
910
+ }
911
+
912
+ inline void Cord::InlineRep::Swap(Cord::InlineRep* rhs) {
913
+ if (rhs == this) {
914
+ return;
915
+ }
916
+
917
+ Cord::InlineRep tmp;
918
+ cord_internal::SmallMemmove(tmp.data_, data_, sizeof(data_));
919
+ cord_internal::SmallMemmove(data_, rhs->data_, sizeof(data_));
920
+ cord_internal::SmallMemmove(rhs->data_, tmp.data_, sizeof(data_));
921
+ }
922
+
923
+ inline const char* Cord::InlineRep::data() const {
924
+ return is_tree() ? nullptr : data_;
925
+ }
926
+
927
+ inline absl::cord_internal::CordRep* Cord::InlineRep::tree() const {
928
+ if (is_tree()) {
929
+ absl::cord_internal::CordRep* rep;
930
+ memcpy(&rep, data_, sizeof(rep));
931
+ return rep;
932
+ } else {
933
+ return nullptr;
934
+ }
935
+ }
936
+
937
+ inline bool Cord::InlineRep::empty() const { return data_[kMaxInline] == 0; }
938
+
939
+ inline size_t Cord::InlineRep::size() const {
940
+ const char tag = data_[kMaxInline];
941
+ if (tag <= kMaxInline) return tag;
942
+ return static_cast<size_t>(tree()->length);
943
+ }
944
+
945
+ inline void Cord::InlineRep::set_tree(absl::cord_internal::CordRep* rep) {
946
+ if (rep == nullptr) {
947
+ memset(data_, 0, sizeof(data_));
948
+ } else {
949
+ bool was_tree = is_tree();
950
+ memcpy(data_, &rep, sizeof(rep));
951
+ memset(data_ + sizeof(rep), 0, sizeof(data_) - sizeof(rep) - 1);
952
+ if (!was_tree) {
953
+ data_[kMaxInline] = kTreeFlag;
954
+ }
955
+ }
956
+ }
957
+
958
+ inline void Cord::InlineRep::replace_tree(absl::cord_internal::CordRep* rep) {
959
+ ABSL_ASSERT(is_tree());
960
+ if (ABSL_PREDICT_FALSE(rep == nullptr)) {
961
+ set_tree(rep);
962
+ return;
963
+ }
964
+ memcpy(data_, &rep, sizeof(rep));
965
+ memset(data_ + sizeof(rep), 0, sizeof(data_) - sizeof(rep) - 1);
966
+ }
967
+
968
+ inline absl::cord_internal::CordRep* Cord::InlineRep::clear() {
969
+ const char tag = data_[kMaxInline];
970
+ absl::cord_internal::CordRep* result = nullptr;
971
+ if (tag > kMaxInline) {
972
+ memcpy(&result, data_, sizeof(result));
973
+ }
974
+ memset(data_, 0, sizeof(data_)); // Clear the cord
975
+ return result;
976
+ }
977
+
978
+ inline void Cord::InlineRep::CopyToArray(char* dst) const {
979
+ assert(!is_tree());
980
+ size_t n = data_[kMaxInline];
981
+ assert(n != 0);
982
+ cord_internal::SmallMemmove(dst, data_, n);
983
+ }
984
+
985
+ constexpr inline Cord::Cord() noexcept {}
986
+
987
+ inline Cord& Cord::operator=(const Cord& x) {
988
+ contents_ = x.contents_;
989
+ return *this;
990
+ }
991
+
992
+ inline Cord::Cord(Cord&& src) noexcept : contents_(std::move(src.contents_)) {}
993
+
994
+ inline void Cord::swap(Cord& other) noexcept {
995
+ contents_.Swap(&other.contents_);
996
+ }
997
+
998
+ inline Cord& Cord::operator=(Cord&& x) noexcept {
999
+ contents_ = std::move(x.contents_);
1000
+ return *this;
1001
+ }
1002
+
1003
+ extern template Cord::Cord(std::string&& src);
1004
+ extern template Cord& Cord::operator=(std::string&& src);
1005
+
1006
+ inline size_t Cord::size() const {
1007
+ // Length is 1st field in str.rep_
1008
+ return contents_.size();
1009
+ }
1010
+
1011
+ inline bool Cord::empty() const { return contents_.empty(); }
1012
+
1013
+ inline size_t Cord::EstimatedMemoryUsage() const {
1014
+ size_t result = sizeof(Cord);
1015
+ if (const absl::cord_internal::CordRep* rep = contents_.tree()) {
1016
+ result += MemoryUsageAux(rep);
1017
+ }
1018
+ return result;
1019
+ }
1020
+
1021
+ inline absl::optional<absl::string_view> Cord::TryFlat() const {
1022
+ absl::cord_internal::CordRep* rep = contents_.tree();
1023
+ if (rep == nullptr) {
1024
+ return absl::string_view(contents_.data(), contents_.size());
1025
+ }
1026
+ absl::string_view fragment;
1027
+ if (GetFlatAux(rep, &fragment)) {
1028
+ return fragment;
1029
+ }
1030
+ return absl::nullopt;
1031
+ }
1032
+
1033
+ inline absl::string_view Cord::Flatten() {
1034
+ absl::cord_internal::CordRep* rep = contents_.tree();
1035
+ if (rep == nullptr) {
1036
+ return absl::string_view(contents_.data(), contents_.size());
1037
+ } else {
1038
+ absl::string_view already_flat_contents;
1039
+ if (GetFlatAux(rep, &already_flat_contents)) {
1040
+ return already_flat_contents;
1041
+ }
1042
+ }
1043
+ return FlattenSlowPath();
1044
+ }
1045
+
1046
+ inline void Cord::Append(absl::string_view src) {
1047
+ contents_.AppendArray(src.data(), src.size());
1048
+ }
1049
+
1050
+ extern template void Cord::Append(std::string&& src);
1051
+ extern template void Cord::Prepend(std::string&& src);
1052
+
1053
+ inline int Cord::Compare(const Cord& rhs) const {
1054
+ if (!contents_.is_tree() && !rhs.contents_.is_tree()) {
1055
+ return contents_.BitwiseCompare(rhs.contents_);
1056
+ }
1057
+
1058
+ return CompareImpl(rhs);
1059
+ }
1060
+
1061
+ // Does 'this' cord start/end with rhs
1062
+ inline bool Cord::StartsWith(const Cord& rhs) const {
1063
+ if (contents_.IsSame(rhs.contents_)) return true;
1064
+ size_t rhs_size = rhs.size();
1065
+ if (size() < rhs_size) return false;
1066
+ return EqualsImpl(rhs, rhs_size);
1067
+ }
1068
+
1069
+ inline bool Cord::StartsWith(absl::string_view rhs) const {
1070
+ size_t rhs_size = rhs.size();
1071
+ if (size() < rhs_size) return false;
1072
+ return EqualsImpl(rhs, rhs_size);
1073
+ }
1074
+
1075
+ inline Cord::ChunkIterator::ChunkIterator(const Cord* cord)
1076
+ : bytes_remaining_(cord->size()) {
1077
+ if (cord->empty()) return;
1078
+ if (cord->contents_.is_tree()) {
1079
+ stack_of_right_children_.push_back(cord->contents_.tree());
1080
+ operator++();
1081
+ } else {
1082
+ current_chunk_ = absl::string_view(cord->contents_.data(), cord->size());
1083
+ }
1084
+ }
1085
+
1086
+ inline Cord::ChunkIterator Cord::ChunkIterator::operator++(int) {
1087
+ ChunkIterator tmp(*this);
1088
+ operator++();
1089
+ return tmp;
1090
+ }
1091
+
1092
+ inline bool Cord::ChunkIterator::operator==(const ChunkIterator& other) const {
1093
+ return bytes_remaining_ == other.bytes_remaining_;
1094
+ }
1095
+
1096
+ inline bool Cord::ChunkIterator::operator!=(const ChunkIterator& other) const {
1097
+ return !(*this == other);
1098
+ }
1099
+
1100
+ inline Cord::ChunkIterator::reference Cord::ChunkIterator::operator*() const {
1101
+ ABSL_HARDENING_ASSERT(bytes_remaining_ != 0);
1102
+ return current_chunk_;
1103
+ }
1104
+
1105
+ inline Cord::ChunkIterator::pointer Cord::ChunkIterator::operator->() const {
1106
+ ABSL_HARDENING_ASSERT(bytes_remaining_ != 0);
1107
+ return &current_chunk_;
1108
+ }
1109
+
1110
+ inline void Cord::ChunkIterator::RemoveChunkPrefix(size_t n) {
1111
+ assert(n < current_chunk_.size());
1112
+ current_chunk_.remove_prefix(n);
1113
+ bytes_remaining_ -= n;
1114
+ }
1115
+
1116
+ inline void Cord::ChunkIterator::AdvanceBytes(size_t n) {
1117
+ if (ABSL_PREDICT_TRUE(n < current_chunk_.size())) {
1118
+ RemoveChunkPrefix(n);
1119
+ } else if (n != 0) {
1120
+ AdvanceBytesSlowPath(n);
1121
+ }
1122
+ }
1123
+
1124
+ inline Cord::ChunkIterator Cord::chunk_begin() const {
1125
+ return ChunkIterator(this);
1126
+ }
1127
+
1128
+ inline Cord::ChunkIterator Cord::chunk_end() const { return ChunkIterator(); }
1129
+
1130
+ inline Cord::ChunkIterator Cord::ChunkRange::begin() const {
1131
+ return cord_->chunk_begin();
1132
+ }
1133
+
1134
+ inline Cord::ChunkIterator Cord::ChunkRange::end() const {
1135
+ return cord_->chunk_end();
1136
+ }
1137
+
1138
+ inline Cord::ChunkRange Cord::Chunks() const { return ChunkRange(this); }
1139
+
1140
+ inline Cord::CharIterator& Cord::CharIterator::operator++() {
1141
+ if (ABSL_PREDICT_TRUE(chunk_iterator_->size() > 1)) {
1142
+ chunk_iterator_.RemoveChunkPrefix(1);
1143
+ } else {
1144
+ ++chunk_iterator_;
1145
+ }
1146
+ return *this;
1147
+ }
1148
+
1149
+ inline Cord::CharIterator Cord::CharIterator::operator++(int) {
1150
+ CharIterator tmp(*this);
1151
+ operator++();
1152
+ return tmp;
1153
+ }
1154
+
1155
+ inline bool Cord::CharIterator::operator==(const CharIterator& other) const {
1156
+ return chunk_iterator_ == other.chunk_iterator_;
1157
+ }
1158
+
1159
+ inline bool Cord::CharIterator::operator!=(const CharIterator& other) const {
1160
+ return !(*this == other);
1161
+ }
1162
+
1163
+ inline Cord::CharIterator::reference Cord::CharIterator::operator*() const {
1164
+ return *chunk_iterator_->data();
1165
+ }
1166
+
1167
+ inline Cord::CharIterator::pointer Cord::CharIterator::operator->() const {
1168
+ return chunk_iterator_->data();
1169
+ }
1170
+
1171
+ inline Cord Cord::AdvanceAndRead(CharIterator* it, size_t n_bytes) {
1172
+ assert(it != nullptr);
1173
+ return it->chunk_iterator_.AdvanceAndReadBytes(n_bytes);
1174
+ }
1175
+
1176
+ inline void Cord::Advance(CharIterator* it, size_t n_bytes) {
1177
+ assert(it != nullptr);
1178
+ it->chunk_iterator_.AdvanceBytes(n_bytes);
1179
+ }
1180
+
1181
+ inline absl::string_view Cord::ChunkRemaining(const CharIterator& it) {
1182
+ return *it.chunk_iterator_;
1183
+ }
1184
+
1185
+ inline Cord::CharIterator Cord::char_begin() const {
1186
+ return CharIterator(this);
1187
+ }
1188
+
1189
+ inline Cord::CharIterator Cord::char_end() const { return CharIterator(); }
1190
+
1191
+ inline Cord::CharIterator Cord::CharRange::begin() const {
1192
+ return cord_->char_begin();
1193
+ }
1194
+
1195
+ inline Cord::CharIterator Cord::CharRange::end() const {
1196
+ return cord_->char_end();
1197
+ }
1198
+
1199
+ inline Cord::CharRange Cord::Chars() const { return CharRange(this); }
1200
+
1201
+ inline void Cord::ForEachChunk(
1202
+ absl::FunctionRef<void(absl::string_view)> callback) const {
1203
+ absl::cord_internal::CordRep* rep = contents_.tree();
1204
+ if (rep == nullptr) {
1205
+ callback(absl::string_view(contents_.data(), contents_.size()));
1206
+ } else {
1207
+ return ForEachChunkAux(rep, callback);
1208
+ }
1209
+ }
1210
+
1211
+ // Nonmember Cord-to-Cord relational operarators.
1212
+ inline bool operator==(const Cord& lhs, const Cord& rhs) {
1213
+ if (lhs.contents_.IsSame(rhs.contents_)) return true;
1214
+ size_t rhs_size = rhs.size();
1215
+ if (lhs.size() != rhs_size) return false;
1216
+ return lhs.EqualsImpl(rhs, rhs_size);
1217
+ }
1218
+
1219
+ inline bool operator!=(const Cord& x, const Cord& y) { return !(x == y); }
1220
+ inline bool operator<(const Cord& x, const Cord& y) {
1221
+ return x.Compare(y) < 0;
1222
+ }
1223
+ inline bool operator>(const Cord& x, const Cord& y) {
1224
+ return x.Compare(y) > 0;
1225
+ }
1226
+ inline bool operator<=(const Cord& x, const Cord& y) {
1227
+ return x.Compare(y) <= 0;
1228
+ }
1229
+ inline bool operator>=(const Cord& x, const Cord& y) {
1230
+ return x.Compare(y) >= 0;
1231
+ }
1232
+
1233
+ // Nonmember Cord-to-absl::string_view relational operators.
1234
+ //
1235
+ // Due to implicit conversions, these also enable comparisons of Cord with
1236
+ // with std::string, ::string, and const char*.
1237
+ inline bool operator==(const Cord& lhs, absl::string_view rhs) {
1238
+ size_t lhs_size = lhs.size();
1239
+ size_t rhs_size = rhs.size();
1240
+ if (lhs_size != rhs_size) return false;
1241
+ return lhs.EqualsImpl(rhs, rhs_size);
1242
+ }
1243
+
1244
+ inline bool operator==(absl::string_view x, const Cord& y) { return y == x; }
1245
+ inline bool operator!=(const Cord& x, absl::string_view y) { return !(x == y); }
1246
+ inline bool operator!=(absl::string_view x, const Cord& y) { return !(x == y); }
1247
+ inline bool operator<(const Cord& x, absl::string_view y) {
1248
+ return x.Compare(y) < 0;
1249
+ }
1250
+ inline bool operator<(absl::string_view x, const Cord& y) {
1251
+ return y.Compare(x) > 0;
1252
+ }
1253
+ inline bool operator>(const Cord& x, absl::string_view y) { return y < x; }
1254
+ inline bool operator>(absl::string_view x, const Cord& y) { return y < x; }
1255
+ inline bool operator<=(const Cord& x, absl::string_view y) { return !(y < x); }
1256
+ inline bool operator<=(absl::string_view x, const Cord& y) { return !(y < x); }
1257
+ inline bool operator>=(const Cord& x, absl::string_view y) { return !(x < y); }
1258
+ inline bool operator>=(absl::string_view x, const Cord& y) { return !(x < y); }
1259
+
1260
+ // Some internals exposed to test code.
1261
+ namespace strings_internal {
1262
+ class CordTestAccess {
1263
+ public:
1264
+ static size_t FlatOverhead();
1265
+ static size_t MaxFlatLength();
1266
+ static size_t SizeofCordRepConcat();
1267
+ static size_t SizeofCordRepExternal();
1268
+ static size_t SizeofCordRepSubstring();
1269
+ static size_t FlatTagToLength(uint8_t tag);
1270
+ static uint8_t LengthToTag(size_t s);
1271
+ };
1272
+ } // namespace strings_internal
1273
+ ABSL_NAMESPACE_END
1274
+ } // namespace absl
1275
+
1276
+ #endif // ABSL_STRINGS_CORD_H_