3 个版本
0.1.9 | 2022年5月12日 |
---|---|
0.1.8 | 2021年10月17日 |
0.1.7 | 2021年10月17日 |
#1491 in 进程宏
1,142 每月下载量
用于 15 个 库(4 个直接使用)
7KB
better-bae
此crate是
bae
的分支
better-bae
是一个针对进程宏作者的crate,它简化了属性的解析。它深受 darling
的启发,但API简单得多。
有关更多信息,请参阅文档。
lib.rs
:
此crate是bae
的分支。
better-bae
是一个针对进程宏作者的crate,它简化了属性的解析。它深受 darling
的启发,但API简单得多。
use better_bae::FromAttributes;
#[derive(
Debug,
Eq,
PartialEq,
// This will add two functions:
// ```
// fn from_attributes(attrs: &[syn::Attribute]) -> Result<MyAttr, syn::Error>
// fn try_from_attributes(attrs: &[syn::Attribute]) -> Result<Option<MyAttr>, syn::Error>
// ```
//
// `try_from_attributes` returns `Ok(None)` if the attribute is missing, `Ok(Some(_))` if
// its there and is valid, `Err(_)` otherwise.
FromAttributes,
)]
pub struct MyAttr {
// Anything that implements `syn::parse::Parse` is supported.
mandatory_type: syn::Type,
mandatory_ident: syn::Ident,
// Fields wrapped in `Option` are optional and default to `None` if
// not specified in the attribute.
optional_missing: Option<syn::Type>,
optional_given: Option<syn::Type>,
// A "switch" is something that doesn't take arguments.
// All fields with type `Option<()>` are considered swiches.
// They default to `None`.
switch: Option<()>,
}
// `MyAttr` is now equipped to parse attributes named `my_attr`. For example:
//
// #[my_attr(
// switch,
// mandatory_ident = foo,
// mandatory_type = SomeType,
// optional_given = OtherType,
// )]
// struct Foo {
// ...
// }
// the input and output type would normally be `proc_macro::TokenStream` but those
// types cannot be used outside the compiler itself.
fn my_proc_macro(input: proc_macro2::TokenStream) -> proc_macro2::TokenStream {
let item_struct = syn::parse2::<syn::ItemStruct>(input).unwrap();
let my_attr = MyAttr::from_attributes(&item_struct.attrs).unwrap();
assert_eq!(
my_attr.mandatory_type,
syn::parse_str::<syn::Type>("SomeType").unwrap()
);
assert_eq!(my_attr.optional_missing, None);
assert_eq!(
my_attr.optional_given,
Some(syn::parse_str::<syn::Type>("OtherType").unwrap())
);
assert_eq!(my_attr.mandatory_ident, syn::parse_str::<syn::Ident>("foo").unwrap());
assert_eq!(my_attr.switch.is_some(), true);
// ...
#
# quote::quote! {}
}
#
依赖关系
~1.5MB
~36K SLoC