aboutsummaryrefslogtreecommitdiff
path: root/keyboards/satan/keymaps/colemak/keymap.c
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/satan/keymaps/colemak/keymap.c')
-rw-r--r--keyboards/satan/keymaps/colemak/keymap.c36
1 files changed, 17 insertions, 19 deletions
diff --git a/keyboards/satan/keymaps/colemak/keymap.c b/keyboards/satan/keymaps/colemak/keymap.c
index d81ca0893..a772e92c7 100644
--- a/keyboards/satan/keymaps/colemak/keymap.c
+++ b/keyboards/satan/keymaps/colemak/keymap.c
@@ -3,7 +3,7 @@
3 3
4 4
5// Used for SHIFT_ESC 5// Used for SHIFT_ESC
6#define MODS_CTRL_MASK (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)) 6#define MODS_SHIFT_MASK (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
7 7
8// Each layer gets a name for readability, which is then used in the keymap matrix below. 8// Each layer gets a name for readability, which is then used in the keymap matrix below.
9// The underscores don't mean anything - you can have a layer called STUFF or any other name. 9// The underscores don't mean anything - you can have a layer called STUFF or any other name.
@@ -14,6 +14,10 @@
14 14
15#define _______ KC_TRNS 15#define _______ KC_TRNS
16 16
17enum custom_keycodes {
18 SFT_ESC = SAFE_RANGE
19};
20
17const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { 21const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
18 /* Keymap _BL: (Base Layer) Default Layer 22 /* Keymap _BL: (Base Layer) Default Layer
19 * ,-----------------------------------------------------------. 23 * ,-----------------------------------------------------------.
@@ -29,7 +33,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
29 * `-----------------------------------------------------------' 33 * `-----------------------------------------------------------'
30 */ 34 */
31[_BL] = LAYOUT_60_ansi( 35[_BL] = LAYOUT_60_ansi(
32 F(0), KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, \ 36 SFT_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, \
33 KC_TAB, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_LBRC, KC_RBRC,KC_BSLS, \ 37 KC_TAB, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_LBRC, KC_RBRC,KC_BSLS, \
34 KC_BSPC, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O,KC_QUOT, KC_ENT, \ 38 KC_BSPC, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O,KC_QUOT, KC_ENT, \
35 KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM,KC_DOT, KC_SLSH, KC_RSFT, \ 39 KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM,KC_DOT, KC_SLSH, KC_RSFT, \
@@ -40,7 +44,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
40 * | | | | | | | | | | | | | | RESET| 44 * | | | | | | | | | | | | | | RESET|
41 * |-----------------------------------------------------------| 45 * |-----------------------------------------------------------|
42 * | | | | | | | | | | | |BL-|BL+|BL | 46 * | | | | | | | | | | | |BL-|BL+|BL |
43 * |--------------------------------------------ΩΩ---------------| 47 * |-----------------------------------------------------------|
44 * | | | | | | | | | | | | | 48 * | | | | | | | | | | | | |
45 * |-----------------------------------------------------------| 49 * |-----------------------------------------------------------|
46 * | | F1|F2 | F3|F4 | F5| F6| F7| F8| | | | 50 * | | F1|F2 | F3|F4 | F5| F6| F7| F8| | | |
@@ -64,21 +68,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
64 #endif 68 #endif
65}; 69};
66 70
67enum function_id { 71bool process_record_user(uint16_t keycode, keyrecord_t *record) {
68 SHIFT_ESC, 72 switch (keycode) {
69}; 73 case SFT_ESC:
70
71const uint16_t PROGMEM fn_actions[] = {
72 [0] = ACTION_FUNCTION(SHIFT_ESC),
73};
74
75void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) {
76 static uint8_t shift_esc_shift_mask;
77 switch (id) {
78 case SHIFT_ESC:
79 shift_esc_shift_mask = get_mods()&MODS_CTRL_MASK;
80 if (record->event.pressed) { 74 if (record->event.pressed) {
81 if (shift_esc_shift_mask) { 75 if (get_mods() & MODS_SHIFT_MASK) {
82 add_key(KC_GRV); 76 add_key(KC_GRV);
83 send_keyboard_report(); 77 send_keyboard_report();
84 } else { 78 } else {
@@ -86,7 +80,7 @@ void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) {
86 send_keyboard_report(); 80 send_keyboard_report();
87 } 81 }
88 } else { 82 } else {
89 if (shift_esc_shift_mask) { 83 if (get_mods() & MODS_SHIFT_MASK) {
90 del_key(KC_GRV); 84 del_key(KC_GRV);
91 send_keyboard_report(); 85 send_keyboard_report();
92 } else { 86 } else {
@@ -94,6 +88,10 @@ void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) {
94 send_keyboard_report(); 88 send_keyboard_report();
95 } 89 }
96 } 90 }
97 break; 91
92 return false;
93
94 default:
95 return true;
98 } 96 }
99} 97}