From d6c3196d02c88887491433b31d92221d0ef0fa43 Mon Sep 17 00:00:00 2001 From: Stjepan Glavina Date: Mon, 3 Jun 2019 18:20:38 +0200 Subject: [PATCH 1/2] Add a few trait impls for AccessError --- src/libstd/thread/local.rs | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/libstd/thread/local.rs b/src/libstd/thread/local.rs index 9b355aa2023ff..d64483c5ac12a 100644 --- a/src/libstd/thread/local.rs +++ b/src/libstd/thread/local.rs @@ -2,6 +2,7 @@ #![unstable(feature = "thread_local_internals", issue = "0")] +use crate::error::Error; use crate::fmt; /// A thread local storage key which owns its contents. @@ -189,6 +190,7 @@ macro_rules! __thread_local_inner { /// An error returned by [`LocalKey::try_with`](struct.LocalKey.html#method.try_with). #[stable(feature = "thread_local_try_with", since = "1.26.0")] +#[derive(Clone, Copy, Eq, PartialEq)] pub struct AccessError { _private: (), } @@ -207,6 +209,8 @@ impl fmt::Display for AccessError { } } +impl Error for AccessError {} + impl LocalKey { #[doc(hidden)] #[unstable(feature = "thread_local_internals", From d2c9c125460ae019c04594dbbe5f204db6add70d Mon Sep 17 00:00:00 2001 From: Stjepan Glavina Date: Sun, 4 Aug 2019 15:11:08 +0200 Subject: [PATCH 2/2] Add #[stable] to Error impl --- src/libstd/thread/local.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/src/libstd/thread/local.rs b/src/libstd/thread/local.rs index d64483c5ac12a..f85b5d632f16b 100644 --- a/src/libstd/thread/local.rs +++ b/src/libstd/thread/local.rs @@ -209,6 +209,7 @@ impl fmt::Display for AccessError { } } +#[stable(feature = "thread_local_try_with", since = "1.26.0")] impl Error for AccessError {} impl LocalKey {