diff options
author | Jeffrey Wilcke <geffobscura@gmail.com> | 2015-07-18 05:09:36 +0800 |
---|---|---|
committer | Jeffrey Wilcke <geffobscura@gmail.com> | 2015-08-07 18:52:17 +0800 |
commit | 846f34f78b5f76233655d0cf3611706e99f2efe2 (patch) | |
tree | 4e25f0320e30c0ed45b706835fd4377632bdcb45 /core/vm/stack.go | |
parent | 698e98d9814605bfea98ba3ad2fe7fda073cb2b1 (diff) | |
download | go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.tar go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.tar.gz go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.tar.bz2 go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.tar.lz go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.tar.xz go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.tar.zst go-tangerine-846f34f78b5f76233655d0cf3611706e99f2efe2.zip |
core/vm, tests: implemented semi-jit vm
* changed stack and removed stack ptr. Let go decide on slice reuse.
Diffstat (limited to 'core/vm/stack.go')
-rw-r--r-- | core/vm/stack.go | 21 |
1 files changed, 8 insertions, 13 deletions
diff --git a/core/vm/stack.go b/core/vm/stack.go index 3d669b2f2..23c109455 100644 --- a/core/vm/stack.go +++ b/core/vm/stack.go @@ -27,32 +27,27 @@ func newstack() *stack { type stack struct { data []*big.Int - ptr int } func (st *stack) Data() []*big.Int { - return st.data[:st.ptr] + return st.data } func (st *stack) push(d *big.Int) { // NOTE push limit (1024) is checked in baseCheck - stackItem := new(big.Int).Set(d) - if len(st.data) > st.ptr { - st.data[st.ptr] = stackItem - } else { - st.data = append(st.data, stackItem) - } - st.ptr++ + //stackItem := new(big.Int).Set(d) + //st.data = append(st.data, stackItem) + st.data = append(st.data, d) } func (st *stack) pop() (ret *big.Int) { - st.ptr-- - ret = st.data[st.ptr] + ret = st.data[len(st.data)-1] + st.data = st.data[:len(st.data)-1] return } func (st *stack) len() int { - return st.ptr + return len(st.data) } func (st *stack) swap(n int) { @@ -60,7 +55,7 @@ func (st *stack) swap(n int) { } func (st *stack) dup(n int) { - st.push(st.data[st.len()-n]) + st.push(new(big.Int).Set(st.data[st.len()-n])) } func (st *stack) peek() *big.Int { |