#[macro_use] extern crate derivative; #[derive(Derivative)] #[derivative(Debug)] struct Foo { foo: T, #[derivative(Debug="ignore")] bar: U, } #[derive(Derivative)] #[derivative(Debug)] struct Bar ( T, #[derivative(Debug="ignore")] U, ); #[derive(Derivative)] #[derivative(Debug)] enum C { C1(T), C2(#[derivative(Debug="ignore")] U), C3(String), } #[derive(Derivative)] #[derivative(Debug)] enum D { D1{ #[derivative(Debug="ignore")] a: U } } #[derive(Derivative)] #[derivative(Debug)] struct F(#[derivative(Debug="ignore")] U); #[derive(Derivative)] #[derivative(Debug)] struct G(isize, #[derivative(Debug="ignore")] U); #[derive(Derivative)] #[derivative(Debug)] struct J(#[derivative(Debug="ignore")] U); struct NoDebug; trait ToDebug { fn to_show(&self) -> String; } impl ToDebug for T { fn to_show(&self) -> String { format!("{:?}", self) } } #[test] fn main() { assert_eq!(Foo { foo: 42, bar: NoDebug }.to_show(), "Foo { foo: 42 }".to_string()); assert_eq!(Bar(42, NoDebug).to_show(), "Bar(42)".to_string()); assert_eq!(C::C1::(12).to_show(), "C1(12)".to_string()); assert_eq!(C::C2::(NoDebug).to_show(), "C2".to_string()); assert_eq!(C::C3::("foo".to_string()).to_show(), "C3(\"foo\")".to_string()); assert_eq!(D::D1 { a: NoDebug }.to_show(), "D1".to_string()); assert_eq!(F(NoDebug).to_show(), "F".to_string()); assert_eq!(G(42, NoDebug).to_show(), "G(42)".to_string()); assert_eq!(J(NoDebug).to_show(), "J".to_string()); }