2023-01-31 01:32:17 +00:00
|
|
|
import stew/bitops2
|
|
|
|
|
|
|
|
{.push raises: [].}
|
2020-04-22 11:21:39 +07:00
|
|
|
|
2020-04-21 18:04:18 +07:00
|
|
|
type
|
|
|
|
TrieNodeType* = enum
|
|
|
|
BranchNodeType
|
|
|
|
ExtensionNodeType
|
|
|
|
AccountNodeType
|
|
|
|
HashNodeType
|
|
|
|
|
|
|
|
AccountType* = enum
|
|
|
|
SimpleAccountType
|
|
|
|
ExtendedAccountType
|
2020-05-14 11:09:01 +07:00
|
|
|
|
|
|
|
BytecodeType* = enum
|
|
|
|
CodeTouched
|
2020-05-05 15:21:39 +07:00
|
|
|
CodeUntouched
|
2020-04-22 11:21:39 +07:00
|
|
|
|
2020-04-29 12:46:50 +07:00
|
|
|
WitnessFlag* = enum
|
|
|
|
wfNoFlag
|
|
|
|
wfEIP170 # fork >= Spurious Dragon
|
|
|
|
|
2020-04-29 15:29:25 +07:00
|
|
|
MetadataType* = enum
|
|
|
|
MetadataNothing
|
|
|
|
MetadataSomething
|
|
|
|
|
2020-04-29 12:46:50 +07:00
|
|
|
WitnessFlags* = set[WitnessFlag]
|
|
|
|
|
|
|
|
ContractCodeError* = object of ValueError
|
2020-04-29 15:29:25 +07:00
|
|
|
ParsingError* = object of ValueError
|
2020-05-05 13:50:31 +07:00
|
|
|
|
|
|
|
StorageSlot* = array[32, byte]
|
2020-04-29 12:46:50 +07:00
|
|
|
|
2020-04-28 21:06:37 +07:00
|
|
|
const
|
|
|
|
StorageLeafNodeType* = AccountNodeType
|
2020-04-29 11:12:15 +07:00
|
|
|
BlockWitnessVersion* = 0x01
|
2020-07-08 21:05:20 +07:00
|
|
|
ShortRlpPrefix* = 0.byte
|
2020-04-29 11:12:15 +07:00
|
|
|
|
2023-01-31 01:32:17 +00:00
|
|
|
proc setBranchMaskBit*(x: var uint, i: int) =
|
2020-04-22 11:21:39 +07:00
|
|
|
assert(i >= 0 and i < 17)
|
|
|
|
x = x or (1 shl i).uint
|
|
|
|
|
2023-01-31 01:32:17 +00:00
|
|
|
func branchMaskBitIsSet*(x: uint, i: int): bool =
|
2020-04-22 11:21:39 +07:00
|
|
|
assert(i >= 0 and i < 17)
|
|
|
|
result = ((x shr i.uint) and 1'u) == 1'u
|
|
|
|
|
2023-01-31 01:32:17 +00:00
|
|
|
func constructBranchMask*(b1, b2: byte): uint
|
|
|
|
{.gcsafe, raises: [ParsingError].} =
|
2020-04-22 11:21:39 +07:00
|
|
|
result = uint(b1) shl 8 or uint(b2)
|
2020-04-29 15:29:25 +07:00
|
|
|
if countOnes(result) < 2 or ((result and (not 0x1FFFF'u)) != 0):
|
2020-05-05 13:50:31 +07:00
|
|
|
raise newException(ParsingError, "Invalid branch mask pattern " & $result)
|
2020-05-07 22:03:00 +07:00
|
|
|
|
|
|
|
iterator nonEmpty*(branchMask: uint): int =
|
|
|
|
for i in 0..<16:
|
|
|
|
if not branchMask.branchMaskBitIsSet(i):
|
|
|
|
# we skip an empty elem
|
|
|
|
continue
|
|
|
|
yield i
|