From 329af64cc59b7a4e7b79860e07fef273a1feb0ea Mon Sep 17 00:00:00 2001 From: Jacob Finkelman Date: Fri, 25 Aug 2023 18:07:27 +0000 Subject: [PATCH] string leek is stable --- src/cargo/util/interning.rs | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/src/cargo/util/interning.rs b/src/cargo/util/interning.rs index 584fdf62382..6d62b167f0e 100644 --- a/src/cargo/util/interning.rs +++ b/src/cargo/util/interning.rs @@ -12,10 +12,6 @@ use std::str; use std::sync::Mutex; use std::sync::OnceLock; -fn leak(s: String) -> &'static str { - Box::leak(s.into_boxed_str()) -} - static STRING_CACHE: OnceLock>> = OnceLock::new(); #[derive(Clone, Copy)] @@ -63,12 +59,9 @@ impl Eq for InternedString {} impl InternedString { pub fn new(str: &str) -> InternedString { - let mut cache = STRING_CACHE - .get_or_init(|| Default::default()) - .lock() - .unwrap(); + let mut cache = STRING_CACHE.get_or_init(Default::default).lock().unwrap(); let s = cache.get(str).cloned().unwrap_or_else(|| { - let s = leak(str.to_string()); + let s = str.to_string().leak(); cache.insert(s); s });