JMS #4: Kinda parsing flags now

This commit is contained in:
Jeremy Saenz 2013-07-16 19:59:04 -07:00
parent 4b4324bb47
commit e2733adc45
2 changed files with 24 additions and 2 deletions

8
cli.go
View File

@ -1,7 +1,7 @@
package cli package cli
import "fmt"
import "os" import "os"
import "flag"
// The name of the program. Defaults to os.Args[0] // The name of the program. Defaults to os.Args[0]
var Name = os.Args[0] var Name = os.Args[0]
@ -21,6 +21,10 @@ var Flags []Flag
var Action = ShowHelp var Action = ShowHelp
func Run(args []string) { func Run(args []string) {
set := flagSet(Flags)
set.Parse(args[1:])
context := Context{} context := Context{}
if len(args) > 1 { if len(args) > 1 {
name := args[1] name := args[1]
@ -42,7 +46,7 @@ type Command struct {
Usage string Usage string
Description string Description string
Action Handler Action Handler
Flags flag.FlagSet Flags []Flag
} }
type Context struct { type Context struct {

18
flag.go
View File

@ -1,9 +1,11 @@
package cli package cli
import "fmt" import "fmt"
import "flag"
type Flag interface { type Flag interface {
fmt.Stringer fmt.Stringer
Apply(*flag.FlagSet)
} }
type BoolFlag struct { type BoolFlag struct {
@ -21,6 +23,22 @@ func (f StringFlag) String() string {
return fmt.Sprintf("--%v 'string'\t%v", f.Name, f.Usage) return fmt.Sprintf("--%v 'string'\t%v", f.Name, f.Usage)
} }
func (f StringFlag) Apply(set *flag.FlagSet) {
set.String(f.Name, f.Value, f.Usage)
}
func (f BoolFlag) String() string { func (f BoolFlag) String() string {
return fmt.Sprintf("--%v\t%v", f.Name, f.Usage) return fmt.Sprintf("--%v\t%v", f.Name, f.Usage)
} }
func (f BoolFlag) Apply(set *flag.FlagSet) {
set.Bool(f.Name, false, f.Usage)
}
func flagSet(flags []Flag) *flag.FlagSet {
set := flag.NewFlagSet("set", flag.PanicOnError)
for _, f := range flags {
f.Apply(set)
}
return set
}