To get a key under a section:
key, err := cfg.Section("").GetKey("key name")
Same rule applies to key operations:
key := cfg.Section("").Key("key name")
To check if a key exists:
yes := cfg.Section("").HasKey("key name")
To create a new key:
err := cfg.Section("").NewKey("name", "value")
To get a list of keys or key names:
keys := cfg.Section("").Keys()
names := cfg.Section("").KeyStrings()
To get a clone hash of keys and corresponding values:
hash := cfg.Section("").KeysHash()
When you do not care about cases of section and key names, you can use InsensitiveLoad to force all names to be lowercased while parsing.
cfg, err := ini.InsensitiveLoad("filename")
//...
// sec1 and sec2 are the exactly same section object
sec1, err := cfg.GetSection("Section")
sec2, err := cfg.GetSection("SecTIOn")
// key1 and key2 are the exactly same key object
key1, err := sec1.GetKey("Key")
key2, err := sec2.GetKey("KeY")
MySQL’s configuration allows a key without value as follows:
[mysqld]
...
skip-host-cache
skip-name-resolve
By default, this is considered as missing value. But if you know you’re going to deal with those cases, you can assign advanced load options:
cfg, err := ini.LoadSources(ini.LoadOptions{
AllowBooleanKeys: true,
}, "my.cnf")
The value of those keys are always true
, and when you save to a file, it will keep in the same foramt as you read.
To generate such keys in your program, you could use NewBooleanKey
:
key, err := sec.NewBooleanKey("skip-host-cache")
Do you ever have a configuration file like this?
[remote "origin"]
url = https://github.com/Antergone/test1.git
url = https://github.com/Antergone/test2.git
fetch = +refs/heads/*:refs/remotes/origin/*
By default, only the last read value will be kept for the key url
. If you want to keep all copies of value of this key, you can use ShadowLoad to achieve it:
cfg, err := ini.ShadowLoad(".gitconfig")
// ...
f.Section(`remote "origin"`).Key("url").String()
// Result: https://github.com/Antergone/test1.git
f.Section(`remote "origin"`).Key("url").ValueWithShadows()
// Result: []string{
// "https://github.com/Antergone/test1.git",
// "https://github.com/Antergone/test2.git",
// }
If key name is -
in data source, then it would be seen as special syntax for auto-increment key name start from 1, and every section is independent on counter.
[features]
-: Support read/write comments of keys and sections
-: Support auto-increment of key names
-: Support load multiple files to overwrite key values
cfg.Section("features").KeyStrings() // []{"#1", "#2", "#3"}
cfg.Section("package.sub").ParentKeys() // ["CLONE_URL"]