diff options
author | Valentin Wüstholz <wuestholz@users.noreply.github.com> | 2017-03-01 20:34:50 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2017-03-01 20:34:50 +0800 |
commit | c52ab932e61ef9eba37c107e8b58b22c7d32e6c2 (patch) | |
tree | 57cfbad3cc6ceba6f292a2d5da8e4624b805db05 /cmd | |
parent | 230cf2ec9142b6a8f421cb8873deb5df1566e89c (diff) | |
download | go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.tar go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.tar.gz go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.tar.bz2 go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.tar.lz go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.tar.xz go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.tar.zst go-tangerine-c52ab932e61ef9eba37c107e8b58b22c7d32e6c2.zip |
cmd/disasm, cmd/evm: integrate disasm tool into evm tool. (#3729)
Diffstat (limited to 'cmd')
-rw-r--r-- | cmd/evm/disasm.go (renamed from cmd/disasm/main.go) | 35 | ||||
-rw-r--r-- | cmd/evm/main.go | 1 |
2 files changed, 24 insertions, 12 deletions
diff --git a/cmd/disasm/main.go b/cmd/evm/disasm.go index 4ea2dfcba..01a8c60ba 100644 --- a/cmd/disasm/main.go +++ b/cmd/evm/disasm.go @@ -1,4 +1,4 @@ -// Copyright 2015 The go-ethereum Authors +// Copyright 2017 The go-ethereum Authors // This file is part of go-ethereum. // // go-ethereum is free software: you can redistribute it and/or modify @@ -14,29 +14,40 @@ // You should have received a copy of the GNU General Public License // along with go-ethereum. If not, see <http://www.gnu.org/licenses/>. -// disasm is a pretty-printer for EVM bytecode. package main import ( + "errors" "fmt" "io/ioutil" - "os" - "strings" "github.com/ethereum/go-ethereum/core/asm" + cli "gopkg.in/urfave/cli.v1" + "strings" ) -func main() { - in, err := ioutil.ReadAll(os.Stdin) +var disasmCommand = cli.Command{ + Action: disasmCmd, + Name: "disasm", + Usage: "disassembles evm binary", + ArgsUsage: "<file>", +} + +func disasmCmd(ctx *cli.Context) error { + if len(ctx.Args().First()) == 0 { + return errors.New("filename required") + } + + fn := ctx.Args().First() + in, err := ioutil.ReadFile(fn) if err != nil { - fmt.Println(err) - os.Exit(1) + return err } + code := strings.TrimSpace(string(in[:])) fmt.Printf("%v\n", code) - err = asm.PrintDisassembled(code) - if err != nil { - fmt.Printf("Error: %v\n", err) - return + if err = asm.PrintDisassembled(code); err != nil { + return err } + return nil } diff --git a/cmd/evm/main.go b/cmd/evm/main.go index 5ce45b9ca..cc4f8a49c 100644 --- a/cmd/evm/main.go +++ b/cmd/evm/main.go @@ -101,6 +101,7 @@ func init() { } app.Commands = []cli.Command{ compileCommand, + disasmCommand, runCommand, } } |