Compare commits

...

2 Commits

Author SHA1 Message Date
b37a283dfb Refactor flags
All checks were successful
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 4s
Signed-off-by: Jan Tytgat <jan.tytgat@corelayer.eu>
2025-06-09 22:36:45 +02:00
ee7cb7e422 Remove dependency on semver package
Signed-off-by: Jan Tytgat <jan.tytgat@corelayer.eu>
2025-06-09 22:36:32 +02:00
4 changed files with 29 additions and 17 deletions

View File

@ -8,8 +8,6 @@ import (
"time"
"github.com/spf13/cobra"
"git.flexabyte.io/flexabyte/go-kit/semver"
)
type Config struct {
@ -99,8 +97,7 @@ func (c Config) Validate() error {
return errors.New("logger is required")
}
var err error
if _, err = semver.Parse(c.Version.Full); err != nil {
if !c.Version.IsValid() {
return fmt.Errorf("invalid version: %s", c.Version)
}
return nil

View File

@ -50,7 +50,7 @@ func persistentPreRunFuncE(cmd *cobra.Command, args []string) error {
slogd.FromContext(cmd.Context()).Log(cmd.Context(), slogd.LevelTrace, "executing PersistentPreRun")
// Make sure we can always get the version
if versionFlag.Value || cmd.CommandPath() == strings.Join([]string{appName, versionName}, " ") {
if versionFlag.Value || cmd.CommandPath() == strings.Join([]string{appName, versionFlagName}, " ") {
slogd.FromContext(cmd.Context()).LogAttrs(cmd.Context(), slogd.LevelTrace, "overriding command", slog.String("old_function", runtime.FuncForPC(reflect.ValueOf(cmd.RunE).Pointer()).Name()), slog.String("new_function", runtime.FuncForPC(reflect.ValueOf(versionRunFuncE).Pointer()).Name()))
cmd.RunE = versionRunFuncE
return nil

View File

@ -8,7 +8,11 @@ import (
)
const (
jsonOutputFlagDefault = false
noColorFlagDefault = false
quietFlagDefault = false
quietFlagShortCode = "q"
verboseFlagDefault = false
verboseFlagShortCode = "v"
)
@ -20,19 +24,19 @@ var (
)
func addJsonOutputFlag(cmd *cobra.Command) {
cmd.PersistentFlags().BoolVarP(&jsonOutputFlag.Value, jsonOutputFlag.Name(), "", false, jsonOutputFlag.Usage())
cmd.PersistentFlags().BoolVarP(&jsonOutputFlag.Value, jsonOutputFlag.Name(), "", jsonOutputFlagDefault, jsonOutputFlag.Usage())
}
func addNoColorFlag(cmd *cobra.Command) {
cmd.PersistentFlags().BoolVarP(&noColorFlag.Value, noColorFlag.Name(), "", false, noColorFlag.Usage())
cmd.PersistentFlags().BoolVarP(&noColorFlag.Value, noColorFlag.Name(), "", noColorFlagDefault, noColorFlag.Usage())
}
func addQuietFlag(cmd *cobra.Command) {
cmd.PersistentFlags().BoolVarP(&quietFlag.Value, quietFlag.Name(), quietFlagShortCode, false, quietFlag.Usage())
cmd.PersistentFlags().BoolVarP(&quietFlag.Value, quietFlag.Name(), quietFlagShortCode, quietFlagDefault, quietFlag.Usage())
}
func addVerboseFlag(cmd *cobra.Command) {
cmd.PersistentFlags().BoolVarP(&verboseFlag.Value, verboseFlag.Name(), verboseFlagShortCode, false, verboseFlag.Usage())
cmd.PersistentFlags().BoolVarP(&verboseFlag.Value, verboseFlag.Name(), verboseFlagShortCode, verboseFlagDefault, verboseFlag.Usage())
}
func configureOutputFlags(cmd *cobra.Command) {

View File

@ -3,6 +3,7 @@ package application
import (
"encoding/json"
"fmt"
"regexp"
"github.com/Oudwins/zog"
"github.com/spf13/cobra"
@ -11,19 +12,25 @@ import (
)
const (
versionName = "version"
versionFlagName = "version"
versionFlagShortCode = "V"
versionUsage = "Show version information"
versionFlagUsage = "Show version information"
versionFlagDefault = false
// https://semver.org/ && https://regex101.com/r/Ly7O1x/3/
validSemVer = `^(?P<major>0|[1-9]\d*)\.(?P<minor>0|[1-9]\d*)\.(?P<patch>0|[1-9]\d*)(?:-(?P<prerelease>(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+(?P<buildmetadata>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$`
)
var (
versionFlag = flagzog.NewBoolFlag(versionName, zog.Bool(), versionUsage)
versionFlag = flagzog.NewBoolFlag(versionFlagName, zog.Bool(), versionFlagUsage)
version Version
versionCmd = &cobra.Command{
Use: versionName,
Short: versionUsage,
Use: versionFlagName,
Short: versionFlagUsage,
RunE: versionRunFuncE,
}
regexSemver = regexp.MustCompile(validSemVer)
)
type Version struct {
@ -39,8 +46,12 @@ type Version struct {
PreRelease string
}
func (v Version) IsValid() bool {
return regexSemver.MatchString(v.Full)
}
func addVersionFlag(cmd *cobra.Command) {
cmd.PersistentFlags().BoolVarP(&versionFlag.Value, versionFlag.Name(), versionFlagShortCode, false, versionFlag.Usage())
cmd.PersistentFlags().BoolVarP(&versionFlag.Value, versionFlag.Name(), versionFlagShortCode, versionFlagDefault, versionFlag.Usage())
}
func configureVersionFlag(cmd *cobra.Command, v Version) {