diff --git a/crates/context/interface/src/block.rs b/crates/context/interface/src/block.rs index fb8d996d01..956d6dfe60 100644 --- a/crates/context/interface/src/block.rs +++ b/crates/context/interface/src/block.rs @@ -4,6 +4,7 @@ pub use blob::{calc_blob_gasprice, calc_excess_blob_gas, BlobExcessGasAndPrice}; use auto_impl::auto_impl; use primitives::{Address, B256, U256}; +use std::boxed::Box; /// Trait for retrieving block information required for execution. #[auto_impl(&, &mut, Box, Arc)] @@ -79,3 +80,15 @@ pub trait BlockGetter { pub trait BlockSetter: BlockGetter { fn set_block(&mut self, block: ::Block); } + +impl BlockSetter for &mut T { + fn set_block(&mut self, block: ::Block) { + (**self).set_block(block) + } +} + +impl BlockSetter for Box { + fn set_block(&mut self, block: ::Block) { + (**self).set_block(block) + } +} diff --git a/crates/context/interface/src/errors.rs b/crates/context/interface/src/errors.rs index ff4c078dc7..c5d2f461a9 100644 --- a/crates/context/interface/src/errors.rs +++ b/crates/context/interface/src/errors.rs @@ -1,4 +1,7 @@ +use auto_impl::auto_impl; + // TODO : Change the name of the trait +#[auto_impl(&mut, Box)] pub trait ErrorGetter { type Error; diff --git a/crates/context/interface/src/host.rs b/crates/context/interface/src/host.rs index de2a2d127d..22981d8dfc 100644 --- a/crates/context/interface/src/host.rs +++ b/crates/context/interface/src/host.rs @@ -5,28 +5,16 @@ pub use dummy::DummyHost; use crate::{ journaled_state::{AccountLoad, Eip7702CodeLoad}, - Block, Cfg, Transaction, + BlockGetter, CfgGetter, TransactionGetter, }; +use auto_impl::auto_impl; use primitives::{Address, Bytes, Log, B256, U256}; /// EVM context host. // TODO : Move to context-interface -pub trait Host { - /// Chain specification - type BLOCK: Block; - type TX: Transaction; - type CFG: Cfg; - - /// Returns a reference to the environment. - fn tx(&self) -> &Self::TX; - - /// Returns a mutable reference to the environment. - fn block(&self) -> &Self::BLOCK; - - // TODO : Make it generic in future - fn cfg(&self) -> &Self::CFG; - - /// Loads an account code. +#[auto_impl(&mut, Box)] +pub trait Host: TransactionGetter + BlockGetter + CfgGetter { + /// Load an account code. fn load_account_delegated(&mut self, address: Address) -> Option; /// Gets the block hash of the given block `number`. diff --git a/crates/context/interface/src/host/dummy.rs b/crates/context/interface/src/host/dummy.rs index da19a89c62..41781d5373 100644 --- a/crates/context/interface/src/host/dummy.rs +++ b/crates/context/interface/src/host/dummy.rs @@ -1,5 +1,5 @@ use super::{Host, SStoreResult, SelfDestructResult}; -use crate::{Block, Cfg, Transaction}; +use crate::{Block, BlockGetter, Cfg, CfgGetter, Transaction, TransactionGetter}; use primitives::{hash_map::Entry, Address, Bytes, HashMap, Log, B256, KECCAK_EMPTY, U256}; use std::vec::Vec; @@ -48,26 +48,31 @@ where } } -impl Host for DummyHost { - type TX = TX; - type BLOCK = BLOCK; - type CFG = CFG; +impl BlockGetter for DummyHost { + type Block = BLOCK; - #[inline] - fn tx(&self) -> &Self::TX { - &self.tx + fn block(&self) -> &Self::Block { + &self.block } +} - #[inline] - fn block(&self) -> &Self::BLOCK { - &self.block +impl TransactionGetter for DummyHost { + type Transaction = TX; + + fn tx(&self) -> &Self::Transaction { + &self.tx } +} - #[inline] - fn cfg(&self) -> &Self::CFG { +impl CfgGetter for DummyHost { + type Cfg = CFG; + + fn cfg(&self) -> &Self::Cfg { &self.cfg } +} +impl Host for DummyHost { #[inline] fn load_account_delegated(&mut self, _address: Address) -> Option { Some(AccountLoad::default()) diff --git a/crates/context/interface/src/journaled_state.rs b/crates/context/interface/src/journaled_state.rs index 2841298a9a..7ec3f4840a 100644 --- a/crates/context/interface/src/journaled_state.rs +++ b/crates/context/interface/src/journaled_state.rs @@ -286,28 +286,38 @@ impl Eip7702CodeLoad { } } -/// Helper that extracts database error from [`JournalStateGetter`] -pub type JournalStateGetterDBError = - <<::Journal as Journal>::Database as Database>::Error; +/// Helper that extracts database error from [`JournalGetter`]. +pub type JournalDBError = + <<::Journal as Journal>::Database as Database>::Error; -pub trait JournalStateGetter: DatabaseGetter { +pub trait JournalGetter: DatabaseGetter { type Journal: Journal::Database>; fn journal(&mut self) -> &mut Self::Journal; + + fn journal_ref(&self) -> &Self::Journal; } -impl JournalStateGetter for &mut T { +impl JournalGetter for &mut T { type Journal = T::Journal; fn journal(&mut self) -> &mut Self::Journal { T::journal(*self) } + + fn journal_ref(&self) -> &Self::Journal { + T::journal_ref(*self) + } } -impl JournalStateGetter for Box { +impl JournalGetter for Box { type Journal = T::Journal; fn journal(&mut self) -> &mut Self::Journal { T::journal(self.as_mut()) } + + fn journal_ref(&self) -> &Self::Journal { + T::journal_ref(self.as_ref()) + } } diff --git a/crates/context/interface/src/lib.rs b/crates/context/interface/src/lib.rs index 7272d38768..8176798392 100644 --- a/crates/context/interface/src/lib.rs +++ b/crates/context/interface/src/lib.rs @@ -17,5 +17,5 @@ pub use block::{Block, BlockGetter}; pub use cfg::{Cfg, CfgGetter, CreateScheme, TransactTo}; pub use database_interface::{DBErrorMarker, Database, DatabaseGetter}; pub use errors::ErrorGetter; -pub use journaled_state::{Journal, JournalStateGetter, JournalStateGetterDBError}; +pub use journaled_state::{Journal, JournalDBError, JournalGetter}; pub use transaction::{Transaction, TransactionGetter, TransactionType}; diff --git a/crates/context/interface/src/transaction.rs b/crates/context/interface/src/transaction.rs index db59b2bd17..dc70c29010 100644 --- a/crates/context/interface/src/transaction.rs +++ b/crates/context/interface/src/transaction.rs @@ -20,6 +20,7 @@ use auto_impl::auto_impl; use core::cmp::min; use core::fmt::Debug; use primitives::{TxKind, U256}; +use std::boxed::Box; /// Transaction validity error types. pub trait TransactionError: Debug + core::error::Error {} @@ -164,3 +165,15 @@ pub trait TransactionGetter { pub trait TransactionSetter: TransactionGetter { fn set_tx(&mut self, tx: ::Transaction); } + +impl TransactionSetter for &mut T { + fn set_tx(&mut self, block: ::Transaction) { + (**self).set_tx(block) + } +} + +impl TransactionSetter for Box { + fn set_tx(&mut self, block: ::Transaction) { + (**self).set_tx(block) + } +} diff --git a/crates/context/src/context.rs b/crates/context/src/context.rs index 125e34706e..21383a0713 100644 --- a/crates/context/src/context.rs +++ b/crates/context/src/context.rs @@ -5,7 +5,7 @@ use context_interface::{ journaled_state::{AccountLoad, Eip7702CodeLoad}, result::EVMError, transaction::TransactionSetter, - Block, BlockGetter, Cfg, CfgGetter, DatabaseGetter, ErrorGetter, Journal, JournalStateGetter, + Block, BlockGetter, Cfg, CfgGetter, DatabaseGetter, ErrorGetter, Journal, JournalGetter, Transaction, TransactionGetter, }; use database_interface::{Database, EmptyDB}; @@ -24,17 +24,17 @@ pub struct Context< JOURNAL: Journal = JournaledState, CHAIN = (), > { - /// Transaction information - pub tx: TX, - /// Block information + /// Block information. pub block: BLOCK, - /// Configurations + /// Transaction information. + pub tx: TX, + /// Configurations. pub cfg: CFG, - /// EVM State with journaling support and database + /// EVM State with journaling support and database. pub journaled_state: JOURNAL, - /// Inner context + /// Inner context. pub chain: CHAIN, - /// Error that happened during execution + /// Error that happened during execution. pub error: Result<(), ::Error>, } @@ -380,22 +380,6 @@ where DB: Database, JOURNAL: Journal, { - type BLOCK = BLOCK; - type TX = TX; - type CFG = CFG; - - fn tx(&self) -> &Self::TX { - &self.tx - } - - fn block(&self) -> &Self::BLOCK { - &self.block - } - - fn cfg(&self) -> &Self::CFG { - &self.cfg - } - fn block_hash(&mut self, requested_number: u64) -> Option { let block_number = as_u64_saturated!(*self.block().number()); @@ -498,7 +482,7 @@ impl, CHAIN> } } -impl JournalStateGetter +impl JournalGetter for Context where DB: Database, @@ -509,6 +493,10 @@ where fn journal(&mut self) -> &mut Self::Journal { &mut self.journaled_state } + + fn journal_ref(&self) -> &Self::Journal { + &self.journaled_state + } } impl DatabaseGetter diff --git a/crates/context/src/default.rs b/crates/context/src/default.rs deleted file mode 100644 index 79e4dd0892..0000000000 --- a/crates/context/src/default.rs +++ /dev/null @@ -1,3 +0,0 @@ -pub mod block; -pub mod cfg; -pub mod tx; diff --git a/crates/database/interface/src/lib.rs b/crates/database/interface/src/lib.rs index 9e2fc53fa3..d1678b6be5 100644 --- a/crates/database/interface/src/lib.rs +++ b/crates/database/interface/src/lib.rs @@ -10,6 +10,7 @@ use core::convert::Infallible; use auto_impl::auto_impl; use primitives::{Address, HashMap, B256, U256}; use state::{Account, AccountInfo, Bytecode}; +use std::string::String; #[cfg(feature = "asyncdb")] pub mod async_db; @@ -28,6 +29,7 @@ pub trait DBErrorMarker {} /// Implement marker for `()`. impl DBErrorMarker for () {} impl DBErrorMarker for Infallible {} +impl DBErrorMarker for String {} /// EVM database interface. #[auto_impl(&mut, Box)] diff --git a/crates/handler/src/execution.rs b/crates/handler/src/execution.rs index 2eab8c1a1c..e265cd0d5e 100644 --- a/crates/handler/src/execution.rs +++ b/crates/handler/src/execution.rs @@ -1,8 +1,8 @@ use super::{frame_data::FrameResult, EthFrame, EthPrecompileProvider}; use bytecode::EOF_MAGIC_BYTES; use context_interface::{ - result::InvalidTransaction, BlockGetter, Cfg, CfgGetter, ErrorGetter, JournalStateGetter, - JournalStateGetterDBError, Transaction, TransactionGetter, + result::InvalidTransaction, BlockGetter, Cfg, CfgGetter, ErrorGetter, JournalDBError, + JournalGetter, Transaction, TransactionGetter, }; use handler_interface::{util::FrameOrFrameResult, ExecutionHandler, Frame as FrameTrait}; use interpreter::{ @@ -125,30 +125,24 @@ impl EthExecution { } pub trait EthExecutionContext: - TransactionGetter + ErrorGetter + BlockGetter + JournalStateGetter + CfgGetter + TransactionGetter + ErrorGetter + BlockGetter + JournalGetter + CfgGetter { } impl< ERROR, - T: TransactionGetter - + ErrorGetter - + BlockGetter - + JournalStateGetter - + CfgGetter, + T: TransactionGetter + ErrorGetter + BlockGetter + JournalGetter + CfgGetter, > EthExecutionContext for T { } -pub trait EthExecutionError: - From + From> +pub trait EthExecutionError: + From + From> { } -impl< - CTX: JournalStateGetter, - T: From + From>, - > EthExecutionError for T +impl + From>> + EthExecutionError for T { } diff --git a/crates/handler/src/frame.rs b/crates/handler/src/frame.rs index 0d4ace11d0..df37db4274 100644 --- a/crates/handler/src/frame.rs +++ b/crates/handler/src/frame.rs @@ -2,8 +2,8 @@ use super::frame_data::*; use bytecode::{Eof, EOF_MAGIC_BYTES}; use context_interface::{ journaled_state::{Journal, JournalCheckpoint}, - BlockGetter, Cfg, CfgGetter, ErrorGetter, JournalStateGetter, JournalStateGetterDBError, - Transaction, TransactionGetter, + BlockGetter, Cfg, CfgGetter, ErrorGetter, JournalDBError, JournalGetter, Transaction, + TransactionGetter, }; use core::{cell::RefCell, cmp::min}; use handler_interface::{Frame, FrameOrResultGen, PrecompileProvider}; @@ -45,7 +45,7 @@ pub struct EthFrame impl EthFrame where - CTX: JournalStateGetter, + CTX: JournalGetter, IW: InterpreterTypes, { pub fn new( @@ -792,7 +792,7 @@ pub fn return_eofcreate( } pub trait EthFrameContext: - TransactionGetter + Host + ErrorGetter + BlockGetter + JournalStateGetter + CfgGetter + TransactionGetter + Host + ErrorGetter + BlockGetter + JournalGetter + CfgGetter { } @@ -801,19 +801,19 @@ impl< CTX: TransactionGetter + ErrorGetter + BlockGetter - + JournalStateGetter + + JournalGetter + CfgGetter + Host, > EthFrameContext for CTX { } -pub trait EthFrameError: - From> + From +pub trait EthFrameError: + From> + From { } -impl> + From> - EthFrameError for T +impl> + From> EthFrameError + for T { } diff --git a/crates/handler/src/lib.rs b/crates/handler/src/lib.rs index 2435b47861..c7967abcbd 100644 --- a/crates/handler/src/lib.rs +++ b/crates/handler/src/lib.rs @@ -42,8 +42,7 @@ use context_interface::{ result::{HaltReason, InvalidHeader, InvalidTransaction}, }; use context_interface::{ - BlockGetter, CfgGetter, ErrorGetter, JournalStateGetter, JournalStateGetterDBError, - TransactionGetter, + BlockGetter, CfgGetter, ErrorGetter, JournalDBError, JournalGetter, TransactionGetter, }; use handler_interface::{ ExecutionHandler, Handler, PostExecutionHandler, PreExecutionHandler, ValidationHandler, @@ -102,14 +101,14 @@ impl Handler where CTX: TransactionGetter + BlockGetter - + JournalStateGetter + + JournalGetter + CfgGetter + ErrorGetter - + JournalStateGetter)>> + + JournalGetter)>> + Host, ERROR: From + From - + From> + + From> + From, VAL: ValidationHandler, PREEXEC: PreExecutionHandler, diff --git a/crates/handler/src/post_execution.rs b/crates/handler/src/post_execution.rs index cb988b586b..217ce4ce17 100644 --- a/crates/handler/src/post_execution.rs +++ b/crates/handler/src/post_execution.rs @@ -1,8 +1,8 @@ use context_interface::{ journaled_state::Journal, result::{ExecutionResult, HaltReasonTrait, ResultAndState}, - Block, BlockGetter, Cfg, CfgGetter, ErrorGetter, JournalStateGetter, JournalStateGetterDBError, - Transaction, TransactionGetter, + Block, BlockGetter, Cfg, CfgGetter, ErrorGetter, JournalDBError, JournalGetter, Transaction, + TransactionGetter, }; use handler_interface::PostExecutionHandler; use interpreter::SuccessOrHalt; @@ -170,7 +170,7 @@ pub trait EthPostExecutionContext: TransactionGetter + ErrorGetter + BlockGetter - + JournalStateGetter)>> + + JournalGetter)>> + CfgGetter { } @@ -180,18 +180,12 @@ impl< CTX: TransactionGetter + ErrorGetter + BlockGetter - + JournalStateGetter)>> + + JournalGetter)>> + CfgGetter, > EthPostExecutionContext for CTX { } -pub trait EthPostExecutionError: - From> -{ -} +pub trait EthPostExecutionError: From> {} -impl>> - EthPostExecutionError for ERROR -{ -} +impl>> EthPostExecutionError for ERROR {} diff --git a/crates/handler/src/pre_execution.rs b/crates/handler/src/pre_execution.rs index 665827328f..ccda8ee2ae 100644 --- a/crates/handler/src/pre_execution.rs +++ b/crates/handler/src/pre_execution.rs @@ -9,8 +9,7 @@ use context_interface::{ transaction::{ eip7702::Authorization, AccessListTrait, Eip4844Tx, Eip7702Tx, Transaction, TransactionType, }, - Block, BlockGetter, Cfg, CfgGetter, JournalStateGetter, JournalStateGetterDBError, - TransactionGetter, + Block, BlockGetter, Cfg, CfgGetter, JournalDBError, JournalGetter, TransactionGetter, }; use handler_interface::PreExecutionHandler; use primitives::{Address, BLOCKHASH_STORAGE_ADDRESS, U256}; @@ -121,8 +120,8 @@ where /// Apply EIP-7702 auth list and return number gas refund on already created accounts. #[inline] pub fn apply_eip7702_auth_list< - CTX: TransactionGetter + JournalStateGetter + CfgGetter, - ERROR: From + From>, + CTX: TransactionGetter + JournalGetter + CfgGetter, + ERROR: From + From>, >( context: &mut CTX, ) -> Result { @@ -203,23 +202,21 @@ pub fn apply_eip7702_auth_list< } pub trait EthPreExecutionContext: - TransactionGetter + BlockGetter + JournalStateGetter + CfgGetter + TransactionGetter + BlockGetter + JournalGetter + CfgGetter { } -impl EthPreExecutionContext +impl EthPreExecutionContext for CTX { } -pub trait EthPreExecutionError: - From + From> +pub trait EthPreExecutionError: + From + From> { } -impl< - CTX: JournalStateGetter, - T: From + From>, - > EthPreExecutionError for T +impl + From>> + EthPreExecutionError for T { } diff --git a/crates/handler/src/validation.rs b/crates/handler/src/validation.rs index 6ac4d52848..0b61c07ce9 100644 --- a/crates/handler/src/validation.rs +++ b/crates/handler/src/validation.rs @@ -5,8 +5,7 @@ use context_interface::{ eip7702::Authorization, Eip1559CommonTxFields, Eip2930Tx, Eip4844Tx, Eip7702Tx, LegacyTx, Transaction, TransactionType, }, - Block, BlockGetter, Cfg, CfgGetter, JournalStateGetter, JournalStateGetterDBError, - TransactionGetter, + Block, BlockGetter, Cfg, CfgGetter, JournalDBError, JournalGetter, TransactionGetter, }; use core::cmp::{self, Ordering}; use handler_interface::ValidationHandler; @@ -43,7 +42,7 @@ impl EthValidation { impl ValidationHandler for EthValidation where CTX: EthValidationContext, - ERROR: From + From + From>, + ERROR: From + From + From>, { type Context = CTX; type Error = ERROR; @@ -385,24 +384,21 @@ where /// Helper trait that summarizes ValidationHandler requirements from Context. pub trait EthValidationContext: - TransactionGetter + BlockGetter + JournalStateGetter + CfgGetter + TransactionGetter + BlockGetter + JournalGetter + CfgGetter { } -impl EthValidationContext - for T -{ -} +impl EthValidationContext for T {} /// Helper trait that summarizes all possible requirements by EthValidation. -pub trait EthValidationError: - From + From + From> +pub trait EthValidationError: + From + From + From> { } impl< - CTX: JournalStateGetter, - T: From + From + From>, + CTX: JournalGetter, + T: From + From + From>, > EthValidationError for T { } diff --git a/crates/inspector/src/eip3155.rs b/crates/inspector/src/eip3155.rs index dfc225e9c0..188f356425 100644 --- a/crates/inspector/src/eip3155.rs +++ b/crates/inspector/src/eip3155.rs @@ -3,7 +3,7 @@ use derive_where::derive_where; use revm::{ bytecode::opcode::OpCode, context::Cfg, - context_interface::{CfgGetter, Journal, JournalStateGetter, Transaction, TransactionGetter}, + context_interface::{CfgGetter, Journal, JournalGetter, Transaction, TransactionGetter}, interpreter::{ interpreter_types::{Jumps, LoopControl, MemoryTrait, StackTrait}, CallInputs, CallOutcome, CreateInputs, CreateOutcome, Interpreter, InterpreterResult, @@ -197,14 +197,11 @@ impl CloneStack for Stack { } } -impl Inspector for TracerEip3155 +impl Inspector for TracerEip3155 where - CTX: CfgGetter + TransactionGetter + JournalStateGetter, + CTX: CfgGetter + TransactionGetter + JournalGetter, INTR: InterpreterTypes, { - type Context = CTX; - type InterpreterTypes = INTR; - fn initialize_interp(&mut self, interp: &mut Interpreter, _: &mut CTX) { self.gas_inspector.initialize_interp(interp.control.gas()); } diff --git a/crates/inspector/src/inspector.rs b/crates/inspector/src/inspector.rs index e4affa64a0..be25d415b3 100644 --- a/crates/inspector/src/inspector.rs +++ b/crates/inspector/src/inspector.rs @@ -1,16 +1,14 @@ use auto_impl::auto_impl; use core::mem::MaybeUninit; -use derive_where::derive_where; use revm::{ bytecode::opcode::OpCode, - context::{block::BlockEnv, cfg::CfgEnv, tx::TxEnv, Cfg, JournaledState}, + context::JournaledState, context_interface::{ block::BlockSetter, journaled_state::{AccountLoad, Eip7702CodeLoad}, - result::EVMError, transaction::TransactionSetter, - Block, BlockGetter, CfgGetter, DatabaseGetter, ErrorGetter, Journal, JournalStateGetter, - JournalStateGetterDBError, Transaction, TransactionGetter, + BlockGetter, CfgGetter, DatabaseGetter, ErrorGetter, Journal, JournalDBError, + JournalGetter, TransactionGetter, }, database_interface::{Database, EmptyDB}, handler::{ @@ -29,27 +27,19 @@ use revm::{ }, precompile::PrecompileErrors, primitives::{Address, Bytes, Log, B256, U256}, - specification::hardfork::SpecId, Context, Error, Evm, JournalEntry, }; use std::{rc::Rc, vec::Vec}; /// EVM [Interpreter] callbacks. #[auto_impl(&mut, Box)] -pub trait Inspector { - type Context; - type InterpreterTypes: InterpreterTypes; - +pub trait Inspector { /// Called before the interpreter is initialized. /// /// If `interp.instruction_result` is set to anything other than [revm::interpreter::InstructionResult::Continue] then the execution of the interpreter /// is skipped. #[inline] - fn initialize_interp( - &mut self, - interp: &mut Interpreter, - context: &mut Self::Context, - ) { + fn initialize_interp(&mut self, interp: &mut Interpreter, context: &mut CTX) { let _ = interp; let _ = context; } @@ -63,11 +53,7 @@ pub trait Inspector { /// /// To get the current opcode, use `interp.current_opcode()`. #[inline] - fn step( - &mut self, - interp: &mut Interpreter, - context: &mut Self::Context, - ) { + fn step(&mut self, interp: &mut Interpreter, context: &mut CTX) { let _ = interp; let _ = context; } @@ -77,23 +63,14 @@ pub trait Inspector { /// Setting `interp.instruction_result` to anything other than [revm::interpreter::InstructionResult::Continue] alters the execution /// of the interpreter. #[inline] - fn step_end( - &mut self, - interp: &mut Interpreter, - context: &mut Self::Context, - ) { + fn step_end(&mut self, interp: &mut Interpreter, context: &mut CTX) { let _ = interp; let _ = context; } /// Called when a log is emitted. #[inline] - fn log( - &mut self, - interp: &mut Interpreter, - context: &mut Self::Context, - log: &Log, - ) { + fn log(&mut self, interp: &mut Interpreter, context: &mut CTX, log: &Log) { let _ = interp; let _ = context; let _ = log; @@ -103,11 +80,7 @@ pub trait Inspector { /// /// InstructionResulting anything other than [revm::interpreter::InstructionResult::Continue] overrides the result of the call. #[inline] - fn call( - &mut self, - context: &mut Self::Context, - inputs: &mut CallInputs, - ) -> Option { + fn call(&mut self, context: &mut CTX, inputs: &mut CallInputs) -> Option { let _ = context; let _ = inputs; None @@ -119,12 +92,7 @@ pub trait Inspector { /// /// This allows the inspector to modify the given `result` before returning it. #[inline] - fn call_end( - &mut self, - context: &mut Self::Context, - inputs: &CallInputs, - outcome: &mut CallOutcome, - ) { + fn call_end(&mut self, context: &mut CTX, inputs: &CallInputs, outcome: &mut CallOutcome) { let _ = context; let _ = inputs; let _ = outcome; @@ -136,11 +104,7 @@ pub trait Inspector { /// /// If this returns `None` then the creation proceeds as normal. #[inline] - fn create( - &mut self, - context: &mut Self::Context, - inputs: &mut CreateInputs, - ) -> Option { + fn create(&mut self, context: &mut CTX, inputs: &mut CreateInputs) -> Option { let _ = context; let _ = inputs; None @@ -153,7 +117,7 @@ pub trait Inspector { #[inline] fn create_end( &mut self, - context: &mut Self::Context, + context: &mut CTX, inputs: &CreateInputs, outcome: &mut CreateOutcome, ) { @@ -167,7 +131,7 @@ pub trait Inspector { /// This can happen from create TX or from EOFCREATE opcode. fn eofcreate( &mut self, - context: &mut Self::Context, + context: &mut CTX, inputs: &mut EOFCreateInputs, ) -> Option { let _ = context; @@ -178,7 +142,7 @@ pub trait Inspector { /// Called when eof creating has ended. fn eofcreate_end( &mut self, - context: &mut Self::Context, + context: &mut CTX, inputs: &EOFCreateInputs, outcome: &mut CreateOutcome, ) { @@ -197,10 +161,9 @@ pub trait Inspector { } /// Provides access to an `Inspector` instance. -pub trait GetInspector { - type Inspector: Inspector; +pub trait GetInspector { /// Returns the associated `Inspector`. - fn get_inspector(&mut self) -> &mut Self::Inspector; + fn get_inspector(&mut self) -> &mut impl Inspector; } pub trait InspectorCtx { @@ -215,41 +178,36 @@ pub trait InspectorCtx { fn inspector_log(&mut self, interp: &mut Interpreter, log: &Log); } -impl GetInspector for INSP { - type Inspector = INSP; +impl> GetInspector for INSP { #[inline] - fn get_inspector(&mut self) -> &mut Self::Inspector { + fn get_inspector(&mut self) -> &mut impl Inspector { self } } /// EVM context contains data that EVM needs for execution. -#[derive_where(Clone, Debug; INSP, BLOCK, CFG, CHAIN, TX, DB,JOURNAL, ::Error)] -pub struct InspectorContext< - INSP, - BLOCK = BlockEnv, - TX = TxEnv, - CFG = CfgEnv, - DB: Database = EmptyDB, - JOURNAL: Journal = JournaledState, - CHAIN = (), -> { - pub inner: Context, +#[derive(Clone, Debug)] +pub struct InspectorContext +where + CTX: DatabaseGetter, +{ pub inspector: INSP, + pub inner: CTX, pub frame_input_stack: Vec, } -impl< - INSP, - BLOCK: Block, - TX: Transaction, - CFG: Cfg, - DB: Database, - JOURNAL: Journal, - CHAIN, - > InspectorContext +impl InspectorContext +where + CTX: BlockGetter + + TransactionGetter + + CfgGetter + + DatabaseGetter + + JournalGetter + + ErrorGetter + + Host + + ErrorGetter, { - pub fn new(inner: Context, inspector: INSP) -> Self { + pub fn new(inner: CTX, inspector: INSP) -> Self { Self { inner, inspector, @@ -258,32 +216,10 @@ impl< } } -impl< - INSP: GetInspector, - BLOCK: Block, - TX: Transaction, - CFG: Cfg, - DB: Database, - JOURNAL: Journal, - CHAIN, - > Host for InspectorContext +impl, DB, CTX> Host for InspectorContext +where + CTX: Host + DatabaseGetter, { - type BLOCK = BLOCK; - type TX = TX; - type CFG = CFG; - - fn tx(&self) -> &Self::TX { - &self.inner.tx - } - - fn block(&self) -> &Self::BLOCK { - &self.inner.block - } - - fn cfg(&self) -> &Self::CFG { - &self.inner.cfg - } - fn block_hash(&mut self, requested_number: u64) -> Option { self.inner.block_hash(requested_number) } @@ -297,12 +233,11 @@ impl< } fn code(&mut self, address: Address) -> Option> { - // TODO : Remove duplicated function name. - as Host>::code(&mut self.inner, address) + self.inner.code(address) } fn code_hash(&mut self, address: Address) -> Option> { - as Host>::code_hash(&mut self.inner, address) + self.inner.code_hash(address) } fn sload(&mut self, address: Address, index: U256) -> Option> { @@ -339,15 +274,10 @@ impl< } } -impl, CHAIN> InspectorCtx - for InspectorContext +impl InspectorCtx for InspectorContext where - INSP: GetInspector< - Inspector: Inspector< - Context = Context, - InterpreterTypes = EthInterpreter, - >, - >, + INSP: GetInspector, + CTX: DatabaseGetter, { type IT = EthInterpreter<()>; @@ -429,96 +359,114 @@ where } } -impl, CHAIN> CfgGetter - for InspectorContext +impl CfgGetter for InspectorContext +where + CTX: CfgGetter + DatabaseGetter, { - type Cfg = CFG; + type Cfg = ::Cfg; fn cfg(&self) -> &Self::Cfg { - &self.inner.cfg + self.inner.cfg() } } -impl, CHAIN> JournalStateGetter - for InspectorContext +impl JournalGetter for InspectorContext +where + CTX: JournalGetter + DatabaseGetter, + DB: Database, { - type Journal = JOURNAL; + type Journal = ::Journal; fn journal(&mut self) -> &mut Self::Journal { - &mut self.inner.journaled_state + self.inner.journal() + } + + fn journal_ref(&self) -> &Self::Journal { + self.inner.journal_ref() } } -impl, CHAIN> DatabaseGetter - for InspectorContext +impl DatabaseGetter for InspectorContext +where + CTX: DatabaseGetter, + DB: Database, { - type Database = DB; + type Database = ::Database; fn db(&mut self) -> &mut Self::Database { - self.inner.journaled_state.db_mut() + self.inner.db() } } -impl, CHAIN> - ErrorGetter for InspectorContext +impl ErrorGetter for InspectorContext +where + CTX: ErrorGetter + DatabaseGetter, { - type Error = EVMError; + type Error = ::Error; fn take_error(&mut self) -> Result<(), Self::Error> { - core::mem::replace(&mut self.inner.error, Ok(())).map_err(EVMError::Database) + self.inner.take_error() } } -impl, CHAIN> - TransactionGetter for InspectorContext +impl TransactionGetter for InspectorContext +where + CTX: TransactionGetter + DatabaseGetter, { - type Transaction = TX; + type Transaction = ::Transaction; fn tx(&self) -> &Self::Transaction { - &self.inner.tx + self.inner.tx() } } -impl, CHAIN> - TransactionSetter for InspectorContext +impl TransactionSetter for InspectorContext +where + CTX: TransactionSetter + DatabaseGetter, { fn set_tx(&mut self, tx: ::Transaction) { - self.inner.tx = tx; + self.inner.set_tx(tx); } } -impl, CHAIN> BlockGetter - for InspectorContext +impl BlockGetter for InspectorContext +where + CTX: BlockGetter + DatabaseGetter, { - type Block = BLOCK; + type Block = ::Block; fn block(&self) -> &Self::Block { - &self.inner.block + self.inner.block() } } -impl, CHAIN> BlockSetter - for InspectorContext +impl BlockSetter for InspectorContext +where + CTX: BlockSetter + DatabaseGetter, { fn set_block(&mut self, block: ::Block) { - self.inner.block = block; + self.inner.set_block(block); } } -impl< - INSP, - BLOCK: Block, - TX, - CFG, - DB: Database, - JOURNAL: Journal + JournalExt, - CHAIN, - > JournalExtGetter for InspectorContext +impl JournalExtGetter for InspectorContext +where + CTX: JournalExtGetter + DatabaseGetter, +{ + type JournalExt = ::JournalExt; + + fn journal_ext(&self) -> &Self::JournalExt { + self.inner.journal_ext() + } +} + +impl + JournalExt, CHAIN> + JournalExtGetter for Context { type JournalExt = JOURNAL; fn journal_ext(&self) -> &Self::JournalExt { - &self.inner.journaled_state + &self.journaled_state } } @@ -601,7 +549,7 @@ pub trait JournalExtGetter { impl InstructionProvider for InspectorInstructionProvider where WIRE: InterpreterTypes, - HOST: Host + JournalExtGetter + JournalStateGetter + InspectorCtx, + HOST: Host + JournalExtGetter + JournalGetter + InspectorCtx, { type WIRE = WIRE; type Host = HOST; @@ -719,12 +667,12 @@ where CTX: TransactionGetter + ErrorGetter + BlockGetter - + JournalStateGetter + + JournalGetter + CfgGetter + JournalExtGetter + Host + InspectorCtx, - ERROR: From> + From, + ERROR: From> + From, PRECOMPILE: PrecompileProvider, { type Context = CTX; @@ -733,7 +681,7 @@ where type FrameResult = FrameResult; fn init_first( - context: &mut Self::Context, + context: &mut CTX, mut frame_input: Self::FrameInit, ) -> Result, Self::Error> { if let Some(output) = context.frame_start(&mut frame_input) { @@ -757,7 +705,7 @@ where fn init( &self, - context: &mut Self::Context, + context: &mut CTX, mut frame_input: Self::FrameInit, ) -> Result, Self::Error> { if let Some(output) = context.frame_start(&mut frame_input) { @@ -779,14 +727,14 @@ where fn run( &mut self, - context: &mut Self::Context, + context: &mut CTX, ) -> Result, Self::Error> { self.eth_frame.run(context) } fn return_result( &mut self, - context: &mut Self::Context, + context: &mut CTX, mut result: Self::FrameResult, ) -> Result<(), Self::Error> { context.frame_end(&mut result); @@ -794,31 +742,17 @@ where } } -pub type InspCtxType< - INSP, - DB, - BLOCK = BlockEnv, - TX = TxEnv, - CFG = CfgEnv, - JOURNAL = JournaledState, -> = InspectorContext; - -pub type InspectorMainEvm< - DB, - INSP, - BLOCK = BlockEnv, - TX = TxEnv, - CFG = CfgEnv, - JOURNAL = JournaledState, -> = Evm< +pub type InspCtxType = InspectorContext; + +pub type InspectorMainEvm = Evm< Error, - InspCtxType, + InspCtxType, EthHandler< - InspCtxType, + InspCtxType, Error, - EthValidation, Error>, - EthPreExecution, Error>, - InspectorEthExecution, Error>, + EthValidation, Error>, + EthPreExecution, Error>, + InspectorEthExecution, Error>, >, >; diff --git a/crates/inspector/src/noop.rs b/crates/inspector/src/noop.rs index f79cff76a1..8119182bda 100644 --- a/crates/inspector/src/noop.rs +++ b/crates/inspector/src/noop.rs @@ -4,11 +4,6 @@ use crate::Inspector; /// Dummy [Inspector], helpful as standalone replacement. #[derive(Clone, Copy, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)] -pub struct NoOpInspector { - _phantom: core::marker::PhantomData<(CTX, INTR)>, -} +pub struct NoOpInspector {} -impl Inspector for NoOpInspector { - type Context = CTX; - type InterpreterTypes = INTR; -} +impl Inspector for NoOpInspector {} diff --git a/crates/interpreter/src/interpreter/input.rs b/crates/interpreter/src/interpreter/input.rs index d3f2e21e56..5b148c6497 100644 --- a/crates/interpreter/src/interpreter/input.rs +++ b/crates/interpreter/src/interpreter/input.rs @@ -4,6 +4,7 @@ use primitives::{Address, Bytes, U256}; use serde::{Deserialize, Serialize}; #[cfg_attr(feature = "serde", derive(Serialize, Deserialize))] +#[derive(Clone, Debug, Default, PartialEq, Eq)] pub struct InputsImpl { pub target_address: Address, pub caller_address: Address, diff --git a/crates/optimism/src/evm.rs b/crates/optimism/src/evm.rs index 01d0148447..392986cffd 100644 --- a/crates/optimism/src/evm.rs +++ b/crates/optimism/src/evm.rs @@ -21,8 +21,11 @@ pub type OpContext = Context, CfgEnv, /// Optimism EVM type pub type OpEvm = Evm, OpContext, OpHandler, OpError>>; -pub type InspCtxType = - InspectorContext, DB, JournaledState, L1BlockInfo>; +pub type InspCtxType = InspectorContext< + INSP, + DB, + Context, DB, JournaledState, L1BlockInfo>, +>; pub type InspectorOpEvm = Evm< OpError, diff --git a/crates/revm/src/evm.rs b/crates/revm/src/evm.rs index 423fa75c11..af925f81a2 100644 --- a/crates/revm/src/evm.rs +++ b/crates/revm/src/evm.rs @@ -8,8 +8,8 @@ use context_interface::{ ResultAndState, }, transaction::TransactionSetter, - BlockGetter, CfgGetter, DatabaseGetter, ErrorGetter, JournalStateGetter, - JournalStateGetterDBError, Transaction, TransactionGetter, + BlockGetter, CfgGetter, DatabaseGetter, ErrorGetter, JournalDBError, JournalGetter, + Transaction, TransactionGetter, }; use database_interface::{Database, DatabaseCommit}; use handler::{EthHandler, FrameResult}; @@ -45,11 +45,11 @@ impl EvmCommit where CTX: TransactionSetter + BlockSetter - + JournalStateGetter + + JournalGetter + CfgGetter + DatabaseGetter + ErrorGetter - + JournalStateGetter< + + JournalGetter< Journal: Journal< FinalOutput = (EvmState, Vec), Database = ::Database, @@ -57,7 +57,7 @@ where > + Host, ERROR: From + From - + From> + + From> + From, VAL: ValidationHandler, PREEXEC: PreExecutionHandler, @@ -92,11 +92,11 @@ impl EvmExec where CTX: TransactionSetter + BlockSetter - + JournalStateGetter + + JournalGetter + CfgGetter + DatabaseGetter + ErrorGetter - + JournalStateGetter< + + JournalGetter< Journal: Journal< FinalOutput = (EvmState, Vec), Database = ::Database, @@ -104,7 +104,7 @@ where > + Host, ERROR: From + From - + From> + + From> + From, VAL: ValidationHandler, PREEXEC: PreExecutionHandler, @@ -150,11 +150,11 @@ impl where CTX: TransactionGetter + BlockGetter - + JournalStateGetter + + JournalGetter + CfgGetter + DatabaseGetter + ErrorGetter - + JournalStateGetter< + + JournalGetter< Journal: Journal< FinalOutput = (EvmState, Vec), Database = ::Database, @@ -162,7 +162,7 @@ where > + Host, ERROR: From + From - + From> + + From> + From, VAL: ValidationHandler, PREEXEC: PreExecutionHandler,