mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-29 11:27:24 +00:00
218 lines
6.6 KiB
Rust
218 lines
6.6 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2017-2022 Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
//! Implementation of `storage_metadata` on module structure, used by construct_runtime.
|
|
|
|
use super::{DeclStorageDefExt, StorageLineDefExt, StorageLineTypeDef};
|
|
use frame_support_procedural_tools::get_doc_literals;
|
|
use proc_macro2::TokenStream;
|
|
use quote::quote;
|
|
|
|
fn storage_line_metadata_type(scrate: &TokenStream, line: &StorageLineDefExt) -> TokenStream {
|
|
let value_type = &line.value_type;
|
|
match &line.storage_type {
|
|
StorageLineTypeDef::Simple(_) => {
|
|
quote! {
|
|
#scrate::metadata::StorageEntryType::Plain(
|
|
#scrate::scale_info::meta_type::<#value_type>()
|
|
)
|
|
}
|
|
},
|
|
StorageLineTypeDef::Map(map) => {
|
|
let hasher = map.hasher.into_metadata();
|
|
let key = &map.key;
|
|
quote! {
|
|
#scrate::metadata::StorageEntryType::Map {
|
|
hashers: #scrate::sp_std::vec! [ #scrate::metadata::#hasher ],
|
|
key: #scrate::scale_info::meta_type::<#key>(),
|
|
value: #scrate::scale_info::meta_type::<#value_type>(),
|
|
}
|
|
}
|
|
},
|
|
StorageLineTypeDef::DoubleMap(map) => {
|
|
let hasher1 = map.hasher1.into_metadata();
|
|
let hasher2 = map.hasher2.into_metadata();
|
|
let key1 = &map.key1;
|
|
let key2 = &map.key2;
|
|
quote! {
|
|
#scrate::metadata::StorageEntryType::Map {
|
|
hashers: #scrate::sp_std::vec! [
|
|
#scrate::metadata::#hasher1,
|
|
#scrate::metadata::#hasher2,
|
|
],
|
|
key: #scrate::scale_info::meta_type::<(#key1, #key2)>(),
|
|
value: #scrate::scale_info::meta_type::<#value_type>(),
|
|
}
|
|
}
|
|
},
|
|
StorageLineTypeDef::NMap(map) => {
|
|
let key_tuple = &map.to_key_tuple();
|
|
let hashers = map
|
|
.hashers
|
|
.iter()
|
|
.map(|hasher| hasher.to_storage_hasher_struct())
|
|
.collect::<Vec<_>>();
|
|
quote! {
|
|
#scrate::metadata::StorageEntryType::Map {
|
|
hashers: #scrate::sp_std::vec! [
|
|
#( #scrate::metadata::StorageHasher::#hashers, )*
|
|
],
|
|
key: #scrate::scale_info::meta_type::<#key_tuple>(),
|
|
value: #scrate::scale_info::meta_type::<#value_type>(),
|
|
}
|
|
}
|
|
},
|
|
}
|
|
}
|
|
|
|
fn default_byte_getter(
|
|
scrate: &TokenStream,
|
|
line: &StorageLineDefExt,
|
|
def: &DeclStorageDefExt,
|
|
) -> (TokenStream, TokenStream) {
|
|
let default = line
|
|
.default_value
|
|
.as_ref()
|
|
.map(|d| quote!( #d ))
|
|
.unwrap_or_else(|| quote!(Default::default()));
|
|
|
|
let str_name = line.name.to_string();
|
|
let struct_name =
|
|
syn::Ident::new(&("__GetByteStruct".to_string() + &str_name), line.name.span());
|
|
let cache_name =
|
|
syn::Ident::new(&("__CACHE_GET_BYTE_STRUCT_".to_string() + &str_name), line.name.span());
|
|
|
|
let runtime_generic = &def.module_runtime_generic;
|
|
let runtime_trait = &def.module_runtime_trait;
|
|
let optional_instance_bound_optional_default = &def.optional_instance_bound_optional_default;
|
|
let optional_instance_bound = &def.optional_instance_bound;
|
|
let optional_instance = &def.optional_instance;
|
|
let optional_comma_instance = optional_instance.as_ref().map(|i| quote!(, #i));
|
|
let where_clause = &def.where_clause;
|
|
|
|
let query_type = &line.query_type;
|
|
|
|
let struct_def = quote! {
|
|
#[doc(hidden)]
|
|
pub struct #struct_name<
|
|
#runtime_generic, #optional_instance_bound_optional_default
|
|
>(pub #scrate::sp_std::marker::PhantomData<(#runtime_generic #optional_comma_instance)>);
|
|
|
|
#[cfg(feature = "std")]
|
|
#[allow(non_upper_case_globals)]
|
|
static #cache_name: #scrate::once_cell::sync::OnceCell<#scrate::sp_std::vec::Vec<u8>> =
|
|
#scrate::once_cell::sync::OnceCell::new();
|
|
|
|
#[cfg(feature = "std")]
|
|
impl<#runtime_generic: #runtime_trait, #optional_instance_bound>
|
|
#struct_name<#runtime_generic, #optional_instance>
|
|
#where_clause
|
|
{
|
|
fn default_byte(&self) -> #scrate::sp_std::vec::Vec<u8> {
|
|
use #scrate::codec::Encode;
|
|
#cache_name.get_or_init(|| {
|
|
let def_val: #query_type = #default;
|
|
<#query_type as Encode>::encode(&def_val)
|
|
}).clone()
|
|
}
|
|
}
|
|
|
|
#[cfg(not(feature = "std"))]
|
|
impl<#runtime_generic: #runtime_trait, #optional_instance_bound>
|
|
#struct_name<#runtime_generic, #optional_instance>
|
|
#where_clause
|
|
{
|
|
fn default_byte(&self) -> #scrate::sp_std::vec::Vec<u8> {
|
|
use #scrate::codec::Encode;
|
|
let def_val: #query_type = #default;
|
|
<#query_type as Encode>::encode(&def_val)
|
|
}
|
|
}
|
|
};
|
|
let struct_instance = quote!(
|
|
#struct_name::<#runtime_generic, #optional_instance>(#scrate::sp_std::marker::PhantomData)
|
|
);
|
|
|
|
(struct_def, struct_instance)
|
|
}
|
|
|
|
pub fn impl_metadata(def: &DeclStorageDefExt) -> TokenStream {
|
|
let scrate = &def.hidden_crate;
|
|
let mut entries = TokenStream::new();
|
|
let mut default_byte_getter_struct_defs = TokenStream::new();
|
|
|
|
for line in def.storage_lines.iter() {
|
|
let str_name = line.name.to_string();
|
|
|
|
let modifier = if line.is_option {
|
|
quote!(#scrate::metadata::StorageEntryModifier::Optional)
|
|
} else {
|
|
quote!(#scrate::metadata::StorageEntryModifier::Default)
|
|
};
|
|
|
|
let ty = storage_line_metadata_type(scrate, line);
|
|
|
|
let (default_byte_getter_struct_def, default_byte_getter_struct_instance) =
|
|
default_byte_getter(scrate, line, def);
|
|
|
|
let docs = get_doc_literals(&line.attrs);
|
|
|
|
let entry = quote! {
|
|
#scrate::metadata::StorageEntryMetadata {
|
|
name: #str_name,
|
|
modifier: #modifier,
|
|
ty: #ty,
|
|
default: #default_byte_getter_struct_instance.default_byte(),
|
|
docs: #scrate::sp_std::vec![ #( #docs ),* ],
|
|
},
|
|
};
|
|
|
|
default_byte_getter_struct_defs.extend(default_byte_getter_struct_def);
|
|
entries.extend(entry);
|
|
}
|
|
|
|
let prefix = if let Some(instance) = &def.module_instance {
|
|
let instance_generic = &instance.instance_generic;
|
|
quote!(#instance_generic::PREFIX)
|
|
} else {
|
|
let prefix = def.crate_name.to_string();
|
|
quote!(#prefix)
|
|
};
|
|
|
|
let store_metadata = quote!(
|
|
#scrate::metadata::PalletStorageMetadata {
|
|
prefix: #prefix,
|
|
entries: #scrate::sp_std::vec![ #entries ],
|
|
}
|
|
);
|
|
|
|
let module_struct = &def.module_struct;
|
|
let module_impl = &def.module_impl;
|
|
let where_clause = &def.where_clause;
|
|
|
|
quote!(
|
|
#default_byte_getter_struct_defs
|
|
|
|
impl #module_impl #module_struct #where_clause {
|
|
#[doc(hidden)]
|
|
pub fn storage_metadata() -> #scrate::metadata::PalletStorageMetadata {
|
|
#store_metadata
|
|
}
|
|
}
|
|
)
|
|
}
|