diff options
Diffstat (limited to 'quantum')
| -rw-r--r-- | quantum/keymap_common.c | 2 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_bepo.h | 4 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_dvorak.h | 15 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_fr_ch.h | 2 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_french.h | 4 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_german.h | 2 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_german_ch.h | 2 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_nordic.h | 4 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_norwegian.h | 2 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_spanish.h | 2 | ||||
| -rw-r--r-- | quantum/keymap_extras/keymap_uk.h | 4 | ||||
| -rw-r--r-- | quantum/process_keycode/process_midi.c | 24 | ||||
| -rw-r--r-- | quantum/process_keycode/process_music.c | 7 | ||||
| -rw-r--r-- | quantum/process_keycode/process_tap_dance.c | 93 | ||||
| -rw-r--r-- | quantum/process_keycode/process_tap_dance.h | 46 | 
15 files changed, 129 insertions, 84 deletions
| diff --git a/quantum/keymap_common.c b/quantum/keymap_common.c index d0a8312c1..833e5a8f8 100644 --- a/quantum/keymap_common.c +++ b/quantum/keymap_common.c @@ -30,7 +30,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.  #include "quantum.h"  #ifdef MIDI_ENABLE -	#include "keymap_midi.h" +	#include "process_midi.h"  #endif  extern keymap_config_t keymap_config; diff --git a/quantum/keymap_extras/keymap_bepo.h b/quantum/keymap_extras/keymap_bepo.h index 4c3096054..e5ef39552 100644 --- a/quantum/keymap_extras/keymap_bepo.h +++ b/quantum/keymap_extras/keymap_bepo.h @@ -118,7 +118,7 @@  // Fourth row  #define BP_COLON    LSFT(BP_DOT)    // :  #define BP_COLN     BP_COLON -#define BP_QUESTION LSFT(BP_QUOTE)  // ? +#define BP_QUESTION LSFT(BP_APOS)  // ?  #define BP_QEST     BP_QUESTION  // Space bar @@ -183,7 +183,7 @@  // Third row  #define BP_AE_LIGATURE              ALTGR(BP_A)         // æ  #define BP_AE                       BP_AE_LIGATURE -#define BP_U_GRAVE                  AGR(BP_U)           // ù +#define BP_U_GRAVE                  ALTGR(BP_U)           // ù  #define BP_UGRV                     BP_U_GRAVE  #define BP_DEAD_TREMA               ALTGR(BP_I)         // dead ¨ (trema/umlaut/diaresis)  #define BP_DTRM                     BP_DEAD_TREMA diff --git a/quantum/keymap_extras/keymap_dvorak.h b/quantum/keymap_extras/keymap_dvorak.h index e855056e8..17f205977 100644 --- a/quantum/keymap_extras/keymap_dvorak.h +++ b/quantum/keymap_extras/keymap_dvorak.h @@ -18,18 +18,19 @@  #define DV_LBRC	KC_MINS  #define DV_RBRC	KC_EQL -#define DV_QUOT KC_Q +#define DV_QUOT	KC_Q  #define DV_COMM	KC_W  #define DV_DOT	KC_E  #define DV_P	KC_R  #define DV_Y	KC_T  #define	DV_F	KC_Y  #define DV_G	KC_U -#define DV_C 	KC_I +#define DV_C	KC_I  #define	DV_R	KC_O  #define DV_L	KC_P  #define DV_SLSH	KC_LBRC  #define DV_EQL	KC_RBRC +#define DV_BSLS	KC_BSLS  #define DV_A	KC_A  #define DV_O	KC_S @@ -68,7 +69,13 @@  #define DV_RPRN	LSFT(DV_0)  #define DV_LCBR	LSFT(DV_LBRC)  #define DV_RCBR	LSFT(DV_RBRC) -#define DV_UNDS LSFT(DV_MINS) -#define DV_PLUS LSFT(DV_EQL) + +#define DV_QUES	LSFT(DV_SLSH) +#define DV_PLUS	LSFT(DV_EQL) +#define DV_PIPE	LSFT(DV_BSLS) + +#define DV_UNDS	LSFT(DV_MINS) + +#define DV_COLN	LSFT(DV_SCLN)  #endif diff --git a/quantum/keymap_extras/keymap_fr_ch.h b/quantum/keymap_extras/keymap_fr_ch.h index 3fd971357..87d4bb24c 100644 --- a/quantum/keymap_extras/keymap_fr_ch.h +++ b/quantum/keymap_extras/keymap_fr_ch.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define FR_CH_ALGR KC_RALT  // normal characters diff --git a/quantum/keymap_extras/keymap_french.h b/quantum/keymap_extras/keymap_french.h index 2a44c80b1..834c69650 100644 --- a/quantum/keymap_extras/keymap_french.h +++ b/quantum/keymap_extras/keymap_french.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define NO_ALGR KC_RALT  // Normal characters @@ -80,4 +80,4 @@  #define FR_EURO	ALGR(KC_E)  #define FR_BULT	ALGR(FR_DLR) -#endif
\ No newline at end of file +#endif diff --git a/quantum/keymap_extras/keymap_german.h b/quantum/keymap_extras/keymap_german.h index 3f9ae8bad..7e2e0ed44 100644 --- a/quantum/keymap_extras/keymap_german.h +++ b/quantum/keymap_extras/keymap_german.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define DE_ALGR KC_RALT  // normal characters diff --git a/quantum/keymap_extras/keymap_german_ch.h b/quantum/keymap_extras/keymap_german_ch.h index 6a782bcd7..b66d582a4 100644 --- a/quantum/keymap_extras/keymap_german_ch.h +++ b/quantum/keymap_extras/keymap_german_ch.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define CH_ALGR KC_RALT  // normal characters diff --git a/quantum/keymap_extras/keymap_nordic.h b/quantum/keymap_extras/keymap_nordic.h index 3acb8b698..da5c82975 100644 --- a/quantum/keymap_extras/keymap_nordic.h +++ b/quantum/keymap_extras/keymap_nordic.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define NO_ALGR KC_RALT  // Normal characters @@ -25,7 +25,7 @@  #define NO_SECT LSFT(NO_HALF)  #define NO_QUO2	LSFT(KC_2)  #define NO_BULT LSFT(KC_4) -#define NO_AMP	LSFT(KC_6) +#define NO_AMPR	LSFT(KC_6)  #define NO_SLSH LSFT(KC_7)  #define NO_LPRN	LSFT(KC_8)  #define NO_RPRN	LSFT(KC_9) diff --git a/quantum/keymap_extras/keymap_norwegian.h b/quantum/keymap_extras/keymap_norwegian.h index 018bfeae5..5c4e8c495 100644 --- a/quantum/keymap_extras/keymap_norwegian.h +++ b/quantum/keymap_extras/keymap_norwegian.h @@ -13,7 +13,7 @@  #undef NO_BSLS  #define NO_BSLS KC_EQL  // '\'  #undef NO_CIRC -#define NO_CIRC LSFT(C_RBRC)  // ^ +#define NO_CIRC LSFT(KC_RBRC)  // ^  #undef NO_GRV  #define NO_GRV	LSFT(NO_BSLS)  //  #undef NO_OSLH diff --git a/quantum/keymap_extras/keymap_spanish.h b/quantum/keymap_extras/keymap_spanish.h index af76e39fc..4ba568af2 100644 --- a/quantum/keymap_extras/keymap_spanish.h +++ b/quantum/keymap_extras/keymap_spanish.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define NO_ALGR KC_RALT  // Normal characters diff --git a/quantum/keymap_extras/keymap_uk.h b/quantum/keymap_extras/keymap_uk.h index 5c5d95179..00c87afc3 100644 --- a/quantum/keymap_extras/keymap_uk.h +++ b/quantum/keymap_extras/keymap_uk.h @@ -4,7 +4,7 @@  #include "keymap.h"  // Alt gr -#define ALGR(kc) kc | 0x1400 +#define ALGR(kc) RALT(kc)  #define NO_ALGR KC_RALT  // Normal characters @@ -33,4 +33,4 @@  #define UK_AACT ALGR(KC_A) -#endif
\ No newline at end of file +#endif diff --git a/quantum/process_keycode/process_midi.c b/quantum/process_keycode/process_midi.c index d6ab9c626..8784e64f3 100644 --- a/quantum/process_keycode/process_midi.c +++ b/quantum/process_keycode/process_midi.c @@ -1,8 +1,8 @@  #include "process_midi.h"  bool midi_activated = false; -uint8_t starting_note = 0x0C; -int offset = 7; +uint8_t midi_starting_note = 0x0C; +int midi_offset = 7;  bool process_midi(uint16_t keycode, keyrecord_t *record) {      if (keycode == MI_ON && record->event.pressed) { @@ -20,42 +20,42 @@ bool process_midi(uint16_t keycode, keyrecord_t *record) {      if (midi_activated) {        if (record->event.key.col == (MATRIX_COLS - 1) && record->event.key.row == (MATRIX_ROWS - 1)) {            if (record->event.pressed) { -              starting_note++; // Change key +              midi_starting_note++; // Change key                midi_send_cc(&midi_device, 0, 0x7B, 0);            }            return false;        }        if (record->event.key.col == (MATRIX_COLS - 2) && record->event.key.row == (MATRIX_ROWS - 1)) {            if (record->event.pressed) { -              starting_note--; // Change key +              midi_starting_note--; // Change key                midi_send_cc(&midi_device, 0, 0x7B, 0);            }            return false;        }        if (record->event.key.col == (MATRIX_COLS - 3) && record->event.key.row == (MATRIX_ROWS - 1) && record->event.pressed) { -          offset++; // Change scale +          midi_offset++; // Change scale            midi_send_cc(&midi_device, 0, 0x7B, 0);            return false;        }        if (record->event.key.col == (MATRIX_COLS - 4) && record->event.key.row == (MATRIX_ROWS - 1) && record->event.pressed) { -          offset--; // Change scale +          midi_offset--; // Change scale            midi_send_cc(&midi_device, 0, 0x7B, 0);            return false;        }        // basic -      // uint8_t note = (starting_note + SCALE[record->event.key.col + offset])+12*(MATRIX_ROWS - record->event.key.row); +      // uint8_t note = (midi_starting_note + SCALE[record->event.key.col + midi_offset])+12*(MATRIX_ROWS - record->event.key.row);        // advanced -      // uint8_t note = (starting_note + record->event.key.col + offset)+12*(MATRIX_ROWS - record->event.key.row); +      // uint8_t note = (midi_starting_note + record->event.key.col + midi_offset)+12*(MATRIX_ROWS - record->event.key.row);        // guitar -      uint8_t note = (starting_note + record->event.key.col + offset)+5*(MATRIX_ROWS - record->event.key.row); +      uint8_t note = (midi_starting_note + record->event.key.col + midi_offset)+5*(MATRIX_ROWS - record->event.key.row);        // violin -      // uint8_t note = (starting_note + record->event.key.col + offset)+7*(MATRIX_ROWS - record->event.key.row); +      // uint8_t note = (midi_starting_note + record->event.key.col + midi_offset)+7*(MATRIX_ROWS - record->event.key.row);        if (record->event.pressed) { -        // midi_send_noteon(&midi_device, record->event.key.row, starting_note + SCALE[record->event.key.col], 127); +        // midi_send_noteon(&midi_device, record->event.key.row, midi_starting_note + SCALE[record->event.key.col], 127);          midi_send_noteon(&midi_device, 0, note, 127);        } else { -        // midi_send_noteoff(&midi_device, record->event.key.row, starting_note + SCALE[record->event.key.col], 127); +        // midi_send_noteoff(&midi_device, record->event.key.row, midi_starting_note + SCALE[record->event.key.col], 127);          midi_send_noteoff(&midi_device, 0, note, 127);        } diff --git a/quantum/process_keycode/process_music.c b/quantum/process_keycode/process_music.c index c8f3ddb90..2d52e47a7 100644 --- a/quantum/process_keycode/process_music.c +++ b/quantum/process_keycode/process_music.c @@ -6,6 +6,7 @@ int offset = 7;  // music sequencer  static bool music_sequence_recording = false; +static bool music_sequence_recorded = false;  static bool music_sequence_playing = false;  static float music_sequence[16] = {0};  static uint8_t music_sequence_count = 0; @@ -77,6 +78,7 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {        if (keycode == KC_LCTL && record->event.pressed) { // Start recording          stop_all_notes();          music_sequence_recording = true; +        music_sequence_recorded = false;          music_sequence_playing = false;          music_sequence_count = 0;          return false; @@ -84,12 +86,15 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {        if (keycode == KC_LALT && record->event.pressed) { // Stop recording/playing          stop_all_notes(); +        if (music_sequence_recording) { // was recording +          music_sequence_recorded = true; +        }          music_sequence_recording = false;          music_sequence_playing = false;          return false;        } -      if (keycode == KC_LGUI && record->event.pressed) { // Start playing +      if (keycode == KC_LGUI && record->event.pressed && music_sequence_recorded) { // Start playing          stop_all_notes();          music_sequence_recording = false;          music_sequence_playing = true; diff --git a/quantum/process_keycode/process_tap_dance.c b/quantum/process_keycode/process_tap_dance.c index 9b172e1b6..d240dc2e6 100644 --- a/quantum/process_keycode/process_tap_dance.c +++ b/quantum/process_keycode/process_tap_dance.c @@ -2,61 +2,70 @@  static qk_tap_dance_state_t qk_tap_dance_state; -static void _process_tap_dance_action_pair (qk_tap_dance_state_t *state, -                                            uint16_t kc1, uint16_t kc2) { -  uint16_t kc; +void qk_tap_dance_pair_finished (qk_tap_dance_state_t *state, void *user_data) { +  qk_tap_dance_pair_t *pair = (qk_tap_dance_pair_t *)user_data; -  if (state->count == 0) -    return; - -  kc = (state->count == 1) ? kc1 : kc2; +  if (state->count == 1) { +    register_code (pair->kc1); +  } else if (state->count == 2) { +    register_code (pair->kc2); +  } +} -  register_code (kc); -  unregister_code (kc); +void qk_tap_dance_pair_reset (qk_tap_dance_state_t *state, void *user_data) { +  qk_tap_dance_pair_t *pair = (qk_tap_dance_pair_t *)user_data; -  if (state->count >= 2) { -    reset_tap_dance (state); +  if (state->count == 1) { +    unregister_code (pair->kc1); +  } else if (state->count == 2) { +    unregister_code (pair->kc2);    }  } -static void _process_tap_dance_action_fn (qk_tap_dance_state_t *state, +static inline void _process_tap_dance_action_fn (qk_tap_dance_state_t *state, +                                          void *user_data,                                            qk_tap_dance_user_fn_t fn)  { -  fn(state); +  if (fn) { +    fn(state, user_data); +  }  } -void process_tap_dance_action (uint16_t keycode) +static inline void process_tap_dance_action_on_each_tap (qk_tap_dance_action_t action)  { -  uint16_t idx = keycode - QK_TAP_DANCE; -  qk_tap_dance_action_t action; - -  action = tap_dance_actions[idx]; +  _process_tap_dance_action_fn (&qk_tap_dance_state, action.user_data, action.fn.on_each_tap); +} -  switch (action.type) { -  case QK_TAP_DANCE_TYPE_PAIR: -    _process_tap_dance_action_pair (&qk_tap_dance_state, -                                    action.pair.kc1, action.pair.kc2); -    break; -  case QK_TAP_DANCE_TYPE_FN: -    _process_tap_dance_action_fn (&qk_tap_dance_state, action.fn); -    break; +static inline void process_tap_dance_action_on_dance_finished (qk_tap_dance_action_t action) +{ +  _process_tap_dance_action_fn (&qk_tap_dance_state, action.user_data, action.fn.on_dance_finished); +} -  default: -    break; -  } +static inline void process_tap_dance_action_on_reset (qk_tap_dance_action_t action) +{ +  _process_tap_dance_action_fn (&qk_tap_dance_state, action.user_data, action.fn.on_reset);  }  bool process_tap_dance(uint16_t keycode, keyrecord_t *record) {    bool r = true; +  uint16_t idx = keycode - QK_TAP_DANCE; +  qk_tap_dance_action_t action;    switch(keycode) {    case QK_TAP_DANCE ... QK_TAP_DANCE_MAX: +    action = tap_dance_actions[idx]; + +    process_tap_dance_action_on_each_tap (action);      if (qk_tap_dance_state.keycode && qk_tap_dance_state.keycode != keycode) { -      process_tap_dance_action (qk_tap_dance_state.keycode); +      process_tap_dance_action_on_dance_finished (action); +    } else if (qk_tap_dance_state.active && qk_tap_dance_state.pressed) { +      reset_tap_dance (&qk_tap_dance_state);      } else {        r = false;      } +    qk_tap_dance_state.active = true; +    qk_tap_dance_state.pressed = record->event.pressed;      if (record->event.pressed) {        qk_tap_dance_state.keycode = keycode;        qk_tap_dance_state.timer = timer_read (); @@ -66,9 +75,14 @@ bool process_tap_dance(uint16_t keycode, keyrecord_t *record) {    default:      if (qk_tap_dance_state.keycode) { -      process_tap_dance_action (qk_tap_dance_state.keycode); +      // if we are here, the tap dance was interrupted by a different key +      idx = qk_tap_dance_state.keycode - QK_TAP_DANCE; +      action = tap_dance_actions[idx]; +      process_tap_dance_action_on_each_tap (action); +      process_tap_dance_action_on_dance_finished (action);        reset_tap_dance (&qk_tap_dance_state); +      qk_tap_dance_state.active = false;      }      break;    } @@ -77,14 +91,27 @@ bool process_tap_dance(uint16_t keycode, keyrecord_t *record) {  }  void matrix_scan_tap_dance () { -  if (qk_tap_dance_state.keycode && timer_elapsed (qk_tap_dance_state.timer) > TAPPING_TERM) { -    process_tap_dance_action (qk_tap_dance_state.keycode); +  if (qk_tap_dance_state.active && timer_elapsed (qk_tap_dance_state.timer) > TAPPING_TERM) { +    // if we are here, the tap dance was timed out +    uint16_t idx = qk_tap_dance_state.keycode - QK_TAP_DANCE; +    qk_tap_dance_action_t action = tap_dance_actions[idx]; +    process_tap_dance_action_on_dance_finished (action);      reset_tap_dance (&qk_tap_dance_state);    }  }  void reset_tap_dance (qk_tap_dance_state_t *state) { +  uint16_t idx = state->keycode - QK_TAP_DANCE; +  qk_tap_dance_action_t action; + +  if (state->pressed) +    return; + +  action = tap_dance_actions[idx]; +  process_tap_dance_action_on_reset (action); +    state->keycode = 0;    state->count = 0; +  state->active = false;  } diff --git a/quantum/process_keycode/process_tap_dance.h b/quantum/process_keycode/process_tap_dance.h index b9d7c7fcf..e2c74efe9 100644 --- a/quantum/process_keycode/process_tap_dance.h +++ b/quantum/process_keycode/process_tap_dance.h @@ -11,38 +11,41 @@ typedef struct    uint8_t count;    uint16_t keycode;    uint16_t timer; +  bool active:1; +  bool pressed:1;  } qk_tap_dance_state_t;  #define TD(n) (QK_TAP_DANCE + n) -typedef enum -{ -  QK_TAP_DANCE_TYPE_PAIR, -  QK_TAP_DANCE_TYPE_FN, -} qk_tap_dance_type_t; - -typedef void (*qk_tap_dance_user_fn_t) (qk_tap_dance_state_t *state); +typedef void (*qk_tap_dance_user_fn_t) (qk_tap_dance_state_t *state, void *user_data);  typedef struct  { -  qk_tap_dance_type_t type; -  union { -    struct { -      uint16_t kc1; -      uint16_t kc2; -    } pair; -    qk_tap_dance_user_fn_t fn; -  }; +  struct { +    qk_tap_dance_user_fn_t on_each_tap; +    qk_tap_dance_user_fn_t on_dance_finished; +    qk_tap_dance_user_fn_t on_reset; +  } fn; +  void *user_data;  } qk_tap_dance_action_t; +typedef struct +{ +  uint16_t kc1; +  uint16_t kc2; +} qk_tap_dance_pair_t; +  #define ACTION_TAP_DANCE_DOUBLE(kc1, kc2) { \ -    .type = QK_TAP_DANCE_TYPE_PAIR,         \ -    .pair = { kc1, kc2 }                    \ +    .fn = { NULL, qk_tap_dance_pair_finished, qk_tap_dance_pair_reset }, \ +    .user_data = (void *)&((qk_tap_dance_pair_t) { kc1, kc2 })  \ +  } + +#define ACTION_TAP_DANCE_FN(user_fn) {  \ +    .fn = { NULL, user_fn, NULL } \    } -#define ACTION_TAP_DANCE_FN(user_fn) { \ -    .type = QK_TAP_DANCE_TYPE_FN, \ -    .fn = user_fn                 \ +#define ACTION_TAP_DANCE_FN_ADVANCED(user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_reset) { \ +    .fn = { user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_reset } \    }  extern const qk_tap_dance_action_t tap_dance_actions[]; @@ -53,6 +56,9 @@ bool process_tap_dance(uint16_t keycode, keyrecord_t *record);  void matrix_scan_tap_dance (void);  void reset_tap_dance (qk_tap_dance_state_t *state); +void qk_tap_dance_pair_finished (qk_tap_dance_state_t *state, void *user_data); +void qk_tap_dance_pair_reset (qk_tap_dance_state_t *state, void *user_data); +  #else  #define TD(n) KC_NO | 
