aboutsummaryrefslogtreecommitdiffstats
path: root/ethereal/ui/debugger.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-06-10 04:04:16 +0800
committerobscuren <geffobscura@gmail.com>2014-06-10 04:04:16 +0800
commitba3623d0cc0608f2d73e10e61a184238924fccdb (patch)
tree288d081c532bc2397809c95497f1e8d23df6cadc /ethereal/ui/debugger.go
parentcc20b0e3a0754c77fe04a8b5c5668d0eda955bcf (diff)
downloaddexon-ba3623d0cc0608f2d73e10e61a184238924fccdb.tar.gz
dexon-ba3623d0cc0608f2d73e10e61a184238924fccdb.tar.zst
dexon-ba3623d0cc0608f2d73e10e61a184238924fccdb.zip
Fixed debugger hang
Diffstat (limited to 'ethereal/ui/debugger.go')
-rw-r--r--ethereal/ui/debugger.go38
1 files changed, 31 insertions, 7 deletions
diff --git a/ethereal/ui/debugger.go b/ethereal/ui/debugger.go
index a4489cdf4..919407b34 100644
--- a/ethereal/ui/debugger.go
+++ b/ethereal/ui/debugger.go
@@ -26,7 +26,7 @@ func NewDebuggerWindow(lib *UiLib) *DebuggerWindow {
}
win := component.CreateWindow(nil)
- db := &Debugger{win, make(chan bool), make(chan bool), true}
+ db := &Debugger{win, make(chan bool), make(chan bool), true, false}
return &DebuggerWindow{engine: engine, win: win, lib: lib, Db: db}
}
@@ -60,6 +60,12 @@ func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, scriptStr, data
self.Db.Q <- true
}
+ defer func() {
+ if r := recover(); r != nil {
+ self.Logf("compile FAULT: %v", r)
+ }
+ }()
+
data := ethutil.StringToByteFunc(dataStr, func(s string) (ret []byte) {
slice := strings.Split(dataStr, "\n")
for _, dataItem := range slice {
@@ -131,7 +137,11 @@ func (self *DebuggerWindow) Debug(valueStr, gasStr, gasPriceStr, scriptStr, data
state.Reset()
- self.Db.done = true
+ if !self.Db.interrupt {
+ self.Db.done = true
+ } else {
+ self.Db.interrupt = false
+ }
}()
}
@@ -149,10 +159,10 @@ func (self *DebuggerWindow) Next() {
}
type Debugger struct {
- win *qml.Window
- N chan bool
- Q chan bool
- done bool
+ win *qml.Window
+ N chan bool
+ Q chan bool
+ done, interrupt bool
}
type storeVal struct {
@@ -185,7 +195,8 @@ out:
case <-d.N:
break out
case <-d.Q:
- d.done = true
+ d.interrupt = true
+ d.clearBuffers()
return false
}
@@ -194,6 +205,19 @@ out:
return true
}
+func (d *Debugger) clearBuffers() {
+out:
+ // drain
+ for {
+ select {
+ case <-d.N:
+ case <-d.Q:
+ default:
+ break out
+ }
+ }
+}
+
func (d *Debugger) Next() {
if !d.done {
d.N <- true