package main import ( "fmt" "os" "time" "github.com/apex/log" lcli "github.com/apex/log/handlers/cli" "github.com/fatih/color" "github.com/goreleaser/goreleaser/goreleaserlib" "github.com/urfave/cli" ) var ( version = "dev" commit = "none" date = "unknown" bold = color.New(color.Bold) ) func init() { log.SetHandler(lcli.Default) } func main() { fmt.Println() defer fmt.Println() var app = cli.NewApp() app.Name = "goreleaser" app.Version = fmt.Sprintf("%v, commit %v, built at %v", version, commit, date) app.Usage = "Deliver Go binaries as fast and easily as possible" app.Flags = []cli.Flag{ cli.StringFlag{ Name: "config, file, c, f", Usage: "Load configuration from `FILE`", Value: ".goreleaser.yml", }, cli.StringFlag{ Name: "release-notes", Usage: "Load custom release notes from a markdown `FILE`", }, cli.BoolFlag{ Name: "skip-validate", Usage: "Skip all the validations against the release", }, cli.BoolFlag{ Name: "skip-publish", Usage: "Skip all publishing pipes of the release", }, cli.BoolFlag{ Name: "snapshot", Usage: "Generate an unversioned snapshot release", }, cli.BoolFlag{ Name: "rm-dist", Usage: "Remove ./dist before building", }, cli.IntFlag{ Name: "parallelism, p", Usage: "Amount of builds launch in parallel", Value: 4, }, cli.BoolFlag{ Name: "debug", Usage: "Enable debug mode", }, cli.DurationFlag{ Name: "timeout", Usage: "How much time the entire release process is allowed to take", Value: 30 * time.Minute, }, } app.Action = func(c *cli.Context) error { start := time.Now() log.Infof(bold.Sprint("releasing...")) if err := goreleaserlib.Release(c); err != nil { log.WithError(err).Errorf(bold.Sprintf("release failed after %0.2fs", time.Since(start).Seconds())) return cli.NewExitError("\n", 1) } log.Infof(bold.Sprintf("release succeeded after %0.2fs", time.Since(start).Seconds())) return nil } app.Commands = []cli.Command{ { Name: "init", Aliases: []string{"i"}, Usage: "generate .goreleaser.yml", Action: func(c *cli.Context) error { var filename = ".goreleaser.yml" if err := goreleaserlib.InitProject(filename); err != nil { log.WithError(err).Error("failed to init project") return cli.NewExitError("\n", 1) } log.WithField("file", filename). Info("config created; please edit accordingly to your needs") return nil }, }, } if err := app.Run(os.Args); err != nil { log.WithError(err).Fatal("failed") } }