#proc-macro #display #from-str #enums #macro-derive #regex #derive

no-std parse-display

Procedural macro to implement Display and FromStr using common settings

20 releases

0.9.0 Feb 4, 2024
0.8.2 Jul 16, 2023
0.8.1 Jun 10, 2023
0.8.0 Dec 21, 2022
0.1.0 Jun 15, 2019

#69 in Rust patterns

Download history 21640/week @ 2023-11-25 19713/week @ 2023-12-02 19519/week @ 2023-12-09 17765/week @ 2023-12-16 13461/week @ 2023-12-23 16406/week @ 2023-12-30 20502/week @ 2024-01-06 20782/week @ 2024-01-13 20801/week @ 2024-01-20 22581/week @ 2024-01-27 22265/week @ 2024-02-03 17344/week @ 2024-02-10 22285/week @ 2024-02-17 23908/week @ 2024-02-24 24084/week @ 2024-03-02 8148/week @ 2024-03-09

81,390 downloads per month
Used in 127 crates (62 directly)

MIT/Apache

41KB
437 lines

parse-display

Crates.io Docs.rs Actions Status

This crate provides derive macro Display and FromStr. These macros use common helper attributes to specify the format.

Install

Add this to your Cargo.toml:

[dependencies]
parse-display = "0.9.0"

Documentation

See #[derive(Display)] documentation for details.

Example

use parse_display::{Display, FromStr};

#[derive(Display, FromStr, PartialEq, Debug)]
#[display("{a}-{b}")]
struct X {
  a: u32,
  b: u32,
}
assert_eq!(X { a:10, b:20 }.to_string(), "10-20");
assert_eq!("10-20".parse(), Ok(X { a:10, b:20 }));


#[derive(Display, FromStr, PartialEq, Debug)]
#[display(style = "snake_case")]
enum Y {
  VarA,
  VarB,
}
assert_eq!(Y::VarA.to_string(), "var_a");
assert_eq!("var_a".parse(), Ok(Y::VarA));

License

This project is dual licensed under Apache-2.0/MIT. See the two LICENSE-* files for details.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~5MB
~95K SLoC