mirror of
https://github.com/spf13/viper
synced 2025-01-22 10:26:36 +00:00
Handle the case Get() returns either map[interface{}]interface{} or map[string]interface{}
This commit is contained in:
parent
110492b300
commit
0c82789feb
2 changed files with 10 additions and 6 deletions
11
viper.go
11
viper.go
|
@ -526,13 +526,14 @@ func (v *Viper) Get(key string) interface{} {
|
|||
// Returns new Viper instance representing a sub tree of this instance
|
||||
func Sub(key string) *Viper { return v.Sub(key) }
|
||||
func (v *Viper) Sub(key string) *Viper {
|
||||
data, ok := v.Get(key).(map[string]interface{})
|
||||
if !ok {
|
||||
subv := New()
|
||||
data := v.Get(key)
|
||||
if reflect.TypeOf(data).Kind() == reflect.Map {
|
||||
subv.config = cast.ToStringMap(data)
|
||||
return subv
|
||||
} else {
|
||||
return nil
|
||||
}
|
||||
subv := New()
|
||||
subv.config = data
|
||||
return subv
|
||||
}
|
||||
|
||||
// Returns the value associated with the key as a string
|
||||
|
|
|
@ -730,7 +730,10 @@ func TestSub(t *testing.T) {
|
|||
v.SetConfigType("yaml")
|
||||
v.ReadConfig(bytes.NewBuffer(yamlExample))
|
||||
|
||||
subv := v.Sub("clothing.pants")
|
||||
subv := v.Sub("clothing")
|
||||
assert.Equal(t, v.Get("clothing.pants.size"), subv.Get("pants.size"))
|
||||
|
||||
subv = v.Sub("clothing.pants")
|
||||
assert.Equal(t, v.Get("clothing.pants.size"), subv.Get("size"))
|
||||
|
||||
subv = v.Sub("clothing.pants.size")
|
||||
|
|
Loading…
Reference in a new issue