Commit e4d2d00d authored by obscuren's avatar obscuren

Added support for breakpoints on specific instructions

parent 315d6528
...@@ -53,7 +53,10 @@ type Vm struct { ...@@ -53,7 +53,10 @@ type Vm struct {
err error err error
// Debugging
Hook DebugHook Hook DebugHook
BreakPoints []int64
Stepping bool
} }
type DebugHook func(step int, op OpCode, mem *Memory, stack *Stack, stateObject *StateObject) bool type DebugHook func(step int, op OpCode, mem *Memory, stack *Stack, stateObject *StateObject) bool
...@@ -742,9 +745,16 @@ func (vm *Vm) RunClosure(closure *Closure) (ret []byte, err error) { ...@@ -742,9 +745,16 @@ func (vm *Vm) RunClosure(closure *Closure) (ret []byte, err error) {
vm.Endl() vm.Endl()
if vm.Hook != nil { if vm.Hook != nil {
for _, instrNo := range vm.BreakPoints {
if pc.Cmp(big.NewInt(instrNo)) == 0 || vm.Stepping {
vm.Stepping = true
if !vm.Hook(prevStep, op, mem, stack, closure.Object()) { if !vm.Hook(prevStep, op, mem, stack, closure.Object()) {
return nil, nil return nil, nil
} }
} }
} }
}
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment