mirror of
https://github.com/status-im/nim-eth.git
synced 2025-02-17 08:27:05 +00:00
Since these types were written, we've gained an executable spec: https://github.com/ethereum/execution-specs This PR aligns some of the types we use with this spec to simplify comparisons and cross-referencing. Using a `distinct` type is a tradeoff between nim ergonomics, type safety and the ability to work around nim quirks and stdlib weaknesses. In particular, it allows us to overload common functions such as `hash` with correct and performant versions as well as maintain control over string conversions etc at the cost of a little bit of ceremony when instantiating them. Apart from distinct byte types, `Hash32`, is introduced in lieu of the existing `Hash256`, again aligning this commonly used type with the spec which picks bytes rather than bits in the name.
35 lines
1012 B
Nim
35 lines
1012 B
Nim
# eth
|
|
# Copyright (c) 2024 Status Research & Development GmbH
|
|
# Licensed and distributed under either of
|
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
{.push raises: [].}
|
|
|
|
# Minimal compatibility layer with earlier versions of this file, to be removed
|
|
# when users have upgraded
|
|
|
|
{.deprecated.}
|
|
|
|
import ./[addresses, hashes]
|
|
|
|
export hashes
|
|
|
|
from nimcrypto import MDigest
|
|
|
|
type
|
|
Hash256* {.deprecated.} = Hash32
|
|
KeccakHash* {.deprecated.} = Hash32
|
|
|
|
template keccakHash*(v: openArray[byte]): Hash32 {.deprecated.} =
|
|
keccak256(v)
|
|
|
|
template keccakHash*(v: Address): Hash32 {.deprecated.} =
|
|
keccak256(v.data)
|
|
|
|
from nimcrypto/hash import MDigest
|
|
|
|
converter toMDigest*(v: Hash32): MDigest[256] {.deprecated.} =
|
|
MDigest[256](data: v.data)
|