bsc/ethereum/flags.go

73 lines
2.3 KiB
Go
Raw Normal View History

2014-03-22 13:03:10 +02:00
package main
import (
"flag"
2014-05-20 23:12:22 +03:00
"fmt"
"os"
"os/user"
"path"
"github.com/ethereum/eth-go/ethlog"
2014-03-22 13:03:10 +02:00
)
2014-05-22 11:38:37 +03:00
var Identifier string
var StartRpc bool
var RpcPort int
2014-03-22 13:03:10 +02:00
var UseUPnP bool
var OutboundPort string
var ShowGenesis bool
var AddPeer string
var MaxPeer int
var GenAddr bool
var UseSeed bool
var ImportKey string
var ExportKey bool
var NonInteractive bool
var Datadir string
var LogFile string
var ConfigFile string
var DebugFile string
var LogLevel int
// flags specific to cli client
var StartMining bool
2014-05-15 23:17:09 +03:00
var StartJsConsole bool
2014-05-19 18:01:40 +03:00
var InputFile string
2014-03-22 13:03:10 +02:00
func defaultDataDir() string {
usr, _ := user.Current()
return path.Join(usr.HomeDir, ".ethereum")
}
var defaultConfigFile = path.Join(defaultDataDir(), "conf.ini")
2014-03-22 13:03:10 +02:00
func Init() {
2014-05-20 23:12:22 +03:00
flag.Usage = func() {
fmt.Fprintf(os.Stderr, "%s [options] [filename]:\noptions precedence: default < config file < environment variables < command line", os.Args[0])
2014-05-20 23:12:22 +03:00
flag.PrintDefaults()
}
flag.StringVar(&Identifier, "id", "", "Custom client identifier")
flag.StringVar(&OutboundPort, "port", "30303", "listening port")
flag.BoolVar(&UseUPnP, "upnp", false, "enable UPnP support")
flag.IntVar(&MaxPeer, "maxpeer", 10, "maximum desired peers")
flag.IntVar(&RpcPort, "rpcport", 8080, "port to start json-rpc server on")
flag.BoolVar(&StartRpc, "rpc", false, "start rpc server")
flag.BoolVar(&NonInteractive, "y", false, "non-interactive mode (say yes to confirmations)")
2014-05-13 12:34:47 +03:00
flag.BoolVar(&UseSeed, "seed", true, "seed peers")
2014-03-22 13:03:10 +02:00
flag.BoolVar(&GenAddr, "genaddr", false, "create a new priv/pub key")
flag.BoolVar(&ExportKey, "export", false, "export private key")
flag.StringVar(&LogFile, "logfile", "", "log file (defaults to standard output)")
2014-03-22 13:03:10 +02:00
flag.StringVar(&ImportKey, "import", "", "imports the given private key (hex)")
flag.StringVar(&Datadir, "datadir", defaultDataDir(), "specifies the datadir to use")
flag.StringVar(&ConfigFile, "conf", defaultConfigFile, "config file")
flag.StringVar(&DebugFile, "debug", "", "debug file (no debugging if not set)")
flag.IntVar(&LogLevel, "loglevel", int(ethlog.InfoLevel), "loglevel: 0-5: silent,error,warn,info,debug,debug detail)")
2014-03-22 13:03:10 +02:00
flag.BoolVar(&StartMining, "mine", false, "start dagger mining")
flag.BoolVar(&StartJsConsole, "js", false, "launches javascript console")
2014-03-22 13:03:10 +02:00
flag.Parse()
2014-05-20 23:12:22 +03:00
InputFile = flag.Arg(0)
2014-03-22 13:03:10 +02:00
}