diff options
author | obscuren <geffobscura@gmail.com> | 2015-03-21 03:37:56 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2015-03-21 03:37:56 +0800 |
commit | abce6804a085087770be587e039fd4669d5eac26 (patch) | |
tree | e2ca07be1981c7ac38227e7d5aeb94870affa37c | |
parent | f4e9638867f5dab01eeb6db5fdbd85737a11fbd6 (diff) | |
download | go-tangerine-abce6804a085087770be587e039fd4669d5eac26.tar.gz go-tangerine-abce6804a085087770be587e039fd4669d5eac26.tar.zst go-tangerine-abce6804a085087770be587e039fd4669d5eac26.zip |
Right pad bytes to prevent future programmers making bugs
-rw-r--r-- | vm/memory.go | 32 |
1 files changed, 18 insertions, 14 deletions
diff --git a/vm/memory.go b/vm/memory.go index 2a1e6e1b9..dd47fa1b5 100644 --- a/vm/memory.go +++ b/vm/memory.go @@ -1,6 +1,10 @@ package vm -import "fmt" +import ( + "fmt" + + "github.com/ethereum/go-ethereum/common" +) type Memory struct { store []byte @@ -11,21 +15,21 @@ func NewMemory() *Memory { } func (m *Memory) Set(offset, size uint64, value []byte) { - if len(value) > 0 { - totSize := offset + size - lenSize := uint64(len(m.store) - 1) - if totSize > lenSize { - // Calculate the diff between the sizes - diff := totSize - lenSize - if diff > 0 { - // Create a new empty slice and append it - newSlice := make([]byte, diff-1) - // Resize slice - m.store = append(m.store, newSlice...) - } + value = common.RightPadBytes(value, int(size)) + + totSize := offset + size + lenSize := uint64(len(m.store) - 1) + if totSize > lenSize { + // Calculate the diff between the sizes + diff := totSize - lenSize + if diff > 0 { + // Create a new empty slice and append it + newSlice := make([]byte, diff-1) + // Resize slice + m.store = append(m.store, newSlice...) } - copy(m.store[offset:offset+size], value) } + copy(m.store[offset:offset+size], value) } func (m *Memory) Resize(size uint64) { |