diff options
| author | Ryan <fauxpark@gmail.com> | 2021-11-01 09:27:54 +1100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-11-01 09:27:54 +1100 |
| commit | 928d9f90ec169f49f50c1566132b06adcaf662d7 (patch) | |
| tree | 5c2c622c1ab75aedd1f87851fa1efa306d7fdb4f /layouts/community/ergodox/osx_whiskey_tango_foxtrot_capslock | |
| parent | b25218ccc1d8f72c14a0c175a7594822ea0f865e (diff) | |
| download | qmk_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.c | 89 |
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 | 8 | enum 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 | ||
| 17 | typedef enum onoff_t {OFF, ON} onoff; | 16 | typedef 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 | |||
| 22 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 18 | const 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 | ||
| 150 | const 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 | |||
| 158 | const 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. | ||
| 194 | void matrix_init_user(void) { | ||
| 195 | |||
| 196 | } | ||
| 197 | // Runs constantly in the background, in a loop. | 146 | // Runs constantly in the background, in a loop. |
| 198 | void matrix_scan_user(void) { | 147 | void 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 { |
