grpc 1.31.1 → 1.32.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 (431) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +595 -15723
  3. data/include/grpc/grpc_security.h +31 -14
  4. data/include/grpc/impl/codegen/README.md +22 -0
  5. data/include/grpc/impl/codegen/port_platform.h +6 -1
  6. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -2
  7. data/src/core/ext/filters/client_channel/client_channel.cc +64 -20
  8. data/src/core/ext/filters/client_channel/client_channel.h +1 -1
  9. data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -3
  10. data/src/core/ext/filters/client_channel/health/health_check_client.cc +6 -1
  11. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +2 -3
  12. data/src/core/ext/filters/client_channel/lb_policy.h +2 -0
  13. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +6 -4
  14. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +20 -13
  15. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -13
  16. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -3
  17. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -37
  18. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +19 -13
  19. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +29 -10
  20. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +5 -4
  21. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +20 -9
  22. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +18 -12
  23. data/src/core/ext/filters/client_channel/lb_policy/xds/eds.cc +22 -14
  24. data/src/core/ext/filters/client_channel/lb_policy/xds/lrs.cc +18 -9
  25. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_routing.cc +54 -56
  26. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +3 -3
  27. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +1 -1
  28. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  29. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +1 -1
  30. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -1
  31. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +363 -14
  32. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +0 -1
  33. data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +5 -4
  34. data/src/core/ext/filters/client_channel/server_address.cc +40 -7
  35. data/src/core/ext/filters/client_channel/server_address.h +42 -4
  36. data/src/core/ext/filters/client_channel/subchannel.cc +64 -23
  37. data/src/core/ext/filters/client_channel/subchannel.h +16 -4
  38. data/src/core/ext/filters/max_age/max_age_filter.cc +2 -1
  39. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +87 -31
  40. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +18 -1
  41. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +10 -35
  42. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +19 -25
  43. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -1
  44. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +2 -2
  45. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +6 -6
  46. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +3 -2
  47. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +239 -277
  48. data/src/core/ext/transport/chttp2/transport/flow_control.cc +1 -1
  49. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +2 -2
  50. data/src/core/ext/transport/chttp2/transport/internal.h +5 -1
  51. data/src/core/ext/transport/chttp2/transport/parsing.cc +1 -28
  52. data/src/core/ext/transport/chttp2/transport/writing.cc +6 -5
  53. data/src/core/ext/transport/inproc/inproc_transport.cc +12 -12
  54. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +224 -0
  55. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +700 -0
  56. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -0
  57. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +226 -0
  58. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +380 -0
  59. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1378 -0
  60. data/src/core/ext/upb-generated/envoy/{api/v2/cluster → config/cluster/v3}/filter.upb.c +8 -8
  61. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +69 -0
  62. data/src/core/ext/upb-generated/envoy/{api/v2/cluster → config/cluster/v3}/outlier_detection.upb.c +8 -8
  63. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +323 -0
  64. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +112 -0
  65. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +334 -0
  66. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/backoff.upb.c +8 -8
  67. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +79 -0
  68. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +309 -0
  69. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +869 -0
  70. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +96 -0
  71. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +328 -0
  72. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +34 -0
  73. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +71 -0
  74. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +195 -0
  75. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +634 -0
  76. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +170 -0
  77. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +684 -0
  78. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/http_uri.upb.c +8 -8
  79. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +80 -0
  80. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +152 -0
  81. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +536 -0
  82. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +28 -0
  83. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +58 -0
  84. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/socket_option.upb.c +6 -6
  85. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +88 -0
  86. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +91 -0
  87. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +220 -0
  88. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +91 -0
  89. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +273 -0
  90. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +112 -0
  91. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +332 -0
  92. data/src/core/ext/upb-generated/envoy/config/listener/{v2 → v3}/api_listener.upb.c +8 -8
  93. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +65 -0
  94. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +108 -0
  95. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +401 -0
  96. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +138 -0
  97. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +490 -0
  98. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +41 -0
  99. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +94 -0
  100. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +174 -0
  101. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +599 -0
  102. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +63 -0
  103. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +204 -0
  104. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +773 -0
  105. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +2855 -0
  106. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +59 -0
  107. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +135 -0
  108. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +50 -0
  109. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +108 -0
  110. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +312 -0
  111. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1125 -0
  112. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +20 -0
  113. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +34 -0
  114. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +111 -0
  115. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +401 -0
  116. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +72 -0
  117. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +198 -0
  118. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +105 -0
  119. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +388 -0
  120. data/src/core/ext/upb-generated/envoy/{api/v2 → service/cluster/v3}/cds.upb.c +5 -6
  121. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +49 -0
  122. data/src/core/ext/upb-generated/envoy/service/discovery/{v2 → v3}/ads.upb.c +5 -4
  123. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +49 -0
  124. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +129 -0
  125. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +386 -0
  126. data/src/core/ext/upb-generated/envoy/{api/v2 → service/endpoint/v3}/eds.upb.c +5 -6
  127. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +49 -0
  128. data/src/core/ext/upb-generated/envoy/{api/v2 → service/listener/v3}/lds.upb.c +5 -6
  129. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +49 -0
  130. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +55 -0
  131. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +136 -0
  132. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/rds.upb.c +5 -6
  133. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +49 -0
  134. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/srds.upb.c +5 -6
  135. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +49 -0
  136. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +47 -0
  137. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +114 -0
  138. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +35 -0
  139. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +77 -0
  140. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +34 -0
  141. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +71 -0
  142. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +64 -0
  143. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +145 -0
  144. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +53 -0
  145. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +127 -0
  146. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +63 -0
  147. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +188 -0
  148. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +88 -0
  149. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +258 -0
  150. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +90 -0
  151. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +250 -0
  152. data/src/core/ext/upb-generated/envoy/type/{http.upb.c → v3/http.upb.c} +2 -2
  153. data/src/core/ext/upb-generated/envoy/type/{http.upb.h → v3/http.upb.h} +8 -8
  154. data/src/core/ext/upb-generated/envoy/type/{percent.upb.c → v3/percent.upb.c} +9 -8
  155. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +86 -0
  156. data/src/core/ext/upb-generated/envoy/type/{range.upb.c → v3/range.upb.c} +12 -11
  157. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +111 -0
  158. data/src/core/ext/upb-generated/envoy/type/{semantic_version.upb.c → v3/semantic_version.upb.c} +6 -5
  159. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +61 -0
  160. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +234 -0
  161. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +759 -0
  162. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +36 -36
  163. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +1 -1
  164. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +27 -0
  165. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +53 -0
  166. data/src/core/ext/upb-generated/validate/validate.upb.c +11 -11
  167. data/src/core/ext/upb-generated/validate/validate.upb.h +1 -1
  168. data/src/core/ext/{filters/client_channel/xds → xds}/xds_api.cc +1045 -767
  169. data/src/core/ext/{filters/client_channel/xds → xds}/xds_api.h +114 -99
  170. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.cc +44 -2
  171. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.h +8 -3
  172. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel.h +4 -4
  173. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_args.h +3 -3
  174. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_secure.cc +2 -5
  175. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.cc +85 -417
  176. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.h +12 -45
  177. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.cc +2 -2
  178. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.h +3 -3
  179. data/src/core/lib/channel/channelz.cc +14 -15
  180. data/src/core/lib/channel/channelz.h +1 -1
  181. data/src/core/lib/channel/channelz_registry.cc +3 -1
  182. data/src/core/lib/gpr/sync_posix.cc +2 -8
  183. data/src/core/lib/iomgr/endpoint.cc +5 -1
  184. data/src/core/lib/iomgr/endpoint.h +7 -3
  185. data/src/core/lib/iomgr/endpoint_cfstream.cc +32 -11
  186. data/src/core/lib/iomgr/ev_posix.cc +0 -2
  187. data/src/core/lib/iomgr/iomgr.cc +0 -10
  188. data/src/core/lib/iomgr/iomgr.h +0 -10
  189. data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.cc +1 -1
  190. data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.h +3 -3
  191. data/src/core/lib/iomgr/sockaddr_utils.cc +2 -1
  192. data/src/core/lib/iomgr/sockaddr_utils.h +2 -1
  193. data/src/core/lib/iomgr/tcp_custom.cc +32 -16
  194. data/src/core/lib/iomgr/tcp_posix.cc +31 -13
  195. data/src/core/lib/iomgr/tcp_windows.cc +26 -10
  196. data/src/core/lib/security/authorization/authorization_engine.cc +177 -0
  197. data/src/core/lib/security/authorization/authorization_engine.h +84 -0
  198. data/src/core/lib/security/authorization/evaluate_args.cc +153 -0
  199. data/src/core/lib/security/authorization/evaluate_args.h +59 -0
  200. data/src/core/lib/security/authorization/mock_cel/activation.h +57 -0
  201. data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +42 -0
  202. data/src/core/lib/security/authorization/mock_cel/cel_expression.h +68 -0
  203. data/src/core/lib/security/authorization/mock_cel/cel_value.h +93 -0
  204. data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +67 -0
  205. data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +56 -0
  206. data/src/core/lib/security/authorization/mock_cel/statusor.h +50 -0
  207. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +56 -38
  208. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -2
  209. data/src/core/lib/security/transport/secure_endpoint.cc +7 -1
  210. data/src/core/lib/surface/call.cc +12 -12
  211. data/src/core/lib/surface/call.h +2 -1
  212. data/src/core/lib/surface/channel.cc +28 -20
  213. data/src/core/lib/surface/channel.h +12 -2
  214. data/src/core/lib/surface/completion_queue.cc +10 -272
  215. data/src/core/lib/surface/completion_queue.h +0 -8
  216. data/src/core/lib/surface/init.cc +1 -3
  217. data/src/core/lib/surface/server.cc +1066 -1244
  218. data/src/core/lib/surface/server.h +363 -87
  219. data/src/core/lib/surface/version.cc +2 -2
  220. data/src/core/lib/transport/authority_override.cc +38 -0
  221. data/src/core/lib/transport/authority_override.h +32 -0
  222. data/src/core/lib/transport/connectivity_state.cc +18 -13
  223. data/src/core/lib/transport/connectivity_state.h +18 -6
  224. data/src/core/lib/transport/error_utils.cc +13 -0
  225. data/src/core/lib/transport/error_utils.h +6 -0
  226. data/src/core/lib/transport/static_metadata.cc +295 -276
  227. data/src/core/lib/transport/static_metadata.h +80 -73
  228. data/src/core/lib/transport/transport.h +7 -0
  229. data/src/core/lib/uri/uri_parser.cc +23 -21
  230. data/src/core/lib/uri/uri_parser.h +3 -1
  231. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +22 -0
  232. data/src/core/tsi/ssl_transport_security.cc +3 -9
  233. data/src/ruby/ext/grpc/rb_channel_credentials.c +9 -0
  234. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +2 -2
  235. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +4 -4
  236. data/src/ruby/lib/grpc/version.rb +1 -1
  237. data/src/ruby/spec/channel_credentials_spec.rb +10 -0
  238. data/src/ruby/spec/generic/active_call_spec.rb +19 -8
  239. data/third_party/abseil-cpp/absl/algorithm/container.h +1727 -0
  240. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +161 -0
  241. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.cc +93 -0
  242. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.h +130 -0
  243. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +620 -0
  244. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +126 -0
  245. data/third_party/abseil-cpp/absl/container/fixed_array.h +515 -0
  246. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +503 -0
  247. data/third_party/abseil-cpp/absl/container/internal/common.h +202 -0
  248. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +440 -0
  249. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +146 -0
  250. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +191 -0
  251. data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
  252. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +269 -0
  253. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +297 -0
  254. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +30 -0
  255. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +49 -0
  256. data/third_party/abseil-cpp/absl/container/internal/layout.h +741 -0
  257. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +48 -0
  258. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1882 -0
  259. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +138 -0
  260. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
  261. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1895 -0
  262. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +71 -0
  263. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +382 -0
  264. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +134 -0
  265. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +192 -0
  266. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +125 -0
  267. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +70 -0
  268. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +99 -0
  269. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +248 -0
  270. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +24 -0
  271. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +85 -0
  272. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +346 -0
  273. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +128 -0
  274. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +194 -0
  275. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
  276. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +140 -0
  277. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +231 -0
  278. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +25 -0
  279. data/third_party/abseil-cpp/absl/debugging/symbolize.h +99 -0
  280. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +1480 -0
  281. data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
  282. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +81 -0
  283. data/third_party/abseil-cpp/absl/functional/function_ref.h +139 -0
  284. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +106 -0
  285. data/third_party/abseil-cpp/absl/hash/hash.h +324 -0
  286. data/third_party/abseil-cpp/absl/hash/internal/city.cc +346 -0
  287. data/third_party/abseil-cpp/absl/hash/internal/city.h +96 -0
  288. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +55 -0
  289. data/third_party/abseil-cpp/absl/hash/internal/hash.h +988 -0
  290. data/third_party/abseil-cpp/absl/status/status.cc +447 -0
  291. data/third_party/abseil-cpp/absl/status/status.h +428 -0
  292. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +43 -0
  293. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +51 -0
  294. data/third_party/abseil-cpp/absl/strings/cord.cc +2019 -0
  295. data/third_party/abseil-cpp/absl/strings/cord.h +1121 -0
  296. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +151 -0
  297. data/third_party/abseil-cpp/absl/synchronization/barrier.cc +52 -0
  298. data/third_party/abseil-cpp/absl/synchronization/barrier.h +79 -0
  299. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +57 -0
  300. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +99 -0
  301. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +140 -0
  302. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +60 -0
  303. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +697 -0
  304. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +141 -0
  305. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +155 -0
  306. data/third_party/abseil-cpp/absl/synchronization/internal/mutex_nonprod.inc +261 -0
  307. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +106 -0
  308. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +115 -0
  309. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +484 -0
  310. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +159 -0
  311. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +2728 -0
  312. data/third_party/abseil-cpp/absl/synchronization/mutex.h +1056 -0
  313. data/third_party/abseil-cpp/absl/synchronization/notification.cc +78 -0
  314. data/third_party/abseil-cpp/absl/synchronization/notification.h +123 -0
  315. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +64 -0
  316. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +82 -0
  317. data/third_party/abseil-cpp/absl/types/internal/variant.h +1646 -0
  318. data/third_party/abseil-cpp/absl/types/variant.h +861 -0
  319. data/third_party/boringssl-with-bazel/err_data.c +263 -257
  320. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +16 -0
  321. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +456 -0
  322. data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +192 -0
  323. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +20 -0
  324. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +52 -0
  325. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +1 -1
  326. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +39 -7
  327. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +2 -3
  328. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +11 -0
  329. data/third_party/boringssl-with-bazel/src/ssl/internal.h +4 -0
  330. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +3 -6
  331. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +10 -0
  332. data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +34 -9
  333. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +5 -0
  334. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +5 -3
  335. data/third_party/upb/upb/decode.c +64 -15
  336. data/third_party/upb/upb/encode.c +2 -2
  337. data/third_party/upb/upb/msg.h +2 -2
  338. data/third_party/upb/upb/port_def.inc +1 -1
  339. data/third_party/upb/upb/table.c +0 -11
  340. data/third_party/upb/upb/table.int.h +0 -9
  341. data/third_party/upb/upb/upb.c +16 -14
  342. data/third_party/upb/upb/upb.h +26 -0
  343. data/third_party/upb/upb/upb.hpp +2 -0
  344. metadata +257 -155
  345. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.c +0 -21
  346. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.h +0 -34
  347. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.c +0 -114
  348. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.h +0 -429
  349. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.c +0 -72
  350. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.h +0 -198
  351. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.c +0 -105
  352. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.h +0 -388
  353. data/src/core/ext/upb-generated/envoy/api/v2/cds.upb.h +0 -52
  354. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.c +0 -403
  355. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.h +0 -1453
  356. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.c +0 -74
  357. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.h +0 -226
  358. data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.h +0 -69
  359. data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.h +0 -323
  360. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.c +0 -112
  361. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.h +0 -334
  362. data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.h +0 -79
  363. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.c +0 -313
  364. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.h +0 -891
  365. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.c +0 -96
  366. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.h +0 -328
  367. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.c +0 -34
  368. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.h +0 -71
  369. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.c +0 -197
  370. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.h +0 -649
  371. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.c +0 -172
  372. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.h +0 -693
  373. data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.h +0 -80
  374. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.c +0 -152
  375. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.h +0 -536
  376. data/src/core/ext/upb-generated/envoy/api/v2/core/socket_option.upb.h +0 -88
  377. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.c +0 -129
  378. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.h +0 -386
  379. data/src/core/ext/upb-generated/envoy/api/v2/eds.upb.h +0 -52
  380. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.c +0 -92
  381. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.h +0 -224
  382. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.c +0 -18
  383. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.h +0 -32
  384. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.c +0 -91
  385. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.h +0 -273
  386. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.c +0 -112
  387. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.h +0 -332
  388. data/src/core/ext/upb-generated/envoy/api/v2/lds.upb.h +0 -52
  389. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.c +0 -109
  390. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.h +0 -415
  391. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.c +0 -18
  392. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.h +0 -32
  393. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.c +0 -145
  394. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.h +0 -538
  395. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.c +0 -43
  396. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.h +0 -111
  397. data/src/core/ext/upb-generated/envoy/api/v2/rds.upb.h +0 -52
  398. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.c +0 -63
  399. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.h +0 -204
  400. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.c +0 -18
  401. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.h +0 -32
  402. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.c +0 -815
  403. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.h +0 -2984
  404. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.c +0 -59
  405. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.h +0 -135
  406. data/src/core/ext/upb-generated/envoy/api/v2/srds.upb.h +0 -52
  407. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.c +0 -228
  408. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.h +0 -732
  409. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.c +0 -316
  410. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.h +0 -1167
  411. data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.h +0 -65
  412. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.c +0 -51
  413. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.h +0 -125
  414. data/src/core/ext/upb-generated/envoy/service/discovery/v2/ads.upb.h +0 -49
  415. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.c +0 -54
  416. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.h +0 -136
  417. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.c +0 -63
  418. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.h +0 -145
  419. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.c +0 -53
  420. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.h +0 -133
  421. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.c +0 -88
  422. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.h +0 -258
  423. data/src/core/ext/upb-generated/envoy/type/percent.upb.h +0 -86
  424. data/src/core/ext/upb-generated/envoy/type/range.upb.h +0 -111
  425. data/src/core/ext/upb-generated/envoy/type/semantic_version.upb.h +0 -61
  426. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.c +0 -89
  427. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.h +0 -250
  428. data/src/core/lib/security/transport/target_authority_table.cc +0 -75
  429. data/src/core/lib/security/transport/target_authority_table.h +0 -40
  430. data/src/core/lib/slice/slice_hash_table.h +0 -199
  431. data/src/core/lib/slice/slice_weak_hash_table.h +0 -102
@@ -0,0 +1,861 @@
1
+ // Copyright 2018 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
+ // variant.h
17
+ // -----------------------------------------------------------------------------
18
+ //
19
+ // This header file defines an `absl::variant` type for holding a type-safe
20
+ // value of some prescribed set of types (noted as alternative types), and
21
+ // associated functions for managing variants.
22
+ //
23
+ // The `absl::variant` type is a form of type-safe union. An `absl::variant`
24
+ // should always hold a value of one of its alternative types (except in the
25
+ // "valueless by exception state" -- see below). A default-constructed
26
+ // `absl::variant` will hold the value of its first alternative type, provided
27
+ // it is default-constructible.
28
+ //
29
+ // In exceptional cases due to error, an `absl::variant` can hold no
30
+ // value (known as a "valueless by exception" state), though this is not the
31
+ // norm.
32
+ //
33
+ // As with `absl::optional`, an `absl::variant` -- when it holds a value --
34
+ // allocates a value of that type directly within the `variant` itself; it
35
+ // cannot hold a reference, array, or the type `void`; it can, however, hold a
36
+ // pointer to externally managed memory.
37
+ //
38
+ // `absl::variant` is a C++11 compatible version of the C++17 `std::variant`
39
+ // abstraction and is designed to be a drop-in replacement for code compliant
40
+ // with C++17.
41
+
42
+ #ifndef ABSL_TYPES_VARIANT_H_
43
+ #define ABSL_TYPES_VARIANT_H_
44
+
45
+ #include "absl/base/config.h"
46
+ #include "absl/utility/utility.h"
47
+
48
+ #ifdef ABSL_USES_STD_VARIANT
49
+
50
+ #include <variant> // IWYU pragma: export
51
+
52
+ namespace absl {
53
+ ABSL_NAMESPACE_BEGIN
54
+ using std::bad_variant_access;
55
+ using std::get;
56
+ using std::get_if;
57
+ using std::holds_alternative;
58
+ using std::monostate;
59
+ using std::variant;
60
+ using std::variant_alternative;
61
+ using std::variant_alternative_t;
62
+ using std::variant_npos;
63
+ using std::variant_size;
64
+ using std::variant_size_v;
65
+ using std::visit;
66
+ ABSL_NAMESPACE_END
67
+ } // namespace absl
68
+
69
+ #else // ABSL_USES_STD_VARIANT
70
+
71
+ #include <functional>
72
+ #include <new>
73
+ #include <type_traits>
74
+ #include <utility>
75
+
76
+ #include "absl/base/macros.h"
77
+ #include "absl/base/port.h"
78
+ #include "absl/meta/type_traits.h"
79
+ #include "absl/types/internal/variant.h"
80
+
81
+ namespace absl {
82
+ ABSL_NAMESPACE_BEGIN
83
+
84
+ // -----------------------------------------------------------------------------
85
+ // absl::variant
86
+ // -----------------------------------------------------------------------------
87
+ //
88
+ // An `absl::variant` type is a form of type-safe union. An `absl::variant` --
89
+ // except in exceptional cases -- always holds a value of one of its alternative
90
+ // types.
91
+ //
92
+ // Example:
93
+ //
94
+ // // Construct a variant that holds either an integer or a std::string and
95
+ // // assign it to a std::string.
96
+ // absl::variant<int, std::string> v = std::string("abc");
97
+ //
98
+ // // A default-constructed variant will hold a value-initialized value of
99
+ // // the first alternative type.
100
+ // auto a = absl::variant<int, std::string>(); // Holds an int of value '0'.
101
+ //
102
+ // // variants are assignable.
103
+ //
104
+ // // copy assignment
105
+ // auto v1 = absl::variant<int, std::string>("abc");
106
+ // auto v2 = absl::variant<int, std::string>(10);
107
+ // v2 = v1; // copy assign
108
+ //
109
+ // // move assignment
110
+ // auto v1 = absl::variant<int, std::string>("abc");
111
+ // v1 = absl::variant<int, std::string>(10);
112
+ //
113
+ // // assignment through type conversion
114
+ // a = 128; // variant contains int
115
+ // a = "128"; // variant contains std::string
116
+ //
117
+ // An `absl::variant` holding a value of one of its alternative types `T` holds
118
+ // an allocation of `T` directly within the variant itself. An `absl::variant`
119
+ // is not allowed to allocate additional storage, such as dynamic memory, to
120
+ // allocate the contained value. The contained value shall be allocated in a
121
+ // region of the variant storage suitably aligned for all alternative types.
122
+ template <typename... Ts>
123
+ class variant;
124
+
125
+ // swap()
126
+ //
127
+ // Swaps two `absl::variant` values. This function is equivalent to `v.swap(w)`
128
+ // where `v` and `w` are `absl::variant` types.
129
+ //
130
+ // Note that this function requires all alternative types to be both swappable
131
+ // and move-constructible, because any two variants may refer to either the same
132
+ // type (in which case, they will be swapped) or to two different types (in
133
+ // which case the values will need to be moved).
134
+ //
135
+ template <
136
+ typename... Ts,
137
+ absl::enable_if_t<
138
+ absl::conjunction<std::is_move_constructible<Ts>...,
139
+ type_traits_internal::IsSwappable<Ts>...>::value,
140
+ int> = 0>
141
+ void swap(variant<Ts...>& v, variant<Ts...>& w) noexcept(noexcept(v.swap(w))) {
142
+ v.swap(w);
143
+ }
144
+
145
+ // variant_size
146
+ //
147
+ // Returns the number of alternative types available for a given `absl::variant`
148
+ // type as a compile-time constant expression. As this is a class template, it
149
+ // is not generally useful for accessing the number of alternative types of
150
+ // any given `absl::variant` instance.
151
+ //
152
+ // Example:
153
+ //
154
+ // auto a = absl::variant<int, std::string>;
155
+ // constexpr int num_types =
156
+ // absl::variant_size<absl::variant<int, std::string>>();
157
+ //
158
+ // // You can also use the member constant `value`.
159
+ // constexpr int num_types =
160
+ // absl::variant_size<absl::variant<int, std::string>>::value;
161
+ //
162
+ // // `absl::variant_size` is more valuable for use in generic code:
163
+ // template <typename Variant>
164
+ // constexpr bool IsVariantMultivalue() {
165
+ // return absl::variant_size<Variant>() > 1;
166
+ // }
167
+ //
168
+ // Note that the set of cv-qualified specializations of `variant_size` are
169
+ // provided to ensure that those specializations compile (especially when passed
170
+ // within template logic).
171
+ template <class T>
172
+ struct variant_size;
173
+
174
+ template <class... Ts>
175
+ struct variant_size<variant<Ts...>>
176
+ : std::integral_constant<std::size_t, sizeof...(Ts)> {};
177
+
178
+ // Specialization of `variant_size` for const qualified variants.
179
+ template <class T>
180
+ struct variant_size<const T> : variant_size<T>::type {};
181
+
182
+ // Specialization of `variant_size` for volatile qualified variants.
183
+ template <class T>
184
+ struct variant_size<volatile T> : variant_size<T>::type {};
185
+
186
+ // Specialization of `variant_size` for const volatile qualified variants.
187
+ template <class T>
188
+ struct variant_size<const volatile T> : variant_size<T>::type {};
189
+
190
+ // variant_alternative
191
+ //
192
+ // Returns the alternative type for a given `absl::variant` at the passed
193
+ // index value as a compile-time constant expression. As this is a class
194
+ // template resulting in a type, it is not useful for access of the run-time
195
+ // value of any given `absl::variant` variable.
196
+ //
197
+ // Example:
198
+ //
199
+ // // The type of the 0th alternative is "int".
200
+ // using alternative_type_0
201
+ // = absl::variant_alternative<0, absl::variant<int, std::string>>::type;
202
+ //
203
+ // static_assert(std::is_same<alternative_type_0, int>::value, "");
204
+ //
205
+ // // `absl::variant_alternative` is more valuable for use in generic code:
206
+ // template <typename Variant>
207
+ // constexpr bool IsFirstElementTrivial() {
208
+ // return std::is_trivial_v<variant_alternative<0, Variant>::type>;
209
+ // }
210
+ //
211
+ // Note that the set of cv-qualified specializations of `variant_alternative`
212
+ // are provided to ensure that those specializations compile (especially when
213
+ // passed within template logic).
214
+ template <std::size_t I, class T>
215
+ struct variant_alternative;
216
+
217
+ template <std::size_t I, class... Types>
218
+ struct variant_alternative<I, variant<Types...>> {
219
+ using type =
220
+ variant_internal::VariantAlternativeSfinaeT<I, variant<Types...>>;
221
+ };
222
+
223
+ // Specialization of `variant_alternative` for const qualified variants.
224
+ template <std::size_t I, class T>
225
+ struct variant_alternative<I, const T> {
226
+ using type = const typename variant_alternative<I, T>::type;
227
+ };
228
+
229
+ // Specialization of `variant_alternative` for volatile qualified variants.
230
+ template <std::size_t I, class T>
231
+ struct variant_alternative<I, volatile T> {
232
+ using type = volatile typename variant_alternative<I, T>::type;
233
+ };
234
+
235
+ // Specialization of `variant_alternative` for const volatile qualified
236
+ // variants.
237
+ template <std::size_t I, class T>
238
+ struct variant_alternative<I, const volatile T> {
239
+ using type = const volatile typename variant_alternative<I, T>::type;
240
+ };
241
+
242
+ // Template type alias for variant_alternative<I, T>::type.
243
+ //
244
+ // Example:
245
+ //
246
+ // using alternative_type_0
247
+ // = absl::variant_alternative_t<0, absl::variant<int, std::string>>;
248
+ // static_assert(std::is_same<alternative_type_0, int>::value, "");
249
+ template <std::size_t I, class T>
250
+ using variant_alternative_t = typename variant_alternative<I, T>::type;
251
+
252
+ // holds_alternative()
253
+ //
254
+ // Checks whether the given variant currently holds a given alternative type,
255
+ // returning `true` if so.
256
+ //
257
+ // Example:
258
+ //
259
+ // absl::variant<int, std::string> foo = 42;
260
+ // if (absl::holds_alternative<int>(foo)) {
261
+ // std::cout << "The variant holds an integer";
262
+ // }
263
+ template <class T, class... Types>
264
+ constexpr bool holds_alternative(const variant<Types...>& v) noexcept {
265
+ static_assert(
266
+ variant_internal::UnambiguousIndexOfImpl<variant<Types...>, T,
267
+ 0>::value != sizeof...(Types),
268
+ "The type T must occur exactly once in Types...");
269
+ return v.index() ==
270
+ variant_internal::UnambiguousIndexOf<variant<Types...>, T>::value;
271
+ }
272
+
273
+ // get()
274
+ //
275
+ // Returns a reference to the value currently within a given variant, using
276
+ // either a unique alternative type amongst the variant's set of alternative
277
+ // types, or the variant's index value. Attempting to get a variant's value
278
+ // using a type that is not unique within the variant's set of alternative types
279
+ // is a compile-time error. If the index of the alternative being specified is
280
+ // different from the index of the alternative that is currently stored, throws
281
+ // `absl::bad_variant_access`.
282
+ //
283
+ // Example:
284
+ //
285
+ // auto a = absl::variant<int, std::string>;
286
+ //
287
+ // // Get the value by type (if unique).
288
+ // int i = absl::get<int>(a);
289
+ //
290
+ // auto b = absl::variant<int, int>;
291
+ //
292
+ // // Getting the value by a type that is not unique is ill-formed.
293
+ // int j = absl::get<int>(b); // Compile Error!
294
+ //
295
+ // // Getting value by index not ambiguous and allowed.
296
+ // int k = absl::get<1>(b);
297
+
298
+ // Overload for getting a variant's lvalue by type.
299
+ template <class T, class... Types>
300
+ constexpr T& get(variant<Types...>& v) { // NOLINT
301
+ return variant_internal::VariantCoreAccess::CheckedAccess<
302
+ variant_internal::IndexOf<T, Types...>::value>(v);
303
+ }
304
+
305
+ // Overload for getting a variant's rvalue by type.
306
+ // Note: `absl::move()` is required to allow use of constexpr in C++11.
307
+ template <class T, class... Types>
308
+ constexpr T&& get(variant<Types...>&& v) {
309
+ return variant_internal::VariantCoreAccess::CheckedAccess<
310
+ variant_internal::IndexOf<T, Types...>::value>(absl::move(v));
311
+ }
312
+
313
+ // Overload for getting a variant's const lvalue by type.
314
+ template <class T, class... Types>
315
+ constexpr const T& get(const variant<Types...>& v) {
316
+ return variant_internal::VariantCoreAccess::CheckedAccess<
317
+ variant_internal::IndexOf<T, Types...>::value>(v);
318
+ }
319
+
320
+ // Overload for getting a variant's const rvalue by type.
321
+ // Note: `absl::move()` is required to allow use of constexpr in C++11.
322
+ template <class T, class... Types>
323
+ constexpr const T&& get(const variant<Types...>&& v) {
324
+ return variant_internal::VariantCoreAccess::CheckedAccess<
325
+ variant_internal::IndexOf<T, Types...>::value>(absl::move(v));
326
+ }
327
+
328
+ // Overload for getting a variant's lvalue by index.
329
+ template <std::size_t I, class... Types>
330
+ constexpr variant_alternative_t<I, variant<Types...>>& get(
331
+ variant<Types...>& v) { // NOLINT
332
+ return variant_internal::VariantCoreAccess::CheckedAccess<I>(v);
333
+ }
334
+
335
+ // Overload for getting a variant's rvalue by index.
336
+ // Note: `absl::move()` is required to allow use of constexpr in C++11.
337
+ template <std::size_t I, class... Types>
338
+ constexpr variant_alternative_t<I, variant<Types...>>&& get(
339
+ variant<Types...>&& v) {
340
+ return variant_internal::VariantCoreAccess::CheckedAccess<I>(absl::move(v));
341
+ }
342
+
343
+ // Overload for getting a variant's const lvalue by index.
344
+ template <std::size_t I, class... Types>
345
+ constexpr const variant_alternative_t<I, variant<Types...>>& get(
346
+ const variant<Types...>& v) {
347
+ return variant_internal::VariantCoreAccess::CheckedAccess<I>(v);
348
+ }
349
+
350
+ // Overload for getting a variant's const rvalue by index.
351
+ // Note: `absl::move()` is required to allow use of constexpr in C++11.
352
+ template <std::size_t I, class... Types>
353
+ constexpr const variant_alternative_t<I, variant<Types...>>&& get(
354
+ const variant<Types...>&& v) {
355
+ return variant_internal::VariantCoreAccess::CheckedAccess<I>(absl::move(v));
356
+ }
357
+
358
+ // get_if()
359
+ //
360
+ // Returns a pointer to the value currently stored within a given variant, if
361
+ // present, using either a unique alternative type amongst the variant's set of
362
+ // alternative types, or the variant's index value. If such a value does not
363
+ // exist, returns `nullptr`.
364
+ //
365
+ // As with `get`, attempting to get a variant's value using a type that is not
366
+ // unique within the variant's set of alternative types is a compile-time error.
367
+
368
+ // Overload for getting a pointer to the value stored in the given variant by
369
+ // index.
370
+ template <std::size_t I, class... Types>
371
+ constexpr absl::add_pointer_t<variant_alternative_t<I, variant<Types...>>>
372
+ get_if(variant<Types...>* v) noexcept {
373
+ return (v != nullptr && v->index() == I)
374
+ ? std::addressof(
375
+ variant_internal::VariantCoreAccess::Access<I>(*v))
376
+ : nullptr;
377
+ }
378
+
379
+ // Overload for getting a pointer to the const value stored in the given
380
+ // variant by index.
381
+ template <std::size_t I, class... Types>
382
+ constexpr absl::add_pointer_t<const variant_alternative_t<I, variant<Types...>>>
383
+ get_if(const variant<Types...>* v) noexcept {
384
+ return (v != nullptr && v->index() == I)
385
+ ? std::addressof(
386
+ variant_internal::VariantCoreAccess::Access<I>(*v))
387
+ : nullptr;
388
+ }
389
+
390
+ // Overload for getting a pointer to the value stored in the given variant by
391
+ // type.
392
+ template <class T, class... Types>
393
+ constexpr absl::add_pointer_t<T> get_if(variant<Types...>* v) noexcept {
394
+ return absl::get_if<variant_internal::IndexOf<T, Types...>::value>(v);
395
+ }
396
+
397
+ // Overload for getting a pointer to the const value stored in the given variant
398
+ // by type.
399
+ template <class T, class... Types>
400
+ constexpr absl::add_pointer_t<const T> get_if(
401
+ const variant<Types...>* v) noexcept {
402
+ return absl::get_if<variant_internal::IndexOf<T, Types...>::value>(v);
403
+ }
404
+
405
+ // visit()
406
+ //
407
+ // Calls a provided functor on a given set of variants. `absl::visit()` is
408
+ // commonly used to conditionally inspect the state of a given variant (or set
409
+ // of variants).
410
+ //
411
+ // The functor must return the same type when called with any of the variants'
412
+ // alternatives.
413
+ //
414
+ // Example:
415
+ //
416
+ // // Define a visitor functor
417
+ // struct GetVariant {
418
+ // template<typename T>
419
+ // void operator()(const T& i) const {
420
+ // std::cout << "The variant's value is: " << i;
421
+ // }
422
+ // };
423
+ //
424
+ // // Declare our variant, and call `absl::visit()` on it.
425
+ // // Note that `GetVariant()` returns void in either case.
426
+ // absl::variant<int, std::string> foo = std::string("foo");
427
+ // GetVariant visitor;
428
+ // absl::visit(visitor, foo); // Prints `The variant's value is: foo'
429
+ template <typename Visitor, typename... Variants>
430
+ variant_internal::VisitResult<Visitor, Variants...> visit(Visitor&& vis,
431
+ Variants&&... vars) {
432
+ return variant_internal::
433
+ VisitIndices<variant_size<absl::decay_t<Variants> >::value...>::Run(
434
+ variant_internal::PerformVisitation<Visitor, Variants...>{
435
+ std::forward_as_tuple(absl::forward<Variants>(vars)...),
436
+ absl::forward<Visitor>(vis)},
437
+ vars.index()...);
438
+ }
439
+
440
+ // monostate
441
+ //
442
+ // The monostate class serves as a first alternative type for a variant for
443
+ // which the first variant type is otherwise not default-constructible.
444
+ struct monostate {};
445
+
446
+ // `absl::monostate` Relational Operators
447
+
448
+ constexpr bool operator<(monostate, monostate) noexcept { return false; }
449
+ constexpr bool operator>(monostate, monostate) noexcept { return false; }
450
+ constexpr bool operator<=(monostate, monostate) noexcept { return true; }
451
+ constexpr bool operator>=(monostate, monostate) noexcept { return true; }
452
+ constexpr bool operator==(monostate, monostate) noexcept { return true; }
453
+ constexpr bool operator!=(monostate, monostate) noexcept { return false; }
454
+
455
+
456
+ //------------------------------------------------------------------------------
457
+ // `absl::variant` Template Definition
458
+ //------------------------------------------------------------------------------
459
+ template <typename T0, typename... Tn>
460
+ class variant<T0, Tn...> : private variant_internal::VariantBase<T0, Tn...> {
461
+ static_assert(absl::conjunction<std::is_object<T0>,
462
+ std::is_object<Tn>...>::value,
463
+ "Attempted to instantiate a variant containing a non-object "
464
+ "type.");
465
+ // Intentionally not qualifying `negation` with `absl::` to work around a bug
466
+ // in MSVC 2015 with inline namespace and variadic template.
467
+ static_assert(absl::conjunction<negation<std::is_array<T0> >,
468
+ negation<std::is_array<Tn> >...>::value,
469
+ "Attempted to instantiate a variant containing an array type.");
470
+ static_assert(absl::conjunction<std::is_nothrow_destructible<T0>,
471
+ std::is_nothrow_destructible<Tn>...>::value,
472
+ "Attempted to instantiate a variant containing a non-nothrow "
473
+ "destructible type.");
474
+
475
+ friend struct variant_internal::VariantCoreAccess;
476
+
477
+ private:
478
+ using Base = variant_internal::VariantBase<T0, Tn...>;
479
+
480
+ public:
481
+ // Constructors
482
+
483
+ // Constructs a variant holding a default-initialized value of the first
484
+ // alternative type.
485
+ constexpr variant() /*noexcept(see 111above)*/ = default;
486
+
487
+ // Copy constructor, standard semantics
488
+ variant(const variant& other) = default;
489
+
490
+ // Move constructor, standard semantics
491
+ variant(variant&& other) /*noexcept(see above)*/ = default;
492
+
493
+ // Constructs a variant of an alternative type specified by overload
494
+ // resolution of the provided forwarding arguments through
495
+ // direct-initialization.
496
+ //
497
+ // Note: If the selected constructor is a constexpr constructor, this
498
+ // constructor shall be a constexpr constructor.
499
+ //
500
+ // NOTE: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2018/p0608r1.html
501
+ // has been voted passed the design phase in the C++ standard meeting in Mar
502
+ // 2018. It will be implemented and integrated into `absl::variant`.
503
+ template <
504
+ class T,
505
+ std::size_t I = std::enable_if<
506
+ variant_internal::IsNeitherSelfNorInPlace<variant,
507
+ absl::decay_t<T>>::value,
508
+ variant_internal::IndexOfConstructedType<variant, T>>::type::value,
509
+ class Tj = absl::variant_alternative_t<I, variant>,
510
+ absl::enable_if_t<std::is_constructible<Tj, T>::value>* =
511
+ nullptr>
512
+ constexpr variant(T&& t) noexcept(std::is_nothrow_constructible<Tj, T>::value)
513
+ : Base(variant_internal::EmplaceTag<I>(), absl::forward<T>(t)) {}
514
+
515
+ // Constructs a variant of an alternative type from the arguments through
516
+ // direct-initialization.
517
+ //
518
+ // Note: If the selected constructor is a constexpr constructor, this
519
+ // constructor shall be a constexpr constructor.
520
+ template <class T, class... Args,
521
+ typename std::enable_if<std::is_constructible<
522
+ variant_internal::UnambiguousTypeOfT<variant, T>,
523
+ Args...>::value>::type* = nullptr>
524
+ constexpr explicit variant(in_place_type_t<T>, Args&&... args)
525
+ : Base(variant_internal::EmplaceTag<
526
+ variant_internal::UnambiguousIndexOf<variant, T>::value>(),
527
+ absl::forward<Args>(args)...) {}
528
+
529
+ // Constructs a variant of an alternative type from an initializer list
530
+ // and other arguments through direct-initialization.
531
+ //
532
+ // Note: If the selected constructor is a constexpr constructor, this
533
+ // constructor shall be a constexpr constructor.
534
+ template <class T, class U, class... Args,
535
+ typename std::enable_if<std::is_constructible<
536
+ variant_internal::UnambiguousTypeOfT<variant, T>,
537
+ std::initializer_list<U>&, Args...>::value>::type* = nullptr>
538
+ constexpr explicit variant(in_place_type_t<T>, std::initializer_list<U> il,
539
+ Args&&... args)
540
+ : Base(variant_internal::EmplaceTag<
541
+ variant_internal::UnambiguousIndexOf<variant, T>::value>(),
542
+ il, absl::forward<Args>(args)...) {}
543
+
544
+ // Constructs a variant of an alternative type from a provided index,
545
+ // through value-initialization using the provided forwarded arguments.
546
+ template <std::size_t I, class... Args,
547
+ typename std::enable_if<std::is_constructible<
548
+ variant_internal::VariantAlternativeSfinaeT<I, variant>,
549
+ Args...>::value>::type* = nullptr>
550
+ constexpr explicit variant(in_place_index_t<I>, Args&&... args)
551
+ : Base(variant_internal::EmplaceTag<I>(), absl::forward<Args>(args)...) {}
552
+
553
+ // Constructs a variant of an alternative type from a provided index,
554
+ // through value-initialization of an initializer list and the provided
555
+ // forwarded arguments.
556
+ template <std::size_t I, class U, class... Args,
557
+ typename std::enable_if<std::is_constructible<
558
+ variant_internal::VariantAlternativeSfinaeT<I, variant>,
559
+ std::initializer_list<U>&, Args...>::value>::type* = nullptr>
560
+ constexpr explicit variant(in_place_index_t<I>, std::initializer_list<U> il,
561
+ Args&&... args)
562
+ : Base(variant_internal::EmplaceTag<I>(), il,
563
+ absl::forward<Args>(args)...) {}
564
+
565
+ // Destructors
566
+
567
+ // Destroys the variant's currently contained value, provided that
568
+ // `absl::valueless_by_exception()` is false.
569
+ ~variant() = default;
570
+
571
+ // Assignment Operators
572
+
573
+ // Copy assignment operator
574
+ variant& operator=(const variant& other) = default;
575
+
576
+ // Move assignment operator
577
+ variant& operator=(variant&& other) /*noexcept(see above)*/ = default;
578
+
579
+ // Converting assignment operator
580
+ //
581
+ // NOTE: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2018/p0608r1.html
582
+ // has been voted passed the design phase in the C++ standard meeting in Mar
583
+ // 2018. It will be implemented and integrated into `absl::variant`.
584
+ template <
585
+ class T,
586
+ std::size_t I = std::enable_if<
587
+ !std::is_same<absl::decay_t<T>, variant>::value,
588
+ variant_internal::IndexOfConstructedType<variant, T>>::type::value,
589
+ class Tj = absl::variant_alternative_t<I, variant>,
590
+ typename std::enable_if<std::is_assignable<Tj&, T>::value &&
591
+ std::is_constructible<Tj, T>::value>::type* =
592
+ nullptr>
593
+ variant& operator=(T&& t) noexcept(
594
+ std::is_nothrow_assignable<Tj&, T>::value&&
595
+ std::is_nothrow_constructible<Tj, T>::value) {
596
+ variant_internal::VisitIndices<sizeof...(Tn) + 1>::Run(
597
+ variant_internal::VariantCoreAccess::MakeConversionAssignVisitor(
598
+ this, absl::forward<T>(t)),
599
+ index());
600
+
601
+ return *this;
602
+ }
603
+
604
+
605
+ // emplace() Functions
606
+
607
+ // Constructs a value of the given alternative type T within the variant.
608
+ //
609
+ // Example:
610
+ //
611
+ // absl::variant<std::vector<int>, int, std::string> v;
612
+ // v.emplace<int>(99);
613
+ // v.emplace<std::string>("abc");
614
+ template <
615
+ class T, class... Args,
616
+ typename std::enable_if<std::is_constructible<
617
+ absl::variant_alternative_t<
618
+ variant_internal::UnambiguousIndexOf<variant, T>::value, variant>,
619
+ Args...>::value>::type* = nullptr>
620
+ T& emplace(Args&&... args) {
621
+ return variant_internal::VariantCoreAccess::Replace<
622
+ variant_internal::UnambiguousIndexOf<variant, T>::value>(
623
+ this, absl::forward<Args>(args)...);
624
+ }
625
+
626
+ // Constructs a value of the given alternative type T within the variant using
627
+ // an initializer list.
628
+ //
629
+ // Example:
630
+ //
631
+ // absl::variant<std::vector<int>, int, std::string> v;
632
+ // v.emplace<std::vector<int>>({0, 1, 2});
633
+ template <
634
+ class T, class U, class... Args,
635
+ typename std::enable_if<std::is_constructible<
636
+ absl::variant_alternative_t<
637
+ variant_internal::UnambiguousIndexOf<variant, T>::value, variant>,
638
+ std::initializer_list<U>&, Args...>::value>::type* = nullptr>
639
+ T& emplace(std::initializer_list<U> il, Args&&... args) {
640
+ return variant_internal::VariantCoreAccess::Replace<
641
+ variant_internal::UnambiguousIndexOf<variant, T>::value>(
642
+ this, il, absl::forward<Args>(args)...);
643
+ }
644
+
645
+ // Destroys the current value of the variant (provided that
646
+ // `absl::valueless_by_exception()` is false, and constructs a new value at
647
+ // the given index.
648
+ //
649
+ // Example:
650
+ //
651
+ // absl::variant<std::vector<int>, int, int> v;
652
+ // v.emplace<1>(99);
653
+ // v.emplace<2>(98);
654
+ // v.emplace<int>(99); // Won't compile. 'int' isn't a unique type.
655
+ template <std::size_t I, class... Args,
656
+ typename std::enable_if<
657
+ std::is_constructible<absl::variant_alternative_t<I, variant>,
658
+ Args...>::value>::type* = nullptr>
659
+ absl::variant_alternative_t<I, variant>& emplace(Args&&... args) {
660
+ return variant_internal::VariantCoreAccess::Replace<I>(
661
+ this, absl::forward<Args>(args)...);
662
+ }
663
+
664
+ // Destroys the current value of the variant (provided that
665
+ // `absl::valueless_by_exception()` is false, and constructs a new value at
666
+ // the given index using an initializer list and the provided arguments.
667
+ //
668
+ // Example:
669
+ //
670
+ // absl::variant<std::vector<int>, int, int> v;
671
+ // v.emplace<0>({0, 1, 2});
672
+ template <std::size_t I, class U, class... Args,
673
+ typename std::enable_if<std::is_constructible<
674
+ absl::variant_alternative_t<I, variant>,
675
+ std::initializer_list<U>&, Args...>::value>::type* = nullptr>
676
+ absl::variant_alternative_t<I, variant>& emplace(std::initializer_list<U> il,
677
+ Args&&... args) {
678
+ return variant_internal::VariantCoreAccess::Replace<I>(
679
+ this, il, absl::forward<Args>(args)...);
680
+ }
681
+
682
+ // variant::valueless_by_exception()
683
+ //
684
+ // Returns false if and only if the variant currently holds a valid value.
685
+ constexpr bool valueless_by_exception() const noexcept {
686
+ return this->index_ == absl::variant_npos;
687
+ }
688
+
689
+ // variant::index()
690
+ //
691
+ // Returns the index value of the variant's currently selected alternative
692
+ // type.
693
+ constexpr std::size_t index() const noexcept { return this->index_; }
694
+
695
+ // variant::swap()
696
+ //
697
+ // Swaps the values of two variant objects.
698
+ //
699
+ void swap(variant& rhs) noexcept(
700
+ absl::conjunction<
701
+ std::is_nothrow_move_constructible<T0>,
702
+ std::is_nothrow_move_constructible<Tn>...,
703
+ type_traits_internal::IsNothrowSwappable<T0>,
704
+ type_traits_internal::IsNothrowSwappable<Tn>...>::value) {
705
+ return variant_internal::VisitIndices<sizeof...(Tn) + 1>::Run(
706
+ variant_internal::Swap<T0, Tn...>{this, &rhs}, rhs.index());
707
+ }
708
+ };
709
+
710
+ // We need a valid declaration of variant<> for SFINAE and overload resolution
711
+ // to work properly above, but we don't need a full declaration since this type
712
+ // will never be constructed. This declaration, though incomplete, suffices.
713
+ template <>
714
+ class variant<>;
715
+
716
+ //------------------------------------------------------------------------------
717
+ // Relational Operators
718
+ //------------------------------------------------------------------------------
719
+ //
720
+ // If neither operand is in the `variant::valueless_by_exception` state:
721
+ //
722
+ // * If the index of both variants is the same, the relational operator
723
+ // returns the result of the corresponding relational operator for the
724
+ // corresponding alternative type.
725
+ // * If the index of both variants is not the same, the relational operator
726
+ // returns the result of that operation applied to the value of the left
727
+ // operand's index and the value of the right operand's index.
728
+ // * If at least one operand is in the valueless_by_exception state:
729
+ // - A variant in the valueless_by_exception state is only considered equal
730
+ // to another variant in the valueless_by_exception state.
731
+ // - If exactly one operand is in the valueless_by_exception state, the
732
+ // variant in the valueless_by_exception state is less than the variant
733
+ // that is not in the valueless_by_exception state.
734
+ //
735
+ // Note: The value 1 is added to each index in the relational comparisons such
736
+ // that the index corresponding to the valueless_by_exception state wraps around
737
+ // to 0 (the lowest value for the index type), and the remaining indices stay in
738
+ // the same relative order.
739
+
740
+ // Equal-to operator
741
+ template <typename... Types>
742
+ constexpr variant_internal::RequireAllHaveEqualT<Types...> operator==(
743
+ const variant<Types...>& a, const variant<Types...>& b) {
744
+ return (a.index() == b.index()) &&
745
+ variant_internal::VisitIndices<sizeof...(Types)>::Run(
746
+ variant_internal::EqualsOp<Types...>{&a, &b}, a.index());
747
+ }
748
+
749
+ // Not equal operator
750
+ template <typename... Types>
751
+ constexpr variant_internal::RequireAllHaveNotEqualT<Types...> operator!=(
752
+ const variant<Types...>& a, const variant<Types...>& b) {
753
+ return (a.index() != b.index()) ||
754
+ variant_internal::VisitIndices<sizeof...(Types)>::Run(
755
+ variant_internal::NotEqualsOp<Types...>{&a, &b}, a.index());
756
+ }
757
+
758
+ // Less-than operator
759
+ template <typename... Types>
760
+ constexpr variant_internal::RequireAllHaveLessThanT<Types...> operator<(
761
+ const variant<Types...>& a, const variant<Types...>& b) {
762
+ return (a.index() != b.index())
763
+ ? (a.index() + 1) < (b.index() + 1)
764
+ : variant_internal::VisitIndices<sizeof...(Types)>::Run(
765
+ variant_internal::LessThanOp<Types...>{&a, &b}, a.index());
766
+ }
767
+
768
+ // Greater-than operator
769
+ template <typename... Types>
770
+ constexpr variant_internal::RequireAllHaveGreaterThanT<Types...> operator>(
771
+ const variant<Types...>& a, const variant<Types...>& b) {
772
+ return (a.index() != b.index())
773
+ ? (a.index() + 1) > (b.index() + 1)
774
+ : variant_internal::VisitIndices<sizeof...(Types)>::Run(
775
+ variant_internal::GreaterThanOp<Types...>{&a, &b},
776
+ a.index());
777
+ }
778
+
779
+ // Less-than or equal-to operator
780
+ template <typename... Types>
781
+ constexpr variant_internal::RequireAllHaveLessThanOrEqualT<Types...> operator<=(
782
+ const variant<Types...>& a, const variant<Types...>& b) {
783
+ return (a.index() != b.index())
784
+ ? (a.index() + 1) < (b.index() + 1)
785
+ : variant_internal::VisitIndices<sizeof...(Types)>::Run(
786
+ variant_internal::LessThanOrEqualsOp<Types...>{&a, &b},
787
+ a.index());
788
+ }
789
+
790
+ // Greater-than or equal-to operator
791
+ template <typename... Types>
792
+ constexpr variant_internal::RequireAllHaveGreaterThanOrEqualT<Types...>
793
+ operator>=(const variant<Types...>& a, const variant<Types...>& b) {
794
+ return (a.index() != b.index())
795
+ ? (a.index() + 1) > (b.index() + 1)
796
+ : variant_internal::VisitIndices<sizeof...(Types)>::Run(
797
+ variant_internal::GreaterThanOrEqualsOp<Types...>{&a, &b},
798
+ a.index());
799
+ }
800
+
801
+ ABSL_NAMESPACE_END
802
+ } // namespace absl
803
+
804
+ namespace std {
805
+
806
+ // hash()
807
+ template <> // NOLINT
808
+ struct hash<absl::monostate> {
809
+ std::size_t operator()(absl::monostate) const { return 0; }
810
+ };
811
+
812
+ template <class... T> // NOLINT
813
+ struct hash<absl::variant<T...>>
814
+ : absl::variant_internal::VariantHashBase<absl::variant<T...>, void,
815
+ absl::remove_const_t<T>...> {};
816
+
817
+ } // namespace std
818
+
819
+ #endif // ABSL_USES_STD_VARIANT
820
+
821
+ namespace absl {
822
+ ABSL_NAMESPACE_BEGIN
823
+ namespace variant_internal {
824
+
825
+ // Helper visitor for converting a variant<Ts...>` into another type (mostly
826
+ // variant) that can be constructed from any type.
827
+ template <typename To>
828
+ struct ConversionVisitor {
829
+ template <typename T>
830
+ To operator()(T&& v) const {
831
+ return To(std::forward<T>(v));
832
+ }
833
+ };
834
+
835
+ } // namespace variant_internal
836
+
837
+ // ConvertVariantTo()
838
+ //
839
+ // Helper functions to convert an `absl::variant` to a variant of another set of
840
+ // types, provided that the alternative type of the new variant type can be
841
+ // converted from any type in the source variant.
842
+ //
843
+ // Example:
844
+ //
845
+ // absl::variant<name1, name2, float> InternalReq(const Req&);
846
+ //
847
+ // // name1 and name2 are convertible to name
848
+ // absl::variant<name, float> ExternalReq(const Req& req) {
849
+ // return absl::ConvertVariantTo<absl::variant<name, float>>(
850
+ // InternalReq(req));
851
+ // }
852
+ template <typename To, typename Variant>
853
+ To ConvertVariantTo(Variant&& variant) {
854
+ return absl::visit(variant_internal::ConversionVisitor<To>{},
855
+ std::forward<Variant>(variant));
856
+ }
857
+
858
+ ABSL_NAMESPACE_END
859
+ } // namespace absl
860
+
861
+ #endif // ABSL_TYPES_VARIANT_H_