Strip out shift modifier for non-alpha bindings

This commit is contained in:
Florian Bruhin 2017-12-29 13:53:43 +01:00
parent 917f2a30de
commit d9c768ed86

View File

@ -260,7 +260,27 @@ class KeySequence:
return self._sequence.matches(other._sequence) return self._sequence.matches(other._sequence)
def append_event(self, ev): def append_event(self, ev):
return self.__class__(*self._sequence, ev.modifiers() | ev.key()) """Create a new KeySequence object with the given QKeyEvent added.
We need to do some sophisticated checking of modifiers here:
We don't care about a shift modifier with symbols (Shift-: should match
a : binding even though we typed it with a shift on an US-keyboard)
However, we *do* care about Shift being involved if we got an upper-case
letter, as Shift-A should match a Shift-A binding, but not an "a"
binding.
In addition, Shift also *is* relevant when other modifiers are involved.
Shift-Ctrl-X should not be equivalent to Ctrl-X.
FIXME: create test cases!
"""
modifiers = ev.modifiers()
if (modifiers == Qt.ShiftModifier and
unicodedata.category(ev.text()) != 'Lu'):
modifiers = Qt.KeyboardModifiers()
return self.__class__(*self._sequence, modifiers | ev.key())
@classmethod @classmethod
def parse(cls, keystr): def parse(cls, keystr):