mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-20 09:09:03 +00:00
1126c7700d
* Bump nim-eth and nimbus-eth2 * Fix ambiguous identifier
69 lines
1.8 KiB
Nim
69 lines
1.8 KiB
Nim
# Nimbus
|
|
# Copyright (c) 2020-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
|
|
eth/common,
|
|
stint,
|
|
evmc/evmc,
|
|
../utils/utils
|
|
|
|
const
|
|
evmc_native* {.booldefine.} = false
|
|
|
|
func toEvmc*(a: Address): evmc_address {.inline.} =
|
|
evmc_address(bytes: a.data)
|
|
|
|
func toEvmc*(h: Hash32): evmc_bytes32 {.inline.} =
|
|
doAssert sizeof(h) == sizeof(evmc_bytes32)
|
|
evmc_bytes32(bytes: h.data)
|
|
|
|
func toEvmc*(h: ContractSalt): evmc_bytes32 {.inline.} =
|
|
doAssert sizeof(h) == sizeof(evmc_bytes32)
|
|
cast[evmc_bytes32](h)
|
|
|
|
func toEvmc*(n: UInt256): evmc_uint256be {.inline.} =
|
|
when evmc_native:
|
|
cast[evmc_uint256be](n)
|
|
else:
|
|
cast[evmc_uint256be](n.toBytesBE)
|
|
|
|
func fromEvmc*(T: type, n: evmc_bytes32): T {.inline.} =
|
|
when T is ContractSalt:
|
|
doAssert sizeof(n) == sizeof(T)
|
|
cast[T](n)
|
|
elif T is Hash32:
|
|
Hash32(n.bytes)
|
|
elif T is UInt256:
|
|
when evmc_native:
|
|
cast[UInt256](n)
|
|
else:
|
|
UInt256.fromBytesBE(n.bytes)
|
|
else:
|
|
{.error: "cannot convert unsupported evmc type".}
|
|
|
|
func fromEvmc*(a: evmc_address): Address {.inline.} =
|
|
Address(a.bytes)
|
|
|
|
when isMainModule:
|
|
import ../constants
|
|
var a: evmc_address
|
|
a.bytes[19] = 3.byte
|
|
var na = fromEvmc(a)
|
|
assert(a == toEvmc(na))
|
|
var b = stuint(10, 256)
|
|
var eb = b.toEvmc
|
|
assert(b == fromEvmc(UInt256, eb))
|
|
var h = EMPTY_SHA3
|
|
var eh = toEvmc(h)
|
|
assert(h == fromEvmc(Hash32, eh))
|
|
var s = cast[ContractSalt](EMPTY_ROOT_HASH)
|
|
var es = toEvmc(s)
|
|
assert(s == fromEvmc(ContractSalt, es))
|