1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
//! Code generation library for the zink API
use proc_macro::TokenStream;
use syn::{parse_macro_input, DeriveInput, ItemType};
mod event;
mod storage;
/// Event logging interface
///
/// ```rust
/// use zink::Event;
///
/// /// A `Ping` event.
/// #[derive(Event)]
/// struct Ping;
///
/// #[no_mangle]
/// pub extern "C" fn log0() {
/// Ping.log0();
/// }
/// ```
///
/// will generate:
///
/// ```rust
/// struct Ping;
///
/// impl zink::Event for Ping {
/// const NAME: &'static [u8] = b"Ping";
/// }
/// ```
#[proc_macro_derive(Event)]
pub fn event(input: TokenStream) -> TokenStream {
let input = parse_macro_input!(input as DeriveInput);
event::parse(input)
}
/// Order-based storage macro.
/// Currently only i32 is supported
///
/// ```rust
/// use zink::storage;
///
/// #[storage]
/// pub type Counter = i32;
/// ```
///
/// will generate:
///
/// ```rust
/// struct Counter;
///
/// impl zink::Storage<i32> for Counter {
/// // if this macro were the second one in the project, this key would be 1i32
/// const STORAGE_KEY: i32 = 0i32;
///
/// fn get() -> i32 {
/// zink::ffi::evm::sload(Self::STORAGE_KEY)
/// }
///
/// fn set(value: i32) {
/// zink::ffi::evm::sstore(Self::STORAGE_KEY, value);
/// }
/// }
/// ```
#[proc_macro_attribute]
pub fn storage(_args: TokenStream, input: TokenStream) -> TokenStream {
let input = parse_macro_input!(input as ItemType);
storage::parse(input).into()
}