summaryrefslogtreecommitdiff
path: root/app/tests/combo/overlapping-combos-2/native_posix.keymap
diff options
context:
space:
mode:
Diffstat (limited to 'app/tests/combo/overlapping-combos-2/native_posix.keymap')
-rw-r--r--app/tests/combo/overlapping-combos-2/native_posix.keymap52
1 files changed, 52 insertions, 0 deletions
diff --git a/app/tests/combo/overlapping-combos-2/native_posix.keymap b/app/tests/combo/overlapping-combos-2/native_posix.keymap
new file mode 100644
index 0000000..3d36421
--- /dev/null
+++ b/app/tests/combo/overlapping-combos-2/native_posix.keymap
@@ -0,0 +1,52 @@
+#include <dt-bindings/zmk/keys.h>
+#include <behaviors.dtsi>
+#include <dt-bindings/zmk/kscan-mock.h>
+
+/*
+ combo 01 timeout 100
+ combo 0123 timeout 100
+ press 012, wait until timeout runs out
+ expected: combo 01 after 100ms, immediately followed by key 2.
+ */
+/ {
+ combos {
+ compatible = "zmk,combos";
+ combo_two {
+ timeout-ms = <100>;
+ key-positions = <0 1>;
+ bindings = <&kp Y>;
+ };
+
+ combo_four {
+ timeout-ms = <100>;
+ key-positions = <0 1 2 3>;
+ bindings = <&kp W>;
+ };
+
+ };
+
+ keymap {
+ compatible = "zmk,keymap";
+ label ="Default keymap";
+
+ default_layer {
+ bindings = <
+ &kp A &kp B
+ &kp C &none
+ >;
+ };
+ };
+};
+
+&kscan {
+ events = <
+ /* if you're debugging these, remember that the timer can be triggered between
+ events while stepping through code. */
+ ZMK_MOCK_PRESS(0,0,10)
+ ZMK_MOCK_PRESS(0,1,10)
+ ZMK_MOCK_PRESS(0,2,100)
+ ZMK_MOCK_RELEASE(0,0,10)
+ ZMK_MOCK_RELEASE(0,1,10)
+ ZMK_MOCK_RELEASE(0,2,100)
+ >;
+}; \ No newline at end of file