Struct ExtBytecode

Source
pub struct ExtBytecode {
    pub action: Option<InterpreterAction>,
    /* private fields */
}
Expand description

Extended bytecode structure that wraps base bytecode with additional execution metadata.

Fields§

§action: Option<InterpreterAction>

Actions that the EVM should do. It contains return value of the Interpreter or inputs for CALL or CREATE instructions. For RETURN or REVERT instructions it contains the result of the instruction.

Implementations§

Source§

impl ExtBytecode

Source

pub fn new(base: Bytecode) -> Self

Create new extended bytecode and set the instruction pointer to the start of the bytecode.

The bytecode hash will not be calculated.

Source

pub fn new_with_hash(base: Bytecode, hash: B256) -> Self

Creates new ExtBytecode with the given hash.

Source

pub fn new_with_optional_hash(base: Bytecode, hash: Option<B256>) -> Self

Creates new ExtBytecode with the given hash.

Source

pub fn calculate_hash(&mut self) -> B256

Re-calculates the bytecode hash.

Prefer get_or_calculate_hash if you just need to get the hash.

Source

pub fn hash(&mut self) -> Option<B256>

Returns the bytecode hash.

Source

pub fn get_or_calculate_hash(&mut self) -> B256

Returns the bytecode hash or calculates it if it is not set.

Methods from Deref<Target = Bytecode>§

pub fn legacy_jump_table(&self) -> Option<&JumpTable>

Returns jump table if bytecode is analyzed.

pub fn hash_slow(&self) -> FixedBytes<32>

Calculates hash of the bytecode.

pub fn is_eip7702(&self) -> bool

Returns true if bytecode is EIP-7702.

pub fn bytecode(&self) -> &Bytes

Returns a reference to the bytecode.

pub fn bytecode_ptr(&self) -> *const u8

Pointer to the executable bytecode.

pub fn bytes(&self) -> Bytes

Returns bytes.

pub fn bytes_ref(&self) -> &Bytes

Returns raw bytes reference.

pub fn bytes_slice(&self) -> &[u8]

Returns raw bytes slice.

pub fn original_bytes(&self) -> Bytes

Returns the original bytecode.

pub fn original_byte_slice(&self) -> &[u8]

Returns the original bytecode as a byte slice.

pub fn len(&self) -> usize

Returns the length of the original bytes.

pub fn is_empty(&self) -> bool

Returns whether the bytecode is empty.

pub fn iter_opcodes(&self) -> BytecodeIterator<'_>

Returns an iterator over the opcodes in this bytecode, skipping immediates. This is useful if you want to ignore immediates and just see what opcodes are inside.

Trait Implementations§

Source§

impl Debug for ExtBytecode

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for ExtBytecode

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Deref for ExtBytecode

Source§

type Target = Bytecode

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl<'de> Deserialize<'de> for ExtBytecode

Source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Immediates for ExtBytecode

Source§

fn read_u16(&self) -> u16

Reads next 16 bits as unsigned integer from the bytecode.
Source§

fn read_u8(&self) -> u8

Reads next 8 bits as unsigned integer from the bytecode.
Source§

fn read_slice(&self, len: usize) -> &[u8]

Reads next len bytes from the bytecode. Read more
Source§

fn read_offset_u16(&self, offset: isize) -> u16

Reads next 16 bits as unsigned integer from the bytecode at given offset.
Source§

fn read_i16(&self) -> i16

Reads next 16 bits as signed integer from the bytecode.
Source§

fn read_i8(&self) -> i8

Reads next 8 bits as signed integer from the bytecode.
Source§

fn read_offset_i16(&self, offset: isize) -> i16

Reads next 16 bits as signed integer from the bytecode at given offset.
Source§

impl Jumps for ExtBytecode

Source§

fn relative_jump(&mut self, offset: isize)

Relative jumps does not require checking for overflow.
Source§

fn absolute_jump(&mut self, offset: usize)

Absolute jumps require checking for overflow and if target is a jump destination from jump table.
Source§

fn is_valid_legacy_jump(&mut self, offset: usize) -> bool

Check legacy jump destination from jump table.
Source§

fn opcode(&self) -> u8

Returns instruction opcode.
Source§

fn pc(&self) -> usize

Returns current program counter.
Source§

impl LegacyBytecode for ExtBytecode

Source§

fn bytecode_len(&self) -> usize

Returns current bytecode original length. Used in [bytecode::opcode::CODESIZE] opcode.
Source§

fn bytecode_slice(&self) -> &[u8]

Returns current bytecode original slice. Used in [bytecode::opcode::CODECOPY] opcode.
Source§

impl LoopControl for ExtBytecode

Source§

fn is_not_end(&self) -> bool

Returns true if the loop should continue.
Source§

fn reset_action(&mut self)

Sets the end flag internally. Action should be taken after.
Source§

fn set_action(&mut self, action: InterpreterAction)

Set return action.
Source§

fn action(&mut self) -> &mut Option<InterpreterAction>

Returns the current action.
Source§

fn is_end(&self) -> bool

Is end of the loop.
Source§

fn instruction_result(&mut self) -> Option<InstructionResult>

Returns instruction result
Source§

impl Serialize for ExtBytecode

Source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,