1个不稳定版本
0.0.1 | 2022年8月15日 |
---|
#25 in #attr
用于 kefta
50KB
1K SLoC
Kefta
使用进程宏简化属性解析
主要特性
- 用于轻松解析结构的 derive 宏
- 内置的“合理的”错误信息
- 内置属性解析
- 可选的
syn
支持
功能切换
literal
- 文本解析util
- 预制类型和实用特性syn
- 通过Syn<impl syn::Parse>
提供syn支持
示例
use kefta::{Attr, parse_attr};
// derive `Attr` onto your struct
#[derive(Attr)]
struct MyAttrs {
// a marker field,
alive: bool,
// an optional field
#[attr(optional)]
name: Option<String>,
// a required field
#[attr(required)]
value: i32,
// a default field (defaults to 0)
count: u32,
// a renamed field
#[attr(optional, name="desc")]
description: Option<String>,
// a field with an alias
#[attr(alias="color")]
colour: Option<String>,
// a field with multiple values
#[attr(multiple)]
jobs: Vec<String>,
// an optional, aliased field, with multiple values
#[attr(multiple, optional, alias="chores")]
tasks: Option<Vec<String>>,
/* you get the point */
}
// parse in your derive-macro
// * this uses the syn crate and `syn` feature
#[proc_macro_derive(Human, attributes(human))]
pub fn test_macro(item: TokenStream) -> TokenStream {
// parse with `syn`
let input = syn::parse_macro_input!(item as DeriveInput);
// parse the attributes with the `parse_attr!` macro
// it contains a `return TokenStream`, so you don't have to handle errors.
let attrs = parse_attr!(input.attrs => MyAttrs);
// print out one of our fields
println!("Name: {:?}", attrs.name);
TokenStream::new()
}
您可以使用如下属性
#[derive(Human)]
#[human(name="Jimmy", value=10, alive)]
#[human(jobs="foo", jobs="bar", jobs="baz")]
pub struct Jimmy;
依赖项
~1.5MB
~34K SLoC