From 078887e706eae5f1569efe5d5f17b069bd09452f Mon Sep 17 00:00:00 2001 From: Amanieu d'Antras Date: Tue, 18 Jun 2024 14:45:19 +0100 Subject: [PATCH] Replace "ahash" with "default-hasher" in Cargo features This allows us to change the default hasher in the future without it being a breaking change. --- Cargo.toml | 20 ++++++++++++++------ src/map.rs | 10 +++++----- src/set.rs | 6 +++--- 3 files changed, 22 insertions(+), 14 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index eb214857c..ebbe8e794 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -22,6 +22,7 @@ serde = { version = "1.0.25", default-features = false, optional = true } rkyv = { version = "0.7.42", optional = true, default-features = false, features = [ "alloc", ] } +borsh = { version = "1.5.0", default-features = false, optional = true, features = ["derive"]} # When built as part of libstd core = { version = "1.0.0", optional = true, package = "rustc-std-workspace-core" } @@ -36,9 +37,6 @@ allocator-api2 = { version = "0.2.9", optional = true, default-features = false, # Equivalent trait which can be shared with other hash table implementations. equivalent = { version = "1.0", optional = true, default-features = false } -# borsh serde -borsh = { version = "1.5.0", default-features = false, optional = true, features = ["derive"]} - [dev-dependencies] lazy_static = "1.4" rand = { version = "0.8.3", features = ["small_rng"] } @@ -50,11 +48,16 @@ bumpalo = { version = "3.13.0", features = ["allocator-api2"] } rkyv = { version = "0.7.42", features = ["validation"] } [features] -default = ["ahash", "inline-more", "allocator-api2", "equivalent"] +default = ["default-hasher", "inline-more", "allocator-api2", "equivalent"] +# Enables use of nightly features. This is only guaranteed to work on the latest +# version of nightly Rust. nightly = ["allocator-api2?/nightly", "bumpalo/allocator_api"] +# Enables the RustcEntry API used to provide the standard library's Entry API. rustc-internal-api = [] + +# Internal feature used when building as part of the standard library. rustc-dep-of-std = [ "nightly", "core", @@ -62,15 +65,20 @@ rustc-dep-of-std = [ "alloc", "rustc-internal-api", ] + +# Enables the RawTable API. raw = [] +# Provides a default hasher. Currently this is AHash but this is subject to +# change in the future. Note that the default hasher does *not* provide HashDoS +# resistance, unlike the one in the standard library. +default-hasher = ["dep:ahash"] + # Enables usage of `#[inline]` on far more functions than by default in this # crate. This may lead to a performance increase but often comes at a compile # time cost. inline-more = [] -borsh = ["dep:borsh"] - [package.metadata.docs.rs] features = ["nightly", "rayon", "serde", "raw"] rustdoc-args = ["--generate-link-to-definition"] diff --git a/src/map.rs b/src/map.rs index 7f06bd558..d83494eb9 100644 --- a/src/map.rs +++ b/src/map.rs @@ -11,11 +11,11 @@ use core::mem; use core::ops::Index; /// Default hasher for `HashMap`. -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] pub type DefaultHashBuilder = core::hash::BuildHasherDefault; /// Dummy default hasher for `HashMap`. -#[cfg(not(feature = "ahash"))] +#[cfg(not(feature = "default-hasher"))] pub enum DefaultHashBuilder {} /// A hash map implemented with quadratic probing and SIMD lookup. @@ -262,7 +262,7 @@ where hash_builder.hash_one(val) } -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] impl HashMap { /// Creates an empty `HashMap`. /// @@ -325,7 +325,7 @@ impl HashMap { } } -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] impl HashMap { /// Creates an empty `HashMap` using the given allocator. /// @@ -2258,7 +2258,7 @@ where } // The default hasher is used to match the std implementation signature -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] impl From<[(K, V); N]> for HashMap where K: Eq + Hash, diff --git a/src/set.rs b/src/set.rs index bd6678833..be03b8703 100644 --- a/src/set.rs +++ b/src/set.rs @@ -128,7 +128,7 @@ impl Clone for HashSet { } } -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] impl HashSet { /// Creates an empty `HashSet`. /// @@ -192,7 +192,7 @@ impl HashSet { } } -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] impl HashSet { /// Creates an empty `HashSet`. /// @@ -1324,7 +1324,7 @@ where } // The default hasher is used to match the std implementation signature -#[cfg(feature = "ahash")] +#[cfg(feature = "default-hasher")] impl From<[T; N]> for HashSet where T: Eq + Hash,