#documentation #reflection #macro-derive #run-time #proc-macro #attributes #accessing

documented

Derive and attribute macros for accessing your type's documentation at runtime

14 releases (8 breaking)

0.9.1 Nov 4, 2024
0.7.1 Oct 16, 2024
0.5.0 Jun 1, 2024
0.3.0 Jan 25, 2024
0.1.2 Jun 7, 2023

#198 in Rust patterns

Download history 3153/week @ 2024-09-26 6292/week @ 2024-10-03 9460/week @ 2024-10-10 10684/week @ 2024-10-17 8810/week @ 2024-10-24 8502/week @ 2024-10-31 6223/week @ 2024-11-07 7507/week @ 2024-11-14 8342/week @ 2024-11-21 7151/week @ 2024-11-28 9402/week @ 2024-12-05 8241/week @ 2024-12-12 5272/week @ 2024-12-19 2284/week @ 2024-12-26 4148/week @ 2025-01-02 3716/week @ 2025-01-09

17,285 downloads per month
Used in 5 crates (4 directly)

MIT license

15KB
130 lines

documented

Derive and attribute macros for accessing your type's documentation at runtime

Quick start

use documented::{Documented, DocumentedFields, DocumentedVariants};

/// Trying is the first step to failure.
#[derive(Documented, DocumentedFields, DocumentedVariants)]
enum AlwaysPlay {
    /// And Kb8.
    #[allow(dead_code)]
    Kb1,
    /// But only if you are white.
    F6,
}

// Documented
assert_eq!(AlwaysPlay::DOCS, "Trying is the first step to failure.");

// DocumentedFields
assert_eq!(
    AlwaysPlay::FIELD_DOCS,
    ["And Kb8.", "But only if you are white."]
);
assert_eq!(AlwaysPlay::get_field_docs("Kb1"), Ok("And Kb8."));

// DocumentedVariants
assert_eq!(
    AlwaysPlay::F6.get_variant_docs(),
    "But only if you are white."
);

Dependencies

~1–1.6MB
~31K SLoC