diff options
author | Maran <maran.hidskes@gmail.com> | 2014-05-27 16:29:12 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-05-27 16:29:12 +0800 |
commit | 474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe (patch) | |
tree | 1d37eab24c24ee7d7aeac452047d0749b6926797 /ethereal/ui/ui_lib.go | |
parent | f7eb4e587f83e4472e3d214076ba0c28102daefd (diff) | |
parent | d694e00a3340a36c39872950bb7a2404e9686c18 (diff) | |
download | go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.tar go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.tar.gz go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.tar.bz2 go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.tar.lz go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.tar.xz go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.tar.zst go-tangerine-474c85bc9d4b8ef88c933cf0fb9d58bf913f6cbe.zip |
Fix merge conflict
Diffstat (limited to 'ethereal/ui/ui_lib.go')
-rw-r--r-- | ethereal/ui/ui_lib.go | 32 |
1 files changed, 18 insertions, 14 deletions
diff --git a/ethereal/ui/ui_lib.go b/ethereal/ui/ui_lib.go index 1c88b0181..51fa26a88 100644 --- a/ethereal/ui/ui_lib.go +++ b/ethereal/ui/ui_lib.go @@ -6,9 +6,7 @@ import ( "github.com/ethereum/eth-go" "github.com/ethereum/eth-go/ethchain" "github.com/ethereum/eth-go/ethutil" - "github.com/ethereum/go-ethereum/utils" "github.com/go-qml/qml" - "github.com/obscuren/mutan" "os" "path" "path/filepath" @@ -121,27 +119,28 @@ func DefaultAssetPath() string { func (ui *UiLib) DebugTx(recipient, valueStr, gasStr, gasPriceStr, data string) { state := ui.eth.BlockChain().CurrentBlock.State() - mainInput, _ := mutan.PreParse(data) - callerScript, err := utils.Compile(mainInput) + script, err := ethutil.Compile(data) if err != nil { ethutil.Config.Log.Debugln(err) return } - dis := ethchain.Disassemble(callerScript) + dis := ethchain.Disassemble(script) ui.win.Root().Call("clearAsm") for _, str := range dis { ui.win.Root().Call("setAsm", str) } - callerTx := ethchain.NewContractCreationTx(ethutil.Big(valueStr), ethutil.Big(gasStr), ethutil.Big(gasPriceStr), nil) - // Contract addr as test address keyPair := ethutil.GetKeyRing().Get(0) + callerTx := + ethchain.NewContractCreationTx(ethutil.Big(valueStr), ethutil.Big(gasStr), ethutil.Big(gasPriceStr), script) + callerTx.Sign(keyPair.PrivateKey) + account := ui.eth.StateManager().TransState().GetStateObject(keyPair.Address()) - c := ethchain.MakeContract(callerTx, state) - callerClosure := ethchain.NewClosure(account, c, c.Script(), state, ethutil.Big(gasStr), ethutil.Big(gasPriceStr)) + contract := ethchain.MakeContract(callerTx, state) + callerClosure := ethchain.NewClosure(account, contract, contract.Init(), state, ethutil.Big(gasStr), ethutil.Big(gasPriceStr)) block := ui.eth.BlockChain().CurrentBlock vm := ethchain.NewVm(state, ui.eth.StateManager(), ethchain.RuntimeVars{ @@ -151,23 +150,28 @@ func (ui *UiLib) DebugTx(recipient, valueStr, gasStr, gasPriceStr, data string) Coinbase: block.Coinbase, Time: block.Time, Diff: block.Difficulty, - TxData: nil, }) + ui.Db.done = false go func() { - callerClosure.Call(vm, nil, ui.Db.halting) + callerClosure.Call(vm, contract.Init(), ui.Db.halting) state.Reset() + + ui.Db.done = true }() } func (ui *UiLib) Next() { - ui.Db.Next() + if !ui.Db.done { + ui.Db.Next() + } } type Debugger struct { - win *qml.Window - N chan bool + win *qml.Window + N chan bool + done bool } func (d *Debugger) halting(pc int, op ethchain.OpCode, mem *ethchain.Memory, stack *ethchain.Stack) { |