Add functions to load configuration
This commit is contained in:
parent
e86ce1aeaf
commit
32bce4eaba
@ -5,6 +5,8 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path"
|
"path"
|
||||||
|
|
||||||
|
"github.com/BurntSushi/toml"
|
||||||
)
|
)
|
||||||
|
|
||||||
const lumercFile string = ".lumerc"
|
const lumercFile string = ".lumerc"
|
||||||
@ -50,6 +52,28 @@ func (c *Config) validateColors() (err error) {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func LoadConfig(s string) (Config, error) {
|
||||||
|
var err error
|
||||||
|
var c Config
|
||||||
|
|
||||||
|
if _, err := toml.Decode(s, &c); err != nil {
|
||||||
|
err = fmt.Errorf("fatal: failed to parse; %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return c, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func LoadConfigFile(configPath string) (Config, error) {
|
||||||
|
var err error
|
||||||
|
var c Config
|
||||||
|
|
||||||
|
if _, err := toml.DecodeFile(configPath, &c); err != nil {
|
||||||
|
err = fmt.Errorf("fatal: failed to parse %s; %w", configPath, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return c, err
|
||||||
|
}
|
||||||
|
|
||||||
func getConfigPath() string {
|
func getConfigPath() string {
|
||||||
var tryPath, configPath string
|
var tryPath, configPath string
|
||||||
|
|
||||||
|
@ -8,7 +8,6 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"git.kill0.net/chill9/lifx-go"
|
"git.kill0.net/chill9/lifx-go"
|
||||||
"github.com/BurntSushi/toml"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var userAgent string
|
var userAgent string
|
||||||
@ -46,8 +45,7 @@ func Main(args []string) (int, error) {
|
|||||||
return ExitFailure, err
|
return ExitFailure, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, err := toml.DecodeFile(configPath, &config); err != nil {
|
if config, err = LoadConfigFile(configPath); err != nil {
|
||||||
err = fmt.Errorf("fatal: failed to parse %s; %w", configPath, err)
|
|
||||||
return ExitFailure, err
|
return ExitFailure, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user