aboutsummaryrefslogtreecommitdiff
path: root/zkvms_host_io
diff options
context:
space:
mode:
authorKamen Mladenov <kamen@syndamia.com>2025-01-31 12:58:02 +0200
committerKamen Mladenov <kamen@syndamia.com>2025-01-31 12:58:02 +0200
commita673cfb1c33c35d4e151329f882a00b12a03da14 (patch)
treecc804741d8a1fc7526d603d29df77ca5445a9de8 /zkvms_host_io
parentce84e507e13de389c023ce42c29bbbea515f67d6 (diff)
downloadzkVMs-benchmarks-a673cfb1c33c35d4e151329f882a00b12a03da14.tar
zkVMs-benchmarks-a673cfb1c33c35d4e151329f882a00b12a03da14.tar.gz
zkVMs-benchmarks-a673cfb1c33c35d4e151329f882a00b12a03da14.zip
feat: Add output type to zkvms_host_io macro
Diffstat (limited to 'zkvms_host_io')
-rw-r--r--zkvms_host_io/input_macros/src/lib.rs18
-rw-r--r--zkvms_host_io/src/lib.rs2
2 files changed, 13 insertions, 7 deletions
diff --git a/zkvms_host_io/input_macros/src/lib.rs b/zkvms_host_io/input_macros/src/lib.rs
index 84c2792..f313a1e 100644
--- a/zkvms_host_io/input_macros/src/lib.rs
+++ b/zkvms_host_io/input_macros/src/lib.rs
@@ -4,13 +4,18 @@ use proc_macro::TokenStream;
mod parse_fn;
use crate::parse_fn::{ args_split, args_divide, group_streams };
-fn get_args() -> TokenStream {
- include_str!("../../../guests/type.txt").parse::<TokenStream>().unwrap()
+fn get_types() -> (TokenStream, TokenStream) {
+ let types: Vec<&str> = include_str!("../../../guests/type.txt")
+ .split('\n')
+ .collect();
+ (types[0].parse::<TokenStream>().unwrap(), types[1].parse::<TokenStream>().unwrap())
}
#[proc_macro]
-pub fn generate_input_struct(_: TokenStream) -> TokenStream {
- let args = &get_args();
+pub fn generate_output_type_input_struct(_: TokenStream) -> TokenStream {
+ let (args, ret) = get_types();
+ let output_type = format!("pub type Output = {};", ret).to_string();
+
let all_args = args_split(&args);
let mut struct_def = "#[derive(Debug, Serialize, Deserialize)] pub struct Input {".to_string();
@@ -31,12 +36,13 @@ pub fn generate_input_struct(_: TokenStream) -> TokenStream {
}
struct_def += ") } }";
- struct_def.parse::<TokenStream>().unwrap()
+ (output_type + &struct_def).parse::<TokenStream>().unwrap()
}
#[proc_macro]
pub fn foreach_input_field(item: TokenStream) -> TokenStream {
- let arg_patterns = args_divide(&get_args()).0;
+ let (args, _) = get_types();
+ let arg_patterns = args_divide(&args).0;
let expr = format!("{}", item);
let mut out = String::new();
diff --git a/zkvms_host_io/src/lib.rs b/zkvms_host_io/src/lib.rs
index c029975..d00a1b1 100644
--- a/zkvms_host_io/src/lib.rs
+++ b/zkvms_host_io/src/lib.rs
@@ -48,7 +48,7 @@ impl<T> RunWith<T> {
}
}
-input_macros::generate_input_struct!();
+input_macros::generate_output_type_input_struct!();
pub fn read_args() -> RunWith<Input> {
let cli = Cli::parse();