mirror of
https://github.com/status-im/nim-eth.git
synced 2025-02-08 04:13:34 +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.
19 lines
683 B
Nim
19 lines
683 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: [].}
|
|
|
|
import "."/hashes, ../rlp
|
|
|
|
export hashes, rlp
|
|
|
|
proc read*(rlp: var Rlp, T: type Hash32): Hash32 {.raises: [RlpError].} =
|
|
Hash32(rlp.read(type(result.data)))
|
|
|
|
proc append*(rlpWriter: var RlpWriter, a: Hash32) =
|
|
rlpWriter.append(a.data)
|