feat(cli): add --version flag (#29)

This commit is contained in:
Julian Tölle 2024-08-25 13:47:55 +02:00 committed by GitHub
parent a67b510284
commit 1ede0bef10
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 28 additions and 26 deletions

View file

@ -1,31 +1,45 @@
package cmd package cmd
import ( import (
"fmt"
"log/slog" "log/slog"
"os" "os"
"runtime/debug"
"github.com/spf13/cobra" "github.com/spf13/cobra"
) )
var logger *slog.Logger var logger *slog.Logger
// rootCmd represents the base command when called without any subcommands
var rootCmd = &cobra.Command{ var rootCmd = &cobra.Command{
Use: "releaser-pleaser", Use: "releaser-pleaser",
Short: "A brief description of your application", Short: "",
Long: `A longer description that spans multiple lines and likely contains Long: ``,
examples and usage of using your application. For example: Version: version(),
}
Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files func version() string {
to quickly create a Cobra application.`, vcsrevision := "unknown"
// Uncomment the following line if your bare application vcsdirty := ""
// has an action associated with it:
// Run: func(cmd *cobra.Command, args []string) { }, buildInfo, ok := debug.ReadBuildInfo()
if ok {
fmt.Println(buildInfo.String())
for _, setting := range buildInfo.Settings {
switch setting.Key {
case "vcs.revision":
vcsrevision = setting.Value
case "vcs.modified":
if setting.Value == "true" {
vcsdirty = " (dirty)"
}
}
}
}
return vcsrevision + vcsdirty
} }
// Execute adds all child commands to the root command and sets flags appropriately.
// This is called by main.main(). It only needs to happen once to the rootCmd.
func Execute() { func Execute() {
err := rootCmd.Execute() err := rootCmd.Execute()
if err != nil { if err != nil {
@ -38,13 +52,4 @@ func init() {
Level: slog.LevelDebug, Level: slog.LevelDebug,
})) }))
// Here you will define your flags and configuration settings.
// Cobra supports persistent flags, which, if defined here,
// will be global for your application.
// rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.releaser-pleaser.yaml)")
// Cobra also supports local flags, which will only run
// when this action is called directly.
rootCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
} }

View file

@ -8,7 +8,6 @@ import (
rp "github.com/apricote/releaser-pleaser" rp "github.com/apricote/releaser-pleaser"
) )
// runCmd represents the run command
var runCmd = &cobra.Command{ var runCmd = &cobra.Command{
Use: "run", Use: "run",
RunE: run, RunE: run,
@ -25,8 +24,6 @@ var (
func init() { func init() {
rootCmd.AddCommand(runCmd) rootCmd.AddCommand(runCmd)
// Here you will define your flags and configuration settings.
runCmd.PersistentFlags().StringVar(&flagForge, "forge", "", "") runCmd.PersistentFlags().StringVar(&flagForge, "forge", "", "")
runCmd.PersistentFlags().StringVar(&flagBranch, "branch", "main", "") runCmd.PersistentFlags().StringVar(&flagBranch, "branch", "main", "")
runCmd.PersistentFlags().StringVar(&flagOwner, "owner", "", "") runCmd.PersistentFlags().StringVar(&flagOwner, "owner", "", "")