nimbus-eth1/nimbus/db/access_list.nim

93 lines
2.7 KiB
Nim
Raw Normal View History

# 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.
2020-12-09 05:24:37 +00:00
import
std/[tables, sets],
2020-12-09 05:24:37 +00:00
stint,
eth/common,
../utils/mergeutils
2020-12-09 05:24:37 +00:00
type
SlotSet = HashSet[UInt256]
AccessList* = object
slots: Table[Address, SlotSet]
2020-12-09 05:24:37 +00:00
# ------------------------------------------------------------------------------
# Private helpers
# ------------------------------------------------------------------------------
func toStorageKeys(slots: SlotSet): seq[Bytes32] =
for slot in slots:
result.add slot.to(Bytes32)
# ------------------------------------------------------------------------------
# Public constructors
# ------------------------------------------------------------------------------
2020-12-09 05:24:37 +00:00
proc init*(ac: var AccessList) =
ac.slots = Table[Address, SlotSet]()
2020-12-09 05:24:37 +00:00
proc init*(_: type AccessList): AccessList {.inline.} =
result.init()
# ------------------------------------------------------------------------------
# Public functions
# ------------------------------------------------------------------------------
func contains*(ac: AccessList, address: Address): bool {.inline.} =
2020-12-09 05:24:37 +00:00
address in ac.slots
# returnValue: (addressPresent, slotPresent)
func contains*(ac: var AccessList, address: Address, slot: UInt256): bool =
2020-12-09 05:24:37 +00:00
ac.slots.withValue(address, val):
result = slot in val[]
proc mergeAndReset*(ac, other: var AccessList) =
# move values in `other` to `ac`
ac.slots.mergeAndReset(other.slots)
2020-12-09 05:24:37 +00:00
proc add*(ac: var AccessList, address: Address) =
2020-12-09 05:24:37 +00:00
if address notin ac.slots:
ac.slots[address] = HashSet[UInt256]()
2020-12-09 05:24:37 +00:00
proc add*(ac: var AccessList, address: Address, slot: UInt256) =
2020-12-09 05:24:37 +00:00
ac.slots.withValue(address, val):
val[].incl slot
do:
ac.slots[address] = toHashSet([slot])
2020-12-11 10:51:17 +00:00
proc clear*(ac: var AccessList) {.inline.} =
ac.slots.clear()
func getAccessList*(ac: AccessList): common.AccessList =
for address, slots in ac.slots:
result.add common.AccessPair(
address : address,
storageKeys: slots.toStorageKeys,
)
func equal*(ac: AccessList, other: var AccessList): bool =
if ac.slots.len != other.slots.len:
return false
for address, slots in ac.slots:
other.slots.withValue(address, otherSlots):
if slots.len != otherSlots[].len:
return false
for slot in slots:
if slot notin otherSlots[]:
return false
do:
return false
true