aboutsummaryrefslogtreecommitdiffstats
path: root/vm/memory.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2015-03-10 07:25:27 +0800
committerobscuren <geffobscura@gmail.com>2015-03-10 07:25:27 +0800
commit9007f2bbdc3b38f8f005778467157db12056c17e (patch)
tree15ceec2bd62ebd11ec7850cebd20a0ba32775c89 /vm/memory.go
parent0795fd2701f67e489e47d9b7998ffa52adf8863e (diff)
downloaddexon-9007f2bbdc3b38f8f005778467157db12056c17e.tar
dexon-9007f2bbdc3b38f8f005778467157db12056c17e.tar.gz
dexon-9007f2bbdc3b38f8f005778467157db12056c17e.tar.bz2
dexon-9007f2bbdc3b38f8f005778467157db12056c17e.tar.lz
dexon-9007f2bbdc3b38f8f005778467157db12056c17e.tar.xz
dexon-9007f2bbdc3b38f8f005778467157db12056c17e.tar.zst
dexon-9007f2bbdc3b38f8f005778467157db12056c17e.zip
reworked stack
Diffstat (limited to 'vm/memory.go')
-rw-r--r--vm/memory.go72
1 files changed, 72 insertions, 0 deletions
diff --git a/vm/memory.go b/vm/memory.go
new file mode 100644
index 000000000..2a1e6e1b9
--- /dev/null
+++ b/vm/memory.go
@@ -0,0 +1,72 @@
+package vm
+
+import "fmt"
+
+type Memory struct {
+ store []byte
+}
+
+func NewMemory() *Memory {
+ return &Memory{nil}
+}
+
+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...)
+ }
+ }
+ copy(m.store[offset:offset+size], value)
+ }
+}
+
+func (m *Memory) Resize(size uint64) {
+ if uint64(m.Len()) < size {
+ m.store = append(m.store, make([]byte, size-uint64(m.Len()))...)
+ }
+}
+
+func (self *Memory) Get(offset, size int64) (cpy []byte) {
+ if size == 0 {
+ return nil
+ }
+
+ if len(self.store) > int(offset) {
+ cpy = make([]byte, size)
+ copy(cpy, self.store[offset:offset+size])
+
+ return
+ }
+
+ return
+}
+
+func (m *Memory) Len() int {
+ return len(m.store)
+}
+
+func (m *Memory) Data() []byte {
+ return m.store
+}
+
+func (m *Memory) Print() {
+ fmt.Printf("### mem %d bytes ###\n", len(m.store))
+ if len(m.store) > 0 {
+ addr := 0
+ for i := 0; i+32 <= len(m.store); i += 32 {
+ fmt.Printf("%03d: % x\n", addr, m.store[i:i+32])
+ addr++
+ }
+ } else {
+ fmt.Println("-- empty --")
+ }
+ fmt.Println("####################")
+}