From 51023b58e9b5f66af665f0a311097bb5eed2a711 Mon Sep 17 00:00:00 2001 From: Jubilee Young Date: Tue, 17 Sep 2024 09:31:57 -0700 Subject: [PATCH] library: Destabilize Lazy{Cell,Lock}::{force,deref}_mut --- core/src/cell/lazy.rs | 17 +++-------------- core/src/lib.rs | 1 + core/tests/lib.rs | 1 + std/src/lib.rs | 1 + std/src/sync/lazy_lock.rs | 17 +++-------------- 5 files changed, 9 insertions(+), 28 deletions(-) diff --git a/core/src/cell/lazy.rs b/core/src/cell/lazy.rs index 6407aba7c8119..8c88f967aa23f 100644 --- a/core/src/cell/lazy.rs +++ b/core/src/cell/lazy.rs @@ -1,6 +1,6 @@ use super::UnsafeCell; use crate::hint::unreachable_unchecked; -use crate::ops::{Deref, DerefMut}; +use crate::ops::Deref; use crate::{fmt, mem}; enum State { @@ -122,11 +122,10 @@ impl T> LazyCell { /// Forces the evaluation of this lazy value and returns a mutable reference to /// the result. /// - /// This is equivalent to the `DerefMut` impl, but is explicit. - /// /// # Examples /// /// ``` + /// #![feature(lazy_get)] /// use std::cell::LazyCell; /// /// let mut lazy = LazyCell::new(|| 92); @@ -135,11 +134,9 @@ impl T> LazyCell { /// assert_eq!(*p, 92); /// *p = 44; /// assert_eq!(*lazy, 44); - /// *lazy = 55; // Using `DerefMut` - /// assert_eq!(*lazy, 55); /// ``` #[inline] - #[stable(feature = "lazy_deref_mut", since = "CURRENT_RUSTC_VERSION")] + #[unstable(feature = "lazy_get", issue = "129333")] pub fn force_mut(this: &mut LazyCell) -> &mut T { #[cold] /// # Safety @@ -286,14 +283,6 @@ impl T> Deref for LazyCell { } } -#[stable(feature = "lazy_deref_mut", since = "CURRENT_RUSTC_VERSION")] -impl T> DerefMut for LazyCell { - #[inline] - fn deref_mut(&mut self) -> &mut T { - LazyCell::force_mut(self) - } -} - #[stable(feature = "lazy_cell", since = "1.80.0")] impl Default for LazyCell { /// Creates a new lazy value using `Default` as the initializing function. diff --git a/core/src/lib.rs b/core/src/lib.rs index e3640627c562a..86b69c18483b3 100644 --- a/core/src/lib.rs +++ b/core/src/lib.rs @@ -172,6 +172,7 @@ #![feature(is_ascii_octdigit)] #![feature(is_val_statically_known)] #![feature(isqrt)] +#![feature(lazy_get)] #![feature(link_cfg)] #![feature(offset_of_enum)] #![feature(panic_internals)] diff --git a/core/tests/lib.rs b/core/tests/lib.rs index 8872b4cbfd5ba..d824f6d203b2b 100644 --- a/core/tests/lib.rs +++ b/core/tests/lib.rs @@ -77,6 +77,7 @@ #![feature(iterator_try_collect)] #![feature(iterator_try_reduce)] #![feature(layout_for_ptr)] +#![feature(lazy_get)] #![feature(maybe_uninit_fill)] #![feature(maybe_uninit_uninit_array_transpose)] #![feature(maybe_uninit_write_slice)] diff --git a/std/src/lib.rs b/std/src/lib.rs index 2530a37638757..57be36fcfcbea 100644 --- a/std/src/lib.rs +++ b/std/src/lib.rs @@ -336,6 +336,7 @@ #![feature(hasher_prefixfree_extras)] #![feature(hashmap_internals)] #![feature(ip)] +#![feature(lazy_get)] #![feature(maybe_uninit_slice)] #![feature(maybe_uninit_write_slice)] #![feature(panic_can_unwind)] diff --git a/std/src/sync/lazy_lock.rs b/std/src/sync/lazy_lock.rs index afdfec43afd36..f6b6887cdbbd7 100644 --- a/std/src/sync/lazy_lock.rs +++ b/std/src/sync/lazy_lock.rs @@ -1,7 +1,7 @@ use super::once::ExclusiveState; use crate::cell::UnsafeCell; use crate::mem::ManuallyDrop; -use crate::ops::{Deref, DerefMut}; +use crate::ops::Deref; use crate::panic::{RefUnwindSafe, UnwindSafe}; use crate::sync::Once; use crate::{fmt, ptr}; @@ -137,11 +137,10 @@ impl T> LazyLock { /// Forces the evaluation of this lazy value and returns a mutable reference to /// the result. /// - /// This is equivalent to the `DerefMut` impl, but is explicit. - /// /// # Examples /// /// ``` + /// #![feature(lazy_get)] /// use std::sync::LazyLock; /// /// let mut lazy = LazyLock::new(|| 92); @@ -150,11 +149,9 @@ impl T> LazyLock { /// assert_eq!(*p, 92); /// *p = 44; /// assert_eq!(*lazy, 44); - /// *lazy = 55; // Using `DerefMut` - /// assert_eq!(*lazy, 55); /// ``` #[inline] - #[stable(feature = "lazy_deref_mut", since = "CURRENT_RUSTC_VERSION")] + #[unstable(feature = "lazy_get", issue = "129333")] pub fn force_mut(this: &mut LazyLock) -> &mut T { #[cold] /// # Safety @@ -317,14 +314,6 @@ impl T> Deref for LazyLock { } } -#[stable(feature = "lazy_deref_mut", since = "CURRENT_RUSTC_VERSION")] -impl T> DerefMut for LazyLock { - #[inline] - fn deref_mut(&mut self) -> &mut T { - LazyLock::force_mut(self) - } -} - #[stable(feature = "lazy_cell", since = "1.80.0")] impl Default for LazyLock { /// Creates a new lazy value using `Default` as the initializing function.