Struct frame_support::dispatch::fmt::DebugStruct 1.2.0[−][src]
#[must_use = "must eventually call `finish()` on Debug builders"]pub struct DebugStruct<'a, 'b> where
'b: 'a, { /* fields omitted */ }
A struct to help with fmt::Debug
implementations.
This is useful when you wish to output a formatted struct as a part of your
Debug::fmt
implementation.
This can be constructed by the Formatter::debug_struct
method.
Examples
use std::fmt; struct Foo { bar: i32, baz: String, } impl fmt::Debug for Foo { fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result { fmt.debug_struct("Foo") .field("bar", &self.bar) .field("baz", &self.baz) .finish() } } assert_eq!( format!("{:?}", Foo { bar: 10, baz: "Hello World".to_string() }), "Foo { bar: 10, baz: \"Hello World\" }", );
Implementations
impl<'a, 'b> DebugStruct<'a, 'b> where
'b: 'a,
[src]
impl<'a, 'b> DebugStruct<'a, 'b> where
'b: 'a,
[src]pub fn field(
&mut self,
name: &str,
value: &dyn Debug
) -> &mut DebugStruct<'a, 'b>
[src]
&mut self,
name: &str,
value: &dyn Debug
) -> &mut DebugStruct<'a, 'b>
Adds a new field to the generated struct output.
Examples
use std::fmt; struct Bar { bar: i32, another: String, } impl fmt::Debug for Bar { fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result { fmt.debug_struct("Bar") .field("bar", &self.bar) // We add `bar` field. .field("another", &self.another) // We add `another` field. // We even add a field which doesn't exist (because why not?). .field("not_existing_field", &1) .finish() // We're good to go! } } assert_eq!( format!("{:?}", Bar { bar: 10, another: "Hello World".to_string() }), "Bar { bar: 10, another: \"Hello World\", not_existing_field: 1 }", );
pub fn finish_non_exhaustive(&mut self) -> Result<(), Error>
1.53.0[src]
Marks the struct as non-exhaustive, indicating to the reader that there are some other fields that are not shown in the debug representation.
Examples
use std::fmt; struct Bar { bar: i32, hidden: f32, } impl fmt::Debug for Bar { fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result { fmt.debug_struct("Bar") .field("bar", &self.bar) .finish_non_exhaustive() // Show that some other field(s) exist. } } assert_eq!( format!("{:?}", Bar { bar: 10, hidden: 1.0 }), "Bar { bar: 10, .. }", );
pub fn finish(&mut self) -> Result<(), Error>
[src]
Finishes output and returns any error encountered.
Examples
use std::fmt; struct Bar { bar: i32, baz: String, } impl fmt::Debug for Bar { fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result { fmt.debug_struct("Bar") .field("bar", &self.bar) .field("baz", &self.baz) .finish() // You need to call it to "finish" the // struct formatting. } } assert_eq!( format!("{:?}", Bar { bar: 10, baz: "Hello World".to_string() }), "Bar { bar: 10, baz: \"Hello World\" }", );
Trait Implementations
impl<'a, 'b> Visit for DebugStruct<'a, 'b>
[src]
impl<'a, 'b> Visit for DebugStruct<'a, 'b>
[src]pub fn record_debug(&mut self, field: &Field, value: &dyn Debug)
[src]
pub fn record_i64(&mut self, field: &Field, value: i64)
[src]
pub fn record_u64(&mut self, field: &Field, value: u64)
[src]
pub fn record_bool(&mut self, field: &Field, value: bool)
[src]
pub fn record_str(&mut self, field: &Field, value: &str)
[src]
pub fn record_error(&mut self, field: &Field, value: &(dyn Error + 'static))
[src]
Auto Trait Implementations
impl<'a, 'b> !RefUnwindSafe for DebugStruct<'a, 'b>
impl<'a, 'b> !Send for DebugStruct<'a, 'b>
impl<'a, 'b> !Sync for DebugStruct<'a, 'b>
impl<'a, 'b> Unpin for DebugStruct<'a, 'b> where
'b: 'a,
'b: 'a,
impl<'a, 'b> !UnwindSafe for DebugStruct<'a, 'b>
Blanket Implementations
impl<T> CheckedConversion for T
[src]
impl<T> CheckedConversion for T
[src]pub fn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
[src]
Self: TryFrom<T>,
pub fn checked_into<T>(self) -> Option<T> where
Self: TryInto<T>,
[src]
Self: TryInto<T>,
impl<T> Instrument for T
[src]
impl<T> Instrument for T
[src]pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]impl<T> SaturatedConversion for T
[src]
impl<T> SaturatedConversion for T
[src]pub fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
[src]
Self: UniqueSaturatedFrom<T>,
pub fn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
[src]
Self: UniqueSaturatedInto<T>,
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]pub fn unchecked_into(self) -> T
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]