grpc 1.58.3 → 1.59.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Makefile +48 -33
- data/include/grpc/event_engine/event_engine.h +6 -10
- data/include/grpc/impl/channel_arg_names.h +4 -0
- data/include/grpc/support/port_platform.h +74 -1
- data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +22 -9
- data/src/core/ext/filters/client_channel/client_channel.cc +422 -56
- data/src/core/ext/filters/client_channel/client_channel.h +52 -8
- data/src/core/ext/filters/client_channel/client_channel_plugin.cc +15 -1
- data/src/core/ext/filters/client_channel/dynamic_filters.h +2 -0
- data/src/core/ext/filters/client_channel/{http_proxy.cc → http_proxy_mapper.cc} +1 -1
- data/src/core/ext/filters/client_channel/{http_proxy.h → http_proxy_mapper.h} +3 -3
- data/src/core/ext/filters/client_channel/lb_policy/endpoint_list.cc +188 -0
- data/src/core/ext/filters/client_channel/lb_policy/endpoint_list.h +214 -0
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +17 -4
- data/src/core/ext/filters/client_channel/lb_policy/health_check_client.cc +41 -6
- data/src/core/ext/filters/client_channel/lb_policy/health_check_client_internal.h +5 -3
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +32 -103
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +0 -7
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +416 -139
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.h +16 -0
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +434 -459
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +410 -26
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +14 -46
- data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/weighted_round_robin.cc +851 -57
- data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +16 -10
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +47 -32
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_override_host.cc +55 -3
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +105 -175
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +14 -7
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +24 -6
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +36 -2
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +54 -44
- data/src/core/ext/filters/client_channel/subchannel.cc +33 -0
- data/src/core/ext/filters/client_channel/subchannel.h +9 -0
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +1 -1
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +11 -6
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +28 -22
- data/src/core/ext/transport/chttp2/transport/flow_control.h +27 -4
- data/src/core/ext/transport/chttp2/transport/frame_data.h +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_ping.cc +9 -0
- data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_settings.cc +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_settings.h +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_window_update.h +1 -1
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +1 -1
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +34 -36
- data/src/core/ext/transport/chttp2/transport/hpack_parser.h +3 -3
- data/src/core/ext/transport/chttp2/transport/internal.h +66 -47
- data/src/core/ext/transport/chttp2/transport/{frame.h → legacy_frame.h} +3 -3
- data/src/core/ext/transport/chttp2/transport/parsing.cc +4 -2
- data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +10 -0
- data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +4 -0
- data/src/core/ext/transport/chttp2/transport/stream_lists.cc +1 -1
- data/src/core/ext/transport/chttp2/transport/writing.cc +2 -1
- data/src/core/ext/transport/inproc/inproc_transport.cc +9 -0
- data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +16 -18
- data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +75 -83
- data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +27 -29
- data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +102 -110
- data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +16 -18
- data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +73 -81
- data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +65 -67
- data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +294 -302
- data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +20 -28
- data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +5 -7
- data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +24 -32
- data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +19 -27
- data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +10 -18
- data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +10 -18
- data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +42 -44
- data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +141 -149
- data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +8 -16
- data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +5 -7
- data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +4 -12
- data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +36 -38
- data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +157 -165
- data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +87 -89
- data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +372 -380
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +13 -15
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +55 -63
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +111 -113
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +441 -449
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +8 -16
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +23 -25
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +88 -96
- data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +40 -42
- data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +180 -188
- data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +26 -28
- data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +108 -116
- data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +9 -17
- data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +65 -67
- data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +245 -253
- data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +27 -29
- data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +119 -127
- data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +6 -14
- data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +8 -16
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +20 -28
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +49 -51
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +184 -192
- data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +49 -51
- data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +225 -233
- data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +13 -21
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +63 -65
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +246 -254
- data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +5 -7
- data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +19 -27
- data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +5 -7
- data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +19 -27
- data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +30 -38
- data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +28 -36
- data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +9 -17
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +12 -14
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +48 -56
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +23 -25
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +92 -100
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +27 -29
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +108 -116
- data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +5 -13
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +38 -40
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +167 -175
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +34 -36
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +162 -170
- data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +10 -12
- data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +37 -45
- data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +13 -21
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +6 -8
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +18 -26
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +22 -24
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +97 -105
- data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +24 -26
- data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +111 -119
- data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +43 -45
- data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +183 -191
- data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +20 -22
- data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +102 -110
- data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +253 -255
- data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +1108 -1116
- data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +31 -39
- data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +35 -37
- data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +150 -158
- data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +10 -18
- data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +8 -16
- data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +13 -21
- data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +5 -7
- data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +19 -27
- data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +14 -16
- data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +53 -61
- data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +8 -16
- data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +5 -13
- data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +24 -32
- data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +1 -3
- data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +23 -31
- data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +23 -31
- data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.c +114 -116
- data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.h +372 -380
- data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +9 -17
- data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +30 -38
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +21 -23
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +81 -89
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +24 -32
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +12 -14
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +52 -60
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +14 -22
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +114 -116
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +468 -476
- data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +5 -13
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +25 -33
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.c +11 -13
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +40 -48
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +4 -12
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +27 -35
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +5 -13
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +1 -3
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +35 -37
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +165 -173
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +9 -11
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +32 -40
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +39 -41
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +169 -177
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +16 -24
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +1 -3
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +55 -57
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +241 -249
- data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +31 -39
- data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +23 -25
- data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +98 -106
- data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +11 -19
- data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +18 -26
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.h +9 -17
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +6 -8
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +16 -24
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +6 -8
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +24 -32
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +13 -21
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +3 -5
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +10 -18
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +6 -14
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +6 -8
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +20 -28
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.c +1 -3
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +33 -41
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +18 -26
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +31 -39
- data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +8 -10
- data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +34 -42
- data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +14 -16
- data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +47 -55
- data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +13 -21
- data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +1 -3
- data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +2 -4
- data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +4 -12
- data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +10 -18
- data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +7 -9
- data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +19 -27
- data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +6 -8
- data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +20 -28
- data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +1 -3
- data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +1 -9
- data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +10 -18
- data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +4 -6
- data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +12 -20
- data/src/core/ext/upb-generated/google/api/annotations.upb.c +2 -4
- data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -9
- data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +45 -47
- data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +190 -198
- data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +54 -56
- data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +210 -218
- data/src/core/ext/upb-generated/google/api/http.upb.c +15 -17
- data/src/core/ext/upb-generated/google/api/http.upb.h +60 -68
- data/src/core/ext/upb-generated/google/api/httpbody.upb.c +4 -6
- data/src/core/ext/upb-generated/google/api/httpbody.upb.h +15 -23
- data/src/core/ext/upb-generated/google/protobuf/any.upb.c +3 -5
- data/src/core/ext/upb-generated/google/protobuf/any.upb.h +7 -15
- data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +359 -204
- data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +1340 -760
- data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +3 -5
- data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +7 -15
- data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -3
- data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +1 -9
- data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +11 -13
- data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +43 -51
- data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +3 -5
- data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +7 -15
- data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +10 -12
- data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +28 -36
- data/src/core/ext/upb-generated/google/rpc/status.upb.c +4 -6
- data/src/core/ext/upb-generated/google/rpc/status.upb.h +15 -23
- data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +11 -13
- data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +35 -43
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +10 -12
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +28 -36
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +48 -50
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +190 -198
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +5 -7
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +15 -23
- data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +3 -5
- data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +7 -15
- data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +21 -23
- data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +80 -88
- data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +9 -11
- data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +29 -37
- data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +32 -34
- data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +147 -155
- data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +10 -12
- data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +13 -21
- data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +4 -6
- data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +7 -15
- data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +2 -4
- data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +1 -9
- data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +4 -6
- data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +7 -15
- data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +3 -5
- data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +4 -12
- data/src/core/ext/upb-generated/validate/validate.upb.c +201 -203
- data/src/core/ext/upb-generated/validate/validate.upb.h +924 -932
- data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +10 -12
- data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +13 -21
- data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +4 -6
- data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +7 -15
- data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +2 -4
- data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +1 -9
- data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +9 -11
- data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +16 -24
- data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +3 -5
- data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +4 -12
- data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +2 -4
- data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +4 -12
- data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.c +3 -5
- data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.h +8 -16
- data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +6 -8
- data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +20 -28
- data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +4 -6
- data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +9 -17
- data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +3 -5
- data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +8 -16
- data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +4 -6
- data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +12 -20
- data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +9 -11
- data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +35 -43
- data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +5 -7
- data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +14 -22
- data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +16 -18
- data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +43 -51
- data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +3 -5
- data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +13 -21
- data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.c +2 -4
- data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.h +5 -13
- data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.c +4 -6
- data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.h +21 -29
- data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.c +1 -3
- data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.h +1 -9
- data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.c +5 -7
- data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.h +24 -32
- data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +24 -26
- data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +103 -111
- data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.c +10 -12
- data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.h +61 -69
- data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +3 -5
- data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +9 -17
- data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +8 -10
- data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +33 -41
- data/src/core/ext/upb-generated/xds/type/v3/cel.upb.c +5 -7
- data/src/core/ext/upb-generated/xds/type/v3/cel.upb.h +18 -26
- data/src/core/ext/upb-generated/xds/type/v3/range.upb.c +7 -9
- data/src/core/ext/upb-generated/xds/type/v3/range.upb.h +19 -27
- data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +3 -5
- data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +8 -16
- data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +367 -290
- data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +10 -0
- data/src/core/ext/xds/xds_client.cc +6 -9
- data/src/core/ext/xds/xds_client.h +2 -2
- data/src/core/ext/xds/xds_cluster.cc +30 -42
- data/src/core/ext/xds/xds_cluster.h +0 -4
- data/src/core/ext/xds/xds_endpoint.cc +12 -19
- data/src/core/ext/xds/xds_endpoint.h +0 -1
- data/src/core/ext/xds/xds_http_filters.cc +1 -4
- data/src/core/ext/xds/xds_listener.cc +14 -14
- data/src/core/ext/xds/xds_listener.h +13 -3
- data/src/core/ext/xds/xds_resource_type.h +1 -7
- data/src/core/ext/xds/xds_resource_type_impl.h +9 -11
- data/src/core/ext/xds/xds_route_config.cc +10 -11
- data/src/core/ext/xds/xds_route_config.h +1 -1
- data/src/core/ext/xds/xds_server_config_fetcher.cc +53 -28
- data/src/core/ext/xds/xds_transport_grpc.cc +11 -1
- data/src/core/lib/backoff/random_early_detection.cc +4 -2
- data/src/core/lib/backoff/random_early_detection.h +2 -4
- data/src/core/lib/channel/call_tracer.cc +7 -1
- data/src/core/lib/channel/call_tracer.h +4 -1
- data/src/core/lib/channel/channelz_registry.h +4 -2
- data/src/core/lib/channel/connected_channel.cc +1 -1
- data/src/core/lib/config/config_vars.h +1 -1
- data/src/core/lib/config/core_configuration.cc +2 -1
- data/src/core/lib/config/core_configuration.h +5 -4
- data/src/core/lib/debug/stats_data.cc +146 -51
- data/src/core/lib/debug/stats_data.h +81 -20
- data/src/core/lib/event_engine/cf_engine/cf_engine.cc +3 -0
- data/src/core/lib/event_engine/cf_engine/cf_engine.h +3 -0
- data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +3 -0
- data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +3 -0
- data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +3 -0
- data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +15 -3
- data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +3 -0
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +1 -1
- data/src/core/lib/event_engine/thread_pool/thread_count.h +15 -0
- data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +3 -15
- data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +10 -4
- data/src/core/lib/experiments/config.cc +9 -1
- data/src/core/lib/experiments/experiments.cc +144 -60
- data/src/core/lib/experiments/experiments.h +146 -41
- data/src/core/lib/gprpp/fork.h +1 -1
- data/src/core/lib/gprpp/manual_constructor.h +1 -2
- data/src/core/lib/gprpp/no_destruct.h +1 -1
- data/src/core/lib/gprpp/per_cpu.cc +2 -0
- data/src/core/lib/gprpp/per_cpu.h +36 -7
- data/src/core/lib/gprpp/ref_counted_ptr.h +63 -0
- data/src/core/lib/gprpp/work_serializer.cc +297 -25
- data/src/core/lib/gprpp/work_serializer.h +25 -9
- data/src/core/lib/iomgr/combiner.cc +54 -15
- data/src/core/lib/iomgr/combiner.h +8 -3
- data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +2 -4
- data/src/core/lib/iomgr/exec_ctx.cc +12 -0
- data/src/core/lib/iomgr/exec_ctx.h +55 -19
- data/src/core/lib/iomgr/polling_entity.cc +10 -0
- data/src/core/lib/iomgr/polling_entity.h +2 -0
- data/src/core/lib/iomgr/port.h +14 -0
- data/src/core/lib/iomgr/tcp_posix.cc +17 -14
- data/src/core/lib/load_balancing/lb_policy.h +10 -9
- data/src/core/lib/promise/arena_promise.h +5 -1
- data/src/core/lib/promise/detail/seq_state.h +418 -0
- data/src/core/lib/promise/latch.h +1 -0
- data/src/core/lib/promise/loop.h +8 -5
- data/src/core/lib/promise/pipe.h +24 -24
- data/src/core/lib/promise/poll.h +4 -6
- data/src/core/lib/resolver/server_address.h +1 -0
- data/src/core/lib/resource_quota/memory_quota.cc +58 -2
- data/src/core/lib/resource_quota/memory_quota.h +4 -1
- data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +115 -9
- data/src/core/lib/security/credentials/ssl/ssl_credentials.h +14 -0
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +86 -0
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +0 -59
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +2 -0
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +7 -57
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +1 -1
- data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +2 -14
- data/src/core/lib/slice/slice.h +6 -0
- data/src/core/lib/slice/slice_buffer.cc +15 -0
- data/src/core/lib/slice/slice_buffer.h +16 -4
- data/src/core/lib/slice/slice_refcount.h +1 -1
- data/src/core/lib/surface/call.cc +92 -34
- data/src/core/lib/surface/call.h +4 -0
- data/src/core/lib/surface/channel.cc +7 -4
- data/src/core/lib/surface/channel_init.h +3 -2
- data/src/core/lib/surface/server.cc +45 -5
- data/src/core/lib/surface/server.h +18 -6
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/batch_builder.cc +3 -5
- data/src/core/lib/transport/metadata_batch.cc +6 -0
- data/src/core/lib/transport/metadata_batch.h +20 -1
- data/src/core/lib/transport/parsed_metadata.h +2 -4
- data/src/core/lib/transport/simple_slice_based_metadata.h +1 -2
- data/src/core/lib/transport/transport.h +21 -11
- data/src/core/tsi/ssl_transport_security.cc +7 -0
- data/src/core/tsi/ssl_transport_security.h +4 -0
- data/src/ruby/ext/grpc/extconf.rb +1 -1
- data/src/ruby/ext/grpc/rb_channel_args.c +6 -4
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +4 -1
- data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +185 -0
- data/third_party/upb/upb/collections/array.c +6 -0
- data/third_party/upb/upb/collections/array.h +6 -0
- data/third_party/upb/upb/collections/map.c +7 -0
- data/third_party/upb/upb/collections/map.h +5 -0
- data/third_party/upb/upb/collections/map_sorter_internal.h +1 -1
- data/third_party/upb/upb/collections/message_value.h +8 -1
- data/third_party/upb/upb/generated_code_support.h +54 -0
- data/third_party/upb/upb/hash/common.c +5 -0
- data/third_party/upb/upb/hash/common.h +1 -0
- data/third_party/upb/upb/hash/str_table.h +1 -0
- data/third_party/upb/upb/message/accessors.c +25 -1
- data/third_party/upb/upb/message/accessors.h +46 -25
- data/third_party/upb/upb/message/accessors_internal.h +69 -3
- data/third_party/upb/upb/message/extension_internal.h +1 -1
- data/third_party/upb/upb/message/internal/map_entry.h +64 -0
- data/third_party/upb/upb/message/internal.h +2 -6
- data/third_party/upb/upb/message/message.c +0 -6
- data/third_party/upb/upb/message/message.h +1 -1
- data/third_party/upb/upb/message/tagged_ptr.h +89 -0
- data/third_party/upb/upb/mini_descriptor/build_enum.c +150 -0
- data/third_party/upb/upb/mini_descriptor/build_enum.h +63 -0
- data/third_party/upb/upb/{mini_table → mini_descriptor}/decode.c +122 -374
- data/third_party/upb/upb/{mini_table → mini_descriptor}/decode.h +11 -50
- data/third_party/upb/upb/mini_descriptor/internal/base92.c +46 -0
- data/third_party/upb/upb/mini_descriptor/internal/base92.h +81 -0
- data/third_party/upb/upb/mini_descriptor/internal/decoder.h +73 -0
- data/third_party/upb/upb/{mini_table → mini_descriptor/internal}/encode.c +58 -32
- data/third_party/upb/upb/{mini_table/encode_internal.h → mini_descriptor/internal/encode.h} +3 -4
- data/third_party/upb/upb/{mini_table/encode_internal.hpp → mini_descriptor/internal/encode.hpp} +1 -1
- data/third_party/upb/upb/mini_descriptor/internal/modifiers.h +50 -0
- data/third_party/upb/upb/{mini_table/common_internal.h → mini_descriptor/internal/wire_constants.h} +3 -23
- data/third_party/upb/upb/mini_descriptor/link.c +142 -0
- data/third_party/upb/upb/mini_descriptor/link.h +104 -0
- data/third_party/upb/upb/mini_table/{types.h → enum.h} +19 -9
- data/third_party/upb/upb/mini_table/extension.h +40 -0
- data/third_party/upb/upb/mini_table/extension_registry.c +1 -1
- data/third_party/upb/upb/mini_table/extension_registry.h +2 -1
- data/third_party/upb/upb/mini_table/field.h +118 -0
- data/third_party/upb/upb/{json_decode.h → mini_table/file.h} +5 -6
- data/third_party/upb/upb/mini_table/{enum_internal.h → internal/enum.h} +7 -19
- data/third_party/upb/upb/mini_table/{extension_internal.h → internal/extension.h} +8 -8
- data/third_party/upb/upb/mini_table/{field_internal.h → internal/field.h} +10 -66
- data/third_party/upb/upb/mini_table/{file_internal.h → internal/file.h} +6 -4
- data/third_party/upb/upb/mini_table/internal/message.c +39 -0
- data/third_party/upb/upb/mini_table/{message_internal.h → internal/message.h} +14 -37
- data/third_party/upb/upb/mini_table/{sub_internal.h → internal/sub.h} +7 -6
- data/third_party/upb/upb/mini_table/{common.c → message.c} +2 -33
- data/third_party/upb/upb/mini_table/{common.h → message.h} +12 -77
- data/third_party/upb/upb/{json_encode.h → mini_table/sub.h} +5 -6
- data/third_party/upb/upb/reflection/def.hpp +16 -4
- data/third_party/upb/upb/reflection/def_pool_internal.h +1 -1
- data/third_party/upb/upb/reflection/desc_state_internal.h +1 -1
- data/third_party/upb/upb/reflection/enum_def.c +1 -1
- data/third_party/upb/upb/reflection/field_def.c +2 -1
- data/third_party/upb/upb/reflection/message.c +2 -2
- data/third_party/upb/upb/reflection/message_def.c +3 -1
- data/third_party/upb/upb/wire/decode.c +68 -29
- data/third_party/upb/upb/wire/decode.h +40 -0
- data/third_party/upb/upb/wire/encode.c +23 -13
- metadata +43 -27
- data/src/core/lib/event_engine/thread_pool/original_thread_pool.cc +0 -256
- data/src/core/lib/event_engine/thread_pool/original_thread_pool.h +0 -137
@@ -25,11 +25,10 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
#ifndef
|
29
|
-
#define
|
28
|
+
#ifndef UPB_MINI_TABLE_INTERNAL_FIELD_H_
|
29
|
+
#define UPB_MINI_TABLE_INTERNAL_FIELD_H_
|
30
30
|
|
31
31
|
#include "upb/base/descriptor_constants.h"
|
32
|
-
#include "upb/mini_table/types.h"
|
33
32
|
|
34
33
|
// Must be last.
|
35
34
|
#include "upb/port/def.inc"
|
@@ -91,7 +90,7 @@ typedef enum {
|
|
91
90
|
// LINT.ThenChange(//depot/google3/third_party/upb/js/impl/upb_bits/mini_table_field.ts:mini_table_field_layout)
|
92
91
|
|
93
92
|
UPB_INLINE upb_FieldRep
|
94
|
-
_upb_MiniTableField_GetRep(const upb_MiniTableField* field) {
|
93
|
+
_upb_MiniTableField_GetRep(const struct upb_MiniTableField* field) {
|
95
94
|
return (upb_FieldRep)(field->mode >> kUpb_FieldRep_Shift);
|
96
95
|
}
|
97
96
|
|
@@ -99,94 +98,39 @@ _upb_MiniTableField_GetRep(const upb_MiniTableField* field) {
|
|
99
98
|
extern "C" {
|
100
99
|
#endif
|
101
100
|
|
102
|
-
UPB_INLINE upb_FieldMode
|
101
|
+
UPB_INLINE upb_FieldMode
|
102
|
+
upb_FieldMode_Get(const struct upb_MiniTableField* field) {
|
103
103
|
return (upb_FieldMode)(field->mode & 3);
|
104
104
|
}
|
105
105
|
|
106
106
|
UPB_INLINE void _upb_MiniTableField_CheckIsArray(
|
107
|
-
const upb_MiniTableField* field) {
|
107
|
+
const struct upb_MiniTableField* field) {
|
108
108
|
UPB_ASSUME(_upb_MiniTableField_GetRep(field) == kUpb_FieldRep_NativePointer);
|
109
109
|
UPB_ASSUME(upb_FieldMode_Get(field) == kUpb_FieldMode_Array);
|
110
110
|
UPB_ASSUME(field->presence == 0);
|
111
111
|
}
|
112
112
|
|
113
113
|
UPB_INLINE void _upb_MiniTableField_CheckIsMap(
|
114
|
-
const upb_MiniTableField* field) {
|
114
|
+
const struct upb_MiniTableField* field) {
|
115
115
|
UPB_ASSUME(_upb_MiniTableField_GetRep(field) == kUpb_FieldRep_NativePointer);
|
116
116
|
UPB_ASSUME(upb_FieldMode_Get(field) == kUpb_FieldMode_Map);
|
117
117
|
UPB_ASSUME(field->presence == 0);
|
118
118
|
}
|
119
119
|
|
120
|
-
UPB_INLINE bool upb_IsRepeatedOrMap(const upb_MiniTableField* field) {
|
120
|
+
UPB_INLINE bool upb_IsRepeatedOrMap(const struct upb_MiniTableField* field) {
|
121
121
|
// This works because upb_FieldMode has no value 3.
|
122
122
|
return !(field->mode & kUpb_FieldMode_Scalar);
|
123
123
|
}
|
124
124
|
|
125
|
-
UPB_INLINE bool upb_IsSubMessage(const upb_MiniTableField* field) {
|
125
|
+
UPB_INLINE bool upb_IsSubMessage(const struct upb_MiniTableField* field) {
|
126
126
|
return field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Message ||
|
127
127
|
field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Group;
|
128
128
|
}
|
129
129
|
|
130
|
-
// LINT.IfChange(presence_logic)
|
131
|
-
|
132
|
-
// Hasbit access ///////////////////////////////////////////////////////////////
|
133
|
-
|
134
|
-
UPB_INLINE size_t _upb_hasbit_ofs(size_t idx) { return idx / 8; }
|
135
|
-
|
136
|
-
UPB_INLINE char _upb_hasbit_mask(size_t idx) { return 1 << (idx % 8); }
|
137
|
-
|
138
|
-
UPB_INLINE bool _upb_hasbit(const upb_Message* msg, size_t idx) {
|
139
|
-
return (*UPB_PTR_AT(msg, _upb_hasbit_ofs(idx), const char) &
|
140
|
-
_upb_hasbit_mask(idx)) != 0;
|
141
|
-
}
|
142
|
-
|
143
|
-
UPB_INLINE void _upb_sethas(const upb_Message* msg, size_t idx) {
|
144
|
-
(*UPB_PTR_AT(msg, _upb_hasbit_ofs(idx), char)) |= _upb_hasbit_mask(idx);
|
145
|
-
}
|
146
|
-
|
147
|
-
UPB_INLINE void _upb_clearhas(const upb_Message* msg, size_t idx) {
|
148
|
-
(*UPB_PTR_AT(msg, _upb_hasbit_ofs(idx), char)) &= ~_upb_hasbit_mask(idx);
|
149
|
-
}
|
150
|
-
|
151
|
-
UPB_INLINE size_t _upb_Message_Hasidx(const upb_MiniTableField* f) {
|
152
|
-
UPB_ASSERT(f->presence > 0);
|
153
|
-
return f->presence;
|
154
|
-
}
|
155
|
-
|
156
|
-
UPB_INLINE bool _upb_hasbit_field(const upb_Message* msg,
|
157
|
-
const upb_MiniTableField* f) {
|
158
|
-
return _upb_hasbit(msg, _upb_Message_Hasidx(f));
|
159
|
-
}
|
160
|
-
|
161
|
-
UPB_INLINE void _upb_sethas_field(const upb_Message* msg,
|
162
|
-
const upb_MiniTableField* f) {
|
163
|
-
_upb_sethas(msg, _upb_Message_Hasidx(f));
|
164
|
-
}
|
165
|
-
|
166
|
-
// Oneof case access ///////////////////////////////////////////////////////////
|
167
|
-
|
168
|
-
UPB_INLINE size_t _upb_oneofcase_ofs(const upb_MiniTableField* f) {
|
169
|
-
UPB_ASSERT(f->presence < 0);
|
170
|
-
return ~(ptrdiff_t)f->presence;
|
171
|
-
}
|
172
|
-
|
173
|
-
UPB_INLINE uint32_t* _upb_oneofcase_field(upb_Message* msg,
|
174
|
-
const upb_MiniTableField* f) {
|
175
|
-
return UPB_PTR_AT(msg, _upb_oneofcase_ofs(f), uint32_t);
|
176
|
-
}
|
177
|
-
|
178
|
-
UPB_INLINE uint32_t _upb_getoneofcase_field(const upb_Message* msg,
|
179
|
-
const upb_MiniTableField* f) {
|
180
|
-
return *_upb_oneofcase_field((upb_Message*)msg, f);
|
181
|
-
}
|
182
|
-
|
183
|
-
// LINT.ThenChange(GoogleInternalName2)
|
184
|
-
// LINT.ThenChange(//depot/google3/third_party/upb/js/impl/upb_bits/presence.ts:presence_logic)
|
185
|
-
|
186
130
|
#ifdef __cplusplus
|
187
131
|
} /* extern "C" */
|
188
132
|
#endif
|
189
133
|
|
190
134
|
#include "upb/port/undef.inc"
|
191
135
|
|
192
|
-
#endif /*
|
136
|
+
#endif /* UPB_MINI_TABLE_INTERNAL_FIELD_H_ */
|
@@ -25,10 +25,12 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
#ifndef
|
29
|
-
#define
|
28
|
+
#ifndef UPB_MINI_TABLE_INTERNAL_FILE_H_
|
29
|
+
#define UPB_MINI_TABLE_INTERNAL_FILE_H_
|
30
30
|
|
31
|
-
#include "upb/mini_table/
|
31
|
+
#include "upb/mini_table/internal/enum.h"
|
32
|
+
#include "upb/mini_table/internal/extension.h"
|
33
|
+
#include "upb/mini_table/internal/message.h"
|
32
34
|
|
33
35
|
// Must be last.
|
34
36
|
#include "upb/port/def.inc"
|
@@ -44,4 +46,4 @@ struct upb_MiniTableFile {
|
|
44
46
|
|
45
47
|
#include "upb/port/undef.inc"
|
46
48
|
|
47
|
-
#endif /*
|
49
|
+
#endif /* UPB_MINI_TABLE_INTERNAL_FILE_H_ */
|
@@ -0,0 +1,39 @@
|
|
1
|
+
/*
|
2
|
+
* Copyright (c) 2023, Google LLC
|
3
|
+
* All rights reserved.
|
4
|
+
*
|
5
|
+
* Redistribution and use in source and binary forms, with or without
|
6
|
+
* modification, are permitted provided that the following conditions are met:
|
7
|
+
* * Redistributions of source code must retain the above copyright
|
8
|
+
* notice, this list of conditions and the following disclaimer.
|
9
|
+
* * Redistributions in binary form must reproduce the above copyright
|
10
|
+
* notice, this list of conditions and the following disclaimer in the
|
11
|
+
* documentation and/or other materials provided with the distribution.
|
12
|
+
* * Neither the name of Google LLC nor the
|
13
|
+
* names of its contributors may be used to endorse or promote products
|
14
|
+
* derived from this software without specific prior written permission.
|
15
|
+
*
|
16
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
17
|
+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
18
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
19
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL Google LLC BE LIABLE FOR ANY DIRECT,
|
20
|
+
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
21
|
+
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
22
|
+
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
23
|
+
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
24
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
25
|
+
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
|
+
*/
|
27
|
+
|
28
|
+
#include "upb/mini_table/internal/message.h"
|
29
|
+
|
30
|
+
const struct upb_MiniTable _kUpb_MiniTable_Empty = {
|
31
|
+
.subs = NULL,
|
32
|
+
.fields = NULL,
|
33
|
+
.size = 0,
|
34
|
+
.field_count = 0,
|
35
|
+
.ext = kUpb_ExtMode_NonExtendable,
|
36
|
+
.dense_below = 0,
|
37
|
+
.table_mask = -1,
|
38
|
+
.required_count = 0,
|
39
|
+
};
|
@@ -25,16 +25,16 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
#ifndef
|
29
|
-
#define
|
28
|
+
#ifndef UPB_MINI_TABLE_INTERNAL_MESSAGE_H_
|
29
|
+
#define UPB_MINI_TABLE_INTERNAL_MESSAGE_H_
|
30
30
|
|
31
|
-
#include "upb/
|
32
|
-
#include "upb/hash/common.h"
|
33
|
-
#include "upb/mini_table/types.h"
|
31
|
+
#include "upb/mini_table/internal/field.h"
|
34
32
|
|
35
33
|
// Must be last.
|
36
34
|
#include "upb/port/def.inc"
|
37
35
|
|
36
|
+
typedef void upb_Message;
|
37
|
+
|
38
38
|
struct upb_Decoder;
|
39
39
|
typedef const char* _upb_FieldParser(struct upb_Decoder* d, const char* ptr,
|
40
40
|
upb_Message* msg, intptr_t table,
|
@@ -58,12 +58,14 @@ typedef enum {
|
|
58
58
|
|
59
59
|
// LINT.IfChange(mini_table_layout)
|
60
60
|
|
61
|
+
union upb_MiniTableSub;
|
62
|
+
|
61
63
|
// upb_MiniTable represents the memory layout of a given upb_MessageDef.
|
62
64
|
// The members are public so generated code can initialize them,
|
63
65
|
// but users MUST NOT directly read or write any of its members.
|
64
66
|
struct upb_MiniTable {
|
65
|
-
const upb_MiniTableSub* subs;
|
66
|
-
const upb_MiniTableField* fields;
|
67
|
+
const union upb_MiniTableSub* subs;
|
68
|
+
const struct upb_MiniTableField* fields;
|
67
69
|
|
68
70
|
// Must be aligned to sizeof(void*). Doesn't include internal members like
|
69
71
|
// unknown fields, extension dict, pointer to msglayout, etc.
|
@@ -83,45 +85,20 @@ struct upb_MiniTable {
|
|
83
85
|
|
84
86
|
// LINT.ThenChange(//depot/google3/third_party/upb/js/impl/upb_bits/mini_table.ts:presence_logic)
|
85
87
|
|
86
|
-
// Map entries aren't actually stored for map fields, they are only used during
|
87
|
-
// parsing. For parsing, it helps a lot if all map entry messages have the same
|
88
|
-
// layout. The layout code in mini_table/decode.c will ensure that all map
|
89
|
-
// entries have this layout.
|
90
|
-
//
|
91
|
-
// Note that users can and do create map entries directly, which will also use
|
92
|
-
// this layout.
|
93
|
-
//
|
94
|
-
// NOTE: sync with mini_table/decode.c.
|
95
|
-
typedef struct {
|
96
|
-
// We only need 2 hasbits max, but due to alignment we'll use 8 bytes here,
|
97
|
-
// and the uint64_t helps make this clear.
|
98
|
-
uint64_t hasbits;
|
99
|
-
union {
|
100
|
-
upb_StringView str; // For str/bytes.
|
101
|
-
upb_value val; // For all other types.
|
102
|
-
} k;
|
103
|
-
union {
|
104
|
-
upb_StringView str; // For str/bytes.
|
105
|
-
upb_value val; // For all other types.
|
106
|
-
} v;
|
107
|
-
} upb_MapEntryData;
|
108
|
-
|
109
|
-
typedef struct {
|
110
|
-
void* internal_data;
|
111
|
-
upb_MapEntryData data;
|
112
|
-
} upb_MapEntry;
|
113
|
-
|
114
88
|
#ifdef __cplusplus
|
115
89
|
extern "C" {
|
116
90
|
#endif
|
117
91
|
|
92
|
+
// A MiniTable for an empty message, used for unlinked sub-messages.
|
93
|
+
extern const struct upb_MiniTable _kUpb_MiniTable_Empty;
|
94
|
+
|
118
95
|
// Computes a bitmask in which the |l->required_count| lowest bits are set,
|
119
96
|
// except that we skip the lowest bit (because upb never uses hasbit 0).
|
120
97
|
//
|
121
98
|
// Sample output:
|
122
99
|
// requiredmask(1) => 0b10 (0x2)
|
123
100
|
// requiredmask(5) => 0b111110 (0x3e)
|
124
|
-
UPB_INLINE uint64_t upb_MiniTable_requiredmask(const upb_MiniTable* l) {
|
101
|
+
UPB_INLINE uint64_t upb_MiniTable_requiredmask(const struct upb_MiniTable* l) {
|
125
102
|
int n = l->required_count;
|
126
103
|
assert(0 < n && n <= 63);
|
127
104
|
return ((1ULL << n) - 1) << 1;
|
@@ -133,4 +110,4 @@ UPB_INLINE uint64_t upb_MiniTable_requiredmask(const upb_MiniTable* l) {
|
|
133
110
|
|
134
111
|
#include "upb/port/undef.inc"
|
135
112
|
|
136
|
-
#endif /*
|
113
|
+
#endif /* UPB_MINI_TABLE_INTERNAL_MESSAGE_H_ */
|
@@ -25,14 +25,15 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
#ifndef
|
29
|
-
#define
|
28
|
+
#ifndef UPB_MINI_TABLE_INTERNAL_SUB_H_
|
29
|
+
#define UPB_MINI_TABLE_INTERNAL_SUB_H_
|
30
30
|
|
31
|
-
#include "upb/mini_table/
|
31
|
+
#include "upb/mini_table/internal/enum.h"
|
32
|
+
#include "upb/mini_table/internal/message.h"
|
32
33
|
|
33
34
|
union upb_MiniTableSub {
|
34
|
-
const upb_MiniTable* submsg;
|
35
|
-
const upb_MiniTableEnum* subenum;
|
35
|
+
const struct upb_MiniTable* submsg;
|
36
|
+
const struct upb_MiniTableEnum* subenum;
|
36
37
|
};
|
37
38
|
|
38
|
-
#endif /*
|
39
|
+
#endif /* UPB_MINI_TABLE_INTERNAL_SUB_H_ */
|
@@ -25,34 +25,16 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
#include "upb/mini_table/
|
28
|
+
#include "upb/mini_table/message.h"
|
29
29
|
|
30
30
|
#include <inttypes.h>
|
31
31
|
|
32
32
|
#include "upb/mem/arena.h"
|
33
|
-
#include "upb/mini_table/
|
33
|
+
#include "upb/mini_table/internal/message.h"
|
34
34
|
|
35
35
|
// Must be last.
|
36
36
|
#include "upb/port/def.inc"
|
37
37
|
|
38
|
-
const char _kUpb_ToBase92[] = {
|
39
|
-
' ', '!', '#', '$', '%', '&', '(', ')', '*', '+', ',', '-', '.', '/',
|
40
|
-
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', ':', ';', '<', '=',
|
41
|
-
'>', '?', '@', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K',
|
42
|
-
'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y',
|
43
|
-
'Z', '[', ']', '^', '_', '`', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
|
44
|
-
'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
|
45
|
-
'w', 'x', 'y', 'z', '{', '|', '}', '~',
|
46
|
-
};
|
47
|
-
|
48
|
-
const int8_t _kUpb_FromBase92[] = {
|
49
|
-
0, 1, -1, 2, 3, 4, 5, -1, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
|
50
|
-
17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35,
|
51
|
-
36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54,
|
52
|
-
55, 56, 57, -1, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72,
|
53
|
-
73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91,
|
54
|
-
};
|
55
|
-
|
56
38
|
const upb_MiniTableField* upb_MiniTable_FindFieldByNumber(
|
57
39
|
const upb_MiniTable* t, uint32_t number) {
|
58
40
|
const size_t i = ((size_t)number) - 1; // 0 wraps to SIZE_MAX
|
@@ -82,19 +64,6 @@ const upb_MiniTableField* upb_MiniTable_FindFieldByNumber(
|
|
82
64
|
return NULL;
|
83
65
|
}
|
84
66
|
|
85
|
-
upb_FieldType upb_MiniTableField_Type(const upb_MiniTableField* field) {
|
86
|
-
if (field->mode & kUpb_LabelFlags_IsAlternate) {
|
87
|
-
if (field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Int32) {
|
88
|
-
return kUpb_FieldType_Enum;
|
89
|
-
} else if (field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Bytes) {
|
90
|
-
return kUpb_FieldType_String;
|
91
|
-
} else {
|
92
|
-
UPB_ASSERT(false);
|
93
|
-
}
|
94
|
-
}
|
95
|
-
return field->UPB_PRIVATE(descriptortype);
|
96
|
-
}
|
97
|
-
|
98
67
|
static bool upb_MiniTable_Is_Oneof(const upb_MiniTableField* f) {
|
99
68
|
return f->presence < 0;
|
100
69
|
}
|
@@ -25,34 +25,22 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
#ifndef
|
29
|
-
#define
|
28
|
+
#ifndef UPB_MINI_TABLE_MESSAGE_H_
|
29
|
+
#define UPB_MINI_TABLE_MESSAGE_H_
|
30
30
|
|
31
|
-
#include "upb/mini_table/
|
32
|
-
#include "upb/mini_table/
|
33
|
-
#include "upb/mini_table/
|
31
|
+
#include "upb/mini_table/enum.h"
|
32
|
+
#include "upb/mini_table/field.h"
|
33
|
+
#include "upb/mini_table/internal/message.h"
|
34
34
|
|
35
35
|
// Must be last.
|
36
36
|
#include "upb/port/def.inc"
|
37
37
|
|
38
|
-
typedef enum {
|
39
|
-
kUpb_FieldModifier_IsRepeated = 1 << 0,
|
40
|
-
kUpb_FieldModifier_IsPacked = 1 << 1,
|
41
|
-
kUpb_FieldModifier_IsClosedEnum = 1 << 2,
|
42
|
-
kUpb_FieldModifier_IsProto3Singular = 1 << 3,
|
43
|
-
kUpb_FieldModifier_IsRequired = 1 << 4,
|
44
|
-
} kUpb_FieldModifier;
|
45
|
-
|
46
|
-
typedef enum {
|
47
|
-
kUpb_MessageModifier_ValidateUtf8 = 1 << 0,
|
48
|
-
kUpb_MessageModifier_DefaultIsPacked = 1 << 1,
|
49
|
-
kUpb_MessageModifier_IsExtendable = 1 << 2,
|
50
|
-
} kUpb_MessageModifier;
|
51
|
-
|
52
38
|
#ifdef __cplusplus
|
53
39
|
extern "C" {
|
54
40
|
#endif
|
55
41
|
|
42
|
+
typedef struct upb_MiniTable upb_MiniTable;
|
43
|
+
|
56
44
|
UPB_API const upb_MiniTableField* upb_MiniTable_FindFieldByNumber(
|
57
45
|
const upb_MiniTable* table, uint32_t number);
|
58
46
|
|
@@ -61,68 +49,15 @@ UPB_API_INLINE const upb_MiniTableField* upb_MiniTable_GetFieldByIndex(
|
|
61
49
|
return &t->fields[index];
|
62
50
|
}
|
63
51
|
|
64
|
-
UPB_API upb_FieldType upb_MiniTableField_Type(const upb_MiniTableField* field);
|
65
|
-
|
66
|
-
UPB_API_INLINE upb_CType upb_MiniTableField_CType(const upb_MiniTableField* f) {
|
67
|
-
switch (f->UPB_PRIVATE(descriptortype)) {
|
68
|
-
case kUpb_FieldType_Double:
|
69
|
-
return kUpb_CType_Double;
|
70
|
-
case kUpb_FieldType_Float:
|
71
|
-
return kUpb_CType_Float;
|
72
|
-
case kUpb_FieldType_Int64:
|
73
|
-
case kUpb_FieldType_SInt64:
|
74
|
-
case kUpb_FieldType_SFixed64:
|
75
|
-
return kUpb_CType_Int64;
|
76
|
-
case kUpb_FieldType_Int32:
|
77
|
-
case kUpb_FieldType_SFixed32:
|
78
|
-
case kUpb_FieldType_SInt32:
|
79
|
-
return kUpb_CType_Int32;
|
80
|
-
case kUpb_FieldType_UInt64:
|
81
|
-
case kUpb_FieldType_Fixed64:
|
82
|
-
return kUpb_CType_UInt64;
|
83
|
-
case kUpb_FieldType_UInt32:
|
84
|
-
case kUpb_FieldType_Fixed32:
|
85
|
-
return kUpb_CType_UInt32;
|
86
|
-
case kUpb_FieldType_Enum:
|
87
|
-
return kUpb_CType_Enum;
|
88
|
-
case kUpb_FieldType_Bool:
|
89
|
-
return kUpb_CType_Bool;
|
90
|
-
case kUpb_FieldType_String:
|
91
|
-
return kUpb_CType_String;
|
92
|
-
case kUpb_FieldType_Bytes:
|
93
|
-
return kUpb_CType_Bytes;
|
94
|
-
case kUpb_FieldType_Group:
|
95
|
-
case kUpb_FieldType_Message:
|
96
|
-
return kUpb_CType_Message;
|
97
|
-
}
|
98
|
-
UPB_UNREACHABLE();
|
99
|
-
}
|
100
|
-
|
101
|
-
UPB_API_INLINE bool upb_MiniTableField_IsExtension(
|
102
|
-
const upb_MiniTableField* field) {
|
103
|
-
return field->mode & kUpb_LabelFlags_IsExtension;
|
104
|
-
}
|
105
|
-
|
106
|
-
UPB_API_INLINE bool upb_MiniTableField_IsClosedEnum(
|
107
|
-
const upb_MiniTableField* field) {
|
108
|
-
return field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Enum;
|
109
|
-
}
|
110
|
-
|
111
|
-
UPB_API_INLINE bool upb_MiniTableField_HasPresence(
|
112
|
-
const upb_MiniTableField* field) {
|
113
|
-
if (upb_MiniTableField_IsExtension(field)) {
|
114
|
-
return !upb_IsRepeatedOrMap(field);
|
115
|
-
} else {
|
116
|
-
return field->presence != 0;
|
117
|
-
}
|
118
|
-
}
|
119
|
-
|
120
52
|
// Returns the MiniTable for this message field. If the field is unlinked,
|
121
53
|
// returns NULL.
|
122
54
|
UPB_API_INLINE const upb_MiniTable* upb_MiniTable_GetSubMessageTable(
|
123
55
|
const upb_MiniTable* mini_table, const upb_MiniTableField* field) {
|
124
56
|
UPB_ASSERT(upb_MiniTableField_CType(field) == kUpb_CType_Message);
|
125
|
-
|
57
|
+
const upb_MiniTable* ret =
|
58
|
+
mini_table->subs[field->UPB_PRIVATE(submsg_index)].submsg;
|
59
|
+
UPB_ASSUME(ret);
|
60
|
+
return ret == &_kUpb_MiniTable_Empty ? NULL : ret;
|
126
61
|
}
|
127
62
|
|
128
63
|
// Returns the MiniTableEnum for this enum field. If the field is unlinked,
|
@@ -167,4 +102,4 @@ bool upb_MiniTable_NextOneofField(const upb_MiniTable* m,
|
|
167
102
|
|
168
103
|
#include "upb/port/undef.inc"
|
169
104
|
|
170
|
-
#endif /*
|
105
|
+
#endif /* UPB_MINI_TABLE_MESSAGE_H_ */
|
@@ -25,12 +25,11 @@
|
|
25
25
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
26
26
|
*/
|
27
27
|
|
28
|
-
|
29
|
-
|
28
|
+
#ifndef UPB_MINI_TABLE_SUB_H_
|
29
|
+
#define UPB_MINI_TABLE_SUB_H_
|
30
30
|
|
31
|
-
#
|
32
|
-
#define UPB_JSONENCODE_H_
|
31
|
+
#include "upb/mini_table/internal/sub.h"
|
33
32
|
|
34
|
-
|
33
|
+
typedef union upb_MiniTableSub upb_MiniTableSub;
|
35
34
|
|
36
|
-
#endif /*
|
35
|
+
#endif /* UPB_MINI_TABLE_INTERNAL_SUB_H_ */
|
@@ -318,8 +318,14 @@ class MessageDefPtr {
|
|
318
318
|
FieldDefPtr operator*() {
|
319
319
|
return FieldDefPtr(upb_MessageDef_Field(m_, i_));
|
320
320
|
}
|
321
|
-
|
322
|
-
bool operator==(
|
321
|
+
|
322
|
+
friend bool operator==(FieldIter lhs, FieldIter rhs) {
|
323
|
+
return lhs.i_ == rhs.i_;
|
324
|
+
}
|
325
|
+
|
326
|
+
friend bool operator!=(FieldIter lhs, FieldIter rhs) {
|
327
|
+
return !(lhs == rhs);
|
328
|
+
}
|
323
329
|
|
324
330
|
private:
|
325
331
|
const upb_MessageDef* m_;
|
@@ -344,8 +350,14 @@ class MessageDefPtr {
|
|
344
350
|
OneofDefPtr operator*() {
|
345
351
|
return OneofDefPtr(upb_MessageDef_Oneof(m_, i_));
|
346
352
|
}
|
347
|
-
|
348
|
-
bool operator==(
|
353
|
+
|
354
|
+
friend bool operator==(OneofIter lhs, OneofIter rhs) {
|
355
|
+
return lhs.i_ == rhs.i_;
|
356
|
+
}
|
357
|
+
|
358
|
+
friend bool operator!=(OneofIter lhs, OneofIter rhs) {
|
359
|
+
return !(lhs == rhs);
|
360
|
+
}
|
349
361
|
|
350
362
|
private:
|
351
363
|
const upb_MessageDef* m_;
|
@@ -27,7 +27,7 @@
|
|
27
27
|
|
28
28
|
#include "upb/hash/int_table.h"
|
29
29
|
#include "upb/hash/str_table.h"
|
30
|
-
#include "upb/
|
30
|
+
#include "upb/mini_descriptor/decode.h"
|
31
31
|
#include "upb/reflection/def_builder_internal.h"
|
32
32
|
#include "upb/reflection/def_type.h"
|
33
33
|
#include "upb/reflection/desc_state_internal.h"
|
@@ -28,7 +28,8 @@
|
|
28
28
|
#include <ctype.h>
|
29
29
|
#include <errno.h>
|
30
30
|
|
31
|
-
#include "upb/
|
31
|
+
#include "upb/mini_descriptor/decode.h"
|
32
|
+
#include "upb/mini_descriptor/internal/modifiers.h"
|
32
33
|
#include "upb/reflection/def.h"
|
33
34
|
#include "upb/reflection/def_builder_internal.h"
|
34
35
|
#include "upb/reflection/def_pool.h"
|
@@ -33,7 +33,7 @@
|
|
33
33
|
#include "upb/hash/common.h"
|
34
34
|
#include "upb/message/accessors.h"
|
35
35
|
#include "upb/message/message.h"
|
36
|
-
#include "upb/mini_table/
|
36
|
+
#include "upb/mini_table/field.h"
|
37
37
|
#include "upb/reflection/def.h"
|
38
38
|
#include "upb/reflection/def_pool.h"
|
39
39
|
#include "upb/reflection/def_type.h"
|
@@ -121,7 +121,7 @@ void upb_Message_ClearFieldByDef(upb_Message* msg, const upb_FieldDef* f) {
|
|
121
121
|
}
|
122
122
|
|
123
123
|
void upb_Message_ClearByDef(upb_Message* msg, const upb_MessageDef* m) {
|
124
|
-
|
124
|
+
upb_Message_Clear(msg, upb_MessageDef_MiniTable(m));
|
125
125
|
}
|
126
126
|
|
127
127
|
bool upb_Message_Next(const upb_Message* msg, const upb_MessageDef* m,
|
@@ -27,7 +27,8 @@
|
|
27
27
|
|
28
28
|
#include "upb/hash/int_table.h"
|
29
29
|
#include "upb/hash/str_table.h"
|
30
|
-
#include "upb/
|
30
|
+
#include "upb/mini_descriptor/decode.h"
|
31
|
+
#include "upb/mini_descriptor/internal/modifiers.h"
|
31
32
|
#include "upb/reflection/def.h"
|
32
33
|
#include "upb/reflection/def_builder_internal.h"
|
33
34
|
#include "upb/reflection/def_type.h"
|
@@ -499,6 +500,7 @@ void _upb_MessageDef_LinkMiniTable(upb_DefBuilder* ctx,
|
|
499
500
|
UPB_ASSERT(layout_index < m->layout->field_count);
|
500
501
|
const upb_MiniTableField* mt_f = &m->layout->fields[layout_index];
|
501
502
|
UPB_ASSERT(upb_FieldDef_Type(f) == upb_MiniTableField_Type(mt_f));
|
503
|
+
UPB_ASSERT(upb_FieldDef_CType(f) == upb_MiniTableField_CType(mt_f));
|
502
504
|
UPB_ASSERT(upb_FieldDef_HasPresence(f) ==
|
503
505
|
upb_MiniTableField_HasPresence(mt_f));
|
504
506
|
}
|