github.com/ethereum/go-ethereum@v1.16.1/cmd/evm/internal/t8ntool/flags.go (about) 1 // Copyright 2020 The go-ethereum Authors 2 // This file is part of go-ethereum. 3 // 4 // go-ethereum is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // go-ethereum is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU General Public License for more details. 13 // 14 // You should have received a copy of the GNU General Public License 15 // along with go-ethereum. If not, see <http://www.gnu.org/licenses/>. 16 17 package t8ntool 18 19 import ( 20 "fmt" 21 "strings" 22 23 "github.com/ethereum/go-ethereum/core/vm" 24 "github.com/ethereum/go-ethereum/tests" 25 "github.com/urfave/cli/v2" 26 ) 27 28 var ( 29 TraceFlag = &cli.BoolFlag{ 30 Name: "trace", 31 Usage: "Configures the use of the JSON opcode tracer. This tracer emits traces to files as trace-<txIndex>-<txHash>.jsonl", 32 } 33 TraceTracerFlag = &cli.StringFlag{ 34 Name: "trace.tracer", 35 Usage: "Configures the use of a custom tracer, e.g native or js tracers. Examples are callTracer and 4byteTracer. These tracers emit results into files as trace-<txIndex>-<txHash>.json", 36 } 37 TraceTracerConfigFlag = &cli.StringFlag{ 38 Name: "trace.jsonconfig", 39 Usage: "The configurations for the custom tracer specified by --trace.tracer. If provided, must be in JSON format", 40 } 41 TraceEnableMemoryFlag = &cli.BoolFlag{ 42 Name: "trace.memory", 43 Usage: "Enable full memory dump in traces", 44 } 45 TraceDisableStackFlag = &cli.BoolFlag{ 46 Name: "trace.nostack", 47 Usage: "Disable stack output in traces", 48 } 49 TraceEnableReturnDataFlag = &cli.BoolFlag{ 50 Name: "trace.returndata", 51 Usage: "Enable return data output in traces", 52 } 53 TraceEnableCallFramesFlag = &cli.BoolFlag{ 54 Name: "trace.callframes", 55 Usage: "Enable call frames output in traces", 56 } 57 OutputBasedir = &cli.StringFlag{ 58 Name: "output.basedir", 59 Usage: "Specifies where output files are placed. Will be created if it does not exist.", 60 Value: "", 61 } 62 OutputBodyFlag = &cli.StringFlag{ 63 Name: "output.body", 64 Usage: "If set, the RLP of the transactions (block body) will be written to this file.", 65 Value: "", 66 } 67 OutputAllocFlag = &cli.StringFlag{ 68 Name: "output.alloc", 69 Usage: "Determines where to put the `alloc` of the post-state.\n" + 70 "\t`stdout` - into the stdout output\n" + 71 "\t`stderr` - into the stderr output\n" + 72 "\t<file> - into the file <file> ", 73 Value: "alloc.json", 74 } 75 OutputResultFlag = &cli.StringFlag{ 76 Name: "output.result", 77 Usage: "Determines where to put the `result` (stateroot, txroot etc) of the post-state.\n" + 78 "\t`stdout` - into the stdout output\n" + 79 "\t`stderr` - into the stderr output\n" + 80 "\t<file> - into the file <file> ", 81 Value: "result.json", 82 } 83 OutputBlockFlag = &cli.StringFlag{ 84 Name: "output.block", 85 Usage: "Determines where to put the `block` after building.\n" + 86 "\t`stdout` - into the stdout output\n" + 87 "\t`stderr` - into the stderr output\n" + 88 "\t<file> - into the file <file> ", 89 Value: "block.json", 90 } 91 InputAllocFlag = &cli.StringFlag{ 92 Name: "input.alloc", 93 Usage: "`stdin` or file name of where to find the prestate alloc to use.", 94 Value: "alloc.json", 95 } 96 InputEnvFlag = &cli.StringFlag{ 97 Name: "input.env", 98 Usage: "`stdin` or file name of where to find the prestate env to use.", 99 Value: "env.json", 100 } 101 InputTxsFlag = &cli.StringFlag{ 102 Name: "input.txs", 103 Usage: "`stdin` or file name of where to find the transactions to apply. " + 104 "If the file extension is '.rlp', then the data is interpreted as an RLP list of signed transactions." + 105 "The '.rlp' format is identical to the output.body format.", 106 Value: "txs.json", 107 } 108 InputHeaderFlag = &cli.StringFlag{ 109 Name: "input.header", 110 Usage: "`stdin` or file name of where to find the block header to use.", 111 Value: "header.json", 112 } 113 InputOmmersFlag = &cli.StringFlag{ 114 Name: "input.ommers", 115 Usage: "`stdin` or file name of where to find the list of ommer header RLPs to use.", 116 } 117 InputWithdrawalsFlag = &cli.StringFlag{ 118 Name: "input.withdrawals", 119 Usage: "`stdin` or file name of where to find the list of withdrawals to use.", 120 } 121 InputTxsRlpFlag = &cli.StringFlag{ 122 Name: "input.txs", 123 Usage: "`stdin` or file name of where to find the transactions list in RLP form.", 124 Value: "txs.rlp", 125 } 126 SealCliqueFlag = &cli.StringFlag{ 127 Name: "seal.clique", 128 Usage: "Seal block with Clique. `stdin` or file name of where to find the Clique sealing data.", 129 } 130 RewardFlag = &cli.Int64Flag{ 131 Name: "state.reward", 132 Usage: "Mining reward. Set to -1 to disable", 133 Value: 0, 134 } 135 ChainIDFlag = &cli.Int64Flag{ 136 Name: "state.chainid", 137 Usage: "ChainID to use", 138 Value: 1, 139 } 140 ForknameFlag = &cli.StringFlag{ 141 Name: "state.fork", 142 Usage: fmt.Sprintf("Name of ruleset to use."+ 143 "\n\tAvailable forknames:"+ 144 "\n\t %v"+ 145 "\n\tAvailable extra eips:"+ 146 "\n\t %v"+ 147 "\n\tSyntax <forkname>(+ExtraEip)", 148 strings.Join(tests.AvailableForks(), "\n\t "), 149 strings.Join(vm.ActivateableEips(), ", ")), 150 Value: "GrayGlacier", 151 } 152 VerbosityFlag = &cli.IntFlag{ 153 Name: "verbosity", 154 Usage: "sets the verbosity level", 155 Value: 3, 156 } 157 )