simplify
This commit is contained in:
parent
33c948fc9b
commit
5b0e465dc5
38
cmd/root.go
38
cmd/root.go
@ -1,12 +1,18 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
u "github.com/bcicen/go-units"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
var rootCmd = &cobra.Command{
|
var (
|
||||||
|
from string
|
||||||
|
to string
|
||||||
|
rootCmd = &cobra.Command{
|
||||||
Use: "converter",
|
Use: "converter",
|
||||||
Short: "A brief description of your application",
|
Short: "A brief description of your application",
|
||||||
Long: `A longer description that spans multiple lines and likely contains
|
Long: `A longer description that spans multiple lines and likely contains
|
||||||
@ -15,7 +21,32 @@ examples and usage of using your application. For example:
|
|||||||
Cobra is a CLI library for Go that empowers applications.
|
Cobra is a CLI library for Go that empowers applications.
|
||||||
This application is a tool to generate the needed files
|
This application is a tool to generate the needed files
|
||||||
to quickly create a Cobra application.`,
|
to quickly create a Cobra application.`,
|
||||||
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
|
in, err := strconv.ParseFloat(args[0], 64)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err.Error())
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
fromVal, err := u.Find(cmd.Flag("from").Value.String())
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
toVal, err := u.Find(cmd.Flag("to").Value.String())
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
val := u.NewValue(in, fromVal)
|
||||||
|
out, err := val.Convert(toVal)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Println(out.String())
|
||||||
|
},
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
func Execute() {
|
func Execute() {
|
||||||
err := rootCmd.Execute()
|
err := rootCmd.Execute()
|
||||||
@ -23,3 +54,8 @@ func Execute() {
|
|||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
rootCmd.PersistentFlags().StringVarP(&from, "from", "f", "c", "unit system to convert from")
|
||||||
|
rootCmd.PersistentFlags().StringVarP(&to, "to", "t", "f", "unit system to convert to")
|
||||||
|
}
|
||||||
|
77
cmd/temp.go
77
cmd/temp.go
@ -1,77 +0,0 @@
|
|||||||
package cmd
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
u "github.com/bcicen/go-units"
|
|
||||||
"github.com/spf13/cobra"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
from string
|
|
||||||
to string
|
|
||||||
tempCmd = &cobra.Command{
|
|
||||||
Use: "temperature",
|
|
||||||
Aliases: []string{"temp", "t", "temps"},
|
|
||||||
Short: "A brief description of your command",
|
|
||||||
Long: `A longer description that spans multiple lines and likely contains examples
|
|
||||||
and usage of using your command. For example:
|
|
||||||
|
|
||||||
Cobra is a CLI library for Go that empowers applications.
|
|
||||||
This application is a tool to generate the needed files
|
|
||||||
to quickly create a Cobra application.`,
|
|
||||||
Args: cobra.MatchAll(cobra.ExactArgs(1)),
|
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
|
||||||
err := cmd.ParseFlags(args)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
in, err := strconv.ParseFloat(args[0], 64)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
fromFlag := strings.ToLower(cmd.Flag("from").Value.String())
|
|
||||||
toFlag := strings.ToLower(cmd.Flag("to").Value.String())
|
|
||||||
var out u.Value
|
|
||||||
switch fromFlag {
|
|
||||||
case "f", "farenheit":
|
|
||||||
out, err = Convert(in, toFlag, u.Fahrenheit)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
case "c", "celsius":
|
|
||||||
out, err = Convert(in, toFlag, u.Celsius)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
case "k", "kelvin":
|
|
||||||
out, err = Convert(in, toFlag, u.Kelvin)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fmt.Println(out.String())
|
|
||||||
return nil
|
|
||||||
},
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
func Convert(in float64, to string, from u.Unit) (u.Value, error) {
|
|
||||||
switch to {
|
|
||||||
case "f", "farenheit":
|
|
||||||
return u.ConvertFloat(in, from, u.Fahrenheit)
|
|
||||||
case "c", "celsius":
|
|
||||||
return u.ConvertFloat(in, from, u.Celsius)
|
|
||||||
case "k", "kelvin":
|
|
||||||
return u.ConvertFloat(in, from, u.Kelvin)
|
|
||||||
}
|
|
||||||
return u.Value{}, fmt.Errorf("Invalid flags provided")
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
rootCmd.AddCommand(tempCmd)
|
|
||||||
tempCmd.PersistentFlags().StringVarP(&from, "from", "f", "c", "unit system to convert from, (farenheit, celsius, kelvin)")
|
|
||||||
tempCmd.PersistentFlags().StringVarP(&to, "to", "t", "f", "unit system to convert to, (farenheit, celsius, kelvin)")
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user