diff options
| author | Kamen Mladenov <kamen@syndamia.com> | 2025-02-03 16:12:26 +0200 |
|---|---|---|
| committer | Kamen Mladenov <kamen@syndamia.com> | 2025-02-03 17:42:20 +0200 |
| commit | 73e27ae16e920424a77be597e4d1b15466b368eb (patch) | |
| tree | 641793dd16d75e912536046927a403c7d34c401f /zkvms/zkm/wrapper_macro/src | |
| parent | 434248bf0ac990ac5cf8e4dfc6b923e6f1cf060c (diff) | |
| download | zkVMs-benchmarks-73e27ae16e920424a77be597e4d1b15466b368eb.tar zkVMs-benchmarks-73e27ae16e920424a77be597e4d1b15466b368eb.tar.gz zkVMs-benchmarks-73e27ae16e920424a77be597e4d1b15466b368eb.zip | |
feat(zkvms/zkm): Implement proper handling of public and private inputs
Diffstat (limited to 'zkvms/zkm/wrapper_macro/src')
| -rw-r--r-- | zkvms/zkm/wrapper_macro/src/lib.rs | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/zkvms/zkm/wrapper_macro/src/lib.rs b/zkvms/zkm/wrapper_macro/src/lib.rs index 57b9d24..4bb580c 100644 --- a/zkvms/zkm/wrapper_macro/src/lib.rs +++ b/zkvms/zkm/wrapper_macro/src/lib.rs @@ -2,17 +2,28 @@ use proc_macro::TokenStream; #[path = "../../../../guests_macro/src/parse_fn.rs"] mod parse_fn; -use crate::parse_fn::{ split_fn, args_split, args_divide_grouped }; +use crate::parse_fn::{ split_fn, args_split, args_divide_public, args_divide_grouped, group_streams }; #[proc_macro] pub fn make_wrapper(item: TokenStream) -> TokenStream { let (name, args, ret) = split_fn(&item); - let (ts_patterns, ts_types) = args_divide_grouped(&args); + let (ts_patterns, _) = args_divide_grouped(&args); + + let public_inputs = toml::from_str::<toml::Table>( + include_str!(concat!(env!("INPUTS_DIR"), "/default_public_input.toml")) + ) + .unwrap(); + let ((pub_pat, pub_typ), (prv_pat, prv_typ)) = args_divide_public(&args, &public_inputs.keys().collect()); + let ((pub_pat, pub_typ), (prv_pat, prv_typ)) = ( + (group_streams(&pub_pat), group_streams(&pub_typ)), + (group_streams(&prv_pat), group_streams(&prv_typ))); let mut out = TokenStream::new(); // NOTE: The first read returns public data, the second returns private - out.extend(format!("let {} : {} = read();", ts_patterns, ts_types).parse::<TokenStream>()); + out.extend(format!("let {} : {} = read();", pub_pat, pub_typ).parse::<TokenStream>()); + out.extend(format!("let {} : {} = read();", prv_pat, prv_typ).parse::<TokenStream>()); + out.extend(format!("commit::<{}>(&zkp::{}{});", ret, name, ts_patterns).parse::<TokenStream>()); let mut block = TokenStream::new(); |
