diff options
author | obscuren <geffobscura@gmail.com> | 2014-09-19 17:13:01 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-09-19 17:13:01 +0800 |
commit | 0a82e3b75b85631b1b3877b9518e782b182baf8a (patch) | |
tree | 01b3d7a125da45d769247136409ff9f603af6e48 /Mist/debugger.go | |
parent | 9689a2012b54a2407619e1562fe7137f6734e8e6 (diff) | |
download | go-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.go | 24 |
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 { |