fix late release of oneshot keys
This commit is contained in:
parent
f7dac9e96e
commit
63973e4a6e
@ -29,7 +29,7 @@ class OneShot(HoldTap):
|
|||||||
state.activated = ActivationType.HOLD_TIMEOUT
|
state.activated = ActivationType.HOLD_TIMEOUT
|
||||||
elif state.activated == ActivationType.RELEASED and is_pressed:
|
elif state.activated == ActivationType.RELEASED and is_pressed:
|
||||||
state.activated = ActivationType.INTERRUPTED
|
state.activated = ActivationType.INTERRUPTED
|
||||||
elif state.activated == ActivationType.INTERRUPTED and not is_pressed:
|
elif state.activated == ActivationType.INTERRUPTED:
|
||||||
self.ht_released(key, keyboard)
|
self.ht_released(key, keyboard)
|
||||||
|
|
||||||
return current_key
|
return current_key
|
||||||
|
@ -102,22 +102,72 @@ class TestHoldTap(unittest.TestCase):
|
|||||||
|
|
||||||
# TODO test TT
|
# TODO test TT
|
||||||
|
|
||||||
|
def test_oneshot(self):
|
||||||
|
keyboard = KeyboardTest(
|
||||||
|
[Layers(), ModTap(), OneShot()],
|
||||||
|
[
|
||||||
|
[
|
||||||
|
KC.MT(KC.A, KC.LCTL),
|
||||||
|
KC.LT(1, KC.B),
|
||||||
|
KC.C,
|
||||||
|
KC.D,
|
||||||
|
KC.OS(KC.E, tap_time=50),
|
||||||
|
],
|
||||||
|
[KC.N1, KC.N2, KC.N3, KC.N4, KC.N5],
|
||||||
|
],
|
||||||
|
debug_enabled=False,
|
||||||
|
)
|
||||||
|
t_within = 40
|
||||||
|
t_after = 60
|
||||||
|
|
||||||
# OS
|
# OS
|
||||||
keyboard.test(
|
keyboard.test(
|
||||||
'OS timed out',
|
'OS timed out',
|
||||||
[(4, True), (4, False), 1050],
|
[(4, True), (4, False), t_after],
|
||||||
[{KC.E}, {}],
|
[{KC.E}, {}],
|
||||||
)
|
)
|
||||||
|
|
||||||
keyboard.test(
|
keyboard.test(
|
||||||
'OS interrupt within tap time',
|
'OS interrupt within tap time',
|
||||||
[(4, True), (4, False), 100, (3, True), (3, False)],
|
[(4, True), (4, False), t_within, (3, True), (3, False)],
|
||||||
[{KC.E}, {KC.D, KC.E}, {}],
|
[{KC.E}, {KC.D, KC.E}, {}],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
keyboard.test(
|
||||||
|
'OS interrupt, multiple within tap time',
|
||||||
|
[(4, True), (4, False), (3, True), (3, False), (2, True), (2, False)],
|
||||||
|
[{KC.E}, {KC.D, KC.E}, {}, {KC.C}, {}],
|
||||||
|
)
|
||||||
|
|
||||||
|
keyboard.test(
|
||||||
|
'OS interrupt, multiple interleaved',
|
||||||
|
[(4, True), (4, False), (3, True), (2, True), (2, False), (3, False)],
|
||||||
|
[{KC.E}, {KC.D, KC.E}, {KC.C, KC.D}, {KC.D}, {}],
|
||||||
|
)
|
||||||
|
|
||||||
|
keyboard.test(
|
||||||
|
'OS interrupt, multiple interleaved',
|
||||||
|
[(4, True), (4, False), (3, True), (2, True), (3, False), (2, False)],
|
||||||
|
[{KC.E}, {KC.D, KC.E}, {KC.C, KC.D}, {KC.C}, {}],
|
||||||
|
)
|
||||||
|
|
||||||
|
keyboard.test(
|
||||||
|
'OS interrupt within tap time, hold',
|
||||||
|
[(4, True), (3, True), (4, False), t_after, (3, False)],
|
||||||
|
[{KC.E}, {KC.D, KC.E}, {KC.D}, {}],
|
||||||
|
)
|
||||||
|
|
||||||
keyboard.test(
|
keyboard.test(
|
||||||
'OS hold with multiple interrupt keys',
|
'OS hold with multiple interrupt keys',
|
||||||
[(4, True), 100, (3, True), (3, False), (2, True), (2, False), (4, False)],
|
[
|
||||||
|
(4, True),
|
||||||
|
t_within,
|
||||||
|
(3, True),
|
||||||
|
(3, False),
|
||||||
|
(2, True),
|
||||||
|
(2, False),
|
||||||
|
(4, False),
|
||||||
|
],
|
||||||
[{KC.E}, {KC.D, KC.E}, {KC.E}, {KC.C, KC.E}, {KC.E}, {}],
|
[{KC.E}, {KC.D, KC.E}, {KC.E}, {KC.C, KC.E}, {KC.E}, {}],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user