Files
ansi_term
base64
bitflags
byteorder
bytes
buf
fmt
cfg_if
chrono
format
naive
offset
sys
crossbeam_channel
crossbeam_utils
either
encoding_rs
fnv
foreign_types
foreign_types_shared
form_urlencoded
futures
futures_channel
futures_core
futures_executor
futures_io
futures_macro
futures_sink
futures_task
futures_util
async_await
future
future
try_future
io
allow_std.rsbuf_reader.rsbuf_writer.rschain.rsclose.rscopy.rscopy_buf.rscursor.rsempty.rsfill_buf.rsflush.rsinto_sink.rslines.rsmod.rsread.rsread_exact.rsread_line.rsread_to_end.rsread_to_string.rsread_until.rsread_vectored.rsrepeat.rsseek.rssink.rssplit.rstake.rswindow.rswrite.rswrite_all.rswrite_vectored.rs
lock
sink
stream
futures_unordered
stream
buffer_unordered.rsbuffered.rscatch_unwind.rschain.rschunks.rscollect.rsconcat.rscycle.rsenumerate.rsfilter.rsfilter_map.rsflatten.rsfold.rsfor_each.rsfor_each_concurrent.rsforward.rsfuse.rsinto_future.rsmap.rsmod.rsnext.rspeek.rsready_chunks.rsscan.rsselect_next_some.rsskip.rsskip_while.rssplit.rstake.rstake_until.rstake_while.rsthen.rszip.rs
try_stream
task
getrandom
h2
codec
frame
hpack
proto
hashbrown
http
http_body
httparse
httpdate
hyper
body
client
common
proto
server
service
hyper_tls
idna
indexmap
instant
iovec
ipnet
itertools
adaptors
combinations.rscombinations_with_replacement.rsconcat_impl.rscons_tuples_impl.rsdiff.rseither_or_both.rsexactly_one_err.rsformat.rsfree.rsgroup_map.rsgroupbylazy.rsimpl_macros.rsintersperse.rskmerge_impl.rslazy_buffer.rslib.rsmerge_join.rsminmax.rsmultipeek_impl.rspad_tail.rspeeking_take_while.rspermutations.rsprocess_results_impl.rsput_back_n_impl.rsrciter_impl.rsrepeatn.rssize_hint.rssources.rstee.rstuple_impl.rsunique_impl.rswith_position.rszip_eq_impl.rszip_longest.rsziptuple.rs
itoa
lazy_static
libc
unix
libhoney
lock_api
log
matchers
matches
memchr
mime
mime_guess
mio
deprecated
net
sys
mio_uds
native_tls
net2
num_cpus
num_integer
num_traits
once_cell
openssl
openssl_probe
openssl_sys
opentelemetry
api
context
correlation
metrics
trace
exporter
sdk
parking_lot
parking_lot_core
percent_encoding
pin_project
pin_project_internal
pin_project_lite
pin_utils
ppv_lite86
proc_macro2
proc_macro_hack
proc_macro_nested
prometheus
protobuf
json
reflect
well_known_types
well_known_types_util
quick_error
quote
rand
distributions
weighted
rngs
seq
rand_chacha
rand_core
regex
literal
regex_automata
regex_syntax
ast
hir
unicode_tables
reqwest
async_impl
blocking
ryu
scopeguard
serde
de
private
ser
serde_derive
serde_json
serde_urlencoded
sharded_slab
signal_hook_registry
slab
smallvec
socket2
spin
syn
attr.rsbigint.rsbuffer.rscustom_keyword.rscustom_punctuation.rsdata.rsderive.rsdiscouraged.rserror.rsexport.rsexpr.rsext.rsfile.rsgenerics.rsgroup.rsident.rsitem.rslib.rslifetime.rslit.rslookahead.rsmac.rsmacros.rsop.rsparse.rsparse_macro_input.rsparse_quote.rspat.rspath.rsprint.rspunctuated.rsreserved.rssealed.rsspan.rsspanned.rsstmt.rsthread.rstoken.rstt.rsty.rsverbatim.rswhitespace.rs
thread_local
time
tinyvec
tinyvec_macros
tokio
fs
future
io
driver
util
async_buf_read_ext.rsasync_read_ext.rsasync_seek_ext.rsasync_write_ext.rsbuf_reader.rsbuf_stream.rsbuf_writer.rschain.rscopy.rsempty.rsflush.rslines.rsmem.rsmod.rsread.rsread_buf.rsread_exact.rsread_int.rsread_line.rsread_to_end.rsread_to_string.rsread_until.rsreader_stream.rsrepeat.rsshutdown.rssink.rssplit.rsstream_reader.rstake.rswrite.rswrite_all.rswrite_buf.rswrite_int.rs
loom
std
macros
net
tcp
udp
unix
park
process
runtime
blocking
task
thread_pool
signal
stream
sync
task
time
util
tokio_macros
tokio_tls
tokio_util
codec
tower_service
tracing
tracing_attributes
tracing_core
tracing_distributed
tracing_futures
tracing_honeycomb
tracing_jaeger
tracing_log
tracing_serde
tracing_subscriber
field
filter
fmt
registry
try_lock
unicase
unicode_bidi
unicode_normalization
unicode_xid
url
want
>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
// Copyright 2019 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or // http://www.apache.org/licenses/LICENSE-2.0> or the MIT license // <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your // option. This file may not be copied, modified, or distributed // except according to those terms. //! Support for lookups based on minimal perfect hashing. // This function is based on multiplication being fast and is "good enough". Also // it can share some work between the unsalted and salted versions. #[inline] fn my_hash(key: u32, salt: u32, n: usize) -> usize { let y = key.wrapping_add(salt).wrapping_mul(2654435769); let y = y ^ key.wrapping_mul(0x31415926); (((y as u64) * (n as u64)) >> 32) as usize } /// Do a lookup using minimal perfect hashing. /// /// The table is stored as a sequence of "salt" values, then a sequence of /// values that contain packed key/value pairs. The strategy is to hash twice. /// The first hash retrieves a salt value that makes the second hash unique. /// The hash function doesn't have to be very good, just good enough that the /// resulting map is unique. #[inline] pub(crate) fn mph_lookup<KV, V, FK, FV>( x: u32, salt: &[u16], kv: &[KV], fk: FK, fv: FV, default: V, ) -> V where KV: Copy, FK: Fn(KV) -> u32, FV: Fn(KV) -> V, { let s = salt[my_hash(x, 0, salt.len())] as u32; let key_val = kv[my_hash(x, s, salt.len())]; if x == fk(key_val) { fv(key_val) } else { default } }