JMS #4: Parsing command flags with context
This commit is contained in:
parent
5f85917dc2
commit
6f22315082
3
cli.go
3
cli.go
@ -48,7 +48,4 @@ type Command struct {
|
|||||||
Flags []Flag
|
Flags []Flag
|
||||||
}
|
}
|
||||||
|
|
||||||
type Context struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
type Handler func(context Context)
|
type Handler func(context Context)
|
||||||
|
57
context.go
Normal file
57
context.go
Normal 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
49
context_test.go
Normal 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)
|
||||||
|
}
|
30
options.go
30
options.go
@ -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
|
|
||||||
}
|
|
||||||
}
|
|
@ -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)
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user