aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorzelig <viktor.tron@gmail.com>2014-07-05 19:52:44 +0800
committerzelig <viktor.tron@gmail.com>2014-07-05 19:52:44 +0800
commit6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd (patch)
tree97aa911429cdda87d8a07c8566e0803a261e23b2
parent1e4ae24126d21305c8fcbebd057ce4ec28ddd242 (diff)
parent8e5117444ebfe4eac4aa96ae431dba5c67b2fcc6 (diff)
downloadgo-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.tar
go-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.tar.gz
go-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.tar.bz2
go-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.tar.lz
go-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.tar.xz
go-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.tar.zst
go-tangerine-6b296d907b848e2a3dbc78ea5c04c3c3d719d9bd.zip
Merge branch 'develop' of github.com:ethereum/go-ethereum into feature/ethutil-refactor
-rw-r--r--ethereal/debugger.go44
1 files changed, 32 insertions, 12 deletions
diff --git a/ethereal/debugger.go b/ethereal/debugger.go
index 89e0f36eb..64ca316f8 100644
--- a/ethereal/debugger.go
+++ b/ethereal/debugger.go
@@ -15,9 +15,8 @@ type DebuggerWindow struct {
engine *qml.Engine
lib *UiLib
- vm *ethchain.Vm
- Db *Debugger
- breakPoints []int64
+ vm *ethchain.Vm
+ Db *Debugger
}
func NewDebuggerWindow(lib *UiLib) *DebuggerWindow {
@@ -30,9 +29,11 @@ func NewDebuggerWindow(lib *UiLib) *DebuggerWindow {
}
win := component.CreateWindow(nil)
- db := &Debugger{win, make(chan bool), make(chan bool), true, false}
- return &DebuggerWindow{engine: engine, win: win, lib: lib, Db: db, vm: &ethchain.Vm{}}
+ w := &DebuggerWindow{engine: engine, win: win, lib: lib, vm: &ethchain.Vm{}}
+ w.Db = NewDebugger(w)
+
+ return w
}
func (self *DebuggerWindow) Show() {
@@ -138,8 +139,7 @@ func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, scriptStr, data
Value: ethutil.Big(valueStr),
})
vm.Verbose = true
- vm.Hook = self.Db.halting
- vm.BreakPoints = self.breakPoints
+ vm.Dbg = self.Db
self.vm = vm
self.Db.done = false
@@ -201,8 +201,7 @@ func (self *DebuggerWindow) ExecCommand(command string) {
self.Logln(err)
break
}
- self.breakPoints = append(self.breakPoints, int64(lineNo))
- self.vm.BreakPoints = self.breakPoints
+ self.Db.breakPoints = append(self.Db.breakPoints, int64(lineNo))
self.Logf("break point set on instruction %d", lineNo)
} else {
self.Logf("'%s' requires line number", cmd[0])
@@ -211,8 +210,7 @@ func (self *DebuggerWindow) ExecCommand(command string) {
if len(cmd) > 1 {
switch cmd[1] {
case "break", "bp":
- self.breakPoints = nil
- self.vm.BreakPoints = nil
+ self.Db.breakPoints = nil
self.Logln("Breakpoints cleared")
case "log":
@@ -231,16 +229,38 @@ func (self *DebuggerWindow) ExecCommand(command string) {
}
type Debugger struct {
- win *qml.Window
N chan bool
Q chan bool
done, interrupt bool
+ breakPoints []int64
+ main *DebuggerWindow
+ win *qml.Window
+}
+
+func NewDebugger(main *DebuggerWindow) *Debugger {
+ db := &Debugger{make(chan bool), make(chan bool), true, false, nil, main, main.win}
+
+ return db
}
type storeVal struct {
Key, Value string
}
+func (self *Debugger) BreakHook(pc int, op ethchain.OpCode, mem *ethchain.Memory, stack *ethchain.Stack, stateObject *ethchain.StateObject) bool {
+ self.main.Logln("break on instr:", pc)
+
+ return self.halting(pc, op, mem, stack, stateObject)
+}
+
+func (self *Debugger) StepHook(pc int, op ethchain.OpCode, mem *ethchain.Memory, stack *ethchain.Stack, stateObject *ethchain.StateObject) bool {
+ return self.halting(pc, op, mem, stack, stateObject)
+}
+
+func (self *Debugger) BreakPoints() []int64 {
+ return self.breakPoints
+}
+
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("clearMem")