func main() { defer func() { if r := recover(); r != nil { // log panics forces exit if _, ok := r.(*logrus.Entry); ok { os.Exit(1) } panic(r) } }() app := cli.NewApp() app.Name = path.Base(os.Args[0]) app.Usage = "a GitLab Runner" app.Version = fmt.Sprintf("%s (%s)", common.VERSION, common.REVISION) app.Authors = []cli.Author{ cli.Author{ Name: "Kamil Trzciński", Email: "*****@*****.**", }, } cli_helpers.SetupLogLevelOptions(app) app.Commands = common.GetCommands() app.CommandNotFound = func(context *cli.Context, command string) { logrus.Fatalln("Command", command, "not found.") } if err := app.Run(os.Args); err != nil { logrus.Fatal(err) } }
func main() { app := cli.NewApp() app.Name = path.Base(os.Args[0]) app.Usage = "a GitLab Runner" app.Version = fmt.Sprintf("%s (%s)", common.VERSION, common.REVISION) app.Author = "Kamil Trzciński" app.Email = "*****@*****.**" cli_helpers.SetupLogLevelOptions(app) app.Commands = common.GetCommands() if err := app.Run(os.Args); err != nil { log.Fatal(err) } }
func main() { app := cli.NewApp() app.Name = path.Base(os.Args[0]) app.Usage = "a GitLab Runner" app.Version = fmt.Sprintf("%s (%s)", common.VERSION, common.REVISION) app.Author = "Kamil Trzciński" app.Email = "*****@*****.**" app.Flags = []cli.Flag{ cli.BoolFlag{ Name: "debug", Usage: "debug mode", EnvVar: "DEBUG", }, cli.StringFlag{ Name: "log-level, l", Value: "info", Usage: "Log level (options: debug, info, warn, error, fatal, panic)", }, } // logs app.Before = func(c *cli.Context) error { log.SetOutput(os.Stderr) level, err := log.ParseLevel(c.String("log-level")) if err != nil { log.Fatalf(err.Error()) } log.SetLevel(level) // If a log level wasn't specified and we are running in debug mode, // enforce log-level=debug. if !c.IsSet("log-level") && !c.IsSet("l") && c.Bool("debug") { log.SetLevel(log.DebugLevel) } return nil } app.Commands = common.GetCommands() if err := app.Run(os.Args); err != nil { log.Fatal(err) } }
func main() { app := cli.NewApp() app.Name = path.Base(os.Args[0]) app.Usage = "a GitLab Runner" app.Version = fmt.Sprintf("%s (%s)", common.VERSION, common.REVISION) app.Authors = []cli.Author{ cli.Author{ Name: "Kamil Trzciński", Email: "*****@*****.**", }, } cli_helpers.SetupLogLevelOptions(app) app.Commands = common.GetCommands() app.CommandNotFound = func(context *cli.Context, command string) { log.Fatalln("Command", command, "not found.") } if err := app.Run(os.Args); err != nil { log.Fatal(err) } }