about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorMichael Bradshaw <mjbshaw@google.com>2020-02-07 21:53:22 -0800
committerMichael Bradshaw <mjbshaw@google.com>2020-02-07 21:53:22 -0800
commit348278a7fd5fd459f555dd763e71e12c23c1661a (patch)
tree0911656aa1da86bce9846c14ac180fca6e691d3f /src/libstd
parent8498c5f5b02dbb4ed58a1eb4901b0b733342c35f (diff)
downloadrust-348278a7fd5fd459f555dd763e71e12c23c1661a.tar.gz
rust-348278a7fd5fd459f555dd763e71e12c23c1661a.zip
Stabilize Once::is_completed
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/sync/once.rs11
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