revm_handler_interface/
execution.rsuse crate::util::FrameOrFrameResult;
pub use crate::{Frame, FrameOrResultGen};
pub use std::{vec, vec::Vec};
pub trait ExecutionHandler {
type Context;
type Error;
type Frame: Frame<Context = Self::Context, Error = Self::Error>;
type ExecResult;
fn init_first_frame(
&mut self,
context: &mut Self::Context,
gas_limit: u64,
) -> Result<FrameOrFrameResult<Self::Frame>, Self::Error>;
fn last_frame_result(
&self,
context: &mut Self::Context,
frame_result: <Self::Frame as Frame>::FrameResult,
) -> Result<Self::ExecResult, Self::Error>;
fn run(
&self,
context: &mut Self::Context,
frame: Self::Frame,
) -> Result<Self::ExecResult, Self::Error> {
let mut frame_stack: Vec<<Self as ExecutionHandler>::Frame> = vec![frame];
loop {
let frame = frame_stack.last_mut().unwrap();
let call_or_result = frame.run(context)?;
let mut result = match call_or_result {
FrameOrResultGen::Frame(init) => match frame.init(context, init)? {
FrameOrResultGen::Frame(new_frame) => {
frame_stack.push(new_frame);
continue;
}
FrameOrResultGen::Result(result) => result,
},
FrameOrResultGen::Result(result) => {
frame_stack.pop();
result
}
};
let Some(frame) = frame_stack.last_mut() else {
Self::Frame::final_return(context, &mut result)?;
return self.last_frame_result(context, result);
};
frame.return_result(context, result)?;
}
}
}