Added recoverable option
This commit is contained in:
parent
306b5bcff3
commit
3c3292d505
22
ethvm/vm.go
22
ethvm/vm.go
|
@ -37,6 +37,8 @@ type Vm struct {
|
||||||
BreakPoints []int64
|
BreakPoints []int64
|
||||||
Stepping bool
|
Stepping bool
|
||||||
Fn string
|
Fn string
|
||||||
|
|
||||||
|
Recoverable bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type Environment interface {
|
type Environment interface {
|
||||||
|
@ -62,18 +64,20 @@ func New(env Environment) *Vm {
|
||||||
lt = LogTyDiff
|
lt = LogTyDiff
|
||||||
}
|
}
|
||||||
|
|
||||||
return &Vm{env: env, logTy: lt}
|
return &Vm{env: env, logTy: lt, Recoverable: true}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *Vm) RunClosure(closure *Closure) (ret []byte, err error) {
|
func (self *Vm) RunClosure(closure *Closure) (ret []byte, err error) {
|
||||||
// Recover from any require exception
|
if self.Recoverable {
|
||||||
defer func() {
|
// Recover from any require exception
|
||||||
if r := recover(); r != nil {
|
defer func() {
|
||||||
ret = closure.Return(nil)
|
if r := recover(); r != nil {
|
||||||
err = fmt.Errorf("%v", r)
|
ret = closure.Return(nil)
|
||||||
vmlogger.Errorln("vm err", err)
|
err = fmt.Errorf("%v", r)
|
||||||
}
|
vmlogger.Errorln("vm err", err)
|
||||||
}()
|
}
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
|
||||||
// Debug hook
|
// Debug hook
|
||||||
if self.Dbg != nil {
|
if self.Dbg != nil {
|
||||||
|
|
Loading…
Reference in New Issue