Formatter

Struct Formatter 

Source
pub struct Formatter<'a> { /* private fields */ }
Expand description

Tool for formatting, used within DebugPls implementations

Implementations§

Source§

impl<'a> Formatter<'a>

Source

pub fn write_expr(self, expr: impl Into<Expr>)

Writes a wrap expression into the formatter. This is typically reserved for more advanced uses

Source

pub fn debug_struct(self, name: &str) -> DebugStruct<'a>

Creates a DebugStruct builder designed to assist with creation of DebugPls implementations for structs.

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};

struct Foo {
    bar: i32,
    baz: String,
}

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter) {
        f.debug_struct("Foo")
            .field("bar", &self.bar)
            .field("baz", &self.baz)
            .finish()
    }
}
let value = Foo {
    bar: 10,
    baz: "Hello World".to_string(),
};
assert_eq!(
    format!("{}", pretty(&value)),
    "Foo { bar: 10, baz: \"Hello World\" }",
);
Source

pub fn debug_tuple(self) -> DebugTuple<'a>

Creates a DebugTuple builder designed to assist with creation of DebugPls implementations for tuples.

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};

struct Foo(i32, String);

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter) {
        f.debug_tuple()
            .field(&self.0)
            .field(&self.1)
            .finish()
    }
}

let value = Foo(10, "Hello".to_string());
assert_eq!(format!("{}", pretty(&value)), "(10, \"Hello\")");
Source

pub fn debug_tuple_struct(self, name: &str) -> DebugTupleStruct<'a>

Creates a DebugTupleStruct builder designed to assist with creation of DebugPls implementations for tuple structs.

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};

struct Foo(i32, String);

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter) {
        f.debug_tuple_struct("Foo")
            .field(&self.0)
            .field(&self.1)
            .finish()
    }
}

let value = Foo(10, "Hello".to_string());
assert_eq!(format!("{}", pretty(&value)), "Foo(10, \"Hello\")");
Source

pub fn debug_list(self) -> DebugList<'a>

Creates a DebugList builder designed to assist with creation of DebugPls implementations for list-like structures.

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};

struct Foo(Vec<i32>);

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter<'_>) {
        f.debug_list().entries(&self.0).finish()
    }
}

let value = Foo(vec![10, 11]);
assert_eq!(format!("{}", pretty(&value)), "[10, 11]");
Source

pub fn debug_map(self) -> DebugMap<'a>

Creates a DebugMap builder designed to assist with creation of DebugPls implementations for maps.

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};
use std::collections::BTreeMap;

struct Foo(BTreeMap<String, i32>);

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter) {
        f.debug_map().entries(&self.0).finish()
    }
}
let mut value = Foo(BTreeMap::from([
    ("Hello".to_string(), 5),
    ("World".to_string(), 10),
]));
assert_eq!(
    format!("{}", pretty(&value)),
"{
    \"Hello\" = 5;
    \"World\" = 10;
}",
);
Source

pub fn debug_set(self) -> DebugSet<'a>

Creates a DebugSet builder designed to assist with creation of DebugPls implementations for sets.

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};
use std::collections::BTreeSet;

struct Foo(BTreeSet<String>);

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter) {
        f.debug_set().entries(&self.0).finish()
    }
}
let mut value = Foo(BTreeSet::from([
    "Hello".to_string(),
    "World".to_string(),
]));
assert_eq!(
    format!("{}", pretty(&value)),
"{
    \"Hello\";
    \"World\"
}",
);
Source

pub fn debug_ident(self, name: &str)

Writes an identifier into the formatter. Useful for unit structs/variants

§Panics

This will panic if the name is not a valid identifier

§Examples
use dbg_pls::{pretty, DebugPls, Formatter};

struct Foo;

impl DebugPls for Foo {
    fn fmt(&self, f: Formatter<'_>) {
        f.debug_ident("Foo");
    }
}

assert_eq!(format!("{}", pretty(&Foo)), "Foo");

Auto Trait Implementations§

§

impl<'a> Freeze for Formatter<'a>

§

impl<'a> RefUnwindSafe for Formatter<'a>

§

impl<'a> !Send for Formatter<'a>

§

impl<'a> !Sync for Formatter<'a>

§

impl<'a> Unpin for Formatter<'a>

§

impl<'a> !UnwindSafe for Formatter<'a>

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.