drt-sc-derive 0.0.1

DharitriOne smart contract API procedural macros
Documentation
pub fn contract_object_def() -> proc_macro2::TokenStream {
    quote! {
        pub struct ContractObj<A>
        where
            A: drt_sc::api::VMApi,
        {
            _phantom: core::marker::PhantomData<A>,
        }
    }
}

pub fn impl_contract_base() -> proc_macro2::TokenStream {
    quote! {
        impl<A> drt_sc::contract_base::ContractBase for ContractObj<A>
        where
            A: drt_sc::api::VMApi,
        {
            type Api = A;
        }
    }
}

pub fn new_contract_object_fn() -> proc_macro2::TokenStream {
    quote! {
        pub fn contract_obj<A>() -> ContractObj<A>
        where
            A: drt_sc::api::VMApi,
        {
            ContractObj {
                _phantom: core::marker::PhantomData,
            }
        }

        pub struct ContractBuilder;

        impl drt_sc::contract_base::CallableContractBuilder for self::ContractBuilder {
            fn new_contract_obj<A: drt_sc::api::VMApi + Send + Sync>(
                &self,
            ) -> drt_sc::types::heap::Box<dyn drt_sc::contract_base::CallableContract> {
                drt_sc::types::heap::Box::new(ContractObj::<A> {
                    _phantom: core::marker::PhantomData,
                })
            }
        }
    }
}

// TODO: explore auto-implementations of supertraits
#[allow(dead_code)]
pub fn impl_auto_impl() -> proc_macro2::TokenStream {
    quote! {
        impl<A> AutoImpl for ContractObj<A> where
            A: drt_sc::contract_base::ContractBase
                + drt_sc::api::ErrorApi
                + drt_sc::api::EndpointArgumentApi
                + drt_sc::api::EndpointFinishApi
                + drt_sc::api::ManagedTypeApi
        {
        }
    }
}

pub fn impl_callable_contract() -> proc_macro2::TokenStream {
    quote! {
        impl<A> drt_sc::contract_base::CallableContract for ContractObj<A>
        where
            A: drt_sc::api::VMApi + Send + Sync,
        {
            fn call(&self, fn_name: &str) -> bool {
                EndpointWrappers::call(self, fn_name)
            }
        }
    }
}

pub fn proxy_object_def() -> proc_macro2::TokenStream {
    quote! {
        pub struct Proxy<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            _phantom: core::marker::PhantomData<A>,
        }

        impl<A> drt_sc::contract_base::ProxyObjBase for Proxy<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            type Api = A;
            type To = ();

            fn extract_opt_address(
                &mut self,
            ) -> drt_sc::types::ManagedOption<
                Self::Api,
                drt_sc::types::ManagedAddress<Self::Api>,
            > {
                drt_sc::types::ManagedOption::none()
            }

            fn extract_address(&mut self) -> drt_sc::types::ManagedAddress<Self::Api> {
                drt_sc::api::ErrorApiImpl::signal_error(
                    &<A as drt_sc::api::ErrorApi>::error_api_impl(),
                    drt_sc::err_msg::RECIPIENT_ADDRESS_NOT_SET.as_bytes(),
                )
            }

            fn extract_proxy_to(&mut self) -> Self::To {}
        }

        impl<A> drt_sc::contract_base::ProxyObjNew for Proxy<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            type ProxyTo = ProxyTo<A>;

            fn new_proxy_obj() -> Self {
                Proxy {
                    _phantom: core::marker::PhantomData,
                }
            }

            fn contract(mut self, address: drt_sc::types::ManagedAddress<Self::Api>) -> Self::ProxyTo {
                ProxyTo {
                    address: drt_sc::types::ManagedOption::some(address)
                }
            }
        }

        pub struct ProxyTo<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            pub address:
                drt_sc::types::ManagedOption<A, drt_sc::types::ManagedAddress<A>>,
        }

        impl<A> drt_sc::contract_base::ProxyObjBase for ProxyTo<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            type Api = A;
            type To = drt_sc::types::ManagedAddress<A>;

            fn extract_opt_address(
                &mut self,
            ) -> drt_sc::types::ManagedOption<
                Self::Api,
                drt_sc::types::ManagedAddress<Self::Api>,
            > {
                core::mem::replace(
                    &mut self.address,
                    drt_sc::types::ManagedOption::none(),
                )
            }

            fn extract_address(&mut self) -> drt_sc::types::ManagedAddress<Self::Api> {
                let address = core::mem::replace(
                    &mut self.address,
                    drt_sc::types::ManagedOption::none(),
                );
                address.unwrap_or_sc_panic(drt_sc::err_msg::RECIPIENT_ADDRESS_NOT_SET)
            }

            fn extract_proxy_to(&mut self) -> Self::To {
                self.extract_address()
            }
        }
    }
}

pub fn callback_proxy_object_def() -> proc_macro2::TokenStream {
    quote! {
        pub struct CallbackProxyObj<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            _phantom: core::marker::PhantomData<A>,
        }

        impl<A> drt_sc::contract_base::CallbackProxyObjBase for CallbackProxyObj<A>
        where
            A: drt_sc::api::VMApi + 'static,
        {
            type Api = A;

            fn new_cb_proxy_obj() -> Self {
                CallbackProxyObj {
                    _phantom: core::marker::PhantomData,
                }
            }
        }
    }
}

pub fn call_method_api_static_init() -> proc_macro2::TokenStream {
    quote! {
        <Self::Api as drt_sc::api::VMApi>::init_static();
    }
}