summaryrefslogtreecommitdiff
path: root/kvmd
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2019-02-09 03:45:18 +0300
committerDevaev Maxim <[email protected]>2019-02-09 03:45:18 +0300
commit649957fdc9e33db291363522cb720b7792d14a52 (patch)
tree33003389107d10724fc81ae3263c8f4293e2c7fb /kvmd
parent444128940a2e4b9dfd2823b48a7ee4f9664ff4d7 (diff)
fixed yamlconf dump for dicts
Diffstat (limited to 'kvmd')
-rw-r--r--kvmd/yamlconf/dumper.py28
1 files changed, 15 insertions, 13 deletions
diff --git a/kvmd/yamlconf/dumper.py b/kvmd/yamlconf/dumper.py
index bbee71d2..28be57ae 100644
--- a/kvmd/yamlconf/dumper.py
+++ b/kvmd/yamlconf/dumper.py
@@ -1,10 +1,6 @@
-# pylint: skip-file
-# infinite recursion
-
-
+import textwrap
import operator
-from typing import Tuple
from typing import List
from typing import Any
@@ -14,28 +10,34 @@ from . import Section
# =====
+_INDENT = 4
+
+
def make_config_dump(config: Section) -> str:
return "\n".join(_inner_make_dump(config))
-def _inner_make_dump(config: Section, _path: Tuple[str, ...]=()) -> List[str]:
+def _inner_make_dump(config: Section, _level: int=0) -> List[str]:
lines = []
for (key, value) in sorted(config.items(), key=operator.itemgetter(0)):
- indent = len(_path) * " "
+ indent = " " * _INDENT * _level
if isinstance(value, Section):
lines.append("{}{}:".format(indent, key))
- lines += _inner_make_dump(value, _path + (key,))
+ lines += _inner_make_dump(value, _level + 1)
lines.append("")
else:
default = config._get_default(key) # pylint: disable=protected-access
comment = config._get_help(key) # pylint: disable=protected-access
if default == value:
- lines.append("{}{}: {} # {}".format(indent, key, _make_yaml(value), comment))
+ lines.append("{}{}: {} # {}".format(indent, key, _make_yaml(value, _level), comment))
else:
- lines.append("{}# {}: {} # {}".format(indent, key, _make_yaml(default), comment))
- lines.append("{}{}: {}".format(indent, key, _make_yaml(value)))
+ lines.append("{}# {}: {} # {}".format(indent, key, _make_yaml(default, _level), comment))
+ lines.append("{}{}: {}".format(indent, key, _make_yaml(value, _level)))
return lines
-def _make_yaml(value: Any) -> str:
- return yaml.dump(value, allow_unicode=True).replace("\n...\n", "").strip()
+def _make_yaml(value: Any, level: int) -> str:
+ dump = yaml.dump(value, indent=_INDENT, allow_unicode=True).replace("\n...\n", "").strip()
+ if isinstance(value, dict) and dump[0] != "{" or isinstance(value, list) and dump[0] != "[":
+ dump = "\n" + textwrap.indent(dump, prefix=" " * _INDENT * (level + 1))
+ return dump