summaryrefslogtreecommitdiffstats
path: root/users
diff options
context:
space:
mode:
authorFred Silberberg <fred@silberberg.xyz>2019-02-24 23:57:16 +0100
committerDrashna Jaelre <drashna@live.com>2019-02-24 23:57:16 +0100
commit6f30a6b4079684742c147741b98414b1b2350b0b (patch)
tree7111640fff952b88302c2bdf9eb39a0c6671fd4b /users
parenta69e4406d4ab0a43077bc130dabda536b4fda9ab (diff)
downloadqmk_firmware-6f30a6b4079684742c147741b98414b1b2350b0b.tar.gz
qmk_firmware-6f30a6b4079684742c147741b98414b1b2350b0b.tar.xz
[Keymap] Added a key to handle copy/paste in and out of a terminal (#5205)
Diffstat (limited to 'users')
-rw-r--r--users/333fred/333fred.c37
-rw-r--r--users/333fred/333fred.h7
2 files changed, 37 insertions, 7 deletions
diff --git a/users/333fred/333fred.c b/users/333fred/333fred.c
index 12ee9e7d7..3b2b36d02 100644
--- a/users/333fred/333fred.c
+++ b/users/333fred/333fred.c
@@ -9,7 +9,7 @@ typedef enum {
static tap_dance_state_enum tap_dance_state;
static bool tap_dance_active = false;
-void tap_dance_layer_finished(qk_tap_dance_state_t *state, void *user_data) {
+void tap_dance_sym_vim_finished(qk_tap_dance_state_t *state, void *user_data) {
// Determine the current state
if (state->count == 1) {
if (state->interrupted || state->pressed == 0) tap_dance_state = SINGLE_TAP;
@@ -38,8 +38,7 @@ void tap_dance_layer_finished(qk_tap_dance_state_t *state, void *user_data) {
}
}
-
-void tap_dance_layer_reset(qk_tap_dance_state_t *state, void *user_data) {
+void tap_dance_sym_vim_reset(qk_tap_dance_state_t *state, void *user_data) {
switch(tap_dance_state) {
case SINGLE_TAP:
clear_oneshot_layer_state(ONESHOT_PRESSED);
@@ -53,8 +52,38 @@ void tap_dance_layer_reset(qk_tap_dance_state_t *state, void *user_data) {
}
}
+void tap_dance_copy_paste_finished(qk_tap_dance_state_t *state, void *user_data) {
+ bool is_paste = state->count == 2;
+ // If either the one-shot shift is set, or if shift is being held, count as shift being held.
+ // We'll clear the one-shot shift if it was held
+ uint8_t one_shot_mods = get_oneshot_mods();
+ bool is_shift = false;
+
+ if (get_mods() & MOD_MASK_SHIFT) {
+ is_shift = true;
+ } else if (one_shot_mods & MOD_MASK_SHIFT) {
+ set_oneshot_mods(one_shot_mods & ~MOD_MASK_SHIFT);
+ is_shift = true;
+ }
+
+ if (is_paste) {
+ if (is_shift) {
+ SEND_STRING(SS_LSFT(SS_TAP(X_INSERT)));
+ } else {
+ SEND_STRING(SS_LCTRL("v"));
+ }
+ } else {
+ if (is_shift) {
+ SEND_STRING(SS_LCTRL(SS_TAP(X_INSERT)));
+ } else {
+ SEND_STRING(SS_LCTRL("c"));
+ }
+ }
+}
+
qk_tap_dance_action_t tap_dance_actions[] = {
- [TD_SYM_VIM] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, tap_dance_layer_finished, tap_dance_layer_reset)
+ [TD_SYM_VIM] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, tap_dance_sym_vim_finished, tap_dance_sym_vim_reset),
+ [TD_COPY_PASTE] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, tap_dance_copy_paste_finished, NULL)
};
void tap_dance_process_record(uint16_t keycode) {
diff --git a/users/333fred/333fred.h b/users/333fred/333fred.h
index 443930a6b..0e6c6a196 100644
--- a/users/333fred/333fred.h
+++ b/users/333fred/333fred.h
@@ -13,9 +13,10 @@
// Tap dance config shared between my keyboards
enum tap_dance_declarations {
- TD_SYM_VIM = 0
+ TD_SYM_VIM = 0,
+ TD_COPY_PASTE,
};
-void tap_dance_layer_finished(qk_tap_dance_state_t*, void*);
-void tap_dance_layer_reset(qk_tap_dance_state_t*, void*);
+void tap_dance_sym_vim_finished(qk_tap_dance_state_t*, void*);
+void tap_dance_sym_vim_reset(qk_tap_dance_state_t*, void*);
void tap_dance_process_record(uint16_t);