diff options
author | skullY <skullydazed@gmail.com> | 2017-08-16 01:07:48 -0700 |
---|---|---|
committer | skullY <skullydazed@gmail.com> | 2017-08-16 01:07:48 -0700 |
commit | 0cc15e117d1c9ce3dd6f44b6b8556273bd0e245b (patch) | |
tree | 11d7a2430c5e038f388b6fe8a588e222d1e90f34 | |
parent | 5bff9d61818c5dd692c505896aee287168af80cc (diff) | |
download | qmk_firmware-0cc15e117d1c9ce3dd6f44b6b8556273bd0e245b.tar.gz qmk_firmware-0cc15e117d1c9ce3dd6f44b6b8556273bd0e245b.zip |
Cleanup the clueboard keymaps
20 files changed, 119 insertions, 666 deletions
diff --git a/keyboards/clueboard/keymaps/bloodlvst/Makefile b/keyboards/clueboard/keymaps/bloodlvst/Makefile new file mode 100644 index 000000000..b1c2f32f6 --- /dev/null +++ b/keyboards/clueboard/keymaps/bloodlvst/Makefile | |||
@@ -0,0 +1,2 @@ | |||
1 | EXTRAKEY_ENABLE = yes | ||
2 | COMMAND_ENABLE = no | ||
diff --git a/keyboards/clueboard/keymaps/bloodlvst/config.h b/keyboards/clueboard/keymaps/bloodlvst/config.h new file mode 100644 index 000000000..320401dbd --- /dev/null +++ b/keyboards/clueboard/keymaps/bloodlvst/config.h | |||
@@ -0,0 +1,8 @@ | |||
1 | #ifndef CONFIG_USER_H | ||
2 | #define CONFIG_USER_H | ||
3 | |||
4 | #include "../../config.h" | ||
5 | |||
6 | #define PREVENT_STUCK_MODIFIERS | ||
7 | #define DISABLE_SPACE_CADET_ROLLOVER | ||
8 | #endif | ||
diff --git a/keyboards/clueboard/keymaps/bloodlvst/keymap.c b/keyboards/clueboard/keymaps/bloodlvst/keymap.c new file mode 100644 index 000000000..bedb658ea --- /dev/null +++ b/keyboards/clueboard/keymaps/bloodlvst/keymap.c | |||
@@ -0,0 +1,41 @@ | |||
1 | #include "clueboard.h" | ||
2 | |||
3 | // Helpful defines | ||
4 | #define _______ KC_TRNS | ||
5 | |||
6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | ||
7 | // The underscores don't mean anything - you can have a layer called STUFF or any other name. | ||
8 | // Layer names don't all need to be of the same length, obviously, and you can also skip them | ||
9 | // entirely and just use numbers. | ||
10 | #define _BL 0 | ||
11 | #define _FL 1 | ||
12 | #define _CL 2 | ||
13 | |||
14 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
15 | /* Keymap _BL: Base Layer (Default Layer) | ||
16 | */ | ||
17 | [_BL] = KEYMAP( | ||
18 | KC_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_INS, KC_DEL, KC_PGUP, \ | ||
19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | ||
20 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | ||
21 | KC_LSPO, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSPC, KC_UP, \ | ||
22 | KC_LCTL, KC_LGUI, MO(_FL), KC_LALT, KC_BSPC,KC_SPC, KC_RALT, KC_APP, MO(_FL), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT), | ||
23 | |||
24 | /* Keymap _FL: Function Layer | ||
25 | */ | ||
26 | [_FL] = KEYMAP( | ||
27 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_HOME, KC_END, KC_VOLU, \ | ||
28 | _______, _______, _______,_______,_______,_______,_______,_______,_______,KC_SLCK, KC_PAUS, _______, _______, KC_MUTE, KC_VOLD, \ | ||
29 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, KC_PSCR, \ | ||
30 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_MPLY, \ | ||
31 | _______, KC_MYCM, MO(_FL), _______, _______,_______, _______, KC_CALC, MO(_FL), _______, KC_MPRV, KC_MSTP, KC_MNXT), | ||
32 | |||
33 | /* Keymap _CL: Control layer | ||
34 | */ | ||
35 | [_CL] = KEYMAP( | ||
36 | KC_PWR, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_TOG, RGB_VAI, \ | ||
37 | _______, _______, _______,_______,RESET, _______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_VAD, \ | ||
38 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, RGB_MOD, \ | ||
39 | _______, _______, _______,_______,_______,_______,_______,_______,_______,RGB_HUD, RGB_HUI, _______, _______, _______, KC_WAKE, \ | ||
40 | _______, _______, MO(_FL), _______, RGB_SAD,RGB_SAI, _______, _______, MO(_FL), _______, _______, KC_SLEP, _______), | ||
41 | }; | ||
diff --git a/keyboards/clueboard/keymaps/bloodlvst/readme.md b/keyboards/clueboard/keymaps/bloodlvst/readme.md new file mode 100644 index 000000000..ee287ca47 --- /dev/null +++ b/keyboards/clueboard/keymaps/bloodlvst/readme.md | |||
@@ -0,0 +1,17 @@ | |||
1 | ``` | ||
2 | ___ _____ _ _ _ __ __ _ __ | ||
3 | |__ \ / ____| | | | | | / / / /(_) / / | ||
4 | ||) | | | | |_ _ ___| |__ ___ __ _ _ __ __| | / /_ / /_ / / | ||
5 | |/ / | | | | | | |/ _ \ '_ \ / _ \ / _` | '__/ _` | | '_ \| '_ \ / / | ||
6 | |_| | |____| | |_| | __/ |_) | (_) | (_| | | | (_| | | (_) | (_) / / _ | ||
7 | (_) \_____|_|\__,_|\___|_.__/ \___/ \__,_|_| \__,_| \___/ \___/_/ (_) | ||
8 | ``` | ||
9 | |||
10 |  | ||
11 | |||
12 | # Default Clueboard Layout | ||
13 | |||
14 | This is the default layout that comes flashed on every Clueboard. For the most | ||
15 | part it's a straightforward and easy to follow layout. The only unusual key is | ||
16 | the key in the upper left, which sends Escape normally, but Grave when any of | ||
17 | the Ctrl, Alt, or GUI modifiers are held down. | ||
diff --git a/keyboards/clueboard/keymaps/caps_fn/keymap.c b/keyboards/clueboard/keymaps/caps_fn/keymap.c index 7fad9c1b2..2e54fdba8 100644 --- a/keyboards/clueboard/keymaps/caps_fn/keymap.c +++ b/keyboards/clueboard/keymaps/caps_fn/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,7 +15,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC, 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_GRV, KC_BSPC, KC_PGUP, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ |
21 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
@@ -40,47 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/colemak/keymap.c b/keyboards/clueboard/keymaps/colemak/keymap.c index 42c85ff9d..2ed354186 100644 --- a/keyboards/clueboard/keymaps/colemak/keymap.c +++ b/keyboards/clueboard/keymaps/colemak/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,71 +15,27 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC, 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_GRV, KC_BSPC, KC_PGUP, \ |
20 | 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, KC_PGDN, \ | 19 | 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, KC_PGDN, \ |
21 | 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_NUHS, KC_ENT, \ | 20 | 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_NUHS, KC_ENT, \ |
22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
23 | KC_LCTL, MO(_FL), KC_LGUI,KC_MHEN, KC_SPC,KC_SPC, KC_HENK, KC_RALT, KC_RCTL, KC_RGUI, KC_LEFT, KC_DOWN, KC_RGHT), | 22 | KC_LCTL, KC_LGUI, KC_LALT,KC_MHEN, KC_SPC,KC_SPC, KC_HENK, KC_RALT, MO(_FL), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT), |
24 | 23 | ||
25 | /* Keymap _FL: Function Layer | 24 | /* Keymap _FL: Function Layer |
26 | */ | 25 | */ |
27 | [_FL] = KEYMAP( | 26 | [_FL] = KEYMAP( |
28 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, KC_CAPS, BL_STEP, \ | 27 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, KC_CAPS, KC_VOLU, \ |
29 | _______, _______, _______,_______,_______,_______,_______,KC_HOME,KC_PGDN,KC_PGUP, KC_END, _______, _______, _______, _______, \ | 28 | _______, _______, _______,_______,_______,_______,_______,KC_HOME,KC_PGDN,KC_PGUP, KC_END, _______, _______, _______, KC_VOLD, \ |
30 | KC_DEL, _______, MO(_CL),_______,_______,_______,_______,KC_LEFT,KC_DOWN,KC_UP, KC_RGHT, _______, _______, _______, \ | 29 | KC_DEL, _______, MO(_CL),_______,_______,_______,_______,KC_LEFT,KC_DOWN,KC_UP, KC_RGHT, _______, _______, _______, \ |
31 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_PGUP, \ | 30 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_PGUP, \ |
32 | _______, _______, _______,_______, _______,_______, _______, _______, _______, MO(_FL), KC_HOME, KC_PGDN, KC_END), | 31 | _______, _______, _______,_______, _______,_______, _______, _______, MO(_FL), _______, KC_HOME, KC_PGDN, KC_END), |
33 | 32 | ||
34 | /* Keymap _CL: Control layer | 33 | /* Keymap _CL: Control layer |
35 | */ | 34 | */ |
36 | [_CL] = KEYMAP( | 35 | [_CL] = KEYMAP( |
37 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_TOG, RGB_VAI, \ | 36 | BL_STEP, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_TOG, RGB_VAI, \ |
38 | _______, _______, _______,_______,RESET, _______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_VAD, \ | 37 | _______, _______, _______,_______,RESET, _______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_VAD, \ |
39 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, \ | 38 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, \ |
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/default/keymap.c b/keyboards/clueboard/keymaps/default/keymap.c index 7fad9c1b2..c4da561fe 100644 --- a/keyboards/clueboard/keymaps/default/keymap.c +++ b/keyboards/clueboard/keymaps/default/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,71 +15,27 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC,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_GRV, KC_BSPC, KC_PGUP, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC,KC_RBRC,KC_BSLS, KC_PGDN, \ |
21 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_CAPS,KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN,KC_QUOT,KC_NUHS,KC_ENT, \ |
22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | KC_LSFT,KC_NUBS,KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM,KC_DOT, KC_SLSH,KC_RO, KC_RSFT, KC_UP, \ |
23 | KC_LCTL, KC_LGUI, KC_LALT, KC_MHEN, KC_SPC,KC_SPC, KC_HENK, KC_RALT, KC_RCTL, MO(_FL), KC_LEFT, KC_DOWN, KC_RGHT), | 22 | KC_LCTL,KC_LGUI,KC_LALT,KC_MHEN, KC_SPC, KC_SPC, KC_HENK,KC_RALT,MO(_FL),KC_RCTL,KC_LEFT,KC_DOWN,KC_RGHT), |
24 | 23 | ||
25 | /* Keymap _FL: Function Layer | 24 | /* Keymap _FL: Function Layer |
26 | */ | 25 | */ |
27 | [_FL] = KEYMAP( | 26 | [_FL] = KEYMAP( |
28 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, KC_DEL, BL_STEP, \ | 27 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______,KC_DEL, KC_VOLU, \ |
29 | _______, _______, _______,_______,_______,_______,_______,_______,KC_PSCR,KC_SLCK, KC_PAUS, _______, _______, _______, _______, \ | 28 | _______,_______,_______,_______,_______,_______,_______,_______,_______,KC_MPRV,KC_MPLY,KC_MNXT,_______,KC_MUTE, KC_VOLD, \ |
30 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, \ | 29 | _______,_______,MO(_CL),_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, \ |
31 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_PGUP, \ | 30 | _______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, KC_PGUP, \ |
32 | _______, _______, _______, _______, _______,_______, _______, _______, _______, MO(_FL), KC_HOME, KC_PGDN, KC_END), | 31 | _______,_______,_______,_______, _______,_______, _______,_______,MO(_FL),_______,KC_HOME,KC_PGDN,KC_END), |
33 | 32 | ||
34 | /* Keymap _CL: Control layer | 33 | /* Keymap _CL: Control layer |
35 | */ | 34 | */ |
36 | [_CL] = KEYMAP( | 35 | [_CL] = KEYMAP( |
37 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_TOG, RGB_VAI, \ | 36 | BL_STEP,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,RGB_TOG, RGB_VAI, \ |
38 | _______, _______, _______,_______,RESET, _______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_VAD, \ | 37 | _______,_______,_______,_______,RESET, _______,_______,_______,_______,_______,_______,_______,_______,_______, RGB_VAD, \ |
39 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, \ | 38 | _______,_______,MO(_CL),_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, \ |
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL),_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______,_______,_______,_______, RGB_MOD, RGB_MOD, _______,_______,MO(_FL),_______,RGB_HUD,RGB_SAD,RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/jokrik/keymap.c b/keyboards/clueboard/keymaps/jokrik/keymap.c index acde4d9e1..dda6a8b90 100644 --- a/keyboards/clueboard/keymaps/jokrik/keymap.c +++ b/keyboards/clueboard/keymaps/jokrik/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -40,47 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, MO(_FL), _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, MO(_FL), _______, RGB_HUD, RGB_SAD, RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/mac_optimized/keymap.c b/keyboards/clueboard/keymaps/mac_optimized/keymap.c index e72733092..e39edb4d6 100644 --- a/keyboards/clueboard/keymaps/mac_optimized/keymap.c +++ b/keyboards/clueboard/keymaps/mac_optimized/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,64 +15,27 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC,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_GRV, KC_BSPC, KC_PGUP, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC,KC_RBRC,KC_BSLS, KC_PGDN, \ |
21 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_CAPS,KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN,KC_QUOT,KC_NUHS,KC_ENT, \ |
22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | KC_LSFT,KC_NUBS,KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM,KC_DOT, KC_SLSH,KC_RO, KC_RSFT, KC_UP, \ |
23 | KC_LCTL, KC_LALT, KC_LGUI,KC_MHEN, KC_SPC, KC_SPC, KC_HENK, KC_RGUI, KC_RCTL, MO(_FL), KC_LEFT, KC_DOWN, KC_RGHT), | 22 | KC_LCTL,KC_LALT,KC_LGUI,KC_MHEN, KC_SPC, KC_SPC, KC_HENK,KC_RGUI,MO(_FL),KC_RCTL,KC_LEFT,KC_DOWN,KC_RGHT), |
24 | 23 | ||
25 | /* Keymap _FL: Function Layer | 24 | /* Keymap _FL: Function Layer |
26 | */ | 25 | */ |
27 | [_FL] = KEYMAP( | 26 | [_FL] = KEYMAP( |
28 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, KC_DEL, BL_STEP, \ | 27 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______,KC_DEL, KC_VOLU, \ |
29 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, _______, \ | 28 | _______,_______,_______,_______,_______,_______,_______,_______,_______,KC_MRWD,KC_MPLY,KC_MFFD,_______,KC_MUTE, KC_VOLD, \ |
30 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, \ | 29 | _______,_______,MO(_CL),_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, \ |
31 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_PGUP, \ | 30 | _______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, KC_PGUP, \ |
32 | _______, _______, _______, _______, _______,_______, _______, _______, _______, MO(_FL), KC_HOME, KC_PGDN, KC_END), | 31 | _______,_______,_______,_______, _______,_______, _______,_______,MO(_FL),_______,KC_HOME,KC_PGDN,KC_END), |
33 | 32 | ||
34 | /* Keymap _CL: Control layer | 33 | /* Keymap _CL: Control layer |
35 | */ | 34 | */ |
36 | [_CL] = KEYMAP( | 35 | [_CL] = KEYMAP( |
37 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_TOG, RGB_VAI, \ | 36 | BL_STEP,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,RGB_TOG, RGB_VAI, \ |
38 | _______, _______, _______,_______,RESET, _______,_______,_______,_______,_______, _______, _______, _______, _______, RGB_VAD, \ | 37 | _______,_______,_______,_______,RESET, _______,_______,_______,_______,_______,_______,_______,_______,_______, RGB_VAD, \ |
39 | _______, _______, MO(_CL),_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, \ | 38 | _______,_______,MO(_CL),_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, \ |
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL),_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______, RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______,_______,_______,_______, RGB_MOD, RGB_MOD, _______,_______,MO(_FL),_______,RGB_HUD,RGB_SAD,RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | |||
54 | switch (id) { | ||
55 | case 0: | ||
56 | /* Handle the combined Grave/Esc key | ||
57 | */ | ||
58 | if (record->event.pressed) { | ||
59 | /* The key is being pressed. | ||
60 | */ | ||
61 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
62 | if (mods_pressed) { | ||
63 | register_code(KC_GRV); | ||
64 | } else { | ||
65 | register_code(KC_ESC); | ||
66 | } | ||
67 | } else { | ||
68 | /* The key is being released. | ||
69 | */ | ||
70 | if (mods_pressed) { | ||
71 | mods_pressed = false; | ||
72 | unregister_code(KC_GRV); | ||
73 | } else { | ||
74 | unregister_code(KC_ESC); | ||
75 | } | ||
76 | } | ||
77 | break; | ||
78 | } | ||
79 | } | ||
diff --git a/keyboards/clueboard/keymaps/magicmonty/keymap.c b/keyboards/clueboard/keymaps/magicmonty/keymap.c index 3d00332b0..feef00e7a 100644 --- a/keyboards/clueboard/keymaps/magicmonty/keymap.c +++ b/keyboards/clueboard/keymaps/magicmonty/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | #define xxxxxxx KC_NO | 5 | #define xxxxxxx KC_NO |
7 | 6 | ||
@@ -45,16 +44,13 @@ | |||
45 | // CTRL when held, ESC when tapped | 44 | // CTRL when held, ESC when tapped |
46 | #define CTL_ESC CTL_T(KC_ESC) | 45 | #define CTL_ESC CTL_T(KC_ESC) |
47 | 46 | ||
48 | // ESC/Grave mode | ||
49 | #define ESC_GRV F(0) | ||
50 | |||
51 | // Reset RGB mode to layer signalling | 47 | // Reset RGB mode to layer signalling |
52 | #define RGB_RST F(1) | 48 | #define RGB_RST F(0) |
53 | 49 | ||
54 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 50 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { |
55 | /* Keymap _BL: Base Layer (Default Layer) */ | 51 | /* Keymap _BL: Base Layer (Default Layer) */ |
56 | [_BL] = KEYMAP( | 52 | [_BL] = KEYMAP( |
57 | ESC_GRV, 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, KC_INS, \ | 53 | KC_GESC, 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, KC_INS, \ |
58 | HPR_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, \ | 54 | HPR_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, \ |
59 | ESC_FUN, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 55 | ESC_FUN, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
60 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, KC_RSFT, KC_UP, \ | 56 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, KC_RSFT, KC_UP, \ |
@@ -116,44 +112,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
116 | */ | 112 | */ |
117 | const uint16_t PROGMEM fn_actions[] = { | 113 | const uint16_t PROGMEM fn_actions[] = { |
118 | [0] = ACTION_FUNCTION(0), // Calls action_function() | 114 | [0] = ACTION_FUNCTION(0), // Calls action_function() |
119 | [1] = ACTION_FUNCTION(1), // Calls action_function() | ||
120 | }; | 115 | }; |
121 | 116 | ||
122 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | 117 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { |
123 | static uint8_t mods_pressed; | ||
124 | static bool mod_flag; | ||
125 | |||
126 | switch (id) { | 118 | switch (id) { |
127 | case 0: | 119 | case 0: |
128 | /* Handle the combined Grave/Esc key | ||
129 | */ | ||
130 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
131 | |||
132 | if (record->event.pressed) { | ||
133 | /* The key is being pressed. | ||
134 | */ | ||
135 | if (mods_pressed) { | ||
136 | mod_flag = true; | ||
137 | add_key(KC_GRV); | ||
138 | send_keyboard_report(); | ||
139 | } else { | ||
140 | add_key(KC_ESC); | ||
141 | send_keyboard_report(); | ||
142 | } | ||
143 | } else { | ||
144 | /* The key is being released. | ||
145 | */ | ||
146 | if (mod_flag) { | ||
147 | mod_flag = false; | ||
148 | del_key(KC_GRV); | ||
149 | send_keyboard_report(); | ||
150 | } else { | ||
151 | del_key(KC_ESC); | ||
152 | send_keyboard_report(); | ||
153 | } | ||
154 | } | ||
155 | break; | ||
156 | case 1: | ||
157 | if (record->event.pressed) { | 120 | if (record->event.pressed) { |
158 | rgblight_mode(1); | 121 | rgblight_mode(1); |
159 | rgblight_sethsv(206, 255, 255); | 122 | rgblight_sethsv(206, 255, 255); |
diff --git a/keyboards/clueboard/keymaps/maximised/keymap.c b/keyboards/clueboard/keymaps/maximised/keymap.c index ebaefa669..583c52091 100644 --- a/keyboards/clueboard/keymaps/maximised/keymap.c +++ b/keyboards/clueboard/keymaps/maximised/keymap.c | |||
@@ -39,9 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ |
40 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), |
41 | }; | 41 | }; |
42 | |||
43 | const uint16_t PROGMEM fn_actions[] = { | ||
44 | }; | ||
45 | |||
46 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
47 | }; | ||
diff --git a/keyboards/clueboard/keymaps/mouse_keys/keymap.c b/keyboards/clueboard/keymaps/mouse_keys/keymap.c index d3108d1e2..259fa29b7 100644 --- a/keyboards/clueboard/keymaps/mouse_keys/keymap.c +++ b/keyboards/clueboard/keymaps/mouse_keys/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -17,7 +16,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
17 | /* Keymap _BL: Base Layer (Default Layer) | 16 | /* Keymap _BL: Base Layer (Default Layer) |
18 | */ | 17 | */ |
19 | [_BL] = KEYMAP( | 18 | [_BL] = KEYMAP( |
20 | 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_GRV, KC_BSPC, KC_PGUP, \ | 19 | KC_GESC, 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_GRV, KC_BSPC, KC_PGUP, \ |
21 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ |
22 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 21 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
23 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
@@ -50,47 +49,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
50 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_MS_U, \ | 49 | _______, _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, _______, KC_MS_U, \ |
51 | _______, _______, _______,_______, LT(_ML, KC_SPC),LT(_ML, KC_SPC), _______, KC_BTN1, KC_BTN2, KC_BTN3, KC_MS_L, KC_MS_D,KC_MS_R), | 50 | _______, _______, _______,_______, LT(_ML, KC_SPC),LT(_ML, KC_SPC), _______, KC_BTN1, KC_BTN2, KC_BTN3, KC_MS_L, KC_MS_D,KC_MS_R), |
52 | }; | 51 | }; |
53 | |||
54 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
55 | of this list. | ||
56 | */ | ||
57 | const uint16_t PROGMEM fn_actions[] = { | ||
58 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
59 | }; | ||
60 | |||
61 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
62 | static uint8_t mods_pressed; | ||
63 | static bool mod_flag; | ||
64 | |||
65 | switch (id) { | ||
66 | case 0: | ||
67 | /* Handle the combined Grave/Esc key | ||
68 | */ | ||
69 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
70 | |||
71 | if (record->event.pressed) { | ||
72 | /* The key is being pressed. | ||
73 | */ | ||
74 | if (mods_pressed) { | ||
75 | mod_flag = true; | ||
76 | add_key(KC_GRV); | ||
77 | send_keyboard_report(); | ||
78 | } else { | ||
79 | add_key(KC_ESC); | ||
80 | send_keyboard_report(); | ||
81 | } | ||
82 | } else { | ||
83 | /* The key is being released. | ||
84 | */ | ||
85 | if (mod_flag) { | ||
86 | mod_flag = false; | ||
87 | del_key(KC_GRV); | ||
88 | send_keyboard_report(); | ||
89 | } else { | ||
90 | del_key(KC_ESC); | ||
91 | send_keyboard_report(); | ||
92 | } | ||
93 | } | ||
94 | break; | ||
95 | } | ||
96 | } | ||
diff --git a/keyboards/clueboard/keymaps/serubin/keymap.c b/keyboards/clueboard/keymaps/serubin/keymap.c index 18446eb31..4212e6a52 100644 --- a/keyboards/clueboard/keymaps/serubin/keymap.c +++ b/keyboards/clueboard/keymaps/serubin/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -51,53 +50,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
51 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, MO(_FL), _______, RGB_SAI, \ | 50 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, MO(_FL), _______, RGB_SAI, \ |
52 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 51 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), |
53 | }; | 52 | }; |
54 | |||
55 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
56 | of this list. | ||
57 | */ | ||
58 | const uint16_t PROGMEM fn_actions[] = { | ||
59 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
60 | [1] = ACTION_MODS_TAP_KEY(MOD_LCTL, KC_ESC), | ||
61 | }; | ||
62 | |||
63 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
64 | static uint8_t mods_pressed; | ||
65 | static bool mod_flag; | ||
66 | |||
67 | switch (id) { | ||
68 | case 0: | ||
69 | /* Handle the combined Grave/Esc key | ||
70 | */ | ||
71 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
72 | |||
73 | if (record->event.pressed) { | ||
74 | /* The key is being pressed. | ||
75 | */ | ||
76 | if (mods_pressed) { | ||
77 | mod_flag = true; | ||
78 | add_key(KC_GRV); | ||
79 | send_keyboard_report(); | ||
80 | } else { | ||
81 | add_key(KC_ESC); | ||
82 | send_keyboard_report(); | ||
83 | } | ||
84 | } else { | ||
85 | /* The key is being released. | ||
86 | */ | ||
87 | if (mod_flag) { | ||
88 | mod_flag = false; | ||
89 | del_key(KC_GRV); | ||
90 | send_keyboard_report(); | ||
91 | } else { | ||
92 | del_key(KC_ESC); | ||
93 | send_keyboard_report(); | ||
94 | } | ||
95 | } | ||
96 | break; | ||
97 | case 1: | ||
98 | if(record->event.pressed) { | ||
99 | del_key(KC_ESC); | ||
100 | } | ||
101 | break; | ||
102 | } | ||
103 | } | ||
diff --git a/keyboards/clueboard/keymaps/shift_fn/keymap.c b/keyboards/clueboard/keymaps/shift_fn/keymap.c index 83ae1d615..be29a0a17 100644 --- a/keyboards/clueboard/keymaps/shift_fn/keymap.c +++ b/keyboards/clueboard/keymaps/shift_fn/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,7 +15,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC, 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_GRV, KC_BSPC, KC_PGUP, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ |
21 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
22 | MO(_FL), KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | MO(_FL), KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
@@ -40,47 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD,RGB_SAD,RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD,RGB_SAD,RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/skully/keymap.c b/keyboards/clueboard/keymaps/skully/keymap.c index 47dee8e6d..81e47811f 100644 --- a/keyboards/clueboard/keymaps/skully/keymap.c +++ b/keyboards/clueboard/keymaps/skully/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,7 +15,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC, 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_GRV, KC_BSPC, KC_PGUP, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ |
21 | KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
22 | MO(_FL), KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | MO(_FL), KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
@@ -40,47 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD,RGB_SAD,RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD,RGB_SAD,RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/smt/keymap.c b/keyboards/clueboard/keymaps/smt/keymap.c index f097afaa8..6797faaa3 100644 --- a/keyboards/clueboard/keymaps/smt/keymap.c +++ b/keyboards/clueboard/keymaps/smt/keymap.c | |||
@@ -19,7 +19,6 @@ enum planck_keycodes { | |||
19 | // Helpful defines | 19 | // Helpful defines |
20 | #define _______ KC_TRNS | 20 | #define _______ KC_TRNS |
21 | #define XXXXXXX KC_NO | 21 | #define XXXXXXX KC_NO |
22 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
23 | 22 | ||
24 | // Custom macros | 23 | // Custom macros |
25 | #define CTL_ESC CTL_T(KC_ESC) // Tap for Esc, hold for Ctrl | 24 | #define CTL_ESC CTL_T(KC_ESC) // Tap for Esc, hold for Ctrl |
@@ -42,7 +41,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
42 | * `------------------------------------------------------------------' | 41 | * `------------------------------------------------------------------' |
43 | */ | 42 | */ |
44 | [_QWERTY] = KEYMAP( | 43 | [_QWERTY] = KEYMAP( |
45 | 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_BSLS, KC_GRV, KC_PGUP, \ | 44 | KC_GESC, 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_BSLS, KC_GRV, KC_PGUP, \ |
46 | HPR_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSPC, KC_PGDN, \ | 45 | HPR_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSPC, KC_PGDN, \ |
47 | CTL_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, XXXXXXX, KC_ENT, \ | 46 | CTL_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, XXXXXXX, KC_ENT, \ |
48 | KC_LSFT, XXXXXXX, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT, MO(_FL), KC_UP, \ | 47 | KC_LSFT, XXXXXXX, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT, MO(_FL), KC_UP, \ |
@@ -62,7 +61,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
62 | * `------------------------------------------------------------------' | 61 | * `------------------------------------------------------------------' |
63 | */ | 62 | */ |
64 | [_COLEMAK] = KEYMAP( | 63 | [_COLEMAK] = KEYMAP( |
65 | 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_BSLS, KC_GRV, KC_PGUP, \ | 64 | KC_GESC, 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_BSLS, KC_GRV, KC_PGUP, \ |
66 | HPR_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_BSPC, KC_PGDN, \ | 65 | HPR_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_BSPC, KC_PGDN, \ |
67 | CTL_ESC, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, KC_QUOT, XXXXXXX, KC_ENT, \ | 66 | CTL_ESC, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, KC_QUOT, XXXXXXX, KC_ENT, \ |
68 | KC_LSFT, XXXXXXX, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT, MO(_FL), KC_UP, \ | 67 | KC_LSFT, XXXXXXX, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT, MO(_FL), KC_UP, \ |
@@ -82,7 +81,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
82 | * `------------------------------------------------------------------' | 81 | * `------------------------------------------------------------------' |
83 | */ | 82 | */ |
84 | [_DVORAK] = KEYMAP( | 83 | [_DVORAK] = KEYMAP( |
85 | F(0), KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_LBRC, KC_RBRC, KC_BSLS, KC_GRV, KC_PGUP, \ | 84 | KC_GESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_LBRC, KC_RBRC, KC_BSLS, KC_GRV, KC_PGUP, \ |
86 | HPR_TAB, KC_QUOT, KC_COMM,KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH, KC_EQL, KC_BSPC, KC_PGDN, \ | 85 | HPR_TAB, KC_QUOT, KC_COMM,KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH, KC_EQL, KC_BSPC, KC_PGDN, \ |
87 | CTL_ESC, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS, XXXXXXX, KC_ENT, \ | 86 | CTL_ESC, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS, XXXXXXX, KC_ENT, \ |
88 | KC_LSFT, XXXXXXX, KC_SCLN,KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, SFT_ENT, MO(_FL), KC_UP, \ | 87 | KC_LSFT, XXXXXXX, KC_SCLN,KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, SFT_ENT, MO(_FL), KC_UP, \ |
@@ -107,50 +106,6 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
107 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 106 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), |
108 | }; | 107 | }; |
109 | 108 | ||
110 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
111 | of this list. | ||
112 | */ | ||
113 | const uint16_t PROGMEM fn_actions[] = { | ||
114 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
115 | }; | ||
116 | |||
117 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
118 | static uint8_t mods_pressed; | ||
119 | static bool mod_flag; | ||
120 | |||
121 | switch (id) { | ||
122 | case 0: | ||
123 | /* Handle the combined Grave/Esc key | ||
124 | */ | ||
125 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
126 | |||
127 | if (record->event.pressed) { | ||
128 | /* The key is being pressed. | ||
129 | */ | ||
130 | if (mods_pressed) { | ||
131 | mod_flag = true; | ||
132 | add_key(KC_GRV); | ||
133 | send_keyboard_report(); | ||
134 | } else { | ||
135 | add_key(KC_ESC); | ||
136 | send_keyboard_report(); | ||
137 | } | ||
138 | } else { | ||
139 | /* The key is being released. | ||
140 | */ | ||
141 | if (mod_flag) { | ||
142 | mod_flag = false; | ||
143 | del_key(KC_GRV); | ||
144 | send_keyboard_report(); | ||
145 | } else { | ||
146 | del_key(KC_ESC); | ||
147 | send_keyboard_report(); | ||
148 | } | ||
149 | } | ||
150 | break; | ||
151 | } | ||
152 | } | ||
153 | |||
154 | void persistent_default_layer_set(uint16_t default_layer) { | 109 | void persistent_default_layer_set(uint16_t default_layer) { |
155 | eeconfig_update_default_layer(default_layer); | 110 | eeconfig_update_default_layer(default_layer); |
156 | default_layer_set(default_layer); | 111 | default_layer_set(default_layer); |
@@ -178,4 +133,4 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
178 | break; | 133 | break; |
179 | } | 134 | } |
180 | return true; | 135 | return true; |
181 | } \ No newline at end of file | 136 | } |
diff --git a/keyboards/clueboard/keymaps/unix_optimized/keymap.c b/keyboards/clueboard/keymaps/unix_optimized/keymap.c index 7c1359954..0de247ca0 100644 --- a/keyboards/clueboard/keymaps/unix_optimized/keymap.c +++ b/keyboards/clueboard/keymaps/unix_optimized/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,7 +15,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_PGUP, \ | 18 | KC_GESC, 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_GRV, KC_BSPC, KC_PGUP, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_PGDN, \ |
21 | KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
@@ -40,47 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD,RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD,RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD,RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/win_optimized/keymap.c b/keyboards/clueboard/keymaps/win_optimized/keymap.c index c5553ff1f..ad02fd59f 100644 --- a/keyboards/clueboard/keymaps/win_optimized/keymap.c +++ b/keyboards/clueboard/keymaps/win_optimized/keymap.c | |||
@@ -1,7 +1,6 @@ | |||
1 | #include "clueboard.h" | 1 | #include "clueboard.h" |
2 | 2 | ||
3 | // Helpful defines | 3 | // Helpful defines |
4 | #define GRAVE_MODS (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT)|MOD_BIT(KC_LGUI)|MOD_BIT(KC_RGUI)|MOD_BIT(KC_LALT)|MOD_BIT(KC_RALT)) | ||
5 | #define _______ KC_TRNS | 4 | #define _______ KC_TRNS |
6 | 5 | ||
7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 6 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
@@ -16,7 +15,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
16 | /* Keymap _BL: Base Layer (Default Layer) | 15 | /* Keymap _BL: Base Layer (Default Layer) |
17 | */ | 16 | */ |
18 | [_BL] = KEYMAP( | 17 | [_BL] = KEYMAP( |
19 | 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_GRV, KC_BSPC, KC_INS, \ | 18 | KC_GESC, 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_GRV, KC_BSPC, KC_INS, \ |
20 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, \ | 19 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, \ |
21 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ | 20 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NUHS, KC_ENT, \ |
22 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ | 21 | KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RO, KC_RSFT, KC_UP, \ |
@@ -40,47 +39,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
40 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ | 39 | MO(_FL), _______, _______,_______,_______,_______,_______,_______,_______,_______, _______, _______, _______, MO(_FL), RGB_SAI, \ |
41 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), | 40 | _______, _______, _______,_______, RGB_MOD, RGB_MOD, _______, _______, _______, _______, RGB_HUD, RGB_SAD, RGB_HUI), |
42 | }; | 41 | }; |
43 | |||
44 | /* This is a list of user defined functions. F(N) corresponds to item N | ||
45 | of this list. | ||
46 | */ | ||
47 | const uint16_t PROGMEM fn_actions[] = { | ||
48 | [0] = ACTION_FUNCTION(0), // Calls action_function() | ||
49 | }; | ||
50 | |||
51 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
52 | static uint8_t mods_pressed; | ||
53 | static bool mod_flag; | ||
54 | |||
55 | switch (id) { | ||
56 | case 0: | ||
57 | /* Handle the combined Grave/Esc key | ||
58 | */ | ||
59 | mods_pressed = get_mods()&GRAVE_MODS; // Check to see what mods are pressed | ||
60 | |||
61 | if (record->event.pressed) { | ||
62 | /* The key is being pressed. | ||
63 | */ | ||
64 | if (mods_pressed) { | ||
65 | mod_flag = true; | ||
66 | add_key(KC_GRV); | ||
67 | send_keyboard_report(); | ||
68 | } else { | ||
69 | add_key(KC_ESC); | ||
70 | send_keyboard_report(); | ||
71 | } | ||
72 | } else { | ||
73 | /* The key is being released. | ||
74 | */ | ||
75 | if (mod_flag) { | ||
76 | mod_flag = false; | ||
77 | del_key(KC_GRV); | ||
78 | send_keyboard_report(); | ||
79 | } else { | ||
80 | del_key(KC_ESC); | ||
81 | send_keyboard_report(); | ||
82 | } | ||
83 | } | ||
84 | break; | ||
85 | } | ||
86 | } | ||
diff --git a/keyboards/clueboard/keymaps/xyverz/keymap.c b/keyboards/clueboard/keymaps/xyverz/keymap.c index 453911973..540cd7983 100644 --- a/keyboards/clueboard/keymaps/xyverz/keymap.c +++ b/keyboards/clueboard/keymaps/xyverz/keymap.c | |||
@@ -29,7 +29,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
29 | * `----------------------------------------------------------------------------------' | 29 | * `----------------------------------------------------------------------------------' |
30 | */ | 30 | */ |
31 | [_BL] = KEYMAP( | 31 | [_BL] = KEYMAP( |
32 | F(0), KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_LBRC, KC_RBRC, KC_GRV, KC_BSPC, KC_PGUP, \ | 32 | KC_GESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_LBRC, KC_RBRC, KC_GRV, KC_BSPC, KC_PGUP, \ |
33 | KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH, KC_EQL, KC_BSLS, KC_PGDN, \ | 33 | KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH, KC_EQL, KC_BSLS, KC_PGDN, \ |
34 | LT(_FL, KC_CAPS), KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS, KC_NUHS, KC_ENT, \ | 34 | LT(_FL, KC_CAPS), KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS, KC_NUHS, KC_ENT, \ |
35 | KC_LSFT, KC_RO, KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, KC_SLSH, KC_RSFT, KC_UP, \ | 35 | KC_LSFT, KC_RO, KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, KC_SLSH, KC_RSFT, KC_UP, \ |
@@ -76,36 +76,3 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
76 | KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_MOD, RGB_MOD, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_HUD, RGB_SAD, RGB_HUI), | 76 | KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_MOD, RGB_MOD, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_HUD, RGB_SAD, RGB_HUI), |
77 | }; | 77 | }; |
78 | 78 | ||
79 | enum function_id { | ||
80 | SHIFT_ESC, | ||
81 | }; | ||
82 | |||
83 | const uint16_t PROGMEM fn_actions[] = { | ||
84 | [0] = ACTION_FUNCTION(SHIFT_ESC), | ||
85 | }; | ||
86 | |||
87 | void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
88 | static uint8_t shift_esc_shift_mask; | ||
89 | switch (id) { | ||
90 | case SHIFT_ESC: | ||
91 | shift_esc_shift_mask = get_mods()&MODS_CTRL_MASK; | ||
92 | if (record->event.pressed) { | ||
93 | if (shift_esc_shift_mask) { | ||
94 | add_key(KC_GRV); | ||
95 | send_keyboard_report(); | ||
96 | } else { | ||
97 | add_key(KC_ESC); | ||
98 | send_keyboard_report(); | ||
99 | } | ||
100 | } else { | ||
101 | if (shift_esc_shift_mask) { | ||
102 | del_key(KC_GRV); | ||
103 | send_keyboard_report(); | ||
104 | } else { | ||
105 | del_key(KC_ESC); | ||
106 | send_keyboard_report(); | ||
107 | } | ||
108 | } | ||
109 | break; | ||
110 | } | ||
111 | } | ||
diff --git a/keyboards/clueboard/rules.mk b/keyboards/clueboard/rules.mk index f852a0184..74bfcfe74 100644 --- a/keyboards/clueboard/rules.mk +++ b/keyboards/clueboard/rules.mk | |||
@@ -92,7 +92,7 @@ OPT_DEFS += -DBOOTLOADER_SIZE=4096 | |||
92 | # | 92 | # |
93 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | 93 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) |
94 | MOUSEKEY_ENABLE = no # Mouse keys(+4700) | 94 | MOUSEKEY_ENABLE = no # Mouse keys(+4700) |
95 | EXTRAKEY_ENABLE = no # Audio control and System control(+450) | 95 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) |
96 | CONSOLE_ENABLE = yes # Console for debug(+400) | 96 | CONSOLE_ENABLE = yes # Console for debug(+400) |
97 | COMMAND_ENABLE = yes # Commands for debug and configuration | 97 | COMMAND_ENABLE = yes # Commands for debug and configuration |
98 | NKRO_ENABLE = yes # USB Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | 98 | NKRO_ENABLE = yes # USB Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work |