mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-28 12:07:57 +00:00
f9975af020
Procedural do not support `$crate` to get access to the crate where the macro is defined. We use a hack to re-export the crate under a known name. With rust edition 2018, people started to rename their crates in `Cargo.toml`, but that breaks the re-export. This commit introduces `proc-maco-crate` that supports finding the requested crate name, even if it was renamed.
116 lines
3.1 KiB
Rust
116 lines
3.1 KiB
Rust
// Copyright 2017-2018 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/>.
|
|
|
|
// tag::description[]
|
|
//! Proc macro helpers for procedural macros
|
|
// end::description[]
|
|
|
|
// reexport proc macros
|
|
pub use srml_support_procedural_tools_derive::*;
|
|
|
|
use proc_macro_crate::crate_name;
|
|
use syn::parse::Error;
|
|
use quote::quote;
|
|
|
|
pub mod syn_ext;
|
|
|
|
#[macro_export]
|
|
macro_rules! custom_keyword_impl {
|
|
($name:ident, $keyident:expr, $keydisp:expr) => {
|
|
|
|
impl CustomKeyword for $name {
|
|
fn ident() -> &'static str { $keyident }
|
|
fn display() -> &'static str { $keydisp }
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
#[macro_export]
|
|
macro_rules! custom_keyword {
|
|
($name:ident, $keyident:expr, $keydisp:expr) => {
|
|
|
|
#[derive(Debug)]
|
|
struct $name;
|
|
|
|
custom_keyword_impl!($name, $keyident, $keydisp);
|
|
|
|
}
|
|
}
|
|
|
|
// FIXME #1569, remove the following functions, which are copied from sr-api-macros
|
|
use proc_macro2::{TokenStream, Span};
|
|
use syn::Ident;
|
|
|
|
fn generate_hidden_includes_mod_name(unique_id: &str) -> Ident {
|
|
Ident::new(&format!("sr_api_hidden_includes_{}", unique_id), Span::call_site())
|
|
}
|
|
|
|
/// Generates the access to the `srml-support` crate.
|
|
pub fn generate_crate_access(unique_id: &str, def_crate: &str) -> TokenStream {
|
|
if ::std::env::var("CARGO_PKG_NAME").unwrap() == def_crate {
|
|
quote::quote!( crate )
|
|
} else {
|
|
let mod_name = generate_hidden_includes_mod_name(unique_id);
|
|
quote::quote!( self::#mod_name::hidden_include )
|
|
}.into()
|
|
}
|
|
|
|
/// 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 {
|
|
if ::std::env::var("CARGO_PKG_NAME").unwrap() == def_crate {
|
|
TokenStream::new()
|
|
} else {
|
|
let mod_name = generate_hidden_includes_mod_name(unique_id);
|
|
|
|
match crate_name(def_crate) {
|
|
Ok(name) => {
|
|
let name = Ident::new(&name, Span::call_site());
|
|
quote::quote!(
|
|
#[doc(hidden)]
|
|
mod #mod_name {
|
|
pub extern crate #name as hidden_include;
|
|
}
|
|
)
|
|
},
|
|
Err(e) => {
|
|
let err = Error::new(Span::call_site(), &e).to_compile_error();
|
|
quote!( #err )
|
|
}
|
|
}
|
|
|
|
}.into()
|
|
}
|
|
|
|
// fn to remove white spaces arount string types
|
|
// (basically whitespaces arount tokens)
|
|
pub fn clean_type_string(input: &str) -> String {
|
|
input
|
|
.replace(" ::", "::")
|
|
.replace(":: ", "::")
|
|
.replace(" ,", ",")
|
|
.replace(" ;", ";")
|
|
.replace(" [", "[")
|
|
.replace("[ ", "[")
|
|
.replace(" ]", "]")
|
|
.replace(" (", "(")
|
|
.replace("( ", "(")
|
|
.replace(" )", ")")
|
|
.replace(" <", "<")
|
|
.replace("< ", "<")
|
|
.replace(" >", ">")
|
|
}
|