vm: create an array of false
items in NEWARRAY/NEWSTRUCT
This commit is contained in:
parent
bafdb916a0
commit
71cfd14b92
2 changed files with 12 additions and 4 deletions
12
pkg/vm/vm.go
12
pkg/vm/vm.go
|
@ -611,7 +611,7 @@ func (v *VM) execute(ctx *Context, op Instruction) {
|
||||||
switch t := item.value.(type) {
|
switch t := item.value.(type) {
|
||||||
case *BigIntegerItem:
|
case *BigIntegerItem:
|
||||||
n := t.value.Int64()
|
n := t.value.Int64()
|
||||||
items := make([]StackItem, n)
|
items := makeArrayOfFalses(int(n))
|
||||||
v.estack.PushVal(&ArrayItem{items})
|
v.estack.PushVal(&ArrayItem{items})
|
||||||
case *StructItem:
|
case *StructItem:
|
||||||
v.estack.PushVal(&ArrayItem{t.value})
|
v.estack.PushVal(&ArrayItem{t.value})
|
||||||
|
@ -626,7 +626,7 @@ func (v *VM) execute(ctx *Context, op Instruction) {
|
||||||
switch t := item.value.(type) {
|
switch t := item.value.(type) {
|
||||||
case *BigIntegerItem:
|
case *BigIntegerItem:
|
||||||
n := t.value.Int64()
|
n := t.value.Int64()
|
||||||
items := make([]StackItem, n)
|
items := makeArrayOfFalses(int(n))
|
||||||
v.estack.PushVal(&StructItem{items})
|
v.estack.PushVal(&StructItem{items})
|
||||||
case *ArrayItem:
|
case *ArrayItem:
|
||||||
v.estack.PushVal(&StructItem{t.value})
|
v.estack.PushVal(&StructItem{t.value})
|
||||||
|
@ -853,6 +853,14 @@ func (v *VM) execute(ctx *Context, op Instruction) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func makeArrayOfFalses(n int) []StackItem {
|
||||||
|
items := make([]StackItem, n)
|
||||||
|
for i := range items {
|
||||||
|
items[i] = &BoolItem{false}
|
||||||
|
}
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
log.SetPrefix("NEO-GO-VM > ")
|
log.SetPrefix("NEO-GO-VM > ")
|
||||||
log.SetFlags(0)
|
log.SetFlags(0)
|
||||||
|
|
|
@ -397,7 +397,7 @@ func TestNEWARRAYInteger(t *testing.T) {
|
||||||
vm.Run()
|
vm.Run()
|
||||||
assert.Equal(t, false, vm.state.HasFlag(faultState))
|
assert.Equal(t, false, vm.state.HasFlag(faultState))
|
||||||
assert.Equal(t, 1, vm.estack.Len())
|
assert.Equal(t, 1, vm.estack.Len())
|
||||||
assert.Equal(t, &ArrayItem{make([]StackItem, 1)}, vm.estack.Pop().value)
|
assert.Equal(t, &ArrayItem{[]StackItem{makeStackItem(false)}}, vm.estack.Pop().value)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNEWARRAYStruct(t *testing.T) {
|
func TestNEWARRAYStruct(t *testing.T) {
|
||||||
|
@ -437,7 +437,7 @@ func TestNEWSTRUCTInteger(t *testing.T) {
|
||||||
vm.Run()
|
vm.Run()
|
||||||
assert.Equal(t, false, vm.state.HasFlag(faultState))
|
assert.Equal(t, false, vm.state.HasFlag(faultState))
|
||||||
assert.Equal(t, 1, vm.estack.Len())
|
assert.Equal(t, 1, vm.estack.Len())
|
||||||
assert.Equal(t, &StructItem{make([]StackItem, 1)}, vm.estack.Pop().value)
|
assert.Equal(t, &StructItem{[]StackItem{makeStackItem(false)}}, vm.estack.Pop().value)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNEWSTRUCTArray(t *testing.T) {
|
func TestNEWSTRUCTArray(t *testing.T) {
|
||||||
|
|
Loading…
Reference in a new issue