diff options
| author | P1start <rewi-github@whanau.org> | 2015-01-21 11:04:17 +1300 |
|---|---|---|
| committer | P1start <rewi-github@whanau.org> | 2015-01-22 22:22:04 +1300 |
| commit | be138ed2bd6a4c4bf1c80287569709a9905e4891 (patch) | |
| tree | 39fcb029ac97f152872750b83ffd1b729b07a66f /src/libcore | |
| parent | 5d2056a7e3e52b2aec41662cfd960e0eafe8494c (diff) | |
| download | rust-be138ed2bd6a4c4bf1c80287569709a9905e4891.tar.gz rust-be138ed2bd6a4c4bf1c80287569709a9905e4891.zip | |
Add `#[rustc_on_unimplemented]` annotations to more traits
Diffstat (limited to 'src/libcore')
| -rw-r--r-- | src/libcore/fmt/mod.rs | 4 | ||||
| -rw-r--r-- | src/libcore/iter.rs | 2 | ||||
| -rw-r--r-- | src/libcore/marker.rs | 3 |
3 files changed, 9 insertions, 0 deletions
diff --git a/src/libcore/fmt/mod.rs b/src/libcore/fmt/mod.rs index 0e8d31a62ee..60403d1c011 100644 --- a/src/libcore/fmt/mod.rs +++ b/src/libcore/fmt/mod.rs @@ -243,6 +243,8 @@ pub trait Show { /// Format trait for the `:?` format. Useful for debugging, most all types /// should implement this. #[unstable = "I/O and core have yet to be reconciled"] +#[rustc_on_unimplemented = "`{Self}` cannot be formatted using `:?`; if it is defined in your \ + crate, add `#[derive(Debug)]` or manually implement it"] pub trait Debug { /// Formats the value using the given formatter. fn fmt(&self, &mut Formatter) -> Result; @@ -266,6 +268,8 @@ pub trait String { /// When a value can be semantically expressed as a String, this trait may be /// used. It corresponds to the default format, `{}`. #[unstable = "I/O and core have yet to be reconciled"] +#[rustc_on_unimplemented = "`{Self}` cannot be formatted with the default formatter; try using \ + `:?` instead if you are using a format string"] pub trait Display { /// Formats the value using the given formatter. fn fmt(&self, &mut Formatter) -> Result; diff --git a/src/libcore/iter.rs b/src/libcore/iter.rs index 773ac99b0de..c31ad56fe5b 100644 --- a/src/libcore/iter.rs +++ b/src/libcore/iter.rs @@ -82,6 +82,8 @@ use uint; /// else. #[lang="iterator"] #[stable] +#[rustc_on_unimplemented = "`{Self}` is not an iterator; maybe try calling `.iter()` or a similar \ + method"] pub trait Iterator { #[stable] type Item; diff --git a/src/libcore/marker.rs b/src/libcore/marker.rs index a987a0a5068..f32552f300c 100644 --- a/src/libcore/marker.rs +++ b/src/libcore/marker.rs @@ -30,6 +30,7 @@ use clone::Clone; /// Types able to be transferred across task boundaries. #[unstable = "will be overhauled with new lifetime rules; see RFC 458"] #[lang="send"] +#[rustc_on_unimplemented = "`{Self}` cannot be sent between threads safely"] pub unsafe trait Send: 'static { // empty. } @@ -37,6 +38,7 @@ pub unsafe trait Send: 'static { /// Types with a constant size known at compile-time. #[stable] #[lang="sized"] +#[rustc_on_unimplemented = "`{Self}` does not have a constant size known at compile-time"] pub trait Sized { // Empty. } @@ -193,6 +195,7 @@ pub trait Copy { /// `transmute`-ing from `&T` to `&mut T` is illegal). #[unstable = "will be overhauled with new lifetime rules; see RFC 458"] #[lang="sync"] +#[rustc_on_unimplemented = "`{Self}` cannot be shared between threads safely"] pub unsafe trait Sync { // Empty } |
