chore: checkpoint before Python removal

This commit is contained in:
2026-03-26 22:33:59 +00:00
parent 683cec9307
commit e568ddf82a
29972 changed files with 11269302 additions and 2 deletions

33
vendor/darling/tests/meta_with.rs vendored Normal file
View File

@@ -0,0 +1,33 @@
use darling::{util::parse_expr, FromDeriveInput, FromMeta};
use syn::{parse_quote, Expr};
#[derive(FromDeriveInput)]
#[darling(attributes(demo))]
pub struct Receiver {
#[darling(with = parse_expr::preserve_str_literal, map = Some)]
example1: Option<Expr>,
#[darling(
with = |m| Ok(String::from_meta(m)?.to_uppercase()),
map = Some
)]
example2: Option<String>,
// This is deliberately strange - it keeps the field name, and ignores
// the rest of the attribute. In normal operation, this is strongly discouraged.
// It's used here to verify that the parameter type is known even if it can't be
// inferred from usage within the closure.
#[darling(with = |m| Ok(m.path().clone()))]
example3: syn::Path,
}
#[test]
fn handles_all_cases() {
let input = Receiver::from_derive_input(&parse_quote! {
#[demo(example1 = test::path, example2 = "hello", example3)]
struct Example;
})
.unwrap();
assert_eq!(input.example1, Some(parse_quote!(test::path)));
assert_eq!(input.example2, Some("HELLO".to_string()));
assert_eq!(input.example3, parse_quote!(example3));
}