mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-12 13:24:21 +00:00
0a8986bc77
Saving both memory and processing, we can move entries from one savepoint to another, specially when the target is empty as it often is during transaction processing
66 lines
1.8 KiB
Nim
66 lines
1.8 KiB
Nim
# Nimbus
|
|
# Copyright (c) 2023-2024 Status Research & Development GmbH
|
|
# Licensed under either of
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
# http://opensource.org/licenses/MIT)
|
|
# at your option. This file may not be copied, modified, or distributed except
|
|
# according to those terms.
|
|
|
|
import
|
|
tables,
|
|
stint,
|
|
eth/common,
|
|
../utils/mergeutils
|
|
|
|
type
|
|
StorageTable = ref object
|
|
map: Table[UInt256, UInt256]
|
|
|
|
TransientStorage* = object
|
|
map: Table[EthAddress, StorageTable]
|
|
|
|
#######################################################################
|
|
# Private helpers
|
|
#######################################################################
|
|
|
|
proc mergeAndReset*(a, b: StorageTable) =
|
|
a.map.mergeAndReset(b.map)
|
|
|
|
#######################################################################
|
|
# Public functions
|
|
#######################################################################
|
|
|
|
proc init*(ac: var TransientStorage) =
|
|
ac.map = Table[EthAddress, StorageTable]()
|
|
|
|
proc init*(_: type TransientStorage): TransientStorage {.inline.} =
|
|
result.init()
|
|
|
|
func getStorage*(ac: TransientStorage,
|
|
address: EthAddress, slot: UInt256): (bool, UInt256) =
|
|
var table = ac.map.getOrDefault(address)
|
|
if table.isNil:
|
|
return (false, 0.u256)
|
|
|
|
table.map.withValue(slot, val):
|
|
return (true, val[])
|
|
do:
|
|
return (false, 0.u256)
|
|
|
|
proc setStorage*(ac: var TransientStorage,
|
|
address: EthAddress, slot, value: UInt256) =
|
|
var table = ac.map.getOrDefault(address)
|
|
if table.isNil:
|
|
table = StorageTable()
|
|
ac.map[address] = table
|
|
|
|
table.map[slot] = value
|
|
|
|
proc mergeAndReset*(ac, other: var TransientStorage) =
|
|
ac.map.mergeAndReset(other.map)
|
|
|
|
proc clear*(ac: var TransientStorage) {.inline.} =
|
|
ac.map.clear()
|