frame_support_procedural/pallet/parse/
hooks.rs1use super::helper;
19use syn::spanned::Spanned;
20
21pub struct HooksDef {
23 pub instances: Vec<helper::InstanceUsage>,
25 pub where_clause: Option<syn::WhereClause>,
27 pub attr_span: proc_macro2::Span,
29 pub has_runtime_upgrade: bool,
31}
32
33impl HooksDef {
34 pub fn try_from(attr_span: proc_macro2::Span, item: &mut syn::Item) -> syn::Result<Self> {
35 let item = if let syn::Item::Impl(item) = item {
36 item
37 } else {
38 let msg = "Invalid pallet::hooks, expected item impl";
39 return Err(syn::Error::new(item.span(), msg))
40 };
41
42 let instances = vec![
43 helper::check_pallet_struct_usage(&item.self_ty)?,
44 helper::check_impl_gen(&item.generics, item.impl_token.span())?,
45 ];
46
47 let item_trait = &item
48 .trait_
49 .as_ref()
50 .ok_or_else(|| {
51 let msg = "Invalid pallet::hooks, expected impl<..> Hooks \
52 for Pallet<..>";
53 syn::Error::new(item.span(), msg)
54 })?
55 .1;
56
57 if item_trait.segments.len() != 1 || item_trait.segments[0].ident != "Hooks" {
58 let msg = format!(
59 "Invalid pallet::hooks, expected trait to be `Hooks` found `{}`\
60 , you can import from `frame_support::pallet_prelude`",
61 quote::quote!(#item_trait)
62 );
63
64 return Err(syn::Error::new(item_trait.span(), msg))
65 }
66
67 let has_runtime_upgrade = item.items.iter().any(|i| match i {
68 syn::ImplItem::Fn(method) => method.sig.ident == "on_runtime_upgrade",
69 _ => false,
70 });
71
72 Ok(Self {
73 attr_span,
74 instances,
75 has_runtime_upgrade,
76 where_clause: item.generics.where_clause.clone(),
77 })
78 }
79}