diff options
| author | Dylan DPC <dylan.dpc@gmail.com> | 2020-02-20 10:49:10 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-02-20 10:49:10 +0100 |
| commit | 588f00841b430b12b39fb75d778bd670df8c59f5 (patch) | |
| tree | 58a8aab3f98c17c9a63efdc9667e72bba6157bf8 /src/libstd | |
| parent | f7ce5ff19c801a08c7b5aa2ff6f7f552e9de4a39 (diff) | |
| parent | 348278a7fd5fd459f555dd763e71e12c23c1661a (diff) | |
| download | rust-588f00841b430b12b39fb75d778bd670df8c59f5.tar.gz rust-588f00841b430b12b39fb75d778bd670df8c59f5.zip | |
Rollup merge of #68945 - mjbshaw:once_is_completed, r=LukasKalbertodt
Stabilize Once::is_completed Closes #54890 This function has been around for some time. I haven't seen anyone raise any objections to it. I've personally found it useful myself. It would be nice to finally stabilize it and
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/sync/once.rs | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/src/libstd/sync/once.rs b/src/libstd/sync/once.rs index 61c4d0c2dbf..b99b4d8d9fd 100644 --- a/src/libstd/sync/once.rs +++ b/src/libstd/sync/once.rs @@ -331,14 +331,14 @@ impl Once { /// * `call_once` was called, but has not yet completed, /// * the `Once` instance is poisoned /// - /// It is also possible that immediately after `is_completed` - /// returns false, some other thread finishes executing - /// `call_once`. + /// This function returning `false` does not mean that `Once` has not been + /// executed. For example, it may have been executed in the time between + /// when `is_completed` starts executing and when it returns, in which case + /// the `false` return value would be stale (but still permissible). /// /// # Examples /// /// ``` - /// #![feature(once_is_completed)] /// use std::sync::Once; /// /// static INIT: Once = Once::new(); @@ -351,7 +351,6 @@ impl Once { /// ``` /// /// ``` - /// #![feature(once_is_completed)] /// use std::sync::Once; /// use std::thread; /// @@ -364,7 +363,7 @@ impl Once { /// assert!(handle.join().is_err()); /// assert_eq!(INIT.is_completed(), false); /// ``` - #[unstable(feature = "once_is_completed", issue = "54890")] + #[stable(feature = "once_is_completed", since = "1.44.0")] #[inline] pub fn is_completed(&self) -> bool { // An `Acquire` load is enough because that makes all the initialization |
