diff --git a/crates/cli/src/main.rs b/crates/cli/src/main.rs index dd5d24419..f7b3ffa87 100644 --- a/crates/cli/src/main.rs +++ b/crates/cli/src/main.rs @@ -1,8 +1,11 @@ #![deny(warnings)] #![allow(clippy::too_many_arguments, clippy::while_let_on_iterator)] +use std::cell::RefCell; +use std::collections::HashMap; use std::fs; use std::path::PathBuf; +use std::rc::Rc; use anyhow::Result; use app_builder::app; @@ -82,6 +85,8 @@ fn main() -> Result<()> { public_inputs, private_inputs, context_inputs, + indexed_witness: Rc::new(RefCell::new(HashMap::default())), + tree_db: None, }, arg.running_arg.context_output, arg.instruction_limit, @@ -152,6 +157,8 @@ fn main() -> Result<()> { public_inputs, private_inputs, context_inputs, + indexed_witness: Rc::new(RefCell::new(HashMap::default())), + tree_db: None, }, arg.running_arg.context_output, arg.mock_test, diff --git a/crates/host/src/lib.rs b/crates/host/src/lib.rs index 275ffaf78..03a1f7e39 100644 --- a/crates/host/src/lib.rs +++ b/crates/host/src/lib.rs @@ -15,22 +15,8 @@ use delphinus_zkwasm::runtime::host::HostEnvBuilder; use serde::Deserialize; use serde::Serialize; use std::collections::HashMap; -use zkwasm_host_circuits::host::db::TreeDB; use zkwasm_host_circuits::proof::OpType; -pub struct StandardExecutionArg { - /// Public inputs for `wasm_input(1)` - pub public_inputs: Vec, - /// Private inputs for `wasm_input(0)` - pub private_inputs: Vec, - /// Context inputs for `wasm_read_context()` - pub context_inputs: Vec, - /// indexed witness context - pub indexed_witness: Rc>>>, - /// db src - pub tree_db: Option>>, -} - #[derive(Serialize, Deserialize, Debug)] pub struct HostEnvConfig { pub ops: Vec, @@ -104,13 +90,6 @@ impl HostEnvBuilder for StandardHostEnvBuilder { let host_env_config = HostEnvConfig { ops: self.ops.clone(), }; - let arg = StandardExecutionArg { - public_inputs: arg.public_inputs, - private_inputs: arg.private_inputs, - context_inputs: arg.context_inputs, - indexed_witness: Rc::new(RefCell::new(HashMap::new())), - tree_db: None, - }; register_wasm_input_foreign(&mut env, arg.public_inputs, arg.private_inputs); register_require_foreign(&mut env); diff --git a/crates/zkwasm/src/runtime/host/default_env.rs b/crates/zkwasm/src/runtime/host/default_env.rs index 7b4221ce0..8b50c9f56 100644 --- a/crates/zkwasm/src/runtime/host/default_env.rs +++ b/crates/zkwasm/src/runtime/host/default_env.rs @@ -1,3 +1,9 @@ +use std::cell::RefCell; +use std::collections::HashMap; +use std::rc::Rc; + +use zkwasm_host_circuits::host::db::TreeDB; + use crate::foreign::context::runtime::register_context_foreign; use crate::foreign::log_helper::register_log_foreign; use crate::foreign::require_helper::register_require_foreign; @@ -6,8 +12,6 @@ use crate::foreign::wasm_input_helper::runtime::register_wasm_input_foreign; use super::host_env::HostEnv; use super::HostEnvBuilder; -// TODO: remove me after refine tracer -#[derive(Clone)] pub struct ExecutionArg { /// Public inputs for `wasm_input(1)` pub public_inputs: Vec, @@ -15,6 +19,10 @@ pub struct ExecutionArg { pub private_inputs: Vec, /// Context inputs for `wasm_read_context()` pub context_inputs: Vec, + /// indexed witness context + pub indexed_witness: Rc>>>, + /// db src + pub tree_db: Option>>, } pub struct DefaultHostEnvBuilder;