Rollup merge of #136360 - slanterns:once_wait, r=tgross35
Stabilize `once_wait` Closes: https://github.com/rust-lang/rust/issues/127527. `@rustbot` label: +T-libs-api r? libs-api
This commit is contained in:
commit
cbcb695f9e
2 changed files with 3 additions and 7 deletions
|
@ -174,8 +174,6 @@ impl<T> OnceLock<T> {
|
|||
///
|
||||
/// Waiting for a computation on another thread to finish:
|
||||
/// ```rust
|
||||
/// #![feature(once_wait)]
|
||||
///
|
||||
/// use std::thread;
|
||||
/// use std::sync::OnceLock;
|
||||
///
|
||||
|
@ -189,7 +187,7 @@ impl<T> OnceLock<T> {
|
|||
/// })
|
||||
/// ```
|
||||
#[inline]
|
||||
#[unstable(feature = "once_wait", issue = "127527")]
|
||||
#[stable(feature = "once_wait", since = "CURRENT_RUSTC_VERSION")]
|
||||
pub fn wait(&self) -> &T {
|
||||
self.once.wait_force();
|
||||
|
||||
|
|
|
@ -269,8 +269,6 @@ impl Once {
|
|||
/// # Example
|
||||
///
|
||||
/// ```rust
|
||||
/// #![feature(once_wait)]
|
||||
///
|
||||
/// use std::sync::Once;
|
||||
/// use std::thread;
|
||||
///
|
||||
|
@ -289,7 +287,7 @@ impl Once {
|
|||
/// If this [`Once`] has been poisoned because an initialization closure has
|
||||
/// panicked, this method will also panic. Use [`wait_force`](Self::wait_force)
|
||||
/// if this behavior is not desired.
|
||||
#[unstable(feature = "once_wait", issue = "127527")]
|
||||
#[stable(feature = "once_wait", since = "CURRENT_RUSTC_VERSION")]
|
||||
pub fn wait(&self) {
|
||||
if !self.inner.is_completed() {
|
||||
self.inner.wait(false);
|
||||
|
@ -298,7 +296,7 @@ impl Once {
|
|||
|
||||
/// Blocks the current thread until initialization has completed, ignoring
|
||||
/// poisoning.
|
||||
#[unstable(feature = "once_wait", issue = "127527")]
|
||||
#[stable(feature = "once_wait", since = "CURRENT_RUSTC_VERSION")]
|
||||
pub fn wait_force(&self) {
|
||||
if !self.inner.is_completed() {
|
||||
self.inner.wait(true);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue