aboutsummaryrefslogtreecommitdiffstats
path: root/quantum/process_keycode/process_combo.h
diff options
context:
space:
mode:
authorGravatar William Chang <william@factual.com>2019-11-20 22:17:07 -0800
committerGravatar William Chang <william@factual.com>2019-11-20 22:17:07 -0800
commite7f4d56592b3975c38af329e77b4efd9108495e8 (patch)
tree0a416bccbf70bfdbdb9ffcdb3bf136b47378c014 /quantum/process_keycode/process_combo.h
parent71493b2f9bbd5f3d18373c518fa14ccafcbf48fc (diff)
parent8416a94ad27b3ff058576f09f35f0704a8b39ff3 (diff)
downloadqmk_firmware-e7f4d56592b3975c38af329e77b4efd9108495e8.tar.gz
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'quantum/process_keycode/process_combo.h')
-rw-r--r--quantum/process_keycode/process_combo.h33
1 files changed, 19 insertions, 14 deletions
diff --git a/quantum/process_keycode/process_combo.h b/quantum/process_keycode/process_combo.h
index f06d2d345..e21ee1960 100644
--- a/quantum/process_keycode/process_combo.h
+++ b/quantum/process_keycode/process_combo.h
@@ -22,40 +22,45 @@
#include <stdint.h>
#ifdef EXTRA_EXTRA_LONG_COMBOS
-#define MAX_COMBO_LENGTH 32
+# define MAX_COMBO_LENGTH 32
#elif EXTRA_LONG_COMBOS
-#define MAX_COMBO_LENGTH 16
+# define MAX_COMBO_LENGTH 16
#else
-#define MAX_COMBO_LENGTH 8
+# define MAX_COMBO_LENGTH 8
#endif
typedef struct {
- const uint16_t *keys;
- uint16_t keycode;
+ const uint16_t *keys;
+ uint16_t keycode;
#ifdef EXTRA_EXTRA_LONG_COMBOS
- uint32_t state;
+ uint32_t state;
#elif EXTRA_LONG_COMBOS
- uint16_t state;
+ uint16_t state;
#else
- uint8_t state;
+ uint8_t state;
#endif
} combo_t;
-#define COMBO(ck, ca) \
- { .keys = &(ck)[0], .keycode = (ca) }
-#define COMBO_ACTION(ck) \
- { .keys = &(ck)[0] }
+#define COMBO(ck, ca) \
+ { .keys = &(ck)[0], .keycode = (ca) }
+#define COMBO_ACTION(ck) \
+ { .keys = &(ck)[0] }
#define COMBO_END 0
#ifndef COMBO_COUNT
-#define COMBO_COUNT 0
+# define COMBO_COUNT 0
#endif
#ifndef COMBO_TERM
-#define COMBO_TERM TAPPING_TERM
+# define COMBO_TERM TAPPING_TERM
#endif
bool process_combo(uint16_t keycode, keyrecord_t *record);
void matrix_scan_combo(void);
void process_combo_event(uint8_t combo_index, bool pressed);
+void combo_enable(void);
+void combo_disable(void);
+void combo_toggle(void);
+bool is_combo_enabled(void);
+
#endif