aboutsummaryrefslogtreecommitdiff
path: root/zkvms/risc0/wrapper_macro
diff options
context:
space:
mode:
authorKamen Mladenov <kamen@syndamia.com>2025-01-10 10:34:17 +0200
committerKamen Mladenov <kamen@syndamia.com>2025-01-10 10:34:17 +0200
commit61d742d473f95103fa54fd5638b26b9c2fe932b4 (patch)
treea55687e2251012bc9a81d4790bace44bdaa717b0 /zkvms/risc0/wrapper_macro
parent3bef1a12c1b3fb9310fbb0fde8d487005ece2913 (diff)
downloadzkVMs-benchmarks-61d742d473f95103fa54fd5638b26b9c2fe932b4.tar
zkVMs-benchmarks-61d742d473f95103fa54fd5638b26b9c2fe932b4.tar.gz
zkVMs-benchmarks-61d742d473f95103fa54fd5638b26b9c2fe932b4.zip
feat(zkvms/risc0): Add guest and it's macro
Diffstat (limited to 'zkvms/risc0/wrapper_macro')
-rw-r--r--zkvms/risc0/wrapper_macro/Cargo.toml7
-rw-r--r--zkvms/risc0/wrapper_macro/src/lib.rs25
2 files changed, 32 insertions, 0 deletions
diff --git a/zkvms/risc0/wrapper_macro/Cargo.toml b/zkvms/risc0/wrapper_macro/Cargo.toml
new file mode 100644
index 0000000..14348e5
--- /dev/null
+++ b/zkvms/risc0/wrapper_macro/Cargo.toml
@@ -0,0 +1,7 @@
+[package]
+name = "wrapper_macro"
+version = "0.1.0"
+edition = "2021"
+
+[lib]
+proc-macro = true
diff --git a/zkvms/risc0/wrapper_macro/src/lib.rs b/zkvms/risc0/wrapper_macro/src/lib.rs
new file mode 100644
index 0000000..eb24c33
--- /dev/null
+++ b/zkvms/risc0/wrapper_macro/src/lib.rs
@@ -0,0 +1,25 @@
+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 args_split = args_split(&args);
+
+ let mut out = TokenStream::new();
+ for arg in args_split {
+ out.extend(format!("let {} = read();", arg).parse::<TokenStream>());
+ }
+
+ let (patterns, _) = args_divide(&args);
+ let ts_patterns = group_streams(&patterns);
+
+ out.extend(format!("commit(&zkp::{}{});", name, ts_patterns).parse::<TokenStream>());
+
+ let mut block = TokenStream::new();
+ block.extend(format!("{{ {} }}", out).parse::<TokenStream>());
+ block
+}