Mercurial > hg-stable
changeset 43219:0101db49606f
fix: make Fixer initialization more explicit for clarity
I found it quite confusing that Fixer accessed fields that seemed like
they didn't exist.
Differential Revision: https://phab.mercurial-scm.org/D7084
author | Martin von Zweigbergk <martinvonz@google.com> |
---|---|
date | Sat, 12 Oct 2019 11:00:20 -0700 |
parents | f4c1fd6addd5 |
children | d3d1a3afe7aa |
files | hgext/fix.py |
diffstat | 1 files changed, 27 insertions(+), 23 deletions(-) [+] |
line wrap: on
line diff
--- a/hgext/fix.py Sat Oct 12 11:16:19 2019 -0700 +++ b/hgext/fix.py Sat Oct 12 11:00:20 2019 -0700 @@ -132,12 +132,8 @@ from mercurial.i18n import _ from mercurial.node import nullrev from mercurial.node import wdirrev -from mercurial.pycompat import setattr -from mercurial.utils import ( - procutil, - stringutil, -) +from mercurial.utils import procutil from mercurial import ( cmdutil, @@ -172,9 +168,9 @@ b'linerange': None, b'pattern': None, b'priority': 0, - b'metadata': b'false', - b'skipclean': b'true', - b'enabled': b'true', + b'metadata': False, + b'skipclean': True, + b'enabled': True, } for key, default in FIXER_ATTRS.items(): @@ -793,29 +789,27 @@ """ fixers = {} for name in fixernames(ui): - fixers[name] = Fixer() - for key in FIXER_ATTRS: - setattr( - fixers[name], - pycompat.sysstr(b'_' + key), - ui.config(b'fix', name + b':' + key), - ) - fixers[name]._priority = int(fixers[name]._priority) - fixers[name]._metadata = stringutil.parsebool(fixers[name]._metadata) - fixers[name]._skipclean = stringutil.parsebool(fixers[name]._skipclean) - fixers[name]._enabled = stringutil.parsebool(fixers[name]._enabled) + enabled = ui.configbool(b'fix', name + b':enabled') + command = ui.config(b'fix', name + b':command') + pattern = ui.config(b'fix', name + b':pattern') + linerange = ui.config(b'fix', name + b':linerange') + priority = ui.configint(b'fix', name + b':priority') + metadata = ui.configbool(b'fix', name + b':metadata') + skipclean = ui.configbool(b'fix', name + b':skipclean') # Don't use a fixer if it has no pattern configured. It would be # dangerous to let it affect all files. It would be pointless to let it # affect no files. There is no reasonable subset of files to use as the # default. - if fixers[name]._pattern is None: + if pattern is None: ui.warn( _(b'fixer tool has no pattern configuration: %s\n') % (name,) ) - del fixers[name] - elif not fixers[name]._enabled: + elif not enabled: ui.debug(b'ignoring disabled fixer tool: %s\n' % (name,)) - del fixers[name] + else: + fixers[name] = Fixer( + command, pattern, linerange, priority, metadata, skipclean + ) return collections.OrderedDict( sorted(fixers.items(), key=lambda item: item[1]._priority, reverse=True) ) @@ -833,6 +827,16 @@ class Fixer(object): """Wraps the raw config values for a fixer with methods""" + def __init__( + self, command, pattern, linerange, priority, metadata, skipclean + ): + self._command = command + self._pattern = pattern + self._linerange = linerange + self._priority = priority + self._metadata = metadata + self._skipclean = skipclean + def affects(self, opts, fixctx, path): """Should this fixer run on the file at the given path and context?""" return self._pattern is not None and scmutil.match(