1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
use syn::spanned::Spanned;
use super::helper;
pub struct GenesisConfigDef {
pub index: usize,
pub gen_kind: super::GenericKind,
pub instances: Vec<helper::InstanceUsage>,
pub genesis_config: syn::Ident,
}
impl GenesisConfigDef {
pub fn try_from(index: usize, item: &mut syn::Item) -> syn::Result<Self> {
let item_span = item.span();
let (vis, ident, generics) = match &item {
syn::Item::Enum(item) => (&item.vis, &item.ident, &item.generics),
syn::Item::Struct(item) => (&item.vis, &item.ident, &item.generics),
_ => {
let msg = "Invalid pallet::genesis_config, expected enum or struct";
return Err(syn::Error::new(item.span(), msg));
},
};
let mut instances = vec![];
if let Some(u) = helper::check_type_def_optional_gen(&generics, ident.span())? {
instances.push(u);
}
let has_instance = generics.type_params().any(|t| t.ident == "I");
let has_config = generics.type_params().any(|t| t.ident == "T");
let gen_kind = super::GenericKind::from_gens(has_config, has_instance)
.expect("Checked by `helper::check_type_def_optional_gen` above");
if !matches!(vis, syn::Visibility::Public(_)) {
let msg = "Invalid pallet::genesis_config, GenesisConfig must be public";
return Err(syn::Error::new(item_span, msg));
}
if ident != "GenesisConfig" {
let msg = "Invalid pallet::genesis_config, ident must `GenesisConfig`";
return Err(syn::Error::new(ident.span(), msg));
}
Ok(GenesisConfigDef {
index,
genesis_config: ident.clone(),
instances,
gen_kind,
})
}
}