Browse Source
* Add optional `hold-trigger-key-positions` hold-tap configuration * Leverage configuration for decision making around when to trigger hold decision in hold-taps. * Add docs for new configuration. * Tests for the new config/decision logic.xmkb
jmding8
3 years ago
committed by
GitHub
43 changed files with 488 additions and 4 deletions
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,5 @@
@@ -0,0 +1,5 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided hold-timer (balanced decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,11 @@
@@ -0,0 +1,11 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,500) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided tap (balanced decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,14 @@
@@ -0,0 +1,14 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,200) |
||||
ZMK_MOCK_PRESS(1,1,200) // non trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,1,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided hold-timer (balanced decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,14 @@
@@ -0,0 +1,14 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,200) |
||||
ZMK_MOCK_PRESS(1,0,200) // trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,0,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,29 @@
@@ -0,0 +1,29 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
|
||||
/ { |
||||
behaviors { |
||||
ht_bal: behavior_hold_tap_balanced { |
||||
compatible = "zmk,behavior-hold-tap"; |
||||
label = "HOLD_TAP_BALANCED"; |
||||
#binding-cells = <2>; |
||||
flavor = "balanced"; |
||||
tapping-term-ms = <300>; |
||||
quick-tap-ms = <200>; |
||||
bindings = <&kp>, <&kp>; |
||||
hold-trigger-key-positions = <2>; |
||||
}; |
||||
}; |
||||
|
||||
keymap { |
||||
compatible = "zmk,keymap"; |
||||
label ="Default keymap"; |
||||
|
||||
default_layer { |
||||
bindings = < |
||||
&ht_bal LEFT_SHIFT F &ht_bal LEFT_CONTROL J |
||||
&kp D &kp E>; |
||||
}; |
||||
}; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,9 @@
@@ -0,0 +1,9 @@
|
||||
kp_pressed: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided tap (balanced decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,16 @@
@@ -0,0 +1,16 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(1,0,10) // trigger key |
||||
ZMK_MOCK_PRESS(0,0,10) |
||||
ZMK_MOCK_PRESS(1,1,400) // not trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,1,10) |
||||
ZMK_MOCK_RELEASE(1,0,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,5 @@
@@ -0,0 +1,5 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided hold-timer (hold-preferred decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,11 @@
@@ -0,0 +1,11 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,500) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided tap (hold-preferred decision moment other-key-down) |
||||
kp_pressed: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,14 @@
@@ -0,0 +1,14 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,200) |
||||
ZMK_MOCK_PRESS(1,1,200) // non trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,1,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided hold-interrupt (hold-preferred decision moment other-key-down) |
||||
kp_pressed: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,14 @@
@@ -0,0 +1,14 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,200) |
||||
ZMK_MOCK_PRESS(1,0,200) // trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,0,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,29 @@
@@ -0,0 +1,29 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
|
||||
/ { |
||||
behaviors { |
||||
ht_hold: behavior_hold_hold_tap { |
||||
compatible = "zmk,behavior-hold-tap"; |
||||
label = "hold_hold_tap"; |
||||
#binding-cells = <2>; |
||||
flavor = "hold-preferred"; |
||||
tapping-term-ms = <300>; |
||||
quick-tap-ms = <200>; |
||||
bindings = <&kp>, <&kp>; |
||||
hold-trigger-key-positions = <2>; |
||||
}; |
||||
}; |
||||
|
||||
keymap { |
||||
compatible = "zmk,keymap"; |
||||
label ="Default keymap"; |
||||
|
||||
default_layer { |
||||
bindings = < |
||||
&ht_hold LEFT_SHIFT F &ht_hold LEFT_CONTROL J |
||||
&kp D &kp E>; |
||||
}; |
||||
}; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,9 @@
@@ -0,0 +1,9 @@
|
||||
kp_pressed: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided tap (hold-preferred decision moment other-key-down) |
||||
kp_pressed: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,16 @@
@@ -0,0 +1,16 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(1,0,10) // trigger key |
||||
ZMK_MOCK_PRESS(0,0,10) |
||||
ZMK_MOCK_PRESS(1,1,400) // not trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,1,10) |
||||
ZMK_MOCK_RELEASE(1,0,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,5 @@
@@ -0,0 +1,5 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided hold-timer (tap-preferred decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,11 @@
@@ -0,0 +1,11 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,500) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided tap (tap-preferred decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,14 @@
@@ -0,0 +1,14 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,200) |
||||
ZMK_MOCK_PRESS(1,1,200) // non trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,1,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided hold-timer (tap-preferred decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0xe1 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,14 @@
@@ -0,0 +1,14 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(0,0,200) |
||||
ZMK_MOCK_PRESS(1,0,200) // trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,0,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
@ -0,0 +1,29 @@
@@ -0,0 +1,29 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
|
||||
/ { |
||||
behaviors { |
||||
tp: behavior_tap_preferred { |
||||
compatible = "zmk,behavior-hold-tap"; |
||||
label = "MOD_TAP"; |
||||
#binding-cells = <2>; |
||||
flavor = "tap-preferred"; |
||||
tapping-term-ms = <300>; |
||||
quick-tap-ms = <200>; |
||||
bindings = <&kp>, <&kp>; |
||||
hold-trigger-key-positions = <2>; |
||||
}; |
||||
}; |
||||
|
||||
keymap { |
||||
compatible = "zmk,keymap"; |
||||
label ="Default keymap"; |
||||
|
||||
default_layer { |
||||
bindings = < |
||||
&tp LEFT_SHIFT F &tp LEFT_CONTROL J |
||||
&kp D &kp E>; |
||||
}; |
||||
}; |
||||
}; |
@ -0,0 +1,4 @@
@@ -0,0 +1,4 @@
|
||||
s/.*hid_listener_keycode/kp/p |
||||
s/.*mo_keymap_binding/mo/p |
||||
s/.*on_hold_tap_binding/ht_binding/p |
||||
s/.*decide_hold_tap/ht_decide/p |
@ -0,0 +1,9 @@
@@ -0,0 +1,9 @@
|
||||
kp_pressed: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_pressed: 0 new undecided hold_tap |
||||
ht_decide: 0 decided tap (tap-preferred decision moment timer) |
||||
kp_pressed: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_pressed: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x08 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x07 implicit_mods 0x00 explicit_mods 0x00 |
||||
kp_released: usage_page 0x07 keycode 0x09 implicit_mods 0x00 explicit_mods 0x00 |
||||
ht_binding_released: 0 cleaning up hold-tap |
@ -0,0 +1,16 @@
@@ -0,0 +1,16 @@
|
||||
#include <dt-bindings/zmk/keys.h> |
||||
#include <behaviors.dtsi> |
||||
#include <dt-bindings/zmk/kscan_mock.h> |
||||
#include "../behavior_keymap.dtsi" |
||||
|
||||
&kscan { |
||||
events = < |
||||
ZMK_MOCK_PRESS(1,0,10) // trigger key |
||||
ZMK_MOCK_PRESS(0,0,10) |
||||
ZMK_MOCK_PRESS(1,1,400) // not trigger key |
||||
/* timer fires */ |
||||
ZMK_MOCK_RELEASE(1,1,10) |
||||
ZMK_MOCK_RELEASE(1,0,10) |
||||
ZMK_MOCK_RELEASE(0,0,10) |
||||
>; |
||||
}; |
Loading…
Reference in new issue