Refactor write_config_py

This commit is contained in:
Florian Bruhin 2017-10-05 09:01:33 +02:00
parent 8dc34cf78a
commit 231b0522ca
2 changed files with 69 additions and 33 deletions

View File

@ -275,5 +275,6 @@ class ConfigCommands:
bindings = dict(self._config.get_obj('bindings.commands')) bindings = dict(self._config.get_obj('bindings.commands'))
commented = False commented = False
configfiles.write_config_py(filename, options, bindings, writer = configfiles.ConfigPyWriter(options, bindings,
commented=commented) commented=commented)
writer.write(filename)

View File

@ -245,59 +245,94 @@ class ConfigAPI:
self._keyconfig.unbind(key, mode=mode) self._keyconfig.unbind(key, mode=mode)
def write_config_py(filename, options, bindings, *, commented): class ConfigPyWriter:
"""Write a config.py file from given values."""
c = '#' if commented else '' """Writer for config.py files from given settings."""
cs = '# ' if commented else ''
def __init__(self, options, bindings, *, commented):
self._options = options
self._bindings = bindings
self._commented = commented
def write(self, filename):
"""Write the config to the given file."""
with open(filename, 'w', encoding='utf-8') as f: with open(filename, 'w', encoding='utf-8') as f:
f.write(c + "# Autogenerated config.py\n") f.write('\n'.join(self._gen_text()))
f.write(c + "# Documentation:\n")
f.write(c + "# qute://help/configuring.html\n") def _line(self, line):
f.write(c + "# qute://help/settings.html\n\n") """Get an (optionally commented) line."""
if commented: if self._commented:
if line.startswith('#'):
return '#' + line
else:
return '# ' + line
else:
return line
def _gen_text(self):
"""Generate a config.py with the given settings/bindings.
Yields individual lines.
"""
yield from self._gen_header()
yield from self._gen_options()
yield from self._gen_bindings()
def _gen_header(self):
"""Generate the intiial header of the config."""
yield self._line("# Autogenerated config.py")
yield self._line("# Documentation:")
yield self._line("# qute://help/configuring.html")
yield self._line("# qute://help/settings.html\n")
if self._commented:
# When generated from an autoconfig.yml with commented=False, # When generated from an autoconfig.yml with commented=False,
# we don't want to load that autoconfig.yml anymore. # we don't want to load that autoconfig.yml anymore.
f.write("## This is here so configs done via the GUI are still " yield self._line("# This is here so configs done via the GUI are "
"loaded.\n") "still loaded.")
f.write("## Remove it to not load settings done via the GUI.\n") yield self._line("# Remove it to not load settings done via the "
f.write("config.load_autoconfig()\n\n") "GUI.")
yield self._line("config.load_autoconfig()\n")
else: else:
f.write("# Uncomment this to still load settings configured via " yield self._line("# Uncomment this to still load settings "
"autoconfig.yml\n") "configured via autoconfig.yml")
f.write("# config.load_autoconfig()\n\n") yield self._line("# config.load_autoconfig()\n")
for opt, value in options: def _gen_options(self):
"""Generate the options part of the config."""
for opt, value in self._options:
if opt.name in ['bindings.commands', 'bindings.default']: if opt.name in ['bindings.commands', 'bindings.default']:
continue continue
for line in textwrap.wrap(opt.description): for line in textwrap.wrap(opt.description):
f.write(c + "# {}\n".format(line)) yield self._line("# {}".format(line))
f.write(c + "# Type: {}\n".format(opt.typ.get_name())) yield self._line("# Type: {}".format(opt.typ.get_name()))
valid_values = opt.typ.get_valid_values() valid_values = opt.typ.get_valid_values()
if valid_values is not None and valid_values.generate_docs: if valid_values is not None and valid_values.generate_docs:
f.write(c + "# Valid values:\n") yield self._line("# Valid values:")
for val in valid_values: for val in valid_values:
try: try:
desc = valid_values.descriptions[val] desc = valid_values.descriptions[val]
f.write(c + "# - {}: {}".format(val, desc) + "\n") yield self._line("# - {}: {}".format(val, desc))
except KeyError: except KeyError:
f.write(c + "# - {}".format(val) + "\n") yield self._line("# - {}".format(val))
f.write(cs + 'c.{} = {!r}\n\n'.format(opt.name, value)) yield self._line('c.{} = {!r}\n'.format(opt.name, value))
normal_bindings = bindings.pop('normal', {}) def _gen_bindings(self):
"""Generate the bindings part of the config."""
normal_bindings = self._bindings.pop('normal', {})
if normal_bindings: if normal_bindings:
f.write(c + '# Bindings for normal mode\n') yield self._line('# Bindings for normal mode')
for key, command in sorted(normal_bindings.items()): for key, command in sorted(normal_bindings.items()):
f.write(cs + 'config.bind({!r}, {!r})\n'.format(key, command)) yield self._line('config.bind({!r}, {!r})'.format(key, command))
for mode, mode_bindings in sorted(bindings.items()): for mode, mode_bindings in sorted(self._bindings.items()):
f.write('\n') yield ''
f.write(c + '# Bindings for {} mode\n'.format(mode)) yield self._line('# Bindings for {} mode'.format(mode))
for key, command in sorted(mode_bindings.items()): for key, command in sorted(mode_bindings.items()):
f.write(cs + 'config.bind({!r}, {!r}, mode={!r})\n'.format( yield self._line('config.bind({!r}, {!r}, mode={!r})'.format(
key, command, mode)) key, command, mode))