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 332/week @ 2024-07-26 373/week @ 2024-08-02 321/week @ 2024-08-09 174/week @ 2024-08-16 405/week @ 2024-08-23 215/week @ 2024-08-30 418/week @ 2024-09-06 274/week @ 2024-09-13 335/week @ 2024-09-20 342/week @ 2024-09-27 414/week @ 2024-10-04 722/week @ 2024-10-11 398/week @ 2024-10-18 200/week @ 2024-10-25 468/week @ 2024-11-01 358/week @ 2024-11-08

1,555 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–680KB
~16K SLoC