aboutsummaryrefslogtreecommitdiffstats
path: root/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
diff options
context:
space:
mode:
authorGravatar lucwastiaux <luc.wastiaux@airpost.net>2017-01-27 23:55:33 +0800
committerGravatar lucwastiaux <luc.wastiaux@airpost.net>2017-01-27 23:55:33 +0800
commit93c1bfa646bd4d53c065df1a1a7e457d49df7e31 (patch)
tree528ef7e11d80062777ad095ff60aad0938b0764d /keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
parent841d7e6a1d74b1fc45575ed551132ec27353ebf3 (diff)
downloadqmk_firmware-93c1bfa646bd4d53c065df1a1a7e457d49df7e31.tar.gz
dual capslock functionality, activating shell nav or brackets
Diffstat (limited to 'keyboards/ergodox/keymaps/dvorak_programmer/keymap.c')
-rw-r--r--keyboards/ergodox/keymaps/dvorak_programmer/keymap.c23
1 files changed, 20 insertions, 3 deletions
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
index 7ed0c7f12..6757355c8 100644
--- a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
+++ b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
@@ -35,7 +35,9 @@
#define SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND 15
#define SEMICOLON_NEWLINE 16
#define END_NEWLINE 17
+#define DUAL_CAPSLOCK 18
+static uint16_t capslock_timer;
const uint16_t PROGMEM fn_actions[] = {
[1] = ACTION_LAYER_TAP_TOGGLE(KEY_NAV), // FN1 - keynav layer
@@ -59,8 +61,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[BASE] = KEYMAP( // layer 0 : default
// left hand
KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6,
- LT(SHELL_NAV,KC_TAB), KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, MO(KEY_SEL),
- OSL(BRACKETS), KC_A, KC_O, KC_E, KC_U, KC_I,
+ KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, MO(KEY_SEL),
+ M(DUAL_CAPSLOCK), KC_A, KC_O, KC_E, KC_U, KC_I,
OSM(MOD_LSFT), KC_SCLN, KC_Q, KC_J, KC_K, KC_X, MO(KEY_NAV),
OSL(SHORTCUTS),KC_FN4, KC_FN5,OSL(SYMBOL),MO(NUMBER),
// thumb cluster
@@ -395,7 +397,22 @@ const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
if (record->event.pressed) {
return MACRO( T(END), T(ENTER), END);
}
- break;
+ break;
+ case DUAL_CAPSLOCK:
+ if (record->event.pressed) {
+ if(timer_elapsed(capslock_timer) < 100) {
+ // activate SHELL_NAV
+ layer_on(SHELL_NAV);
+ } else {
+ layer_on(BRACKETS);
+ }
+ } else {
+ layer_off(SHELL_NAV);
+ layer_off(BRACKETS);
+ capslock_timer = timer_read();
+ }
+ break;
+
}
return MACRO_NONE;