1c0e57d984
This commit systematically rebrands various references from Parity Technologies' Polkadot/Substrate ecosystem to PezkuwiChain within the kurdistan-sdk. Key changes include: - Updated external repository URLs (zombienet-sdk, parity-db, parity-scale-codec, wasm-instrument) to point to pezkuwichain forks. - Modified internal documentation and code comments to reflect PezkuwiChain naming and structure. - Replaced direct references to with or specific paths within the for XCM, Pezkuwi, and other modules. - Cleaned up deprecated issue and PR references in various and files, particularly in and modules. - Adjusted image and logo URLs in documentation to point to PezkuwiChain assets. - Removed or rephrased comments related to external Polkadot/Substrate PRs and issues. This is a significant step towards fully customizing the SDK for the PezkuwiChain ecosystem.
198 lines
5.8 KiB
Rust
198 lines
5.8 KiB
Rust
// This file is part of Bizinikiwi.
|
|
|
|
// Copyright (C) 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.
|
|
|
|
// tag::description[]
|
|
//! Proc macro helpers for procedural macros
|
|
// end::description[]
|
|
|
|
// reexport proc macros
|
|
pub use pezframe_support_procedural_tools_derive::*;
|
|
|
|
use proc_macro_crate::{crate_name, FoundCrate};
|
|
use quote::quote;
|
|
use syn::parse::Error;
|
|
|
|
pub mod syn_ext;
|
|
|
|
// FIXME #1569, remove the following functions, which are copied from sp-api-macros
|
|
use proc_macro2::{Span, TokenStream};
|
|
use syn::Ident;
|
|
|
|
fn generate_hidden_includes_mod_name(unique_id: &str) -> Ident {
|
|
Ident::new(&format!("pezsp_api_hidden_includes_{}", unique_id), Span::call_site())
|
|
}
|
|
|
|
/// Generates the access to the `pezframe-support` crate.
|
|
pub fn generate_crate_access(unique_id: &str, def_crate: &str) -> TokenStream {
|
|
if std::env::var("CARGO_PKG_NAME").unwrap() == def_crate {
|
|
let pezframe_support = match generate_access_from_frame_or_crate("pezframe-support") {
|
|
Ok(c) => c,
|
|
Err(e) => return e.into_compile_error().into(),
|
|
};
|
|
quote::quote!(#pezframe_support)
|
|
} else {
|
|
let mod_name = generate_hidden_includes_mod_name(unique_id);
|
|
quote::quote!( self::#mod_name::hidden_include )
|
|
}
|
|
}
|
|
|
|
/// Check if a path is using the `frame` crate or not.
|
|
///
|
|
/// This will usually check the output of [`generate_access_from_frame_or_crate`].
|
|
/// We want to know if whatever the `path` takes us to, is exported from `frame` or not. In that
|
|
/// case `path` would start with `frame`, something like `pezkuwi_sdk_frame::x::y:z` or
|
|
/// frame::x::y:z.
|
|
pub fn is_using_frame_crate(path: &syn::Path) -> bool {
|
|
path.segments
|
|
.first()
|
|
.map(|s| s.ident == "pezkuwi_sdk_frame" || s.ident == "frame")
|
|
.unwrap_or(false)
|
|
}
|
|
|
|
/// Generate the crate access for the crate using 2018 syntax.
|
|
///
|
|
/// If `frame` is in scope, it will use `pezkuwi_sdk_frame::deps::<def_crate>`. Else, it will try
|
|
/// and find `<def_crate>` directly.
|
|
pub fn generate_access_from_frame_or_crate(def_crate: &str) -> Result<syn::Path, Error> {
|
|
if let Some(path) = get_frame_crate_path(def_crate) {
|
|
Ok(path)
|
|
} else if let Some(path) = get_sdk_crate_path(def_crate) {
|
|
Ok(path)
|
|
} else {
|
|
let ident = match crate_name(def_crate) {
|
|
Ok(FoundCrate::Itself) => {
|
|
let name = def_crate.to_string().replace("-", "_");
|
|
Ok(syn::Ident::new(&name, Span::call_site()))
|
|
},
|
|
Ok(FoundCrate::Name(name)) => Ok(Ident::new(&name, Span::call_site())),
|
|
Err(e) => Err(Error::new(Span::call_site(), e)),
|
|
}?;
|
|
|
|
Ok(syn::Path::from(ident))
|
|
}
|
|
}
|
|
|
|
/// Generates the hidden includes that are required to make the macro independent from its scope.
|
|
pub fn generate_hidden_includes(unique_id: &str, def_crate: &str) -> TokenStream {
|
|
let mod_name = generate_hidden_includes_mod_name(unique_id);
|
|
|
|
if let Some(path) = get_frame_crate_path(def_crate) {
|
|
quote::quote!(
|
|
#[doc(hidden)]
|
|
mod #mod_name {
|
|
pub use #path as hidden_include;
|
|
}
|
|
)
|
|
} else if let Some(path) = get_sdk_crate_path(def_crate) {
|
|
quote::quote!(
|
|
#[doc(hidden)]
|
|
mod #mod_name {
|
|
pub use #path as hidden_include;
|
|
}
|
|
)
|
|
} else {
|
|
match crate_name(def_crate) {
|
|
Ok(FoundCrate::Itself) => quote!(),
|
|
Ok(FoundCrate::Name(name)) => {
|
|
let name = Ident::new(&name, Span::call_site());
|
|
quote::quote!(
|
|
#[doc(hidden)]
|
|
mod #mod_name {
|
|
pub use #name as hidden_include;
|
|
}
|
|
)
|
|
},
|
|
Err(e) => {
|
|
let err = Error::new(Span::call_site(), e).to_compile_error();
|
|
quote!( #err )
|
|
},
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Generates the path to the frame crate deps.
|
|
fn get_frame_crate_path(def_crate: &str) -> Option<syn::Path> {
|
|
// This does not work if the frame crate is renamed.
|
|
if let Ok(FoundCrate::Name(name)) =
|
|
crate_name(&"pezkuwi-sdk-frame").or_else(|_| crate_name(&"frame"))
|
|
{
|
|
let path = format!("{}::deps::{}", name, def_crate.to_string().replace("-", "_"));
|
|
Some(syn::parse_str::<syn::Path>(&path).expect("is a valid path; qed"))
|
|
} else {
|
|
None
|
|
}
|
|
}
|
|
|
|
fn get_sdk_crate_path(def_crate: &str) -> Option<syn::Path> {
|
|
if let Ok(FoundCrate::Name(name)) = crate_name(&"pezkuwi-sdk") {
|
|
let path = format!("{}::{}", name, def_crate.to_string()).replace("-", "_");
|
|
Some(syn::parse_str::<syn::Path>(&path).expect("is a valid path; qed"))
|
|
} else {
|
|
None
|
|
}
|
|
}
|
|
|
|
// fn to remove white spaces around string types
|
|
// (basically whitespaces around tokens)
|
|
pub fn clean_type_string(input: &str) -> String {
|
|
input
|
|
.replace(" ::", "::")
|
|
.replace(":: ", "::")
|
|
.replace(" ,", ",")
|
|
.replace(" ;", ";")
|
|
.replace(" [", "[")
|
|
.replace("[ ", "[")
|
|
.replace(" ]", "]")
|
|
.replace(" (", "(")
|
|
.replace("( ", "(")
|
|
.replace(" )", ")")
|
|
.replace(" <", "<")
|
|
.replace("< ", "<")
|
|
.replace(" >", ">")
|
|
}
|
|
|
|
/// Return all doc attributes literals found.
|
|
pub fn get_doc_literals(attrs: &[syn::Attribute]) -> Vec<syn::Expr> {
|
|
attrs
|
|
.iter()
|
|
.filter_map(|attr| {
|
|
if let syn::Meta::NameValue(meta) = &attr.meta {
|
|
meta.path
|
|
.get_ident()
|
|
.filter(|ident| *ident == "doc")
|
|
.map(|_| meta.value.clone())
|
|
} else {
|
|
None
|
|
}
|
|
})
|
|
.collect()
|
|
}
|
|
|
|
/// Return all cfg attributes literals found.
|
|
pub fn get_cfg_attributes(attrs: &[syn::Attribute]) -> Vec<syn::Attribute> {
|
|
attrs
|
|
.iter()
|
|
.filter_map(|attr| {
|
|
if let syn::Meta::List(meta) = &attr.meta {
|
|
meta.path.get_ident().filter(|ident| *ident == "cfg").map(|_| attr.clone())
|
|
} else {
|
|
None
|
|
}
|
|
})
|
|
.collect()
|
|
}
|