44440e5c18
fmt::Show is for debugging, and can and should be implemented for all public types. This trait is used with `{:?}` syntax. There still exists #[derive(Show)]. fmt::String is for types that faithfully be represented as a String. Because of this, there is no way to derive fmt::String, all implementations must be purposeful. It is used by the default format syntax, `{}`. This will break most instances of `{}`, since that now requires the type to impl fmt::String. In most cases, replacing `{}` with `{:?}` is the correct fix. Types that were being printed specifically for users should receive a fmt::String implementation to fix this. Part of #20013 [breaking-change]
63 lines
1.7 KiB
Rust
63 lines
1.7 KiB
Rust
// Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
use std::fmt;
|
|
|
|
#[derive(Show)]
|
|
enum A {}
|
|
#[derive(Show)]
|
|
enum B { B1, B2, B3 }
|
|
#[derive(Show)]
|
|
enum C { C1(int), C2(B), C3(String) }
|
|
#[derive(Show)]
|
|
enum D { D1{ a: int } }
|
|
#[derive(Show)]
|
|
struct E;
|
|
#[derive(Show)]
|
|
struct F(int);
|
|
#[derive(Show)]
|
|
struct G(int, int);
|
|
#[derive(Show)]
|
|
struct H { a: int }
|
|
#[derive(Show)]
|
|
struct I { a: int, b: int }
|
|
#[derive(Show)]
|
|
struct J(Custom);
|
|
|
|
struct Custom;
|
|
impl fmt::Show for Custom {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
write!(f, "yay")
|
|
}
|
|
}
|
|
|
|
trait ToShow {
|
|
fn to_show(&self) -> String;
|
|
}
|
|
|
|
impl<T: fmt::Show> ToShow for T {
|
|
fn to_show(&self) -> String {
|
|
format!("{:?}", self)
|
|
}
|
|
}
|
|
|
|
pub fn main() {
|
|
assert_eq!(B::B1.to_show(), "B1".to_string());
|
|
assert_eq!(B::B2.to_show(), "B2".to_string());
|
|
assert_eq!(C::C1(3).to_show(), "C1(3i)".to_string());
|
|
assert_eq!(C::C2(B::B2).to_show(), "C2(B2)".to_string());
|
|
assert_eq!(D::D1{ a: 2 }.to_show(), "D1 { a: 2i }".to_string());
|
|
assert_eq!(E.to_show(), "E".to_string());
|
|
assert_eq!(F(3).to_show(), "F(3i)".to_string());
|
|
assert_eq!(G(3, 4).to_show(), "G(3i, 4i)".to_string());
|
|
assert_eq!(I{ a: 2, b: 4 }.to_show(), "I { a: 2i, b: 4i }".to_string());
|
|
assert_eq!(J(Custom).to_show(), "J(yay)".to_string());
|
|
}
|