diff options
author | obscuren <geffobscura@gmail.com> | 2014-12-04 00:22:26 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-12-04 00:22:26 +0800 |
commit | 6d99c03d915789c445c2d40579419a16fde2b7c8 (patch) | |
tree | 5ea03daf33b053d197ff8f1246936232f140c63a /cmd/mist/debugger.go | |
parent | 99853ac3ce57807deb4822dd324186e1d2ee0821 (diff) | |
download | go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.tar go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.tar.gz go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.tar.bz2 go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.tar.lz go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.tar.xz go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.tar.zst go-tangerine-6d99c03d915789c445c2d40579419a16fde2b7c8.zip |
Updated environments according to the new interface set
Diffstat (limited to 'cmd/mist/debugger.go')
-rw-r--r-- | cmd/mist/debugger.go | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/cmd/mist/debugger.go b/cmd/mist/debugger.go index a2aae6f0b..8331b5566 100644 --- a/cmd/mist/debugger.go +++ b/cmd/mist/debugger.go @@ -144,24 +144,28 @@ func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, scriptStr, data statedb := self.lib.eth.BlockManager().TransState() account := self.lib.eth.BlockManager().TransState().GetAccount(keyPair.Address()) contract := statedb.NewStateObject([]byte{0}) + contract.SetCode(script) contract.SetBalance(value) self.SetAsm(script) block := self.lib.eth.ChainManager().CurrentBlock - callerClosure := vm.NewClosure(&state.Message{}, account, contract, script, gas, gasPrice) env := utils.NewEnv(statedb, block, account.Address(), value) - evm := vm.NewDebugVm(env) - evm.Dbg = self.Db + /* + callerClosure := vm.NewClosure(&state.Message{}, account, contract, script, gas, gasPrice) + evm := vm.NewDebugVm(env) + evm.Dbg = self.Db + self.vm = evm + self.Db.done = false + */ - self.vm = evm - self.Db.done = false self.Logf("callsize %d", len(script)) go func() { - ret, g, err := callerClosure.Call(evm, data) - tot := new(big.Int).Mul(g, gasPrice) - self.Logf("gas usage %v total price = %v (%v)", g, tot, ethutil.CurrencyToString(tot)) + ret, err := env.Call(account, contract.Address(), data, gas, gasPrice, ethutil.Big0) + //ret, g, err := callerClosure.Call(evm, data) + tot := new(big.Int).Mul(env.Gas, gasPrice) + self.Logf("gas usage %v total price = %v (%v)", env.Gas, tot, ethutil.CurrencyToString(tot)) if err != nil { self.Logln("exited with errors:", err) } else { |