add '--config-yaml' option

(#8)
This commit is contained in:
Mike Fährmann 2017-03-08 16:57:42 +01:00
parent 379125746a
commit 0cfe51dc78
No known key found for this signature in database
GPG Key ID: 5680CA389D365A88
2 changed files with 30 additions and 8 deletions

View File

@ -70,6 +70,11 @@ def build_cmdline_parser():
metavar="CFG", dest="cfgfiles", action="append",
help="additional configuration files",
)
parser.add_argument(
"--config-yaml",
metavar="CFG", dest="yamlfiles", action="append",
help="additional configuration files (YAML format)",
)
parser.add_argument(
"-o", "--option",
metavar="OPT", action="append", default=[],
@ -139,6 +144,8 @@ def main():
if args.cfgfiles:
config.load(*args.cfgfiles, strict=True)
if args.yamlfiles:
config.load(*args.yamlfiles, format="yaml", strict=True)
if args.dest:
config.set(("base-directory",), args.dest)

View File

@ -1,6 +1,6 @@
# -*- coding: utf-8 -*-
# Copyright 2015, 2016 Mike Fährmann
# Copyright 2015-2017 Mike Fährmann
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
@ -11,27 +11,42 @@
import sys
import json
import os.path
import logging
# --------------------------------------------------------------------
# public interface
def load(*files, strict=False):
def load(*files, format="json", strict=False):
"""Load JSON configuration files"""
log = logging.getLogger("config")
configfiles = files or _default_configs
if format == "yaml":
try:
import yaml
parsefunc = yaml.safe_load
except ImportError:
log.error("Could not import 'yaml' module")
return
else:
parsefunc = json.load
for conf in configfiles:
try:
path = os.path.expanduser(os.path.expandvars(conf))
with open(path) as file:
confdict = json.load(file)
confdict = parsefunc(file)
_config.update(confdict)
except FileNotFoundError:
if strict:
raise
continue
except ValueError as exception:
print("Error while loading '", path, "':", sep="", file=sys.stderr)
print(exception, file=sys.stderr)
log.error("Configuration file '%s' not found", path)
sys.exit(1)
except Exception as exception:
log.warning("Could not parse '%s'", path)
log.warning(exception)
if strict:
sys.exit(2)
def clear():