From 6152d25e5599a864f4efe727d1fc5b2b586f5e89 Mon Sep 17 00:00:00 2001 From: Roman Volosatovs Date: Tue, 18 Apr 2017 15:54:21 +0200 Subject: [PATCH] properly handle uint types --- viper.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/viper.go b/viper.go index be8500a..1125aad 100644 --- a/viper.go +++ b/viper.go @@ -614,6 +614,8 @@ func (v *Viper) Get(key string) interface{} { return cast.ToString(val) case int64, int32, int16, int8, int: return cast.ToInt(val) + case uint64, uint32, uint16, uint8, uint: + return cast.ToUint(val) case float64, float32: return cast.ToFloat64(val) case time.Time: @@ -897,6 +899,8 @@ func (v *Viper) find(lcaseKey string) interface{} { switch flag.ValueType() { case "int", "int8", "int16", "int32", "int64": return cast.ToInt(flag.ValueString()) + case "uint", "uint8", "uint16", "uint32", "uint64": + return cast.ToUint(flag.ValueString()) case "bool": return cast.ToBool(flag.ValueString()) case "stringSlice", "stringArray", "boolSlice", "ipSlice", "uintSlice", "intSlice": @@ -966,6 +970,8 @@ func (v *Viper) find(lcaseKey string) interface{} { switch flag.ValueType() { case "int", "int8", "int16", "int32", "int64": return cast.ToInt(flag.ValueString()) + case "uint", "uint8", "uint16", "uint32", "uint64": + return cast.ToUint(flag.ValueString()) case "bool": return cast.ToBool(flag.ValueString()) case "stringSlice", "stringArray", "boolSlice", "ipSlice", "uintSlice", "intSlice":