revm_interpreter/interpreter_action/call_outcome.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
use crate::{Gas, InstructionResult, InterpreterResult};
use core::ops::Range;
use primitives::Bytes;
/// Represents the outcome of a call operation in a virtual machine.
///
/// This struct encapsulates the result of executing an instruction by an interpreter, including
/// the result itself, gas usage information, and the memory offset where output data is stored.
///
/// # Fields
///
/// * `result` - The result of the interpreter's execution, including output data and gas usage.
/// * `memory_offset` - The range in memory where the output data is located.
#[derive(Clone, Debug, PartialEq, Eq)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct CallOutcome {
pub result: InterpreterResult,
pub memory_offset: Range<usize>,
}
impl CallOutcome {
/// Constructs a new [`CallOutcome`].
///
/// Creates an instance of [`CallOutcome`] with the given interpreter result and memory offset.
///
/// # Arguments
///
/// * `result` - The result of the interpreter's execution.
/// * `memory_offset` - The range in memory indicating where the output data is stored.
pub fn new(result: InterpreterResult, memory_offset: Range<usize>) -> Self {
Self {
result,
memory_offset,
}
}
/// Returns a reference to the instruction result.
///
/// Provides access to the result of the executed instruction.
///
/// # Returns
///
/// A reference to the [`InstructionResult`].
pub fn instruction_result(&self) -> &InstructionResult {
&self.result.result
}
/// Returns the gas usage information.
///
/// Provides access to the gas usage details of the executed instruction.
///
/// # Returns
///
/// An instance of [`Gas`] representing the gas usage.
pub fn gas(&self) -> Gas {
self.result.gas
}
/// Returns a reference to the output data.
///
/// Provides access to the output data generated by the executed instruction.
///
/// # Returns
///
/// A reference to the output data as [`Bytes`].
pub fn output(&self) -> &Bytes {
&self.result.output
}
/// Returns the start position of the memory offset.
///
/// Provides the starting index of the memory range where the output data is stored.
///
/// # Returns
///
/// The starting index of the memory offset as [`usize`].
pub fn memory_start(&self) -> usize {
self.memory_offset.start
}
/// Returns the length of the memory range.
///
/// Provides the length of the memory range where the output data is stored.
///
/// # Returns
///
/// The length of the memory range as [`usize`].
pub fn memory_length(&self) -> usize {
self.memory_offset.len()
}
}