rlp: avoid aliasing casts (#637)

* also get rid of unused concept
This commit is contained in:
Jacek Sieka 2023-09-25 11:30:47 +02:00 committed by GitHub
parent fe88d9e6b7
commit 34ab6bd986
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 7 additions and 22 deletions

View File

@ -317,7 +317,7 @@ proc readImpl(rlp: var Rlp, T: type float64): T =
# https://github.com/gopherjs/gopherjs/blob/master/compiler/natives/src/math/math.go
let uint64bits = rlp.toInt(uint64)
var uint32parts = [uint32(uint64bits), uint32(uint64bits shr 32)]
return cast[ptr float64](unsafeAddr uint32parts)[]
copyMem(addr result, unsafeAddr uint32parts, sizeof(result))
proc readImpl[R, E](rlp: var Rlp, T: type array[R, E]): T =
mixin read

View File

@ -8,23 +8,7 @@ type
pendingLists: seq[tuple[remainingItems, outBytes: int]]
output: seq[byte]
IntLike* = concept x, y
type T = type(x)
# arithmetic ops
x + y is T
x * y is T
x - y is T
x div y is T
x mod y is T
# some int compatibility required for big endian encoding:
x shr int is T
x shl int is T
x and 0xff is int
x < 128 is bool
Integer* = SomeInteger # or IntLike
Integer* = SomeInteger
const
wrapObjsInList* = true
@ -157,8 +141,9 @@ proc appendFloat(self: var RlpWriter, data: float64) =
# This is not covered in the RLP spec, but Geth uses Go's
# `math.Float64bits`, which is defined here:
# https://github.com/gopherjs/gopherjs/blob/master/compiler/natives/src/math/math.go
let uintWords = cast[ptr UncheckedArray[uint32]](unsafeAddr data)
let uint64bits = (uint64(uintWords[1]) shl 32) or uint64(uintWords[0])
var uint32Words: array[2, uint32]
copyMem(addr uint32Words[0], unsafeAddr data, sizeof(uint32Words))
let uint64bits = (uint64(uint32Words[1]) shl 32) or uint64(uint32Words[0])
self.appendInt(uint64bits)
template appendImpl(self: var RlpWriter, i: Integer) =