3 releases

0.0.3 Nov 5, 2023
0.0.2 Jul 25, 2023
0.0.1 Jul 23, 2023

#192 in Value formatting

Download history 323/week @ 2024-06-03 253/week @ 2024-06-10 531/week @ 2024-06-17 347/week @ 2024-06-24 274/week @ 2024-07-01 173/week @ 2024-07-08 283/week @ 2024-07-15 171/week @ 2024-07-22 373/week @ 2024-07-29 292/week @ 2024-08-05 340/week @ 2024-08-12 238/week @ 2024-08-19 374/week @ 2024-08-26 227/week @ 2024-09-02 403/week @ 2024-09-09 224/week @ 2024-09-16

1,241 downloads per month
Used in inlyne

MIT/Apache

11KB
73 lines

⚠️ !!This is currently pre-alpha software!! ⚠️

Allows for easy manipulation of debug formatting through a derive macro

use smart_debug::SmartDebug;
use std::fmt;

#[derive(SmartDebug, Default)]
#[debug(skip_defaults)]
struct Text {
    #[debug(no_skip)]
    text: &'static str,
    #[debug("0x{:06x}")]
    color: u32,
    #[debug(wrapper = DebugInline)]
    hyperlink: Option<&'static str>,
    is_bold: bool,
    is_italics: bool,
}

// Wrapper that displays inline even when using pretty formatting (`{:#?}`)
struct DebugInline<'inner, T>(pub &'inner T);

impl<T: fmt::Debug> fmt::Debug for DebugInline<'_, T> {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        f.write_fmt(format_args!("{:?}", self.0))
    }
}

const HYPERLINK: &str = r#"
Text {
    text: "Look! A link",
    color: 0x005cc5,
    hyperlink: Some("https://example.org"),
    is_italics: true,
    ..
}
"#;

fn main() {
    let hyperlink = Text {
        text: "Look! A link",
        hyperlink: Some("https://example.org"),
        color: 0x00_5c_c5,
        is_italics: true,
        ..Text::default()
    };

    let formatted = format!("\n{hyperlink:#?}\n");
    assert_eq!(formatted, HYPERLINK);
}

Dependencies

~215–640KB
~15K SLoC