nimbus-eth1/src/vm/memory.nim

52 lines
1.6 KiB
Nim
Raw Normal View History

import
2018-02-07 16:16:04 +00:00
sequtils, ttmath,
../constants, ../errors, ../logging, ../validation, ../utils_numeric, ../utils/bytes
type
Memory* = ref object
logger*: Logger
bytes*: seq[byte]
proc newMemory*: Memory =
new(result)
result.bytes = @[]
2018-02-07 09:50:15 +00:00
result.logger = logging.getLogger("memory.Memory")
proc len*(memory: Memory): int =
result = memory.bytes.len
proc extend*(memory: var Memory; startPosition: Int256; size: Int256) =
if size == 0:
return
var newSize = ceil32(startPosition + size)
if newSize <= len(memory).int256:
return
var sizeToExtend = newSize - len(memory).int256
memory.bytes = memory.bytes.concat(repeat(0.byte, sizeToExtend.getInt))
proc newMemory*(size: Int256): Memory =
result = newMemory()
result.extend(0.int256, size)
proc read*(memory: var Memory, startPosition: Int256, size: Int256): seq[byte] =
result = memory.bytes[startPosition.getInt ..< (startPosition + size).getInt]
proc write*(memory: var Memory, startPosition: Int256, size: Int256, value: seq[byte]) =
if size == 0:
return
2018-02-07 16:16:04 +00:00
#echo size
#echo startPosition
validateGte(startPosition, 0)
validateGte(size, 0)
validateLength(value, size.getInt)
validateLte(startPosition + size, memory.len)
let index = memory.len
if memory.len.i256 < startPosition + size:
memory.bytes = memory.bytes.concat(repeat(0.byte, memory.len - (startPosition + size).getInt)) # TODO: better logarithmic scaling?
for z, b in value:
memory.bytes[z + startPosition.getInt] = b
template write*(memory: var Memory, startPosition: Int256, size: Int256, value: cstring) =
memory.write(startPosition, size, value.toBytes)