diff options
| author | Kamen Mladenov <kamen@syndamia.com> | 2025-01-15 13:10:35 +0200 |
|---|---|---|
| committer | Kamen Mladenov <kamen@syndamia.com> | 2025-01-15 13:10:52 +0200 |
| commit | b1825ecc10e33565ea7bab6ed80be82356423446 (patch) | |
| tree | 36f92c563b24b37899356427ee421ce7293edee7 /zkvms/zkwasm/wrapper_macro/src | |
| parent | 8658f70ebec1c186115500f34a87ffaefd170982 (diff) | |
| download | zkVMs-benchmarks-b1825ecc10e33565ea7bab6ed80be82356423446.tar zkVMs-benchmarks-b1825ecc10e33565ea7bab6ed80be82356423446.tar.gz zkVMs-benchmarks-b1825ecc10e33565ea7bab6ed80be82356423446.zip | |
feat(zkvms): Add zkwasm guest and it's macro
Diffstat (limited to 'zkvms/zkwasm/wrapper_macro/src')
| -rw-r--r-- | zkvms/zkwasm/wrapper_macro/src/lib.rs | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/zkvms/zkwasm/wrapper_macro/src/lib.rs b/zkvms/zkwasm/wrapper_macro/src/lib.rs new file mode 100644 index 0000000..edb2fcd --- /dev/null +++ b/zkvms/zkwasm/wrapper_macro/src/lib.rs @@ -0,0 +1,33 @@ +use proc_macro::TokenStream; + +#[path = "../../../../guests_macro/src/parse_fn.rs"] +mod parse_fn; +use crate::parse_fn::{ split_fn, args_split, args_divide, group_streams }; + +#[proc_macro] +pub fn make_wrapper(item: TokenStream) -> TokenStream { + let (name, args, ret) = split_fn(&item); + let (patterns, types) = args_divide(&args); + + let mut out = TokenStream::new(); + + for i in 0..patterns.len() { + let type_note: String = format!("{}", types[i]) + .chars() + .map(|c| match c { + '<' => ',', + '>' => ' ', + _ => c, + }) + .collect(); + out.extend(format!("let {} : {} = read!({});", patterns[i], types[i], type_note).parse::<TokenStream>()); + } + + let ts_patterns = group_streams(&patterns); + + out.extend(format!("let result = zkp::{}{}; assert(result); write(result as u64);", name, ts_patterns).parse::<TokenStream>()); + + let mut block = TokenStream::new(); + block.extend(format!("{{ {} }}", out).parse::<TokenStream>()); + block +} |
