JMS #4: Parsing command flags with context

This commit is contained in:
Jeremy Saenz 2013-07-17 17:00:02 -07:00
parent 5f85917dc2
commit 6f22315082
5 changed files with 106 additions and 85 deletions

3
cli.go
View File

@ -48,7 +48,4 @@ type Command struct {
Flags []Flag
}
type Context struct {
}
type Handler func(context Context)

57
context.go Normal file
View File

@ -0,0 +1,57 @@
package cli
import (
"flag"
"strconv"
)
// Context is a type that is passed through to
// each Handler action in a cli application. Context
// can be used to retrieve context-specific Args and
// parsed command-line options.
type Context struct {
flagSet *flag.FlagSet
}
func NewContext(flagSet *flag.FlagSet) *Context {
return &Context{flagSet}
}
func (c *Context) IntFlag(name string) int {
flag := c.flagSet.Lookup(name)
if flag != nil {
val, err := strconv.Atoi(flag.Value.String())
if err != nil {
panic(err)
}
return val
} else {
return 0
}
}
func (c *Context) BoolFlag(name string) bool {
flag := c.flagSet.Lookup(name)
if flag != nil {
val, err := strconv.ParseBool(flag.Value.String())
if err != nil {
panic(err)
}
return val
} else {
return false
}
}
func (c *Context) StringFlag(name string) string {
flag := c.flagSet.Lookup(name)
if flag != nil {
return flag.Value.String()
} else {
return ""
}
}
func (c *Context) Args() []string {
return c.flagSet.Args()
}

49
context_test.go Normal file
View File

@ -0,0 +1,49 @@
package cli
import (
"flag"
"reflect"
"testing"
)
func expect(t *testing.T, a interface{}, b interface{}) {
if a != b {
t.Errorf("Expected %v (type %v) - Got %v (type %v)", b, reflect.TypeOf(b), a, reflect.TypeOf(a))
}
}
func refute(t *testing.T, a interface{}, b interface{}) {
if a == b {
t.Errorf("Did not expect %v (type %v) - Got %v (type %v)", b, reflect.TypeOf(b), a, reflect.TypeOf(a))
}
}
func Test_IntFlag(t *testing.T) {
set := flag.NewFlagSet("test", 0)
set.Int("myflag", 12, "doc")
c := NewContext(set)
expect(t, c.IntFlag("myflag"), 12)
}
func Test_StringFlag(t *testing.T) {
set := flag.NewFlagSet("test", 0)
set.String("myflag", "hello world", "doc")
c := NewContext(set)
expect(t, c.StringFlag("myflag"), "hello world")
}
func Test_BoolFlag(t *testing.T) {
set := flag.NewFlagSet("test", 0)
set.Bool("myflag", false, "doc")
c := NewContext(set)
expect(t, c.BoolFlag("myflag"), false)
}
func Test_Args(t *testing.T) {
set := flag.NewFlagSet("test", 0)
set.Bool("myflag", false, "doc")
c := NewContext(set)
set.Parse([]string{"--myflag", "bat", "baz"})
expect(t, len(c.Args()), 2)
expect(t, c.BoolFlag("myflag"), true)
}

View File

@ -1,30 +0,0 @@
package cli
type Options map[string] interface{}
func (o Options) Int(key string) int {
val := o[key]
if val != nil {
return val.(int)
} else {
return 0
}
}
func (o Options) String(key string) string {
val := o[key]
if val != nil {
return val.(string)
} else {
return ""
}
}
func (o Options) Bool(key string) bool {
val := o[key]
if val != nil {
return val.(bool)
} else {
return false
}
}

View File

@ -1,52 +0,0 @@
package cli
import "testing"
import "reflect"
func expect(t *testing.T, a interface{}, b interface{}) {
if a != b {
t.Errorf("Expected %v (%v) - Got %v (%v)", b, reflect.TypeOf(b), a, reflect.TypeOf(a))
}
}
func refute(t *testing.T, a interface{}, b interface{}) {
if a == b {
t.Errorf("Did not expect %v (%v) - Got %v (%v)", b, reflect.TypeOf(b), a, reflect.TypeOf(a))
}
}
func Test_Int(t *testing.T) {
opts := Options{
"foo": 1,
"bar": 2,
"bat": 3,
}
expect(t, opts.Int("foo"), 1)
expect(t, opts.Int("bar"), 2)
expect(t, opts.Int("bat"), 3)
refute(t, opts.Int("foo"), "1")
expect(t, opts.Int("nope"), 0)
}
func Test_String(t *testing.T) {
opts := Options{
"foo": "bar",
"bat": "baz",
}
expect(t, opts.String("foo"), "bar")
expect(t, opts.String("bat"), "baz")
expect(t, opts.String("nope"), "")
}
func Test_Bool(t *testing.T) {
opts := Options{
"foo": false,
"bar": true,
}
expect(t, opts.Bool("foo"), false)
expect(t, opts.Bool("bar"), true)
expect(t, opts.Bool("nope"), false)
}