From f799e59bc3cf42ac9dd8e49f1f56e49cab73bb89 Mon Sep 17 00:00:00 2001 From: Yoav Gross Date: Tue, 19 Nov 2024 10:34:59 +0200 Subject: [PATCH] refactor(blockifier): diff of StateCache is StateChanges --- crates/blockifier/src/blockifier/transaction_executor.rs | 7 ++++++- crates/blockifier/src/concurrency/worker_logic.rs | 2 +- crates/blockifier/src/state/cached_state.rs | 9 +++++---- crates/blockifier/src/state/cached_state_test.rs | 2 +- crates/papyrus_execution/src/execution_utils.rs | 3 ++- 5 files changed, 15 insertions(+), 8 deletions(-) diff --git a/crates/blockifier/src/blockifier/transaction_executor.rs b/crates/blockifier/src/blockifier/transaction_executor.rs index 63887ff9d2..af9d216e1b 100644 --- a/crates/blockifier/src/blockifier/transaction_executor.rs +++ b/crates/blockifier/src/blockifier/transaction_executor.rs @@ -168,7 +168,12 @@ impl TransactionExecutor { log::debug!("Final block weights: {:?}.", self.bouncer.get_accumulated_weights()); Ok(( - self.block_state.as_mut().expect(BLOCK_STATE_ACCESS_ERR).to_state_diff()?.into(), + self.block_state + .as_mut() + .expect(BLOCK_STATE_ACCESS_ERR) + .to_state_diff()? + .state_maps + .into(), visited_segments, *self.bouncer.get_accumulated_weights(), )) diff --git a/crates/blockifier/src/concurrency/worker_logic.rs b/crates/blockifier/src/concurrency/worker_logic.rs index d24d33223d..b66de3b3de 100644 --- a/crates/blockifier/src/concurrency/worker_logic.rs +++ b/crates/blockifier/src/concurrency/worker_logic.rs @@ -139,7 +139,7 @@ impl<'a, S: StateReader> WorkerExecutor<'a, S> { let execution_output_inner = match execution_result { Ok(_) => { let tx_reads_writes = transactional_state.cache.take(); - let writes = tx_reads_writes.to_state_diff(); + let writes = tx_reads_writes.to_state_diff().state_maps; let contract_classes = transactional_state.class_hash_to_class.take(); let visited_pcs = transactional_state.visited_pcs; // The versioned state does not carry the visited PCs. diff --git a/crates/blockifier/src/state/cached_state.rs b/crates/blockifier/src/state/cached_state.rs index 52b8435eb5..f0b903efca 100644 --- a/crates/blockifier/src/state/cached_state.rs +++ b/crates/blockifier/src/state/cached_state.rs @@ -47,7 +47,7 @@ impl CachedState { /// Returns the state diff resulting from the performed writes, with respect to the parent /// state. - pub fn to_state_diff(&mut self) -> StateResult { + pub fn to_state_diff(&mut self) -> StateResult { self.update_initial_values_of_write_only_access()?; Ok(self.cache.borrow().to_state_diff()) } @@ -55,7 +55,7 @@ impl CachedState { // TODO(Yoni, 1/8/2024): remove this function. /// Returns the state changes made on this state. pub fn get_actual_state_changes(&mut self) -> StateResult { - Ok(StateChanges { state_maps: self.to_state_diff()? }) + self.to_state_diff() } pub fn update_cache( @@ -399,8 +399,9 @@ pub struct StateCache { impl StateCache { /// Returns the state diff resulting from the performed writes, with respect to the initial /// reads. Assumes (and enforces) all initial reads are cached. - pub fn to_state_diff(&self) -> StateMaps { - self.writes.diff(&self.initial_reads) + pub fn to_state_diff(&self) -> StateChanges { + let state_maps = self.writes.diff(&self.initial_reads); + StateChanges { state_maps } } fn declare_contract(&mut self, class_hash: ClassHash) { diff --git a/crates/blockifier/src/state/cached_state_test.rs b/crates/blockifier/src/state/cached_state_test.rs index 9d32af747b..f260250115 100644 --- a/crates/blockifier/src/state/cached_state_test.rs +++ b/crates/blockifier/src/state/cached_state_test.rs @@ -286,7 +286,7 @@ fn cached_state_state_diff_conversion() { address_to_nonce: IndexMap::from_iter([(contract_address2, nonce!(1_u64))]), }; - assert_eq!(expected_state_diff, state.to_state_diff().unwrap().into()); + assert_eq!(expected_state_diff, state.to_state_diff().unwrap().state_maps.into()); } fn create_state_changes_for_test( diff --git a/crates/papyrus_execution/src/execution_utils.rs b/crates/papyrus_execution/src/execution_utils.rs index afec631cb1..45e45d16b8 100644 --- a/crates/papyrus_execution/src/execution_utils.rs +++ b/crates/papyrus_execution/src/execution_utils.rs @@ -123,7 +123,8 @@ pub fn induced_state_diff( transactional_state: &mut CachedState>>, deprecated_declared_class_hash: Option, ) -> ExecutionResult { - let blockifier_state_diff = CommitmentStateDiff::from(transactional_state.to_state_diff()?); + let blockifier_state_diff = + CommitmentStateDiff::from(transactional_state.to_state_diff()?.state_maps); // Determine which contracts were deployed and which were replaced by comparing their // previous class hash (default value suggests it didn't exist before). let mut deployed_contracts = IndexMap::new();