diff options
author | obscuren <geffobscura@gmail.com> | 2014-12-20 09:34:29 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-12-20 09:34:29 +0800 |
commit | 6cff6dd8b863e340851a9ec9a559881ea9520688 (patch) | |
tree | 3a2dc53b365e6f377fc82a3514150d1297fe549c /core/execution.go | |
parent | 12671c82eadc367a43502109e5e0237e228da998 (diff) | |
parent | 0a9dc1536c5d776844d6947a0090ff7e1a7c6ab4 (diff) | |
download | dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.tar dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.tar.gz dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.tar.bz2 dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.tar.lz dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.tar.xz dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.tar.zst dexon-6cff6dd8b863e340851a9ec9a559881ea9520688.zip |
Merge branch 'release/v0.7.10' into develop
Diffstat (limited to 'core/execution.go')
-rw-r--r-- | core/execution.go | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/core/execution.go b/core/execution.go index 0b5e0558f..b7eead0dd 100644 --- a/core/execution.go +++ b/core/execution.go @@ -3,6 +3,7 @@ package core import ( "fmt" "math/big" + "time" "github.com/ethereum/go-ethereum/state" "github.com/ethereum/go-ethereum/vm" @@ -12,7 +13,6 @@ type Execution struct { env vm.Environment address, input []byte Gas, price, value *big.Int - object *state.StateObject SkipTransfer bool } @@ -35,8 +35,6 @@ func (self *Execution) exec(code, contextAddr []byte, caller vm.ClosureRef) (ret env := self.env evm := vm.New(env, vm.DebugVmTy) - chainlogger.Debugf("pre state %x\n", env.State().Root()) - if env.Depth() == vm.MaxCallDepth { // Consume all gas (by not returning it) and return a depth error return nil, vm.DepthError{} @@ -55,15 +53,12 @@ func (self *Execution) exec(code, contextAddr []byte, caller vm.ClosureRef) (ret } snapshot := env.State().Copy() - defer func() { - if vm.IsOOGErr(err) { - env.State().Set(snapshot) - } - chainlogger.Debugf("post state %x\n", env.State().Root()) - }() - - self.object = to + start := time.Now() ret, err = evm.Run(to, caller, code, self.value, self.Gas, self.price, self.input) + if err != nil { + env.State().Set(snapshot) + } + chainlogger.Debugf("vm took %v\n", time.Since(start)) return } |