Get rid of _warn_on_keychains and _supports_chains
This commit is contained in:
parent
ba012c6ba8
commit
ec3ad8a969
@ -48,13 +48,9 @@ class BaseKeyParser(QObject):
|
|||||||
Attributes:
|
Attributes:
|
||||||
bindings: Bound key bindings
|
bindings: Bound key bindings
|
||||||
_win_id: The window ID this keyparser is associated with.
|
_win_id: The window ID this keyparser is associated with.
|
||||||
_warn_on_keychains: Whether a warning should be logged when binding
|
|
||||||
keychains in a section which does not support them.
|
|
||||||
_sequence: The currently entered key sequence
|
_sequence: The currently entered key sequence
|
||||||
_modename: The name of the input mode associated with this keyparser.
|
_modename: The name of the input mode associated with this keyparser.
|
||||||
_supports_count: Whether count is supported
|
_supports_count: Whether count is supported
|
||||||
# FIXME is this still needed?
|
|
||||||
_supports_chains: Whether keychains are supported
|
|
||||||
|
|
||||||
Signals:
|
Signals:
|
||||||
keystring_updated: Emitted when the keystring is updated.
|
keystring_updated: Emitted when the keystring is updated.
|
||||||
@ -70,24 +66,18 @@ class BaseKeyParser(QObject):
|
|||||||
do_log = True
|
do_log = True
|
||||||
passthrough = False
|
passthrough = False
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None, supports_count=None,
|
def __init__(self, win_id, parent=None, supports_count=True):
|
||||||
supports_chains=False):
|
|
||||||
super().__init__(parent)
|
super().__init__(parent)
|
||||||
self._win_id = win_id
|
self._win_id = win_id
|
||||||
self._modename = None
|
self._modename = None
|
||||||
self._sequence = keyutils.KeySequence()
|
self._sequence = keyutils.KeySequence()
|
||||||
self._count = ''
|
self._count = ''
|
||||||
if supports_count is None:
|
|
||||||
supports_count = supports_chains
|
|
||||||
self._supports_count = supports_count
|
self._supports_count = supports_count
|
||||||
self._supports_chains = supports_chains
|
|
||||||
self._warn_on_keychains = True
|
|
||||||
self.bindings = {}
|
self.bindings = {}
|
||||||
config.instance.changed.connect(self._on_config_changed)
|
config.instance.changed.connect(self._on_config_changed)
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return utils.get_repr(self, supports_count=self._supports_count,
|
return utils.get_repr(self, supports_count=self._supports_count)
|
||||||
supports_chains=self._supports_chains)
|
|
||||||
|
|
||||||
def _debug_log(self, message):
|
def _debug_log(self, message):
|
||||||
"""Log a message to the debug log if logging is active.
|
"""Log a message to the debug log if logging is active.
|
||||||
@ -195,10 +185,6 @@ class BaseKeyParser(QObject):
|
|||||||
"""
|
"""
|
||||||
match = self._handle_key(e)
|
match = self._handle_key(e)
|
||||||
|
|
||||||
# FIXME
|
|
||||||
# if handled or not self._supports_chains:
|
|
||||||
# return handled
|
|
||||||
|
|
||||||
# don't emit twice if the keystring was cleared in self.clear_keystring
|
# don't emit twice if the keystring was cleared in self.clear_keystring
|
||||||
if self._sequence:
|
if self._sequence:
|
||||||
self.keystring_updated.emit(self._count + str(self._sequence))
|
self.keystring_updated.emit(self._count + str(self._sequence))
|
||||||
@ -232,14 +218,6 @@ class BaseKeyParser(QObject):
|
|||||||
assert cmd
|
assert cmd
|
||||||
self.bindings[key] = cmd
|
self.bindings[key] = cmd
|
||||||
|
|
||||||
# FIXME
|
|
||||||
# def _parse_key_command(self, modename, key, cmd):
|
|
||||||
# """Parse the keys and their command and store them in the object."""
|
|
||||||
# elif self._warn_on_keychains:
|
|
||||||
# log.keyboard.warning("Ignoring keychain '{}' in mode '{}' "
|
|
||||||
# "because keychains are not supported there."
|
|
||||||
# .format(key, modename))
|
|
||||||
|
|
||||||
def execute(self, cmdstr, count=None):
|
def execute(self, cmdstr, count=None):
|
||||||
"""Handle a completed keychain.
|
"""Handle a completed keychain.
|
||||||
|
|
||||||
|
@ -34,9 +34,8 @@ class CommandKeyParser(BaseKeyParser):
|
|||||||
_commandrunner: CommandRunner instance.
|
_commandrunner: CommandRunner instance.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None, supports_count=None,
|
def __init__(self, win_id, parent=None, supports_count=None):
|
||||||
supports_chains=False):
|
super().__init__(win_id, parent, supports_count)
|
||||||
super().__init__(win_id, parent, supports_count, supports_chains)
|
|
||||||
self._commandrunner = runners.CommandRunner(win_id)
|
self._commandrunner = runners.CommandRunner(win_id)
|
||||||
|
|
||||||
def execute(self, cmdstr, count=None):
|
def execute(self, cmdstr, count=None):
|
||||||
@ -60,7 +59,7 @@ class PassthroughKeyParser(CommandKeyParser):
|
|||||||
# do_log = False
|
# do_log = False
|
||||||
passthrough = True
|
passthrough = True
|
||||||
|
|
||||||
def __init__(self, win_id, mode, parent=None, warn=True):
|
def __init__(self, win_id, mode, parent=None):
|
||||||
"""Constructor.
|
"""Constructor.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
@ -68,11 +67,9 @@ class PassthroughKeyParser(CommandKeyParser):
|
|||||||
parent: Qt parent.
|
parent: Qt parent.
|
||||||
warn: Whether to warn if an ignored key was bound.
|
warn: Whether to warn if an ignored key was bound.
|
||||||
"""
|
"""
|
||||||
super().__init__(win_id, parent, supports_chains=False)
|
super().__init__(win_id, parent)
|
||||||
self._warn_on_keychains = warn
|
|
||||||
self._read_config(mode)
|
self._read_config(mode)
|
||||||
self._mode = mode
|
self._mode = mode
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return utils.get_repr(self, mode=self._mode,
|
return utils.get_repr(self, mode=self._mode)
|
||||||
warn=self._warn_on_keychains)
|
|
||||||
|
@ -71,8 +71,7 @@ def init(win_id, parent):
|
|||||||
KM.passthrough: keyparser.PassthroughKeyParser(win_id, 'passthrough',
|
KM.passthrough: keyparser.PassthroughKeyParser(win_id, 'passthrough',
|
||||||
modeman),
|
modeman),
|
||||||
KM.command: keyparser.PassthroughKeyParser(win_id, 'command', modeman),
|
KM.command: keyparser.PassthroughKeyParser(win_id, 'command', modeman),
|
||||||
KM.prompt: keyparser.PassthroughKeyParser(win_id, 'prompt', modeman,
|
KM.prompt: keyparser.PassthroughKeyParser(win_id, 'prompt', modeman),
|
||||||
warn=False),
|
|
||||||
KM.yesno: modeparsers.PromptKeyParser(win_id, modeman),
|
KM.yesno: modeparsers.PromptKeyParser(win_id, modeman),
|
||||||
KM.caret: modeparsers.CaretKeyParser(win_id, modeman),
|
KM.caret: modeparsers.CaretKeyParser(win_id, modeman),
|
||||||
KM.set_mark: modeparsers.RegisterKeyParser(win_id, KM.set_mark,
|
KM.set_mark: modeparsers.RegisterKeyParser(win_id, KM.set_mark,
|
||||||
|
@ -48,8 +48,7 @@ class NormalKeyParser(keyparser.CommandKeyParser):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None):
|
def __init__(self, win_id, parent=None):
|
||||||
super().__init__(win_id, parent, supports_count=True,
|
super().__init__(win_id, parent, supports_count=True)
|
||||||
supports_chains=True)
|
|
||||||
self._read_config('normal')
|
self._read_config('normal')
|
||||||
self._partial_timer = usertypes.Timer(self, 'partial-match')
|
self._partial_timer = usertypes.Timer(self, 'partial-match')
|
||||||
self._partial_timer.setSingleShot(True)
|
self._partial_timer.setSingleShot(True)
|
||||||
@ -131,8 +130,7 @@ class PromptKeyParser(keyparser.CommandKeyParser):
|
|||||||
"""KeyParser for yes/no prompts."""
|
"""KeyParser for yes/no prompts."""
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None):
|
def __init__(self, win_id, parent=None):
|
||||||
super().__init__(win_id, parent, supports_count=False,
|
super().__init__(win_id, parent, supports_count=False)
|
||||||
supports_chains=True)
|
|
||||||
self._read_config('yesno')
|
self._read_config('yesno')
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
@ -149,8 +147,7 @@ class HintKeyParser(keyparser.CommandKeyParser):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None):
|
def __init__(self, win_id, parent=None):
|
||||||
super().__init__(win_id, parent, supports_count=False,
|
super().__init__(win_id, parent, supports_count=False)
|
||||||
supports_chains=True)
|
|
||||||
self._filtertext = ''
|
self._filtertext = ''
|
||||||
self._last_press = LastPress.none
|
self._last_press = LastPress.none
|
||||||
self._read_config('hint')
|
self._read_config('hint')
|
||||||
@ -261,8 +258,7 @@ class CaretKeyParser(keyparser.CommandKeyParser):
|
|||||||
passthrough = True
|
passthrough = True
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None):
|
def __init__(self, win_id, parent=None):
|
||||||
super().__init__(win_id, parent, supports_count=True,
|
super().__init__(win_id, parent, supports_count=True)
|
||||||
supports_chains=True)
|
|
||||||
self._read_config('caret')
|
self._read_config('caret')
|
||||||
|
|
||||||
|
|
||||||
@ -276,8 +272,7 @@ class RegisterKeyParser(keyparser.CommandKeyParser):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, win_id, mode, parent=None):
|
def __init__(self, win_id, mode, parent=None):
|
||||||
super().__init__(win_id, parent, supports_count=False,
|
super().__init__(win_id, parent, supports_count=False)
|
||||||
supports_chains=False)
|
|
||||||
self._mode = mode
|
self._mode = mode
|
||||||
self._read_config('register')
|
self._read_config('register')
|
||||||
|
|
||||||
|
@ -19,7 +19,6 @@
|
|||||||
|
|
||||||
"""Tests for BaseKeyParser."""
|
"""Tests for BaseKeyParser."""
|
||||||
|
|
||||||
import logging
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
from PyQt5.QtCore import Qt
|
from PyQt5.QtCore import Qt
|
||||||
@ -37,8 +36,7 @@ def keyseq(s):
|
|||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def keyparser(key_config_stub):
|
def keyparser(key_config_stub):
|
||||||
"""Fixture providing a BaseKeyParser supporting count/chains."""
|
"""Fixture providing a BaseKeyParser supporting count/chains."""
|
||||||
kp = basekeyparser.BaseKeyParser(
|
kp = basekeyparser.BaseKeyParser(0, supports_count=True)
|
||||||
0, supports_count=True, supports_chains=True)
|
|
||||||
kp.execute = mock.Mock()
|
kp.execute = mock.Mock()
|
||||||
yield kp
|
yield kp
|
||||||
|
|
||||||
@ -56,19 +54,6 @@ def handle_text(fake_keyevent_factory, keyparser):
|
|||||||
return func
|
return func
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('count, chains, count_expected, chains_expected', [
|
|
||||||
(True, False, True, False),
|
|
||||||
(False, True, False, True),
|
|
||||||
(None, True, True, True),
|
|
||||||
])
|
|
||||||
def test_supports_args(config_stub, count, chains, count_expected,
|
|
||||||
chains_expected):
|
|
||||||
kp = basekeyparser.BaseKeyParser(
|
|
||||||
0, supports_count=count, supports_chains=chains)
|
|
||||||
assert kp._supports_count == count_expected
|
|
||||||
assert kp._supports_chains == chains_expected
|
|
||||||
|
|
||||||
|
|
||||||
class TestDebugLog:
|
class TestDebugLog:
|
||||||
|
|
||||||
"""Make sure _debug_log only logs when do_log is set."""
|
"""Make sure _debug_log only logs when do_log is set."""
|
||||||
@ -154,20 +139,6 @@ class TestReadConfig:
|
|||||||
assert keyseq('a') in keyparser.bindings
|
assert keyseq('a') in keyparser.bindings
|
||||||
assert (keyseq('new') in keyparser.bindings) == expected
|
assert (keyseq('new') in keyparser.bindings) == expected
|
||||||
|
|
||||||
# FIXME do we still need this?
|
|
||||||
@pytest.mark.parametrize('warn_on_keychains', [True, False])
|
|
||||||
@pytest.mark.skip(reason='unneeded?')
|
|
||||||
def test_warn_on_keychains(self, caplog, warn_on_keychains):
|
|
||||||
"""Test _warn_on_keychains."""
|
|
||||||
kp = basekeyparser.BaseKeyParser(
|
|
||||||
0, supports_count=False, supports_chains=False)
|
|
||||||
kp._warn_on_keychains = warn_on_keychains
|
|
||||||
|
|
||||||
with caplog.at_level(logging.WARNING):
|
|
||||||
kp._read_config('normal')
|
|
||||||
|
|
||||||
assert bool(caplog.records) == warn_on_keychains
|
|
||||||
|
|
||||||
|
|
||||||
class TestSpecialKeys:
|
class TestSpecialKeys:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user