Struct DebugStruct

Source
pub struct DebugStruct<'f, 'w> { /* private fields */ }
Expand description

A helper struct for debug formatting a braced struct, or braced variant.

§Example

This example demonstrates how you can debug format a struct, and a braced variant.


use const_format::{Error, Formatter};
use const_format::{call_debug_fmt, coerce_to_fmt, formatc, impl_fmt, try_};

fn main() {
    const STRUC: &str = formatc!("{:?}", Foo { a: 5, b: [8, 13, 21], c: "34" });
    const ENUM_: &str = formatc!("{:?}", Bar::Baz { d: false, e: None });
     
    assert_eq!(STRUC, "Foo { a: 5, b: [8, 13, 21], c: \"34\" }");
    assert_eq!(ENUM_, "Baz { d: false, e: None }");
}

struct Foo{
    a: u32,
    b: [u32; 3],
    c: &'static str,
}

enum Bar {
    Baz{
        d: bool,
        e: Option<bool>,
    }
}

impl_fmt!{
    impl Foo;
     
    const fn const_debug_fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error> {
        let mut f = f.debug_struct("Foo");
        try_!(coerce_to_fmt!(&self.a).const_debug_fmt(f.field("a")));
        try_!(coerce_to_fmt!(&self.b).const_debug_fmt(f.field("b")));
        try_!(coerce_to_fmt!(&self.c).const_debug_fmt(f.field("c")));
        f.finish()
    }
}

impl_fmt!{
    impl Bar;
     
    const fn const_debug_fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error> {
        match self {
            Bar::Baz{d, e} => {
                let mut f = f.debug_struct("Baz");
                 
                // This macro allows debug formatting some generic types that
                // don't have a const_debug_fmt fn, like Options which wrap non-std types.
                call_debug_fmt!(std, d, f.field("d"));
                call_debug_fmt!(Option, e, f.field("e"));
                 
                f.finish()
            }
        }
    }
}


Implementations§

Source§

impl<'f, 'w> DebugStruct<'f, 'w>

Source

pub const fn field(&mut self, name: &str) -> &mut Formatter<'w>

Adds a field to the formatted output.

Source

pub const fn finish(self) -> Result<(), Error>

Finishes writing the struct/variant, and if anything went wrong in the field method,returns an error.

Auto Trait Implementations§

§

impl<'f, 'w> Freeze for DebugStruct<'f, 'w>

§

impl<'f, 'w> RefUnwindSafe for DebugStruct<'f, 'w>

§

impl<'f, 'w> Send for DebugStruct<'f, 'w>

§

impl<'f, 'w> Sync for DebugStruct<'f, 'w>

§

impl<'f, 'w> Unpin for DebugStruct<'f, 'w>

§

impl<'f, 'w> !UnwindSafe for DebugStruct<'f, 'w>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 16 bytes