forked from TrueCloudLab/neoneo-go
vm: implement * -> Boolean conversion
This commit is contained in:
parent
7e14c5a274
commit
f2393e5efc
1 changed files with 16 additions and 3 deletions
|
@ -77,10 +77,23 @@ func (e *Element) BigInt() *big.Int {
|
||||||
// Bool attempts to get the underlying value of the element as a boolean.
|
// Bool attempts to get the underlying value of the element as a boolean.
|
||||||
// Will panic if the assertion failed which will be caught by the VM.
|
// Will panic if the assertion failed which will be caught by the VM.
|
||||||
func (e *Element) Bool() bool {
|
func (e *Element) Bool() bool {
|
||||||
if v, ok := e.value.Value().(*big.Int); ok {
|
switch t := e.value.(type) {
|
||||||
return v.Int64() == 1
|
case *BigIntegerItem:
|
||||||
|
return t.value.Int64() != 0
|
||||||
|
case *BoolItem:
|
||||||
|
return t.value
|
||||||
|
case *ArrayItem, *StructItem:
|
||||||
|
return true
|
||||||
|
case *ByteArrayItem:
|
||||||
|
for _, b := range t.value {
|
||||||
|
if b != 0 {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
default:
|
||||||
|
panic("can't convert to bool: " + t.String())
|
||||||
}
|
}
|
||||||
return e.value.Value().(bool)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Bytes attempts to get the underlying value of the element as a byte array.
|
// Bytes attempts to get the underlying value of the element as a byte array.
|
||||||
|
|
Loading…
Reference in a new issue