4 Commits

Author SHA1 Message Date
6fea990cb9 remove empty map 2022-03-27 15:03:39 +02:00
19fdcd7e05 remove empty map 2022-03-27 14:53:46 +02:00
7a72947737 test 2022-03-27 14:42:43 +02:00
3c23ee5473 change map offset 2022-03-27 14:32:28 +02:00
2 changed files with 26 additions and 21 deletions

View File

@ -44,7 +44,7 @@ func NewConfig() *Config {
if len(splitted) == 2 {
key := cleanKey(splitted[0])
val := splitted[1]
splitted = strings.Split(key, "_")
splitted = append(strings.Split(key, "_"), "", "", "")
if unicode.IsLetter(getFirstRune(key)) {
var entry cEntry
entry.value = val
@ -54,29 +54,35 @@ func NewConfig() *Config {
config.env[key] = entry
if len(splitted) > 1 {
for count, _ := range splitted {
left := strings.Join(splitted[:count], "_")
right := strings.Join(splitted[count:], "_")
if len(config.mapEnv[left]) == 0 {
config.mapEnv[left] = make(map[string]string)
config.mapMapEnv[left] = make(map[string]map[string]string)
config.mapMapMapEnv[left] = make(map[string]map[string]map[string]string)
}
config.mapEnv[left][right] = key
if count < len(splitted)-2 {
if count < len(splitted)-3 {
left := strings.Trim(strings.Join(splitted[:count], "_"), "_")
right := strings.Trim(strings.Join(splitted[count:], "_"), "_")
if len(config.mapEnv[left]) == 0 {
config.mapEnv[left] = make(map[string]string)
config.mapMapEnv[left] = make(map[string]map[string]string)
config.mapMapMapEnv[left] = make(map[string]map[string]map[string]string)
}
if left != "" && right != "" {
config.mapEnv[left][right] = key
}
middle := splitted[count]
right = strings.Join(splitted[count+1:], "_")
right = strings.Trim(strings.Join(splitted[count+1:], "_"), "_")
if len(config.mapMapEnv[left][middle]) == 0 {
config.mapMapEnv[left][middle] = make(map[string]string)
config.mapMapMapEnv[left][middle] = make(map[string]map[string]string)
}
config.mapMapEnv[left][middle][right] = key
if count < len(splitted)-3 {
lmiddle := splitted[count]
rmiddle := splitted[count+1]
right = strings.Join(splitted[count+2:], "_")
if len(config.mapMapEnv[left][lmiddle][rmiddle]) == 0 {
config.mapMapMapEnv[left][lmiddle][rmiddle] = make(map[string]string)
}
if left != "" && middle != "" && right != "" {
config.mapMapEnv[left][middle][right] = key
}
lmiddle := splitted[count]
rmiddle := splitted[count+1]
right = strings.Trim(strings.Join(splitted[count+2:], "_"), "_")
if len(config.mapMapMapEnv[left][lmiddle][rmiddle]) == 0 {
config.mapMapMapEnv[left][lmiddle][rmiddle] = make(map[string]string)
}
if left != "" && lmiddle != "" && rmiddle != "" && right != "" {
config.mapMapMapEnv[left][lmiddle][rmiddle][right] = key
}
}

View File

@ -11,7 +11,6 @@ func main() {
conf.DefineMap("test_map", envconf.TypeInt)
conf.Parse()
conf.Status()
fmt.Println(conf)
fmt.Println(conf.GetMapInt("test_map"))
fmt.Println(conf.GetMapMapInt("test_map"))
fmt.Println(conf.GetInt("this_is_a_map"))
}