Skip to content

Commit

Permalink
Add ToBoolSlice()
Browse files Browse the repository at this point in the history
Fixes #1
  • Loading branch information
cognusion authored and bep committed Sep 19, 2016
1 parent fa673d6 commit 60e7a69
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 0 deletions.
5 changes: 5 additions & 0 deletions cast.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,11 @@ func ToSlice(i interface{}) []interface{} {
return v
}

func ToBoolSlice(i interface{}) []bool {
v, _ := ToBoolSliceE(i)
return v
}

func ToStringSlice(i interface{}) []string {
v, _ := ToStringSliceE(i)
return v
Expand Down
4 changes: 4 additions & 0 deletions cast_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,10 @@ func TestSlices(t *testing.T) {
assert.Equal(t, []int{1, 3}, ToIntSlice([]interface{}{1.2, 3.2}))
assert.Equal(t, []int{2, 3}, ToIntSlice([]string{"2", "3"}))
assert.Equal(t, []int{2, 3}, ToIntSlice([2]string{"2", "3"}))
assert.Equal(t, []bool{true, false, true}, ToBoolSlice([]bool{true, false, true}))
assert.Equal(t, []bool{true, false, true}, ToBoolSlice([]interface{}{true, false, true}))
assert.Equal(t, []bool{true, false, true}, ToBoolSlice([]int{1,0,1}))
assert.Equal(t, []bool{true, false, true}, ToBoolSlice([]string{"true","false","true"}))
}

func TestToBool(t *testing.T) {
Expand Down
32 changes: 32 additions & 0 deletions caste.go
Original file line number Diff line number Diff line change
Expand Up @@ -422,6 +422,38 @@ func ToSliceE(i interface{}) ([]interface{}, error) {
}
}

// ToBoolSliceE casts an empty interface to a []bool.
func ToBoolSliceE(i interface{}) ([]bool, error) {
jww.DEBUG.Println("ToBoolSliceE called on type:", reflect.TypeOf(i))

if i == nil {
return []bool{}, fmt.Errorf("Unable to Cast %#v to []bool", i)
}

switch v := i.(type) {
case []bool:
return v, nil
}

kind := reflect.TypeOf(i).Kind()
switch kind {
case reflect.Slice, reflect.Array:
s := reflect.ValueOf(i)
a := make([]bool, s.Len())
for j := 0; j < s.Len(); j++ {
val, err := ToBoolE(s.Index(j).Interface())
if err != nil {
return []bool{}, fmt.Errorf("Unable to Cast %#v to []bool", i)
}
a[j] = val
}
return a, nil
default:
return []bool{}, fmt.Errorf("Unable to Cast %#v to []bool", i)
}
}


// ToStringSliceE casts an empty interface to a []string.
func ToStringSliceE(i interface{}) ([]string, error) {
jww.TRACE.Println("ToStringSliceE called on type:", reflect.TypeOf(i))
Expand Down

0 comments on commit 60e7a69

Please sign in to comment.