summaryrefslogtreecommitdiff
path: root/kvmd/yamlconf/dumper.py
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/yamlconf/dumper.py')
-rw-r--r--kvmd/yamlconf/dumper.py52
1 files changed, 31 insertions, 21 deletions
diff --git a/kvmd/yamlconf/dumper.py b/kvmd/yamlconf/dumper.py
index 93bced3a..6dac6baa 100644
--- a/kvmd/yamlconf/dumper.py
+++ b/kvmd/yamlconf/dumper.py
@@ -23,7 +23,7 @@
import textwrap
import operator
-from typing import List
+from typing import Generator
from typing import Any
import yaml
@@ -32,34 +32,44 @@ from . import Section
# =====
-_INDENT = 4
+def make_config_dump(config: Section, indent: int=4) -> str:
+ return "\n".join(_inner_make_dump(config, indent))
-def make_config_dump(config: Section) -> str:
- return "\n".join(_inner_make_dump(config))
-
-
-def _inner_make_dump(config: Section, _level: int=0) -> List[str]:
- lines = []
+def _inner_make_dump(config: Section, indent: int, _level: int=0) -> Generator[str, None, None]:
for (key, value) in sorted(config.items(), key=operator.itemgetter(0)):
- indent = " " * _INDENT * _level
if isinstance(value, Section):
- lines.append("%s%s:" % (indent, key))
- lines += _inner_make_dump(value, _level + 1)
- lines.append("")
+ yield "%s%s:" % (" " * indent * _level, key)
+ yield from _inner_make_dump(value, indent, _level + 1)
+ yield ""
else:
default = config._get_default(key) # pylint: disable=protected-access
comment = config._get_help(key) # pylint: disable=protected-access
if default == value:
- lines.append("%s%s: %s # %s" % (indent, key, _make_yaml(value, _level), comment))
+ yield _make_yaml_kv(key, value, indent, _level, comment=comment)
else:
- lines.append("%s# %s: %s # %s" % (indent, key, _make_yaml(default, _level), comment))
- lines.append("%s%s: %s" % (indent, key, _make_yaml(value, _level)))
- return lines
+ yield _make_yaml_kv(key, default, indent, _level, comment=comment, commented=True)
+ yield _make_yaml_kv(key, value, indent, _level)
+
+
+def _make_yaml_kv(key: str, value: Any, indent: int, level: int, comment: str="", commented: bool=False) -> str:
+ text = yaml.dump(value, indent=indent, allow_unicode=True)
+ text = text.replace("\n...\n", "").strip()
+ if (
+ isinstance(value, dict) and text[0] != "{"
+ or isinstance(value, list) and text[0] != "["
+ ):
+ text = "\n" + textwrap.indent(text, prefix=" " * indent)
+ else:
+ text = " " + text
+ prefix = " " * indent * level
+ if commented:
+ prefix = prefix + "# "
+ text = textwrap.indent("%s:%s" % (key, text), prefix=prefix)
-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
+ if comment:
+ lines = text.split("\n")
+ lines[0] += " # " + comment
+ text = "\n".join(lines)
+ return text