grpc 1.74.1 → 1.75.0.pre1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Makefile +83 -41
- data/include/grpc/credentials.h +7 -1
- data/src/core/call/client_call.cc +4 -4
- data/src/core/call/filter_fusion.h +1230 -0
- data/src/core/call/metadata.cc +22 -0
- data/src/core/call/metadata.h +24 -2
- data/src/core/channelz/channelz.cc +10 -17
- data/src/core/channelz/channelz.h +58 -19
- data/src/core/channelz/channelz_registry.cc +0 -162
- data/src/core/channelz/channelz_registry.h +14 -7
- data/src/core/channelz/property_list.cc +19 -23
- data/src/core/channelz/property_list.h +3 -1
- data/src/core/channelz/v2tov1/convert.cc +683 -0
- data/src/core/channelz/v2tov1/convert.h +58 -0
- data/src/core/channelz/v2tov1/legacy_api.cc +425 -0
- data/src/core/channelz/v2tov1/legacy_api.h +32 -0
- data/src/core/channelz/v2tov1/property_list.cc +118 -0
- data/src/core/channelz/v2tov1/property_list.h +52 -0
- data/src/core/client_channel/client_channel_filter.cc +5 -4
- data/src/core/client_channel/client_channel_filter.h +2 -2
- data/src/core/client_channel/client_channel_internal.h +2 -1
- data/src/core/client_channel/load_balanced_call_destination.cc +6 -5
- data/src/core/client_channel/subchannel.cc +14 -6
- data/src/core/client_channel/subchannel.h +2 -0
- data/src/core/config/core_configuration.cc +3 -1
- data/src/core/config/core_configuration.h +12 -0
- data/src/core/credentials/transport/alts/alts_credentials.cc +5 -0
- data/src/core/credentials/transport/alts/check_gcp_environment_windows.cc +2 -0
- data/src/core/credentials/transport/channel_creds_registry_init.cc +3 -1
- data/src/core/credentials/transport/ssl/ssl_credentials.cc +1 -1
- data/src/core/credentials/transport/ssl/ssl_security_connector.cc +8 -3
- data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.cc +29 -24
- data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.h +19 -8
- data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.cc +96 -54
- data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.h +15 -2
- data/src/core/credentials/transport/tls/spiffe_utils.cc +371 -0
- data/src/core/credentials/transport/tls/spiffe_utils.h +171 -0
- data/src/core/credentials/transport/tls/ssl_utils.cc +11 -10
- data/src/core/credentials/transport/tls/ssl_utils.h +4 -2
- data/src/core/credentials/transport/tls/tls_credentials.cc +2 -0
- data/src/core/credentials/transport/tls/tls_security_connector.cc +11 -26
- data/src/core/credentials/transport/tls/tls_security_connector.h +12 -12
- data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +1 -2
- data/src/core/ext/filters/http/client/http_client_filter.cc +3 -6
- data/src/core/ext/filters/http/client_authority_filter.cc +1 -2
- data/src/core/ext/filters/http/message_compress/compression_filter.cc +8 -8
- data/src/core/ext/filters/http/server/http_server_filter.cc +3 -6
- data/src/core/ext/filters/message_size/message_size_filter.cc +4 -4
- data/src/core/ext/filters/rbac/rbac_filter.cc +1 -1
- data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +3 -5
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +3 -2
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +1 -0
- data/src/core/ext/transport/chttp2/transport/flow_control.h +1 -0
- data/src/core/ext/transport/chttp2/transport/frame.cc +89 -6
- data/src/core/ext/transport/chttp2/transport/frame.h +38 -0
- data/src/core/ext/transport/chttp2/transport/header_assembler.h +5 -14
- data/src/core/ext/transport/chttp2/transport/hpack_parser.h +4 -1
- data/src/core/ext/transport/chttp2/transport/http2_client_transport.cc +294 -78
- data/src/core/ext/transport/chttp2/transport/http2_client_transport.h +128 -9
- data/src/core/ext/transport/chttp2/transport/http2_settings.cc +11 -38
- data/src/core/ext/transport/chttp2/transport/http2_settings.h +52 -35
- data/src/core/ext/transport/chttp2/transport/http2_settings_manager.cc +61 -0
- data/src/core/ext/transport/chttp2/transport/http2_settings_manager.h +142 -0
- data/src/core/ext/transport/chttp2/transport/http2_transport.cc +81 -3
- data/src/core/ext/transport/chttp2/transport/http2_transport.h +12 -1
- data/src/core/ext/transport/chttp2/transport/message_assembler.h +2 -2
- data/src/core/ext/transport/chttp2/transport/parsing.cc +2 -1
- data/src/core/ext/transport/chttp2/transport/ping_promise.cc +2 -1
- data/src/core/ext/transport/chttp2/transport/ping_promise.h +22 -5
- data/src/core/ext/transport/chttp2/transport/stream_data_queue.h +607 -0
- data/src/core/ext/transport/chttp2/transport/writable_streams.h +254 -0
- data/src/core/ext/transport/chttp2/transport/writing.cc +6 -4
- data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb.h +4959 -0
- data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb_minitable.c +1111 -0
- data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb_minitable.h +108 -0
- data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb.h +142 -54
- data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb_minitable.c +18 -14
- data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb_minitable.h +2 -2
- data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/channelz.upbdefs.c +716 -0
- data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/channelz.upbdefs.h +227 -0
- data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/property_list.upbdefs.c +86 -88
- data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/property_list.upbdefs.h +2 -2
- data/src/core/filter/auth/auth_filters.h +2 -2
- data/src/core/filter/fused_filters.cc +154 -0
- data/src/core/handshaker/security/legacy_secure_endpoint.cc +1 -1
- data/src/core/handshaker/security/pipelined_secure_endpoint.cc +965 -0
- data/src/core/handshaker/security/secure_endpoint.cc +28 -13
- data/src/core/handshaker/security/secure_endpoint.h +8 -0
- data/src/core/lib/channel/promise_based_filter.cc +15 -25
- data/src/core/lib/channel/promise_based_filter.h +6 -5
- data/src/core/lib/event_engine/ares_resolver.h +3 -1
- data/src/core/lib/event_engine/cf_engine/cf_engine.cc +9 -5
- data/src/core/lib/event_engine/cf_engine/cf_engine.h +2 -1
- data/src/core/lib/event_engine/cf_engine/cfsocket_listener.cc +263 -0
- data/src/core/lib/event_engine/cf_engine/cfsocket_listener.h +107 -0
- data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +31 -3
- data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +12 -0
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +12 -10
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +6 -4
- data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +15 -14
- data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +7 -5
- data/src/core/lib/event_engine/posix_engine/event_poller.h +0 -8
- data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +11 -5
- data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +3 -2
- data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +1 -0
- data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +4 -4
- data/src/core/lib/event_engine/posix_engine/lockfree_event.h +3 -4
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +2 -2
- data/src/core/lib/event_engine/posix_engine/posix_engine.cc +188 -199
- data/src/core/lib/event_engine/posix_engine/posix_engine.h +30 -45
- data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +1 -1
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +1 -1
- data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +2 -1
- data/src/core/lib/experiments/experiments.cc +120 -6
- data/src/core/lib/experiments/experiments.h +46 -3
- data/src/core/lib/iomgr/combiner.cc +1 -1
- data/src/core/lib/iomgr/exec_ctx.h +3 -9
- data/src/core/lib/iomgr/socket_mutator.cc +1 -1
- data/src/core/lib/iomgr/socket_utils_posix.cc +1 -1
- data/src/core/lib/iomgr/socket_utils_posix.h +1 -1
- data/src/core/lib/iomgr/tcp_client_posix.cc +1 -1
- data/src/core/lib/iomgr/tcp_posix.cc +3 -3
- data/src/core/lib/promise/activity.h +2 -2
- data/src/core/lib/promise/mpsc.cc +8 -8
- data/src/core/lib/promise/party.cc +7 -7
- data/src/core/lib/promise/party.h +4 -4
- data/src/core/lib/promise/poll.h +10 -0
- data/src/core/lib/resource_quota/memory_quota.cc +90 -3
- data/src/core/lib/resource_quota/memory_quota.h +20 -9
- data/src/core/lib/resource_quota/periodic_update.cc +14 -0
- data/src/core/lib/resource_quota/periodic_update.h +8 -0
- data/src/core/lib/resource_quota/resource_quota.cc +15 -4
- data/src/core/lib/resource_quota/resource_quota.h +3 -0
- data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +1 -2
- data/src/core/lib/surface/call.cc +5 -5
- data/src/core/lib/surface/call.h +6 -5
- data/src/core/lib/surface/completion_queue.cc +2 -4
- data/src/core/lib/surface/filter_stack_call.cc +1 -1
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/promise_endpoint.cc +2 -2
- data/src/core/lib/transport/promise_endpoint.h +3 -3
- data/src/core/load_balancing/endpoint_list.cc +29 -2
- data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +3 -3
- data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +1 -1
- data/src/core/load_balancing/pick_first/pick_first.cc +12 -5
- data/src/core/load_balancing/xds/xds_cluster_impl.cc +5 -3
- data/src/core/net/socket_mutator.cc +19 -0
- data/src/core/net/socket_mutator.h +25 -0
- data/src/core/plugin_registry/grpc_plugin_registry.cc +6 -0
- data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +6 -1
- data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +2 -1
- data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +8 -5
- data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +2 -1
- data/src/core/resolver/xds/xds_dependency_manager.cc +1 -1
- data/src/core/server/server.cc +1 -1
- data/src/core/server/server_call_tracer_filter.cc +0 -66
- data/src/core/server/server_call_tracer_filter.h +64 -0
- data/src/core/server/server_config_selector_filter.cc +1 -1
- data/src/core/service_config/service_config_channel_arg_filter.cc +3 -60
- data/src/core/service_config/service_config_channel_arg_filter.h +82 -0
- data/src/core/telemetry/call_tracer.cc +20 -14
- data/src/core/telemetry/call_tracer.h +22 -17
- data/src/core/telemetry/metrics.h +8 -8
- data/src/core/telemetry/stats_data.cc +151 -151
- data/src/core/telemetry/stats_data.h +87 -87
- data/src/core/transport/auth_context.cc +20 -0
- data/src/core/transport/auth_context.h +4 -0
- data/src/core/transport/auth_context_comparator_registry.h +69 -0
- data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +2 -3
- data/src/core/tsi/ssl_transport_security.cc +202 -32
- data/src/core/tsi/ssl_transport_security.h +19 -10
- data/src/core/tsi/ssl_transport_security_utils.cc +21 -0
- data/src/core/tsi/ssl_transport_security_utils.h +4 -0
- data/src/core/util/http_client/httpcli_security_connector.cc +3 -1
- data/src/core/util/latent_see.cc +178 -146
- data/src/core/util/latent_see.h +245 -188
- data/src/core/util/single_set_ptr.h +5 -2
- data/src/core/util/useful.h +91 -0
- data/src/core/util/windows/directory_reader.cc +1 -0
- data/src/core/util/windows/thd.cc +1 -3
- data/src/core/util/work_serializer.cc +1 -1
- data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +32 -5
- data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +5 -0
- data/src/core/xds/grpc/xds_certificate_provider.cc +5 -6
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +1 -1
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/third_party/cares/cares/include/ares.h +925 -460
- data/third_party/cares/cares/include/ares_dns.h +86 -71
- data/third_party/cares/cares/include/ares_dns_record.h +1118 -0
- data/third_party/cares/cares/include/ares_nameser.h +215 -189
- data/third_party/cares/cares/include/ares_version.h +37 -14
- data/third_party/cares/cares/src/lib/ares_addrinfo2hostent.c +305 -0
- data/third_party/cares/cares/src/lib/ares_addrinfo_localhost.c +245 -0
- data/third_party/cares/cares/src/lib/ares_android.c +216 -164
- data/third_party/cares/cares/src/lib/ares_android.h +25 -14
- data/third_party/cares/cares/src/lib/ares_cancel.c +68 -44
- data/third_party/cares/cares/src/lib/ares_close_sockets.c +137 -0
- data/third_party/cares/cares/src/lib/ares_conn.c +511 -0
- data/third_party/cares/cares/src/lib/ares_conn.h +196 -0
- data/third_party/cares/cares/src/lib/ares_cookie.c +461 -0
- data/third_party/cares/cares/src/lib/ares_data.c +93 -181
- data/third_party/cares/cares/src/lib/ares_data.h +50 -39
- data/third_party/cares/cares/src/lib/ares_destroy.c +127 -89
- data/third_party/cares/cares/src/lib/ares_free_hostent.c +35 -24
- data/third_party/cares/cares/src/lib/ares_free_string.c +24 -16
- data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +45 -38
- data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +549 -663
- data/third_party/cares/cares/src/lib/ares_getenv.c +25 -15
- data/third_party/cares/cares/src/lib/ares_getenv.h +26 -18
- data/third_party/cares/cares/src/lib/ares_gethostbyaddr.c +163 -221
- data/third_party/cares/cares/src/lib/ares_gethostbyname.c +222 -223
- data/third_party/cares/cares/src/lib/ares_getnameinfo.c +328 -338
- data/third_party/cares/cares/src/lib/ares_hosts_file.c +952 -0
- data/third_party/cares/cares/src/lib/ares_inet_net_pton.h +25 -19
- data/third_party/cares/cares/src/lib/ares_init.c +425 -2091
- data/third_party/cares/cares/src/lib/ares_ipv6.h +63 -33
- data/third_party/cares/cares/src/lib/ares_library_init.c +110 -54
- data/third_party/cares/cares/src/lib/ares_metrics.c +261 -0
- data/third_party/cares/cares/src/lib/ares_options.c +418 -332
- data/third_party/cares/cares/src/lib/ares_parse_into_addrinfo.c +179 -0
- data/third_party/cares/cares/src/lib/ares_private.h +558 -356
- data/third_party/cares/cares/src/lib/ares_process.c +1224 -1369
- data/third_party/cares/cares/src/lib/ares_qcache.c +430 -0
- data/third_party/cares/cares/src/lib/ares_query.c +126 -121
- data/third_party/cares/cares/src/lib/ares_search.c +564 -262
- data/third_party/cares/cares/src/lib/ares_send.c +264 -93
- data/third_party/cares/cares/src/lib/ares_set_socket_functions.c +588 -0
- data/third_party/cares/cares/src/lib/ares_setup.h +115 -111
- data/third_party/cares/cares/src/lib/ares_socket.c +425 -0
- data/third_party/cares/cares/src/lib/ares_socket.h +163 -0
- data/third_party/cares/cares/src/lib/ares_sortaddrinfo.c +447 -0
- data/third_party/cares/cares/src/lib/ares_strerror.c +83 -48
- data/third_party/cares/cares/src/lib/ares_sysconfig.c +639 -0
- data/third_party/cares/cares/src/lib/ares_sysconfig_files.c +839 -0
- data/third_party/cares/cares/src/lib/ares_sysconfig_mac.c +373 -0
- data/third_party/cares/cares/src/lib/ares_sysconfig_win.c +621 -0
- data/third_party/cares/cares/src/lib/ares_timeout.c +136 -73
- data/third_party/cares/cares/src/lib/ares_update_servers.c +1362 -0
- data/third_party/cares/cares/src/lib/ares_version.c +29 -4
- data/third_party/cares/cares/src/lib/config-dos.h +88 -89
- data/third_party/cares/cares/src/lib/config-win32.h +122 -77
- data/third_party/cares/cares/src/lib/dsa/ares_array.c +394 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable.c +447 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable.h +174 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable_asvp.c +224 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable_dict.c +228 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable_strvp.c +210 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable_szvp.c +188 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable_vpstr.c +186 -0
- data/third_party/cares/cares/src/lib/dsa/ares_htable_vpvp.c +194 -0
- data/third_party/cares/cares/src/lib/dsa/ares_llist.c +382 -0
- data/third_party/cares/cares/src/lib/dsa/ares_slist.c +479 -0
- data/third_party/cares/cares/src/lib/dsa/ares_slist.h +207 -0
- data/third_party/cares/cares/src/lib/event/ares_event.h +191 -0
- data/third_party/cares/cares/src/lib/event/ares_event_configchg.c +743 -0
- data/third_party/cares/cares/src/lib/event/ares_event_epoll.c +192 -0
- data/third_party/cares/cares/src/lib/event/ares_event_kqueue.c +248 -0
- data/third_party/cares/cares/src/lib/event/ares_event_poll.c +140 -0
- data/third_party/cares/cares/src/lib/event/ares_event_select.c +159 -0
- data/third_party/cares/cares/src/lib/event/ares_event_thread.c +567 -0
- data/third_party/cares/cares/src/lib/event/ares_event_wake_pipe.c +166 -0
- data/third_party/cares/cares/src/lib/event/ares_event_win32.c +978 -0
- data/third_party/cares/cares/src/lib/event/ares_event_win32.h +161 -0
- data/third_party/cares/cares/src/lib/include/ares_array.h +276 -0
- data/third_party/cares/cares/src/lib/include/ares_buf.h +732 -0
- data/third_party/cares/cares/src/lib/include/ares_htable_asvp.h +130 -0
- data/third_party/cares/cares/src/lib/include/ares_htable_dict.h +123 -0
- data/third_party/cares/cares/src/lib/include/ares_htable_strvp.h +130 -0
- data/third_party/cares/cares/src/lib/include/ares_htable_szvp.h +118 -0
- data/third_party/cares/cares/src/lib/include/ares_htable_vpstr.h +111 -0
- data/third_party/cares/cares/src/lib/include/ares_htable_vpvp.h +128 -0
- data/third_party/cares/cares/src/lib/include/ares_llist.h +239 -0
- data/third_party/cares/cares/src/lib/include/ares_mem.h +38 -0
- data/third_party/cares/cares/src/lib/include/ares_str.h +244 -0
- data/third_party/cares/cares/src/lib/inet_net_pton.c +202 -157
- data/third_party/cares/cares/src/lib/inet_ntop.c +87 -69
- data/third_party/cares/cares/src/lib/legacy/ares_create_query.c +78 -0
- data/third_party/cares/cares/src/lib/legacy/ares_expand_name.c +99 -0
- data/third_party/cares/cares/src/lib/legacy/ares_expand_string.c +107 -0
- data/third_party/cares/cares/src/lib/legacy/ares_fds.c +80 -0
- data/third_party/cares/cares/src/lib/legacy/ares_getsock.c +85 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_a_reply.c +107 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_aaaa_reply.c +109 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_caa_reply.c +137 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_mx_reply.c +110 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_naptr_reply.c +132 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_ns_reply.c +154 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_ptr_reply.c +213 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_soa_reply.c +115 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_srv_reply.c +114 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_txt_reply.c +144 -0
- data/third_party/cares/cares/src/lib/legacy/ares_parse_uri_reply.c +113 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_mapping.c +982 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_multistring.c +307 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_multistring.h +72 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_name.c +673 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_parse.c +1329 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_private.h +273 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_record.c +1661 -0
- data/third_party/cares/cares/src/lib/record/ares_dns_write.c +1229 -0
- data/third_party/cares/cares/src/lib/str/ares_buf.c +1498 -0
- data/third_party/cares/cares/src/lib/str/ares_str.c +508 -0
- data/third_party/cares/cares/src/lib/str/ares_strsplit.c +90 -0
- data/third_party/cares/cares/src/lib/str/ares_strsplit.h +51 -0
- data/third_party/cares/cares/src/lib/thirdparty/apple/dnsinfo.h +122 -0
- data/third_party/cares/cares/src/lib/util/ares_iface_ips.c +628 -0
- data/third_party/cares/cares/src/lib/util/ares_iface_ips.h +139 -0
- data/third_party/cares/cares/src/lib/util/ares_math.c +158 -0
- data/third_party/cares/cares/src/lib/util/ares_math.h +45 -0
- data/third_party/cares/cares/src/lib/util/ares_rand.c +389 -0
- data/third_party/cares/cares/src/lib/util/ares_rand.h +36 -0
- data/third_party/cares/cares/src/lib/util/ares_threads.c +614 -0
- data/third_party/cares/cares/src/lib/util/ares_threads.h +60 -0
- data/third_party/cares/cares/src/lib/util/ares_time.h +48 -0
- data/third_party/cares/cares/src/lib/util/ares_timeval.c +95 -0
- data/third_party/cares/cares/src/lib/util/ares_uri.c +1626 -0
- data/third_party/cares/cares/src/lib/util/ares_uri.h +252 -0
- data/third_party/cares/cares/src/lib/windows_port.c +16 -9
- metadata +121 -49
- data/src/core/util/ring_buffer.h +0 -122
- data/third_party/cares/cares/include/ares_rules.h +0 -125
- data/third_party/cares/cares/src/lib/ares__addrinfo2hostent.c +0 -266
- data/third_party/cares/cares/src/lib/ares__addrinfo_localhost.c +0 -240
- data/third_party/cares/cares/src/lib/ares__close_sockets.c +0 -61
- data/third_party/cares/cares/src/lib/ares__get_hostent.c +0 -260
- data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +0 -229
- data/third_party/cares/cares/src/lib/ares__read_line.c +0 -73
- data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +0 -258
- data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +0 -507
- data/third_party/cares/cares/src/lib/ares__timeval.c +0 -111
- data/third_party/cares/cares/src/lib/ares_create_query.c +0 -197
- data/third_party/cares/cares/src/lib/ares_expand_name.c +0 -311
- data/third_party/cares/cares/src/lib/ares_expand_string.c +0 -67
- data/third_party/cares/cares/src/lib/ares_fds.c +0 -59
- data/third_party/cares/cares/src/lib/ares_getsock.c +0 -66
- data/third_party/cares/cares/src/lib/ares_iphlpapi.h +0 -221
- data/third_party/cares/cares/src/lib/ares_llist.c +0 -63
- data/third_party/cares/cares/src/lib/ares_llist.h +0 -39
- data/third_party/cares/cares/src/lib/ares_mkquery.c +0 -24
- data/third_party/cares/cares/src/lib/ares_nowarn.c +0 -260
- data/third_party/cares/cares/src/lib/ares_nowarn.h +0 -61
- data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +0 -90
- data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +0 -92
- data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +0 -199
- data/third_party/cares/cares/src/lib/ares_parse_mx_reply.c +0 -164
- data/third_party/cares/cares/src/lib/ares_parse_naptr_reply.c +0 -183
- data/third_party/cares/cares/src/lib/ares_parse_ns_reply.c +0 -177
- data/third_party/cares/cares/src/lib/ares_parse_ptr_reply.c +0 -228
- data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +0 -179
- data/third_party/cares/cares/src/lib/ares_parse_srv_reply.c +0 -168
- data/third_party/cares/cares/src/lib/ares_parse_txt_reply.c +0 -214
- data/third_party/cares/cares/src/lib/ares_parse_uri_reply.c +0 -184
- data/third_party/cares/cares/src/lib/ares_platform.c +0 -11042
- data/third_party/cares/cares/src/lib/ares_platform.h +0 -43
- data/third_party/cares/cares/src/lib/ares_rand.c +0 -279
- data/third_party/cares/cares/src/lib/ares_strcasecmp.c +0 -66
- data/third_party/cares/cares/src/lib/ares_strcasecmp.h +0 -30
- data/third_party/cares/cares/src/lib/ares_strdup.c +0 -42
- data/third_party/cares/cares/src/lib/ares_strdup.h +0 -24
- data/third_party/cares/cares/src/lib/ares_strsplit.c +0 -94
- data/third_party/cares/cares/src/lib/ares_strsplit.h +0 -42
- data/third_party/cares/cares/src/lib/ares_writev.c +0 -79
- data/third_party/cares/cares/src/lib/ares_writev.h +0 -36
- data/third_party/cares/cares/src/lib/bitncmp.c +0 -59
- data/third_party/cares/cares/src/lib/bitncmp.h +0 -26
- data/third_party/cares/cares/src/lib/setup_once.h +0 -554
- data/third_party/cares/cares/src/tools/ares_getopt.h +0 -53
@@ -0,0 +1,447 @@
|
|
1
|
+
/* MIT License
|
2
|
+
*
|
3
|
+
* Copyright (c) 2023 Brad House
|
4
|
+
*
|
5
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
|
+
* of this software and associated documentation files (the "Software"), to deal
|
7
|
+
* in the Software without restriction, including without limitation the rights
|
8
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9
|
+
* copies of the Software, and to permit persons to whom the Software is
|
10
|
+
* furnished to do so, subject to the following conditions:
|
11
|
+
*
|
12
|
+
* The above copyright notice and this permission notice (including the next
|
13
|
+
* paragraph) shall be included in all copies or substantial portions of the
|
14
|
+
* Software.
|
15
|
+
*
|
16
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
17
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
18
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
19
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
20
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
21
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
22
|
+
* SOFTWARE.
|
23
|
+
*
|
24
|
+
* SPDX-License-Identifier: MIT
|
25
|
+
*/
|
26
|
+
#include "ares_private.h"
|
27
|
+
#include "ares_llist.h"
|
28
|
+
#include "ares_htable.h"
|
29
|
+
|
30
|
+
#define ARES__HTABLE_MAX_BUCKETS (1U << 24)
|
31
|
+
#define ARES__HTABLE_MIN_BUCKETS (1U << 4)
|
32
|
+
#define ARES__HTABLE_EXPAND_PERCENT 75
|
33
|
+
|
34
|
+
struct ares_htable {
|
35
|
+
ares_htable_hashfunc_t hash;
|
36
|
+
ares_htable_bucket_key_t bucket_key;
|
37
|
+
ares_htable_bucket_free_t bucket_free;
|
38
|
+
ares_htable_key_eq_t key_eq;
|
39
|
+
unsigned int seed;
|
40
|
+
unsigned int size;
|
41
|
+
size_t num_keys;
|
42
|
+
size_t num_collisions;
|
43
|
+
/* NOTE: if we converted buckets into ares_slist_t we could guarantee on
|
44
|
+
* hash collisions we would have O(log n) worst case insert and search
|
45
|
+
* performance. (We'd also need to make key_eq into a key_cmp to
|
46
|
+
* support sort). That said, risk with a random hash seed is near zero,
|
47
|
+
* and ares_slist_t is heavier weight, so I think using ares_llist_t
|
48
|
+
* is an overall win. */
|
49
|
+
ares_llist_t **buckets;
|
50
|
+
};
|
51
|
+
|
52
|
+
static unsigned int ares_htable_generate_seed(ares_htable_t *htable)
|
53
|
+
{
|
54
|
+
#ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION
|
55
|
+
/* Seed needs to be static for fuzzing */
|
56
|
+
return 0;
|
57
|
+
#else
|
58
|
+
unsigned int seed = 0;
|
59
|
+
time_t t = time(NULL);
|
60
|
+
|
61
|
+
/* Mix stack address, heap address, and time to generate a random seed, it
|
62
|
+
* doesn't have to be super secure, just quick. Likelihood of a hash
|
63
|
+
* collision attack is very low with a small amount of effort */
|
64
|
+
seed |= (unsigned int)((size_t)htable & 0xFFFFFFFF);
|
65
|
+
seed |= (unsigned int)((size_t)&seed & 0xFFFFFFFF);
|
66
|
+
seed |= (unsigned int)(((ares_uint64_t)t) & 0xFFFFFFFF);
|
67
|
+
return seed;
|
68
|
+
#endif
|
69
|
+
}
|
70
|
+
|
71
|
+
static void ares_htable_buckets_destroy(ares_llist_t **buckets,
|
72
|
+
unsigned int size,
|
73
|
+
ares_bool_t destroy_vals)
|
74
|
+
{
|
75
|
+
unsigned int i;
|
76
|
+
|
77
|
+
if (buckets == NULL) {
|
78
|
+
return;
|
79
|
+
}
|
80
|
+
|
81
|
+
for (i = 0; i < size; i++) {
|
82
|
+
if (buckets[i] == NULL) {
|
83
|
+
continue;
|
84
|
+
}
|
85
|
+
|
86
|
+
if (!destroy_vals) {
|
87
|
+
ares_llist_replace_destructor(buckets[i], NULL);
|
88
|
+
}
|
89
|
+
|
90
|
+
ares_llist_destroy(buckets[i]);
|
91
|
+
}
|
92
|
+
|
93
|
+
ares_free(buckets);
|
94
|
+
}
|
95
|
+
|
96
|
+
void ares_htable_destroy(ares_htable_t *htable)
|
97
|
+
{
|
98
|
+
if (htable == NULL) {
|
99
|
+
return;
|
100
|
+
}
|
101
|
+
ares_htable_buckets_destroy(htable->buckets, htable->size, ARES_TRUE);
|
102
|
+
ares_free(htable);
|
103
|
+
}
|
104
|
+
|
105
|
+
ares_htable_t *ares_htable_create(ares_htable_hashfunc_t hash_func,
|
106
|
+
ares_htable_bucket_key_t bucket_key,
|
107
|
+
ares_htable_bucket_free_t bucket_free,
|
108
|
+
ares_htable_key_eq_t key_eq)
|
109
|
+
{
|
110
|
+
ares_htable_t *htable = NULL;
|
111
|
+
|
112
|
+
if (hash_func == NULL || bucket_key == NULL || bucket_free == NULL ||
|
113
|
+
key_eq == NULL) {
|
114
|
+
goto fail;
|
115
|
+
}
|
116
|
+
|
117
|
+
htable = ares_malloc_zero(sizeof(*htable));
|
118
|
+
if (htable == NULL) {
|
119
|
+
goto fail;
|
120
|
+
}
|
121
|
+
|
122
|
+
htable->hash = hash_func;
|
123
|
+
htable->bucket_key = bucket_key;
|
124
|
+
htable->bucket_free = bucket_free;
|
125
|
+
htable->key_eq = key_eq;
|
126
|
+
htable->seed = ares_htable_generate_seed(htable);
|
127
|
+
htable->size = ARES__HTABLE_MIN_BUCKETS;
|
128
|
+
htable->buckets = ares_malloc_zero(sizeof(*htable->buckets) * htable->size);
|
129
|
+
|
130
|
+
if (htable->buckets == NULL) {
|
131
|
+
goto fail;
|
132
|
+
}
|
133
|
+
|
134
|
+
return htable;
|
135
|
+
|
136
|
+
fail:
|
137
|
+
ares_htable_destroy(htable);
|
138
|
+
return NULL;
|
139
|
+
}
|
140
|
+
|
141
|
+
const void **ares_htable_all_buckets(const ares_htable_t *htable, size_t *num)
|
142
|
+
{
|
143
|
+
const void **out = NULL;
|
144
|
+
size_t cnt = 0;
|
145
|
+
size_t i;
|
146
|
+
|
147
|
+
if (htable == NULL || num == NULL) {
|
148
|
+
return NULL; /* LCOV_EXCL_LINE */
|
149
|
+
}
|
150
|
+
|
151
|
+
*num = 0;
|
152
|
+
|
153
|
+
out = ares_malloc_zero(sizeof(*out) * htable->num_keys);
|
154
|
+
if (out == NULL) {
|
155
|
+
return NULL; /* LCOV_EXCL_LINE */
|
156
|
+
}
|
157
|
+
|
158
|
+
for (i = 0; i < htable->size; i++) {
|
159
|
+
ares_llist_node_t *node;
|
160
|
+
for (node = ares_llist_node_first(htable->buckets[i]); node != NULL;
|
161
|
+
node = ares_llist_node_next(node)) {
|
162
|
+
out[cnt++] = ares_llist_node_val(node);
|
163
|
+
}
|
164
|
+
}
|
165
|
+
|
166
|
+
*num = cnt;
|
167
|
+
return out;
|
168
|
+
}
|
169
|
+
|
170
|
+
/*! Grabs the Hashtable index from the key and length. The h index is
|
171
|
+
* the hash of the function reduced to the size of the bucket list.
|
172
|
+
* We are doing "hash & (size - 1)" since we are guaranteeing a power of
|
173
|
+
* 2 for size. This is equivalent to "hash % size", but should be more
|
174
|
+
* efficient */
|
175
|
+
#define HASH_IDX(h, key) h->hash(key, h->seed) & (h->size - 1)
|
176
|
+
|
177
|
+
static ares_llist_node_t *ares_htable_find(const ares_htable_t *htable,
|
178
|
+
unsigned int idx, const void *key)
|
179
|
+
{
|
180
|
+
ares_llist_node_t *node = NULL;
|
181
|
+
|
182
|
+
for (node = ares_llist_node_first(htable->buckets[idx]); node != NULL;
|
183
|
+
node = ares_llist_node_next(node)) {
|
184
|
+
if (htable->key_eq(key, htable->bucket_key(ares_llist_node_val(node)))) {
|
185
|
+
break;
|
186
|
+
}
|
187
|
+
}
|
188
|
+
|
189
|
+
return node;
|
190
|
+
}
|
191
|
+
|
192
|
+
static ares_bool_t ares_htable_expand(ares_htable_t *htable)
|
193
|
+
{
|
194
|
+
ares_llist_t **buckets = NULL;
|
195
|
+
unsigned int old_size = htable->size;
|
196
|
+
size_t i;
|
197
|
+
ares_llist_t **prealloc_llist = NULL;
|
198
|
+
size_t prealloc_llist_len = 0;
|
199
|
+
ares_bool_t rv = ARES_FALSE;
|
200
|
+
|
201
|
+
/* Not a failure, just won't expand */
|
202
|
+
if (old_size == ARES__HTABLE_MAX_BUCKETS) {
|
203
|
+
return ARES_TRUE; /* LCOV_EXCL_LINE */
|
204
|
+
}
|
205
|
+
|
206
|
+
htable->size <<= 1;
|
207
|
+
|
208
|
+
/* We must pre-allocate all memory we'll need before moving entries to the
|
209
|
+
* new hash array. Otherwise if there's a memory allocation failure in the
|
210
|
+
* middle, we wouldn't be able to recover. */
|
211
|
+
buckets = ares_malloc_zero(sizeof(*buckets) * htable->size);
|
212
|
+
if (buckets == NULL) {
|
213
|
+
goto done; /* LCOV_EXCL_LINE */
|
214
|
+
}
|
215
|
+
|
216
|
+
/* The maximum number of new llists we'll need is the number of collisions
|
217
|
+
* that were recorded */
|
218
|
+
prealloc_llist_len = htable->num_collisions;
|
219
|
+
if (prealloc_llist_len) {
|
220
|
+
prealloc_llist =
|
221
|
+
ares_malloc_zero(sizeof(*prealloc_llist) * prealloc_llist_len);
|
222
|
+
if (prealloc_llist == NULL) {
|
223
|
+
goto done; /* LCOV_EXCL_LINE */
|
224
|
+
}
|
225
|
+
}
|
226
|
+
for (i = 0; i < prealloc_llist_len; i++) {
|
227
|
+
prealloc_llist[i] = ares_llist_create(htable->bucket_free);
|
228
|
+
if (prealloc_llist[i] == NULL) {
|
229
|
+
goto done;
|
230
|
+
}
|
231
|
+
}
|
232
|
+
|
233
|
+
/* Iterate across all buckets and move the entries to the new buckets */
|
234
|
+
htable->num_collisions = 0;
|
235
|
+
for (i = 0; i < old_size; i++) {
|
236
|
+
ares_llist_node_t *node;
|
237
|
+
|
238
|
+
/* Nothing in this bucket */
|
239
|
+
if (htable->buckets[i] == NULL) {
|
240
|
+
continue;
|
241
|
+
}
|
242
|
+
|
243
|
+
/* Fast path optimization (most likely case), there is likely only a single
|
244
|
+
* entry in both the source and destination, check for this to confirm and
|
245
|
+
* if so, just move the bucket over */
|
246
|
+
if (ares_llist_len(htable->buckets[i]) == 1) {
|
247
|
+
const void *val = ares_llist_first_val(htable->buckets[i]);
|
248
|
+
size_t idx = HASH_IDX(htable, htable->bucket_key(val));
|
249
|
+
|
250
|
+
if (buckets[idx] == NULL) {
|
251
|
+
/* Swap! */
|
252
|
+
buckets[idx] = htable->buckets[i];
|
253
|
+
htable->buckets[i] = NULL;
|
254
|
+
continue;
|
255
|
+
}
|
256
|
+
}
|
257
|
+
|
258
|
+
/* Slow path, collisions */
|
259
|
+
while ((node = ares_llist_node_first(htable->buckets[i])) != NULL) {
|
260
|
+
const void *val = ares_llist_node_val(node);
|
261
|
+
size_t idx = HASH_IDX(htable, htable->bucket_key(val));
|
262
|
+
|
263
|
+
/* Try fast path again as maybe we popped one collision off and the
|
264
|
+
* next we can reuse the llist parent */
|
265
|
+
if (buckets[idx] == NULL && ares_llist_len(htable->buckets[i]) == 1) {
|
266
|
+
/* Swap! */
|
267
|
+
buckets[idx] = htable->buckets[i];
|
268
|
+
htable->buckets[i] = NULL;
|
269
|
+
break;
|
270
|
+
}
|
271
|
+
|
272
|
+
/* Grab one off our preallocated list */
|
273
|
+
if (buckets[idx] == NULL) {
|
274
|
+
/* Silence static analysis, this isn't possible but it doesn't know */
|
275
|
+
if (prealloc_llist == NULL || prealloc_llist_len == 0) {
|
276
|
+
goto done; /* LCOV_EXCL_LINE */
|
277
|
+
}
|
278
|
+
buckets[idx] = prealloc_llist[prealloc_llist_len - 1];
|
279
|
+
prealloc_llist_len--;
|
280
|
+
} else {
|
281
|
+
/* Collision occurred since the bucket wasn't empty */
|
282
|
+
htable->num_collisions++;
|
283
|
+
}
|
284
|
+
|
285
|
+
ares_llist_node_mvparent_first(node, buckets[idx]);
|
286
|
+
}
|
287
|
+
|
288
|
+
/* Abandoned bucket, destroy */
|
289
|
+
if (htable->buckets[i] != NULL) {
|
290
|
+
ares_llist_destroy(htable->buckets[i]);
|
291
|
+
htable->buckets[i] = NULL;
|
292
|
+
}
|
293
|
+
}
|
294
|
+
|
295
|
+
/* We have guaranteed all the buckets have either been moved or destroyed,
|
296
|
+
* so we just call ares_free() on the array and swap out the pointer */
|
297
|
+
ares_free(htable->buckets);
|
298
|
+
htable->buckets = buckets;
|
299
|
+
buckets = NULL;
|
300
|
+
rv = ARES_TRUE;
|
301
|
+
|
302
|
+
done:
|
303
|
+
ares_free(buckets);
|
304
|
+
/* destroy any unused preallocated buckets */
|
305
|
+
ares_htable_buckets_destroy(prealloc_llist, (unsigned int)prealloc_llist_len,
|
306
|
+
ARES_FALSE);
|
307
|
+
|
308
|
+
/* On failure, we need to restore the htable size */
|
309
|
+
if (rv != ARES_TRUE) {
|
310
|
+
htable->size = old_size; /* LCOV_EXCL_LINE */
|
311
|
+
}
|
312
|
+
|
313
|
+
return rv;
|
314
|
+
}
|
315
|
+
|
316
|
+
ares_bool_t ares_htable_insert(ares_htable_t *htable, void *bucket)
|
317
|
+
{
|
318
|
+
unsigned int idx = 0;
|
319
|
+
ares_llist_node_t *node = NULL;
|
320
|
+
const void *key = NULL;
|
321
|
+
|
322
|
+
if (htable == NULL || bucket == NULL) {
|
323
|
+
return ARES_FALSE;
|
324
|
+
}
|
325
|
+
|
326
|
+
|
327
|
+
key = htable->bucket_key(bucket);
|
328
|
+
idx = HASH_IDX(htable, key);
|
329
|
+
|
330
|
+
/* See if we have a matching bucket already, if so, replace it */
|
331
|
+
node = ares_htable_find(htable, idx, key);
|
332
|
+
if (node != NULL) {
|
333
|
+
ares_llist_node_replace(node, bucket);
|
334
|
+
return ARES_TRUE;
|
335
|
+
}
|
336
|
+
|
337
|
+
/* Check to see if we should rehash because likelihood of collisions has
|
338
|
+
* increased beyond our threshold */
|
339
|
+
if (htable->num_keys + 1 >
|
340
|
+
(htable->size * ARES__HTABLE_EXPAND_PERCENT) / 100) {
|
341
|
+
if (!ares_htable_expand(htable)) {
|
342
|
+
return ARES_FALSE; /* LCOV_EXCL_LINE */
|
343
|
+
}
|
344
|
+
/* If we expanded, need to calculate a new index */
|
345
|
+
idx = HASH_IDX(htable, key);
|
346
|
+
}
|
347
|
+
|
348
|
+
/* We lazily allocate the linked list */
|
349
|
+
if (htable->buckets[idx] == NULL) {
|
350
|
+
htable->buckets[idx] = ares_llist_create(htable->bucket_free);
|
351
|
+
if (htable->buckets[idx] == NULL) {
|
352
|
+
return ARES_FALSE;
|
353
|
+
}
|
354
|
+
}
|
355
|
+
|
356
|
+
node = ares_llist_insert_first(htable->buckets[idx], bucket);
|
357
|
+
if (node == NULL) {
|
358
|
+
return ARES_FALSE;
|
359
|
+
}
|
360
|
+
|
361
|
+
/* Track collisions for rehash stability */
|
362
|
+
if (ares_llist_len(htable->buckets[idx]) > 1) {
|
363
|
+
htable->num_collisions++;
|
364
|
+
}
|
365
|
+
|
366
|
+
htable->num_keys++;
|
367
|
+
|
368
|
+
return ARES_TRUE;
|
369
|
+
}
|
370
|
+
|
371
|
+
void *ares_htable_get(const ares_htable_t *htable, const void *key)
|
372
|
+
{
|
373
|
+
unsigned int idx;
|
374
|
+
|
375
|
+
if (htable == NULL || key == NULL) {
|
376
|
+
return NULL;
|
377
|
+
}
|
378
|
+
|
379
|
+
idx = HASH_IDX(htable, key);
|
380
|
+
|
381
|
+
return ares_llist_node_val(ares_htable_find(htable, idx, key));
|
382
|
+
}
|
383
|
+
|
384
|
+
ares_bool_t ares_htable_remove(ares_htable_t *htable, const void *key)
|
385
|
+
{
|
386
|
+
ares_llist_node_t *node;
|
387
|
+
unsigned int idx;
|
388
|
+
|
389
|
+
if (htable == NULL || key == NULL) {
|
390
|
+
return ARES_FALSE;
|
391
|
+
}
|
392
|
+
|
393
|
+
idx = HASH_IDX(htable, key);
|
394
|
+
node = ares_htable_find(htable, idx, key);
|
395
|
+
if (node == NULL) {
|
396
|
+
return ARES_FALSE;
|
397
|
+
}
|
398
|
+
|
399
|
+
htable->num_keys--;
|
400
|
+
|
401
|
+
/* Reduce collisions */
|
402
|
+
if (ares_llist_len(ares_llist_node_parent(node)) > 1) {
|
403
|
+
htable->num_collisions--;
|
404
|
+
}
|
405
|
+
|
406
|
+
ares_llist_node_destroy(node);
|
407
|
+
return ARES_TRUE;
|
408
|
+
}
|
409
|
+
|
410
|
+
size_t ares_htable_num_keys(const ares_htable_t *htable)
|
411
|
+
{
|
412
|
+
if (htable == NULL) {
|
413
|
+
return 0;
|
414
|
+
}
|
415
|
+
return htable->num_keys;
|
416
|
+
}
|
417
|
+
|
418
|
+
unsigned int ares_htable_hash_FNV1a(const unsigned char *key, size_t key_len,
|
419
|
+
unsigned int seed)
|
420
|
+
{
|
421
|
+
unsigned int hv = seed ^ 2166136261U;
|
422
|
+
size_t i;
|
423
|
+
|
424
|
+
for (i = 0; i < key_len; i++) {
|
425
|
+
hv ^= (unsigned int)key[i];
|
426
|
+
/* hv *= 16777619 (0x01000193) */
|
427
|
+
hv += (hv << 1) + (hv << 4) + (hv << 7) + (hv << 8) + (hv << 24);
|
428
|
+
}
|
429
|
+
|
430
|
+
return hv;
|
431
|
+
}
|
432
|
+
|
433
|
+
/* Case insensitive version, meant for ASCII strings */
|
434
|
+
unsigned int ares_htable_hash_FNV1a_casecmp(const unsigned char *key,
|
435
|
+
size_t key_len, unsigned int seed)
|
436
|
+
{
|
437
|
+
unsigned int hv = seed ^ 2166136261U;
|
438
|
+
size_t i;
|
439
|
+
|
440
|
+
for (i = 0; i < key_len; i++) {
|
441
|
+
hv ^= (unsigned int)ares_tolower(key[i]);
|
442
|
+
/* hv *= 16777619 (0x01000193) */
|
443
|
+
hv += (hv << 1) + (hv << 4) + (hv << 7) + (hv << 8) + (hv << 24);
|
444
|
+
}
|
445
|
+
|
446
|
+
return hv;
|
447
|
+
}
|
@@ -0,0 +1,174 @@
|
|
1
|
+
/* MIT License
|
2
|
+
*
|
3
|
+
* Copyright (c) 2023 Brad House
|
4
|
+
*
|
5
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
|
+
* of this software and associated documentation files (the "Software"), to deal
|
7
|
+
* in the Software without restriction, including without limitation the rights
|
8
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9
|
+
* copies of the Software, and to permit persons to whom the Software is
|
10
|
+
* furnished to do so, subject to the following conditions:
|
11
|
+
*
|
12
|
+
* The above copyright notice and this permission notice (including the next
|
13
|
+
* paragraph) shall be included in all copies or substantial portions of the
|
14
|
+
* Software.
|
15
|
+
*
|
16
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
17
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
18
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
19
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
20
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
21
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
22
|
+
* SOFTWARE.
|
23
|
+
*
|
24
|
+
* SPDX-License-Identifier: MIT
|
25
|
+
*/
|
26
|
+
#ifndef __ARES__HTABLE_H
|
27
|
+
#define __ARES__HTABLE_H
|
28
|
+
|
29
|
+
|
30
|
+
/*! \addtogroup ares_htable Base HashTable Data Structure
|
31
|
+
*
|
32
|
+
* This is a basic hashtable data structure that is meant to be wrapped
|
33
|
+
* by a higher level implementation. This data structure is designed to
|
34
|
+
* be callback-based in order to facilitate wrapping without needing to
|
35
|
+
* worry about any underlying complexities of the hashtable implementation.
|
36
|
+
*
|
37
|
+
* This implementation supports automatic growing by powers of 2 when reaching
|
38
|
+
* 75% capacity. A rehash will be performed on the expanded bucket list.
|
39
|
+
*
|
40
|
+
* Average time complexity:
|
41
|
+
* - Insert: O(1)
|
42
|
+
* - Search: O(1)
|
43
|
+
* - Delete: O(1)
|
44
|
+
*
|
45
|
+
* @{
|
46
|
+
*/
|
47
|
+
|
48
|
+
struct ares_htable;
|
49
|
+
|
50
|
+
/*! Opaque data type for generic hash table implementation */
|
51
|
+
typedef struct ares_htable ares_htable_t;
|
52
|
+
|
53
|
+
/*! Callback for generating a hash of the key.
|
54
|
+
*
|
55
|
+
* \param[in] key pointer to key to be hashed
|
56
|
+
* \param[in] seed randomly generated seed used by hash function.
|
57
|
+
* value is specific to the hashtable instance
|
58
|
+
* but otherwise will not change between calls.
|
59
|
+
* \return hash
|
60
|
+
*/
|
61
|
+
typedef unsigned int (*ares_htable_hashfunc_t)(const void *key,
|
62
|
+
unsigned int seed);
|
63
|
+
|
64
|
+
/*! Callback to free the bucket
|
65
|
+
*
|
66
|
+
* \param[in] bucket user provided bucket
|
67
|
+
*/
|
68
|
+
typedef void (*ares_htable_bucket_free_t)(void *bucket);
|
69
|
+
|
70
|
+
/*! Callback to extract the key from the user-provided bucket
|
71
|
+
*
|
72
|
+
* \param[in] bucket user provided bucket
|
73
|
+
* \return pointer to key held in bucket
|
74
|
+
*/
|
75
|
+
typedef const void *(*ares_htable_bucket_key_t)(const void *bucket);
|
76
|
+
|
77
|
+
/*! Callback to compare two keys for equality
|
78
|
+
*
|
79
|
+
* \param[in] key1 first key
|
80
|
+
* \param[in] key2 second key
|
81
|
+
* \return ARES_TRUE if equal, ARES_FALSE if not
|
82
|
+
*/
|
83
|
+
typedef ares_bool_t (*ares_htable_key_eq_t)(const void *key1, const void *key2);
|
84
|
+
|
85
|
+
|
86
|
+
/*! Destroy the initialized hashtable
|
87
|
+
*
|
88
|
+
* \param[in] htable initialized hashtable
|
89
|
+
*/
|
90
|
+
void ares_htable_destroy(ares_htable_t *htable);
|
91
|
+
|
92
|
+
/*! Create a new hashtable
|
93
|
+
*
|
94
|
+
* \param[in] hash_func Required. Callback for Hash function.
|
95
|
+
* \param[in] bucket_key Required. Callback to extract key from bucket.
|
96
|
+
* \param[in] bucket_free Required. Callback to free bucket.
|
97
|
+
* \param[in] key_eq Required. Callback to check for key equality.
|
98
|
+
* \return initialized hashtable. NULL if out of memory or misuse.
|
99
|
+
*/
|
100
|
+
ares_htable_t *ares_htable_create(ares_htable_hashfunc_t hash_func,
|
101
|
+
ares_htable_bucket_key_t bucket_key,
|
102
|
+
ares_htable_bucket_free_t bucket_free,
|
103
|
+
ares_htable_key_eq_t key_eq);
|
104
|
+
|
105
|
+
/*! Count of keys from initialized hashtable
|
106
|
+
*
|
107
|
+
* \param[in] htable Initialized hashtable.
|
108
|
+
* \return count of keys
|
109
|
+
*/
|
110
|
+
size_t ares_htable_num_keys(const ares_htable_t *htable);
|
111
|
+
|
112
|
+
/*! Retrieve an array of buckets from the hashtable. This is mainly used as
|
113
|
+
* a helper for retrieving an array of keys.
|
114
|
+
*
|
115
|
+
* \param[in] htable Initialized hashtable
|
116
|
+
* \param[out] num Count of returned buckets
|
117
|
+
* \return Array of pointers to the buckets. These are internal pointers
|
118
|
+
* to data within the hashtable, so if the key is removed, there
|
119
|
+
* will be a dangling pointer. It is expected wrappers will make
|
120
|
+
* such values safe by duplicating them.
|
121
|
+
*/
|
122
|
+
const void **ares_htable_all_buckets(const ares_htable_t *htable, size_t *num);
|
123
|
+
|
124
|
+
/*! Insert bucket into hashtable
|
125
|
+
*
|
126
|
+
* \param[in] htable Initialized hashtable.
|
127
|
+
* \param[in] bucket User-provided bucket to insert. Takes "ownership". Not
|
128
|
+
* allowed to be NULL.
|
129
|
+
* \return ARES_TRUE on success, ARES_FALSE if out of memory
|
130
|
+
*/
|
131
|
+
ares_bool_t ares_htable_insert(ares_htable_t *htable, void *bucket);
|
132
|
+
|
133
|
+
/*! Retrieve bucket from hashtable based on key.
|
134
|
+
*
|
135
|
+
* \param[in] htable Initialized hashtable
|
136
|
+
* \param[in] key Pointer to key to use for comparison.
|
137
|
+
* \return matching bucket, or NULL if not found.
|
138
|
+
*/
|
139
|
+
void *ares_htable_get(const ares_htable_t *htable, const void *key);
|
140
|
+
|
141
|
+
/*! Remove bucket from hashtable by key
|
142
|
+
*
|
143
|
+
* \param[in] htable Initialized hashtable
|
144
|
+
* \param[in] key Pointer to key to use for comparison
|
145
|
+
* \return ARES_TRUE if found, ARES_FALSE if not found
|
146
|
+
*/
|
147
|
+
ares_bool_t ares_htable_remove(ares_htable_t *htable, const void *key);
|
148
|
+
|
149
|
+
/*! FNV1a hash algorithm. Can be used as underlying primitive for building
|
150
|
+
* a wrapper hashtable.
|
151
|
+
*
|
152
|
+
* \param[in] key pointer to key
|
153
|
+
* \param[in] key_len Length of key
|
154
|
+
* \param[in] seed Seed for generating hash
|
155
|
+
* \return hash value
|
156
|
+
*/
|
157
|
+
unsigned int ares_htable_hash_FNV1a(const unsigned char *key, size_t key_len,
|
158
|
+
unsigned int seed);
|
159
|
+
|
160
|
+
/*! FNV1a hash algorithm, but converts all characters to lowercase before
|
161
|
+
* hashing to make the hash case-insensitive. Can be used as underlying
|
162
|
+
* primitive for building a wrapper hashtable. Used on string-based keys.
|
163
|
+
*
|
164
|
+
* \param[in] key pointer to key
|
165
|
+
* \param[in] key_len Length of key
|
166
|
+
* \param[in] seed Seed for generating hash
|
167
|
+
* \return hash value
|
168
|
+
*/
|
169
|
+
unsigned int ares_htable_hash_FNV1a_casecmp(const unsigned char *key,
|
170
|
+
size_t key_len, unsigned int seed);
|
171
|
+
|
172
|
+
/*! @} */
|
173
|
+
|
174
|
+
#endif /* __ARES__HTABLE_H */
|