aboutsummaryrefslogtreecommitdiff
path: root/layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock
diff options
context:
space:
mode:
authorRyan <fauxpark@gmail.com>2021-11-01 09:27:54 +1100
committerGitHub <noreply@github.com>2021-11-01 09:27:54 +1100
commit928d9f90ec169f49f50c1566132b06adcaf662d7 (patch)
tree5c2c622c1ab75aedd1f87851fa1efa306d7fdb4f /layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock
parentb25218ccc1d8f72c14a0c175a7594822ea0f865e (diff)
downloadqmk_firmware-928d9f90ec169f49f50c1566132b06adcaf662d7.tar.gz
qmk_firmware-928d9f90ec169f49f50c1566132b06adcaf662d7.zip
Remove complex `fn_actions` macros (#14662)
* Remove complex `fn_actions` macros * Remove additional `KC_FN*` instances
Diffstat (limited to 'layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock')
-rw-r--r--layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock/keymap.c89
1 files changed, 19 insertions, 70 deletions
diff --git a/layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock/keymap.c b/layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock/keymap.c
index 6bf0285ab..54e1183e9 100644
--- a/layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock/keymap.c
+++ b/layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock/keymap.c
@@ -4,21 +4,17 @@
4 */ 4 */
5 5
6#include QMK_KEYBOARD_H 6#include QMK_KEYBOARD_H
7#include "debug.h"
8#include "action_layer.h"
9#include "timer.h"
10 7
11#define BASE 0 // default layer 8enum layer_names {
12#define SYMB 1 // symbols 9 BASE, // default layer
13#define MDIA 2 // media keys 10 SYMB, // symbols
11 MDIA // media keys
12};
14 13
15#define BLINK_BASE 150U // timer threshold for blinking on MDIA layer 14#define BLINK_BASE 150U // timer threshold for blinking on MDIA layer
16 15
17typedef enum onoff_t {OFF, ON} onoff; 16typedef enum onoff_t {OFF, ON} onoff;
18 17
19#define caps_led_on ergodox_right_led_2_on
20#define caps_led_off ergodox_right_led_2_off
21
22const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { 18const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
23/* Keymap 0: Basic layer 19/* Keymap 0: Basic layer
24 * 20 *
@@ -45,18 +41,18 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
45 [BASE] = LAYOUT_ergodox( // layer 0 : default 41 [BASE] = LAYOUT_ergodox( // layer 0 : default
46 // left hand 42 // left hand
47 KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, 43 KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6,
48 KC_TAB, M(KC_Q), M(KC_W), M(KC_E), M(KC_R), M(KC_T), KC_LBRC, 44 KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_LBRC,
49 M(KC_CAPS), M(KC_A), M(KC_S), M(KC_D), M(KC_F), M(KC_G), 45 KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G,
50 KC_LSFT, M(KC_Z), M(KC_X), M(KC_C), M(KC_V), M(KC_B), MO(SYMB), 46 KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, MO(SYMB),
51 KC_LCTL, KC_LALT, KC_LGUI, KC_LEFT, KC_RGHT, 47 KC_LCTL, KC_LALT, KC_LGUI, KC_LEFT, KC_RGHT,
52 KC_TRNS, F(1), 48 KC_TRNS, TG(SYMB),
53 KC_HOME, 49 KC_HOME,
54 KC_BSPC, KC_DEL, KC_END, 50 KC_BSPC, KC_DEL, KC_END,
55 // right hand 51 // right hand
56 KC_GRV, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, 52 KC_GRV, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL,
57 KC_RBRC, M(KC_Y), M(KC_U), M(KC_I), M(KC_O), M(KC_P), KC_BSLS, 53 KC_RBRC, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSLS,
58 M(KC_H), M(KC_J), M(KC_K), M(KC_L), KC_SCLN, KC_QUOT, 54 KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT,
59 MO(SYMB), M(KC_N), M(KC_M), KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, 55 MO(SYMB), KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT,
60 KC_DOWN, KC_UP, KC_RCTL, KC_RGUI, KC_RALT, 56 KC_DOWN, KC_UP, KC_RCTL, KC_RGUI, KC_RALT,
61 KC_RALT, KC_RCTL, 57 KC_RALT, KC_RCTL,
62 KC_PGUP, 58 KC_PGUP,
@@ -91,7 +87,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
91 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, 87 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
92 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, 88 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
93 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, 89 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
94 F(3), F(2), 90 TG(SYMB),TG(MDIA),
95 KC_TRNS, 91 KC_TRNS,
96 KC_TRNS,KC_TRNS,KC_TRNS, 92 KC_TRNS,KC_TRNS,KC_TRNS,
97 // right hand 93 // right hand
@@ -132,7 +128,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
132 KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, 128 KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
133 KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, 129 KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
134 KC_TRNS, KC_TRNS, KC_TRNS, KC_NO, KC_NO, 130 KC_TRNS, KC_TRNS, KC_TRNS, KC_NO, KC_NO,
135 F(4), KC_NO, 131 TG(MDIA),KC_NO,
136 KC_TRNS, 132 KC_TRNS,
137 KC_TRNS, KC_TRNS, KC_TRNS, 133 KC_TRNS, KC_TRNS, KC_TRNS,
138 // right hand 134 // right hand
@@ -147,64 +143,17 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
147 ), 143 ),
148}; 144};
149 145
150const uint16_t PROGMEM fn_actions[] = {
151 [1] = ACTION_LAYER_ON(SYMB,ON_RELEASE), // FN1 - Enable Layer 1 (Symbols)
152 [2] = ACTION_LAYER_ON(MDIA,ON_RELEASE), // FN2 - Enable Layer 2 (Media)
153 [3] = ACTION_LAYER_OFF(SYMB,ON_RELEASE), // FN3 - Disable Layer 1 (Symbols)
154 [4] = ACTION_LAYER_OFF(MDIA,ON_RELEASE), // FN4 - Disable Layer 2 (MMedia)
155};
156
157
158const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) {
159 static onoff caps_state = OFF;
160 switch(id) {
161 case KC_CAPS:
162 if (record->event.pressed) {
163 // Toggle caps state;
164 if (caps_state == OFF) {
165 // Turn it on then!
166 caps_led_on();
167 caps_state = ON;
168 } else {
169 caps_led_off();
170 caps_state = OFF;
171 }
172 }
173 break;
174 default:
175 if (record->event.pressed) {
176 bool shifted = false;
177 if (caps_state == ON && get_mods() == 0) {
178 register_code(KC_LSFT);
179 shifted = true;
180 }
181 register_code(id);
182 if(shifted) {
183 unregister_code(KC_LSFT);
184 }
185 } else {
186 unregister_code(id);
187 }
188 break;
189 }
190 return MACRO_NONE;
191};
192
193// Runs just one time when the keyboard initializes.
194void matrix_init_user(void) {
195
196}
197// Runs constantly in the background, in a loop. 146// Runs constantly in the background, in a loop.
198void matrix_scan_user(void) { 147void matrix_scan_user(void) {
199 uint8_t layer = biton32(layer_state); 148 uint8_t layer = get_highest_layer(layer_state);
200 149
201 static onoff board_led_state = OFF; 150 static onoff board_led_state = OFF;
202 static uint16_t dt = 0; 151 static uint16_t dt = 0;
203 static uint8_t oldlayer = 0; 152 static uint8_t oldlayer = 0;
204 153
205 if(oldlayer != layer) { 154 if (oldlayer != layer) {
206 // Layer was just toggled. 155 // Layer was just toggled.
207 if(layer == BASE) { 156 if (layer == BASE) {
208 ergodox_board_led_off(); 157 ergodox_board_led_off();
209 board_led_state = OFF; 158 board_led_state = OFF;
210 } else { 159 } else {
@@ -213,10 +162,10 @@ void matrix_scan_user(void) {
213 } 162 }
214 } else if (layer >= MDIA) { 163 } else if (layer >= MDIA) {
215 // We need to do blinking. 164 // We need to do blinking.
216 if(timer_elapsed(dt) > BLINK_BASE) { 165 if (timer_elapsed(dt) > BLINK_BASE) {
217 // toggle 166 // toggle
218 dt = timer_read(); 167 dt = timer_read();
219 if(board_led_state == OFF) { 168 if (board_led_state == OFF) {
220 ergodox_board_led_on(); 169 ergodox_board_led_on();
221 board_led_state = ON; 170 board_led_state = ON;
222 } else { 171 } else {