drt-sc-derive 0.0.1

DharitriOne smart contract API procedural macros
Documentation
// ensure we don't run out of macro stack
#![recursion_limit = "1024"]

#[macro_use]
extern crate syn;

#[macro_use]
extern crate quote;

mod contract_impl;
mod format;
mod generate;
mod macro_contract;
mod macro_module;
mod macro_proxy;
mod managed_vec_item_derive;
mod model;
mod parse;
mod preprocessing;
mod type_abi_derive;
mod validate;

#[proc_macro_attribute]
pub fn contract(
    args: proc_macro::TokenStream,
    input: proc_macro::TokenStream,
) -> proc_macro::TokenStream {
    macro_contract::process_contract(args, input)
}

#[proc_macro_attribute]
pub fn module(
    args: proc_macro::TokenStream,
    input: proc_macro::TokenStream,
) -> proc_macro::TokenStream {
    macro_module::process_module(args, input)
}

#[proc_macro_attribute]
pub fn proxy(
    args: proc_macro::TokenStream,
    input: proc_macro::TokenStream,
) -> proc_macro::TokenStream {
    macro_proxy::process_proxy(args, input)
}

#[proc_macro_derive(TypeAbi)]
pub fn type_abi_derive(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    type_abi_derive::type_abi_derive(input).into()
}

#[proc_macro_attribute]
pub fn type_abi(
    args: proc_macro::TokenStream,
    input: proc_macro::TokenStream,
) -> proc_macro::TokenStream {
    assert!(args.is_empty(), "#[type_abi] attribute takes no args");
    type_abi_derive::type_abi_full(input).into()
}

#[proc_macro_derive(ManagedVecItem)]
pub fn managed_vec_item_derive(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    let ast = syn::parse(input).unwrap();
    managed_vec_item_derive::managed_vec_item_derive(&ast)
}

#[proc_macro]
pub fn format_receiver_args(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    format::format_receiver_args_macro(input.into()).into()
}

#[proc_macro]
pub fn semver_tuple(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    format::semver_tuple(input.into()).into()
}

#[proc_macro]
pub fn const_managed_decimal(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    let input = parse_macro_input!(input as syn::LitStr);
    let (raw_int, decimals) = format::extract_number_data(input);

    let expanded = quote! {
        drt_sc::types::ManagedDecimal::<<Self as ContractBase>::Api, drt_sc::types::ConstDecimals<#decimals>>::const_decimals_from_raw(drt_sc::types::BigUint::from(#raw_int))
    };

    proc_macro::TokenStream::from(expanded)
}

#[proc_macro]
pub fn managed_decimal(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    let input = parse_macro_input!(input as syn::LitStr);
    let (raw_int, decimals) = format::extract_number_data(input);

    let expanded = quote! {
        drt_sc::types::ManagedDecimal::<<Self as ContractBase>::Api, usize>::from_raw_units(drt_sc::types::BigUint::from(#raw_int), #decimals)
    };

    proc_macro::TokenStream::from(expanded)
}

#[proc_macro]
pub fn debug_const_managed_decimal(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    let input = parse_macro_input!(input as syn::LitStr);
    let (raw_int, decimals) = format::extract_number_data(input);

    let expanded = quote! {
        drt_sc::types::ManagedDecimal::<drt_sc_scenario::imports::StaticApi, drt_sc::types::ConstDecimals<#decimals>>::const_decimals_from_raw(drt_sc::types::BigUint::from(#raw_int))
    };

    proc_macro::TokenStream::from(expanded)
}

#[proc_macro]
pub fn debug_managed_decimal(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
    let input = parse_macro_input!(input as syn::LitStr);
    let (raw_int, decimals) = format::extract_number_data(input);

    let expanded = quote! {
        drt_sc::types::ManagedDecimal::<drt_sc_scenario::imports::StaticApi, usize>::from_raw_units(drt_sc::types::BigUint::from(#raw_int), #decimals)
    };

    proc_macro::TokenStream::from(expanded)
}