3 releases

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

#188 in Value formatting

Download history 348/week @ 2024-07-27 311/week @ 2024-08-03 332/week @ 2024-08-10 232/week @ 2024-08-17 371/week @ 2024-08-24 231/week @ 2024-08-31 397/week @ 2024-09-07 245/week @ 2024-09-14 360/week @ 2024-09-21 383/week @ 2024-09-28 377/week @ 2024-10-05 764/week @ 2024-10-12 328/week @ 2024-10-19 257/week @ 2024-10-26 439/week @ 2024-11-02 363/week @ 2024-11-09

1,478 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

~240–690KB
~16K SLoC