aboutsummaryrefslogtreecommitdiffstats
path: root/core/vm/stack.go
diff options
context:
space:
mode:
authorJeffrey Wilcke <geffobscura@gmail.com>2015-07-18 05:09:36 +0800
committerJeffrey Wilcke <geffobscura@gmail.com>2015-08-07 18:52:17 +0800
commit846f34f78b5f76233655d0cf3611706e99f2efe2 (patch)
tree4e25f0320e30c0ed45b706835fd4377632bdcb45 /core/vm/stack.go
parent698e98d9814605bfea98ba3ad2fe7fda073cb2b1 (diff)
downloadgo-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.go21
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 {