mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 02:17:58 +00:00
60e5011c72
* Adding first rough ouline of the repository structure * Remove old CI stuff * add title * formatting fixes * move node-exits job's script to scripts dir * Move docs into subdir * move to bin * move maintainence scripts, configs and helpers into its own dir * add .local to ignore * move core->client * start up 'test' area * move test client * move test runtime * make test move compile * Add dependencies rule enforcement. * Fix indexing. * Update docs to reflect latest changes * Moving /srml->/paint * update docs * move client/sr-* -> primitives/ * clean old readme * remove old broken code in rhd * update lock * Step 1. * starting to untangle client * Fix after merge. * start splitting out client interfaces * move children and blockchain interfaces * Move trie and state-machine to primitives. * Fix WASM builds. * fixing broken imports * more interface moves * move backend and light to interfaces * move CallExecutor * move cli off client * moving around more interfaces * re-add consensus crates into the mix * fix subkey path * relieve client from executor * starting to pull out client from grandpa * move is_decendent_of out of client * grandpa still depends on client directly * lemme tests pass * rename srml->paint * Make it compile. * rename interfaces->client-api * Move keyring to primitives. * fixup libp2p dep * fix broken use * allow dependency enforcement to fail * move fork-tree * Moving wasm-builder * make env * move build-script-utils * fixup broken crate depdencies and names * fix imports for authority discovery * fix typo * update cargo.lock * fixing imports * Fix paths and add missing crates * re-add missing crates
163 lines
5.0 KiB
Rust
163 lines
5.0 KiB
Rust
// Copyright 2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Substrate is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Substrate. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
//! Util function used by this crate.
|
|
|
|
use proc_macro2::{TokenStream, Span};
|
|
|
|
use syn::{
|
|
Ident, Error, Signature, Pat, PatType, FnArg, Type, token, TraitItemMethod, ItemTrait,
|
|
TraitItem, parse_quote, spanned::Spanned,
|
|
};
|
|
|
|
use proc_macro_crate::crate_name;
|
|
|
|
use std::env;
|
|
|
|
use quote::quote;
|
|
|
|
use inflector::Inflector;
|
|
|
|
/// Generates the include for the runtime-interface crate.
|
|
pub fn generate_runtime_interface_include() -> TokenStream {
|
|
if env::var("CARGO_PKG_NAME").unwrap() == "substrate-runtime-interface" {
|
|
TokenStream::new()
|
|
} else {
|
|
match crate_name("substrate-runtime-interface") {
|
|
Ok(crate_name) => {
|
|
let crate_name = Ident::new(&crate_name, Span::call_site());
|
|
quote!(
|
|
#[doc(hidden)]
|
|
extern crate #crate_name as proc_macro_runtime_interface;
|
|
)
|
|
},
|
|
Err(e) => {
|
|
let err = Error::new(Span::call_site(), &e).to_compile_error();
|
|
quote!( #err )
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Generates the access to the `substrate-runtime-interface` crate.
|
|
pub fn generate_crate_access() -> TokenStream {
|
|
if env::var("CARGO_PKG_NAME").unwrap() == "substrate-runtime-interface" {
|
|
quote!( substrate_runtime_interface )
|
|
} else {
|
|
quote!( proc_macro_runtime_interface )
|
|
}
|
|
}
|
|
|
|
/// Create the exchangeable host function identifier for the given function name.
|
|
pub fn create_exchangeable_host_function_ident(name: &Ident) -> Ident {
|
|
Ident::new(&format!("host_{}", name), Span::call_site())
|
|
}
|
|
|
|
/// Create the host function identifier for the given function name.
|
|
pub fn create_host_function_ident(name: &Ident, trait_name: &Ident) -> Ident {
|
|
Ident::new(
|
|
&format!(
|
|
"ext_{}_{}_version_1",
|
|
trait_name.to_string().to_snake_case(),
|
|
name,
|
|
),
|
|
Span::call_site(),
|
|
)
|
|
}
|
|
|
|
/// Returns the function arguments of the given `Signature`, minus any `self` arguments.
|
|
pub fn get_function_arguments<'a>(sig: &'a Signature) -> impl Iterator<Item = PatType> + 'a {
|
|
sig.inputs
|
|
.iter()
|
|
.filter_map(|a| match a {
|
|
FnArg::Receiver(_) => None,
|
|
FnArg::Typed(pat_type) => Some(pat_type),
|
|
})
|
|
.enumerate()
|
|
.map(|(i, arg)| {
|
|
let mut res = arg.clone();
|
|
if let Pat::Wild(wild) = &*arg.pat {
|
|
let ident = Ident::new(
|
|
&format!("__runtime_interface_generated_{}_", i),
|
|
wild.span(),
|
|
);
|
|
|
|
res.pat = Box::new(parse_quote!( #ident ))
|
|
}
|
|
|
|
res
|
|
})
|
|
}
|
|
|
|
/// Returns the function argument names of the given `Signature`, minus any `self`.
|
|
pub fn get_function_argument_names<'a>(sig: &'a Signature) -> impl Iterator<Item = Box<Pat>> + 'a {
|
|
get_function_arguments(sig).map(|pt| pt.pat)
|
|
}
|
|
|
|
/// Returns the function argument types of the given `Signature`, minus any `Self` type.
|
|
pub fn get_function_argument_types<'a>(sig: &'a Signature) -> impl Iterator<Item = Box<Type>> + 'a {
|
|
get_function_arguments(sig).map(|pt| pt.ty)
|
|
}
|
|
|
|
/// Returns the function argument types, minus any `Self` type. If any of the arguments
|
|
/// is a reference, the underlying type without the ref is returned.
|
|
pub fn get_function_argument_types_without_ref<'a>(
|
|
sig: &'a Signature,
|
|
) -> impl Iterator<Item = Box<Type>> + 'a {
|
|
get_function_arguments(sig)
|
|
.map(|pt| pt.ty)
|
|
.map(|ty| match *ty {
|
|
Type::Reference(type_ref) => type_ref.elem,
|
|
_ => ty,
|
|
})
|
|
}
|
|
|
|
/// Returns the function argument names and types, minus any `self`. If any of the arguments
|
|
/// is a reference, the underlying type without the ref is returned.
|
|
pub fn get_function_argument_names_and_types_without_ref<'a>(
|
|
sig: &'a Signature,
|
|
) -> impl Iterator<Item = (Box<Pat>, Box<Type>)> + 'a {
|
|
get_function_arguments(sig)
|
|
.map(|pt| match *pt.ty {
|
|
Type::Reference(type_ref) => (pt.pat, type_ref.elem),
|
|
_ => (pt.pat, pt.ty),
|
|
})
|
|
}
|
|
|
|
/// Returns the `&`/`&mut` for all function argument types, minus the `self` arg. If a function
|
|
/// argument is not a reference, `None` is returned.
|
|
pub fn get_function_argument_types_ref_and_mut<'a>(
|
|
sig: &'a Signature,
|
|
) -> impl Iterator<Item = Option<(token::And, Option<token::Mut>)>> + 'a {
|
|
get_function_arguments(sig)
|
|
.map(|pt| pt.ty)
|
|
.map(|ty| match *ty {
|
|
Type::Reference(type_ref) => Some((type_ref.and_token, type_ref.mutability)),
|
|
_ => None,
|
|
})
|
|
}
|
|
|
|
/// Returns an iterator over all trait methods for the given trait definition.
|
|
pub fn get_trait_methods<'a>(trait_def: &'a ItemTrait) -> impl Iterator<Item = &'a TraitItemMethod> {
|
|
trait_def
|
|
.items
|
|
.iter()
|
|
.filter_map(|i| match i {
|
|
TraitItem::Method(ref method) => Some(method),
|
|
_ => None,
|
|
})
|
|
}
|