New debugger implemented

This commit is contained in:
obscuren 2014-05-27 13:28:11 +02:00
parent d0b31e2030
commit 47417506c3
4 changed files with 25 additions and 18 deletions

View File

@ -175,19 +175,18 @@ ApplicationWindow {
} }
function setAsm(asm) { function setAsm(asm) {
console.log("set asm", asm)
asmModel.append({asm: asm}) asmModel.append({asm: asm})
} }
function clearAsm() {
asmModel.clear()
}
function setInstruction(num) { function setInstruction(num) {
asmTableView.selection.clear() asmTableView.selection.clear()
asmTableView.selection.select(num-1) asmTableView.selection.select(num-1)
} }
function clearAsm() {
asmModel.clear()
}
function setMem(mem) { function setMem(mem) {
memModel.append({num: mem.num, value: mem.value}) memModel.append({num: mem.num, value: mem.value})
} }

View File

@ -306,14 +306,6 @@ ApplicationWindow {
text: "Connect" text: "Connect"
} }
*/ */
Button {
property var enabled: true
id: debuggerWindow
onClicked: {
ui.startDebugger()
}
text: "Debugger"
}
Button { Button {
id: importAppButton id: importAppButton

View File

@ -24,7 +24,7 @@ func NewDebuggerWindow(lib *UiLib) *DebuggerWindow {
} }
win := component.CreateWindow(nil) win := component.CreateWindow(nil)
db := &Debugger{win, make(chan bool), true} db := &Debugger{win, make(chan bool), make(chan bool), true}
return &DebuggerWindow{engine: engine, win: win, lib: lib, Db: db} return &DebuggerWindow{engine: engine, win: win, lib: lib, Db: db}
} }
@ -40,8 +40,18 @@ func (self *DebuggerWindow) Show() {
} }
func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, data string) { func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, data string) {
if !self.Db.done {
self.Db.Q <- true
}
state := self.lib.eth.BlockChain().CurrentBlock.State() state := self.lib.eth.BlockChain().CurrentBlock.State()
defer func() {
if r := recover(); r != nil {
fmt.Println(r)
}
}()
script, err := ethutil.Compile(data) script, err := ethutil.Compile(data)
if err != nil { if err != nil {
ethutil.Config.Log.Debugln(err) ethutil.Config.Log.Debugln(err)
@ -50,7 +60,7 @@ func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, data string) {
} }
dis := ethchain.Disassemble(script) dis := ethchain.Disassemble(script)
self.lib.win.Root().Call("clearAsm") self.win.Root().Call("clearAsm")
for _, str := range dis { for _, str := range dis {
self.win.Root().Call("setAsm", str) self.win.Root().Call("setAsm", str)
@ -91,6 +101,7 @@ func (self *DebuggerWindow) Next() {
type Debugger struct { type Debugger struct {
win *qml.Window win *qml.Window
N chan bool N chan bool
Q chan bool
done bool done bool
} }
@ -98,7 +109,7 @@ type storeVal struct {
Key, Value string Key, Value string
} }
func (d *Debugger) halting(pc int, op ethchain.OpCode, mem *ethchain.Memory, stack *ethchain.Stack, stateObject *ethchain.StateObject) { func (d *Debugger) halting(pc int, op ethchain.OpCode, mem *ethchain.Memory, stack *ethchain.Stack, stateObject *ethchain.StateObject) bool {
d.win.Root().Call("setInstruction", pc) d.win.Root().Call("setInstruction", pc)
d.win.Root().Call("clearMem") d.win.Root().Call("clearMem")
d.win.Root().Call("clearStack") d.win.Root().Call("clearStack")
@ -123,9 +134,14 @@ out:
select { select {
case <-d.N: case <-d.N:
break out break out
default: case <-d.Q:
d.done = true
return false
} }
} }
return true
} }
func (d *Debugger) Next() { func (d *Debugger) Next() {

View File

@ -130,7 +130,7 @@ func (gui *Gui) createWindow(comp qml.Object) *qml.Window {
gui.win = win gui.win = win
gui.uiLib.win = win gui.uiLib.win = win
db := &Debugger{gui.win, make(chan bool), true} db := &Debugger{gui.win, make(chan bool), make(chan bool), true}
gui.lib.Db = db gui.lib.Db = db
gui.uiLib.Db = db gui.uiLib.Db = db