Skip to content

Commit

Permalink
Merge pull request #6 from cecton/rename-prop-struct
Browse files Browse the repository at this point in the history
Allow customizing the struct properties name
  • Loading branch information
valyagolev authored Oct 30, 2023
2 parents 070689a + 172ba88 commit bb2772d
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 5 deletions.
30 changes: 26 additions & 4 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -58,14 +58,37 @@ pub fn autoprops_component(
let visibility = &function.vis;
let generics = &function.sig.generics;

let component_name = match args.len() {
0 => None,
let (component_name, struct_name) = match args.len() {
0 => (
None,
Some(syn::Ident::new(
&format!("{}Props", fn_name),
Span::call_site().into(),
)),
),
1 => {
let TokenTree::Ident(name) = &args[0] else {
panic!("Invalid argument: {}", args[0].to_string());
};

Some(name)
(
Some(name),
Some(syn::Ident::new(
&format!("{}Props", name),
Span::call_site().into(),
)),
)
}
3 => {
let TokenTree::Ident(name) = &args[0] else {
panic!("Invalid argument: {}", args[0].to_string());
};

let TokenTree::Ident(props) = args[2].clone() else {
panic!("Invalid argument: {}", args[2].to_string());
};

(Some(name), Some(props))
}
_ => panic!("Invalid arguments: {:?}", args),
};
Expand Down Expand Up @@ -108,7 +131,6 @@ pub fn autoprops_component(

let partial_eq_constraints = arg_types.iter().map(|ty| quote! { #ty: PartialEq });

let struct_name = syn::Ident::new(&format!("{}Props", fn_name), Span::call_site().into());
let (impl_generics, ty_generics, _) = generics.split_for_impl();
let bounds = generics.where_clause.clone();

Expand Down
3 changes: 2 additions & 1 deletion tests/cases/partialeq-fail.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -12,5 +12,6 @@ note: an implementation of `PartialEq` might be missing for `NotPartialEq`
= note: this error originates in the derive macro `PartialEq` (in Nightly builds, run with -Z macro-backtrace for more info)
help: consider annotating `NotPartialEq` with `#[derive(PartialEq)]`
|
14 | #[derive(PartialEq)]
14 + #[derive(PartialEq)]
15 | struct NotPartialEq();
|

0 comments on commit bb2772d

Please sign in to comment.