From b1ea85003f3554789ebc20145c14d6331ebb7bc3 Mon Sep 17 00:00:00 2001 From: Ralf Jung Date: Wed, 13 Nov 2024 09:56:48 +0100 Subject: [PATCH 1/2] allow 'extern crate alloc' even when that is the crates.io crate --- src/lib.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/src/lib.rs b/src/lib.rs index a2d0d03b8..6c3256829 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -52,6 +52,7 @@ pub enum DefaultHashBuilder {} extern crate std; #[cfg_attr(test, macro_use)] +#[cfg_attr(feature = "rustc-dep-of-std", allow(unused_extern_crates))] extern crate alloc; #[cfg(feature = "nightly")] From 855feb0f070edbeed6609d3af46b103155ee6395 Mon Sep 17 00:00:00 2001 From: Ralf Jung Date: Wed, 13 Nov 2024 10:00:14 +0100 Subject: [PATCH 2/2] mark const fn constructors as rustc_const_stable_indirect --- src/lib.rs | 1 + src/map.rs | 2 ++ src/raw/mod.rs | 2 ++ src/set.rs | 2 ++ 4 files changed, 7 insertions(+) diff --git a/src/lib.rs b/src/lib.rs index 6c3256829..c4a0532ba 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -24,6 +24,7 @@ strict_provenance_lints ) )] +#![cfg_attr(feature = "rustc-dep-of-std", feature(rustc_attrs))] #![allow( clippy::doc_markdown, clippy::module_name_repetitions, diff --git a/src/map.rs b/src/map.rs index 1969bff54..c373d5958 100644 --- a/src/map.rs +++ b/src/map.rs @@ -453,6 +453,7 @@ impl HashMap { /// map.insert(1, 2); /// ``` #[cfg_attr(feature = "inline-more", inline)] + #[cfg_attr(feature = "rustc-dep-of-std", rustc_const_stable_indirect)] pub const fn with_hasher(hash_builder: S) -> Self { Self { hash_builder, @@ -538,6 +539,7 @@ impl HashMap { /// map.insert(1, 2); /// ``` #[cfg_attr(feature = "inline-more", inline)] + #[cfg_attr(feature = "rustc-dep-of-std", rustc_const_stable_indirect)] pub const fn with_hasher_in(hash_builder: S, alloc: A) -> Self { Self { hash_builder, diff --git a/src/raw/mod.rs b/src/raw/mod.rs index 1c4a5f42e..e4b25e166 100644 --- a/src/raw/mod.rs +++ b/src/raw/mod.rs @@ -677,6 +677,7 @@ impl RawTable { /// leave the data pointer dangling since that bucket is never written to /// due to our load factor forcing us to always have at least 1 free bucket. #[inline] + #[cfg_attr(feature = "rustc-dep-of-std", rustc_const_stable_indirect)] pub const fn new() -> Self { Self { table: RawTableInner::NEW, @@ -702,6 +703,7 @@ impl RawTable { /// leave the data pointer dangling since that bucket is never written to /// due to our load factor forcing us to always have at least 1 free bucket. #[inline] + #[cfg_attr(feature = "rustc-dep-of-std", rustc_const_stable_indirect)] pub const fn new_in(alloc: A) -> Self { Self { table: RawTableInner::NEW, diff --git a/src/set.rs b/src/set.rs index 819d01c66..d57390f67 100644 --- a/src/set.rs +++ b/src/set.rs @@ -465,6 +465,7 @@ impl HashSet { /// set.insert(2); /// ``` #[cfg_attr(feature = "inline-more", inline)] + #[cfg_attr(feature = "rustc-dep-of-std", rustc_const_stable_indirect)] pub const fn with_hasher(hasher: S) -> Self { Self { map: HashMap::with_hasher(hasher), @@ -552,6 +553,7 @@ where /// set.insert(2); /// ``` #[cfg_attr(feature = "inline-more", inline)] + #[cfg_attr(feature = "rustc-dep-of-std", rustc_const_stable_indirect)] pub const fn with_hasher_in(hasher: S, alloc: A) -> Self { Self { map: HashMap::with_hasher_in(hasher, alloc),