aboutsummaryrefslogtreecommitdiffstats
path: root/Mist/debugger.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-09-19 17:13:01 +0800
committerobscuren <geffobscura@gmail.com>2014-09-19 17:13:01 +0800
commit0a82e3b75b85631b1b3877b9518e782b182baf8a (patch)
tree01b3d7a125da45d769247136409ff9f603af6e48 /Mist/debugger.go
parent9689a2012b54a2407619e1562fe7137f6734e8e6 (diff)
downloadgo-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.tar
go-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.tar.gz
go-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.tar.bz2
go-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.tar.lz
go-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.tar.xz
go-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.tar.zst
go-tangerine-0a82e3b75b85631b1b3877b9518e782b182baf8a.zip
Stack info
Diffstat (limited to 'Mist/debugger.go')
-rw-r--r--Mist/debugger.go24
1 files changed, 20 insertions, 4 deletions
diff --git a/Mist/debugger.go b/Mist/debugger.go
index 2b9081419..a9086921d 100644
--- a/Mist/debugger.go
+++ b/Mist/debugger.go
@@ -5,6 +5,7 @@ import (
"math/big"
"strconv"
"strings"
+ "unicode"
"github.com/ethereum/eth-go/ethchain"
"github.com/ethereum/eth-go/ethstate"
@@ -271,9 +272,20 @@ func (d *Debugger) halting(pc int, op ethvm.OpCode, mem *ethvm.Memory, stack *et
d.win.Root().Call("clearStorage")
addr := 0
- for i := 0; i+32 <= mem.Len(); i += 32 {
- d.win.Root().Call("setMem", memAddr{fmt.Sprintf("%03d", addr), fmt.Sprintf("% x", mem.Data()[i:i+32])})
- addr++
+ for i := 0; i+32 <= mem.Len(); i += 16 {
+ dat := mem.Data()[i : i+16]
+ var str string
+
+ for _, d := range dat {
+ if unicode.IsGraphic(rune(d)) {
+ str += string(d)
+ } else {
+ str += "?"
+ }
+ }
+
+ d.win.Root().Call("setMem", memAddr{fmt.Sprintf("%03d", addr), fmt.Sprintf("%s % x", str, dat)})
+ addr += 16
}
for _, val := range stack.Data() {
@@ -284,7 +296,11 @@ func (d *Debugger) halting(pc int, op ethvm.OpCode, mem *ethvm.Memory, stack *et
d.win.Root().Call("setStorage", storeVal{fmt.Sprintf("% x", key), fmt.Sprintf("% x", node.Str())})
})
- d.win.Root().ObjectByName("info").Set("text", fmt.Sprintf(`stack frame %v`, new(big.Int).SetBytes(mem.Get(0, 32))))
+ stackFrameAt := new(big.Int).SetBytes(mem.Get(0, 32))
+ psize := mem.Len() - int(new(big.Int).SetBytes(mem.Get(0, 32)).Uint64())
+ d.win.Root().ObjectByName("stackFrame").Set("text", fmt.Sprintf(`<b>stack ptr</b>: %v`, stackFrameAt))
+ d.win.Root().ObjectByName("stackSize").Set("text", fmt.Sprintf(`<b>stack size</b>: %d`, psize))
+ d.win.Root().ObjectByName("memSize").Set("text", fmt.Sprintf(`<b>mem size</b>: %v`, mem.Len()))
out:
for {