diff options
| author | IBNobody <ibnobody@gmail.com> | 2016-05-24 17:55:46 -0500 | 
|---|---|---|
| committer | IBNobody <ibnobody@gmail.com> | 2016-05-24 17:55:46 -0500 | 
| commit | 76e36a787a58ad0e72fac579e4a02aa66ce26be1 (patch) | |
| tree | 22eb10d93b95cfb52560a91450a29bd9aabdbc61 /tmk_core/common | |
| parent | 35d7081899df3a486b9b5785c7e8ec9481195848 (diff) | |
| parent | d66aa0abf96b5e887250cf0a7fa5e575f18c5a91 (diff) | |
| download | firmware-76e36a787a58ad0e72fac579e4a02aa66ce26be1.tar.gz firmware-76e36a787a58ad0e72fac579e4a02aa66ce26be1.tar.bz2 firmware-76e36a787a58ad0e72fac579e4a02aa66ce26be1.zip | |
Merge remote-tracking branch 'remotes/jackhumbert/master'
Diffstat (limited to 'tmk_core/common')
| -rw-r--r-- | tmk_core/common/action.c | 135 | ||||
| -rw-r--r-- | tmk_core/common/action.h | 7 | ||||
| -rw-r--r-- | tmk_core/common/action_code.h | 5 | ||||
| -rw-r--r-- | tmk_core/common/action_tapping.c | 30 | ||||
| -rw-r--r-- | tmk_core/common/action_util.c | 70 | ||||
| -rw-r--r-- | tmk_core/common/action_util.h | 20 | ||||
| -rw-r--r-- | tmk_core/common/backlight.c | 5 | ||||
| -rw-r--r-- | tmk_core/common/backlight.h | 1 | ||||
| -rw-r--r-- | tmk_core/common/command.c | 4 | ||||
| -rw-r--r-- | tmk_core/common/matrix.h | 4 | ||||
| -rw-r--r-- | tmk_core/common/nodebug.h | 12 | 
11 files changed, 240 insertions, 53 deletions
| diff --git a/tmk_core/common/action.c b/tmk_core/common/action.c index f9e6c17dc..be6dea2b7 100644 --- a/tmk_core/common/action.c +++ b/tmk_core/common/action.c @@ -46,7 +46,7 @@ void action_exec(keyevent_t event)  #ifndef NO_ACTION_TAPPING      action_tapping_process(record);  #else -    process_action(&record); +    process_record(&record);      if (!IS_NOEVENT(record.event)) {          dprint("processed: "); debug_record(record); dprintln();      } @@ -56,34 +56,32 @@ void action_exec(keyevent_t event)  #if !defined(NO_ACTION_LAYER) && defined(PREVENT_STUCK_MODIFIERS)  bool disable_action_cache = false; -void process_action_nocache(keyrecord_t *record) +void process_record_nocache(keyrecord_t *record)  {      disable_action_cache = true; -    process_action(record); +    process_record(record);      disable_action_cache = false;  }  #else -void process_action_nocache(keyrecord_t *record) +void process_record_nocache(keyrecord_t *record)  { -    process_action(record); +    process_record(record);  }  #endif  __attribute__ ((weak)) -void process_action_kb(keyrecord_t *record) {} +bool process_record_quantum(keyrecord_t *record) { +    return true; +} -void process_action(keyrecord_t *record) +void process_record(keyrecord_t *record)   { -    keyevent_t event = record->event; -#ifndef NO_ACTION_TAPPING -    uint8_t tap_count = record->tap.count; -#endif - -    if (IS_NOEVENT(event)) { return; } +    if (IS_NOEVENT(record->event)) { return; } -    process_action_kb(record); +    if(!process_record_quantum(record)) +        return; -    action_t action = store_or_get_action(event.pressed, event.key); +    action_t action = store_or_get_action(record->event.pressed, record->event.key);      dprint("ACTION: "); debug_action(action);  #ifndef NO_ACTION_LAYER      dprint(" layer_state: "); layer_debug(); @@ -91,10 +89,37 @@ void process_action(keyrecord_t *record)  #endif      dprintln(); +    process_action(record, action); +} + +void process_action(keyrecord_t *record, action_t action) +{ +    bool do_release_oneshot = false; +    keyevent_t event = record->event; +#ifndef NO_ACTION_TAPPING +    uint8_t tap_count = record->tap.count; +#endif + +#if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) +    if (has_oneshot_layer_timed_out()) { +        dprintf("Oneshot layer: timeout\n"); +        clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); +    } +#endif +      if (event.pressed) {          // clear the potential weak mods left by previously pressed keys          clear_weak_mods();      } + +#ifndef NO_ACTION_ONESHOT +    // notice we only clear the one shot layer if the pressed key is not a modifier. +    if (is_oneshot_layer_active() && event.pressed && !IS_MOD(action.key.code)) { +        clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); +        do_release_oneshot = !is_oneshot_layer_active(); +    } +#endif +      switch (action.kind.id) {          /* Key and Mods */          case ACT_LMODS: @@ -139,24 +164,37 @@ void process_action(keyrecord_t *record)                          // Oneshot modifier                          if (event.pressed) {                              if (tap_count == 0) { +                                dprint("MODS_TAP: Oneshot: 0\n");                                  register_mods(mods); -                            } -                            else if (tap_count == 1) { +                            } else if (tap_count == 1) {                                  dprint("MODS_TAP: Oneshot: start\n");                                  set_oneshot_mods(mods); -                            } -                            else { +                    #if defined(ONESHOT_TAP_TOGGLE) && ONESHOT_TAP_TOGGLE > 1 +                            } else if (tap_count == ONESHOT_TAP_TOGGLE) { +                                dprint("MODS_TAP: Toggling oneshot"); +                                clear_oneshot_mods(); +                                set_oneshot_locked_mods(mods); +                                register_mods(mods); +                    #endif +                            } else {                                  register_mods(mods);                              }                          } else {                              if (tap_count == 0) {                                  clear_oneshot_mods();                                  unregister_mods(mods); -                            } -                            else if (tap_count == 1) { +                            } else if (tap_count == 1) {                                  // Retain Oneshot mods -                            } -                            else { +                    #if defined(ONESHOT_TAP_TOGGLE) && ONESHOT_TAP_TOGGLE > 1 +                                if (mods & get_mods()) { +                                    clear_oneshot_locked_mods(); +                                    clear_oneshot_mods(); +                                    unregister_mods(mods); +                                } +                            } else if (tap_count == ONESHOT_TAP_TOGGLE) { +                                // Toggle Oneshot Layer +                    #endif +                            } else {                                  clear_oneshot_mods();                                  unregister_mods(mods);                              } @@ -309,6 +347,44 @@ void process_action(keyrecord_t *record)                      event.pressed ? layer_move(action.layer_tap.val) :                                      layer_clear();                      break; +            #ifndef NO_ACTION_ONESHOT +                case OP_ONESHOT: +                    // Oneshot modifier +                #if defined(ONESHOT_TAP_TOGGLE) && ONESHOT_TAP_TOGGLE > 1 +                    do_release_oneshot = false; +                    if (event.pressed) { +                        del_mods(get_oneshot_locked_mods()); +                        if (get_oneshot_layer_state() == ONESHOT_TOGGLED) { +                            reset_oneshot_layer(); +                            layer_off(action.layer_tap.val); +                            break; +                        } else if (tap_count < ONESHOT_TAP_TOGGLE) { +                            layer_on(action.layer_tap.val); +                            set_oneshot_layer(action.layer_tap.val, ONESHOT_START); +                        } +                    } else { +                        add_mods(get_oneshot_locked_mods()); +                        if (tap_count >= ONESHOT_TAP_TOGGLE) { +                            reset_oneshot_layer(); +                            clear_oneshot_locked_mods(); +                            set_oneshot_layer(action.layer_tap.val, ONESHOT_TOGGLED); +                        } else { +                            clear_oneshot_layer_state(ONESHOT_PRESSED); +                        } +                    } +                #else +                    if (event.pressed) { +                        layer_on(action.layer_tap.val); +                        set_oneshot_layer(action.layer_tap.val, ONESHOT_START); +                    } else { +                        clear_oneshot_layer_state(ONESHOT_PRESSED); +                        if (tap_count > 1) { +                            clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); +                        } +                    } +                #endif +                    break; +            #endif                  default:                      /* tap key */                      if (event.pressed) { @@ -372,6 +448,18 @@ void process_action(keyrecord_t *record)          default:              break;      } + +#ifndef NO_ACTION_ONESHOT +    /* Because we switch layers after a oneshot event, we need to release the +     * key before we leave the layer or no key up event will be generated. +     */ +    if (do_release_oneshot && !(get_oneshot_layer_state() & ONESHOT_PRESSED )   ) { +        record->event.pressed = false; +        layer_on(get_oneshot_layer()); +        process_record(record); +        layer_off(get_oneshot_layer()); +    } +#endif  } @@ -560,6 +648,7 @@ bool is_tap_key(keypos_t key)              switch (action.layer_tap.code) {                  case 0x00 ... 0xdf:                  case OP_TAP_TOGGLE: +                case OP_ONESHOT:                      return true;              }              return false; diff --git a/tmk_core/common/action.h b/tmk_core/common/action.h index 44ec3047b..e8aa12a7c 100644 --- a/tmk_core/common/action.h +++ b/tmk_core/common/action.h @@ -59,14 +59,15 @@ const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt);  void action_function(keyrecord_t *record, uint8_t id, uint8_t opt);  /* keyboard-specific key event (pre)processing */ -void process_action_kb(keyrecord_t *record); +bool process_record_quantum(keyrecord_t *record);  /* Utilities for actions.  */  #if !defined(NO_ACTION_LAYER) && defined(PREVENT_STUCK_MODIFIERS)  extern bool disable_action_cache;  #endif -void process_action_nocache(keyrecord_t *record); -void process_action(keyrecord_t *record); +void process_record_nocache(keyrecord_t *record); +void process_record(keyrecord_t *record); +void process_action(keyrecord_t *record, action_t action);  void register_code(uint8_t code);  void unregister_code(uint8_t code);  void register_mods(uint8_t mods); diff --git a/tmk_core/common/action_code.h b/tmk_core/common/action_code.h index 2b0b0b077..ca729aaec 100644 --- a/tmk_core/common/action_code.h +++ b/tmk_core/common/action_code.h @@ -76,7 +76,8 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.   * 101E|LLLL|1111 0001   On/Off                 (0xF1)   [NOT TAP]   * 101E|LLLL|1111 0010   Off/On                 (0xF2)   [NOT TAP]   * 101E|LLLL|1111 0011   Set/Clear              (0xF3)   [NOT TAP] - * 101E|LLLL|1111 xxxx   Reserved               (0xF4-FF) + * 101E|LLLL|1111 0100   One Shot Layer         (0xF4)   [TAP] + * 101E|LLLL|1111 xxxx   Reserved               (0xF5-FF)   *   ELLLL: layer 0-31(E: extra bit for layer 16-31)   *   * @@ -250,6 +251,7 @@ enum layer_pram_tap_op {      OP_ON_OFF,      OP_OFF_ON,      OP_SET_CLEAR, +    OP_ONESHOT,  };  #define ACTION_LAYER_BITOP(op, part, bits, on)      (ACT_LAYER<<12 | (op)<<10 | (on)<<8 | (part)<<5 | ((bits)&0x1f))  #define ACTION_LAYER_TAP(layer, key)                (ACT_LAYER_TAP<<12 | (layer)<<8 | (key)) @@ -266,6 +268,7 @@ enum layer_pram_tap_op {  #define ACTION_LAYER_ON_OFF(layer)                  ACTION_LAYER_TAP((layer), OP_ON_OFF)  #define ACTION_LAYER_OFF_ON(layer)                  ACTION_LAYER_TAP((layer), OP_OFF_ON)  #define ACTION_LAYER_SET_CLEAR(layer)               ACTION_LAYER_TAP((layer), OP_SET_CLEAR) +#define ACTION_LAYER_ONESHOT(layer)                 ACTION_LAYER_TAP((layer), OP_ONESHOT)  #define ACTION_LAYER_MODS(layer, mods)              ACTION_LAYER_TAP((layer), 0xe0 | ((mods)&0x0f))  /* With Tapping */  #define ACTION_LAYER_TAP_KEY(layer, key)            ACTION_LAYER_TAP((layer), (key)) diff --git a/tmk_core/common/action_tapping.c b/tmk_core/common/action_tapping.c index e6343e6da..ff78d7f2a 100644 --- a/tmk_core/common/action_tapping.c +++ b/tmk_core/common/action_tapping.c @@ -89,7 +89,7 @@ bool process_tapping(keyrecord_t *keyp)                      debug("Tapping: First tap(0->1).\n");                      tapping_key.tap.count = 1;                      debug_tapping_key(); -                    process_action(&tapping_key); +                    process_record(&tapping_key);                      // copy tapping state                      keyp->tap = tapping_key.tap; @@ -103,7 +103,7 @@ bool process_tapping(keyrecord_t *keyp)                   */                  else if (IS_RELEASED(event) && waiting_buffer_typed(event)) {                      debug("Tapping: End. No tap. Interfered by typing key\n"); -                    process_action(&tapping_key); +                    process_record(&tapping_key);                      tapping_key = (keyrecord_t){};                      debug_tapping_key();                      // enqueue @@ -131,7 +131,7 @@ bool process_tapping(keyrecord_t *keyp)                      }                      // Release of key should be process immediately.                      debug("Tapping: release event of a key pressed before tapping\n"); -                    process_action(keyp); +                    process_record(keyp);                      return true;                  }                  else { @@ -148,7 +148,7 @@ bool process_tapping(keyrecord_t *keyp)                  if (IS_TAPPING_KEY(event.key) && !event.pressed) {                      debug("Tapping: Tap release("); debug_dec(tapping_key.tap.count); debug(")\n");                      keyp->tap = tapping_key.tap; -                    process_action(keyp); +                    process_record(keyp);                      tapping_key = *keyp;                      debug_tapping_key();                      return true; @@ -157,7 +157,7 @@ bool process_tapping(keyrecord_t *keyp)                      if (tapping_key.tap.count > 1) {                          debug("Tapping: Start new tap with releasing last tap(>1).\n");                          // unregister key -                        process_action(&(keyrecord_t){ +                        process_record(&(keyrecord_t){                                  .tap = tapping_key.tap,                                  .event.key = tapping_key.event.key,                                  .event.time = event.time, @@ -175,7 +175,7 @@ bool process_tapping(keyrecord_t *keyp)                      if (!IS_NOEVENT(event)) {                          debug("Tapping: key event while last tap(>0).\n");                      } -                    process_action(keyp); +                    process_record(keyp);                      return true;                  }              } @@ -185,7 +185,7 @@ bool process_tapping(keyrecord_t *keyp)              if (tapping_key.tap.count == 0) {                  debug("Tapping: End. Timeout. Not tap(0): ");                  debug_event(event); debug("\n"); -                process_action(&tapping_key); +                process_record(&tapping_key);                  tapping_key = (keyrecord_t){};                  debug_tapping_key();                  return false; @@ -193,7 +193,7 @@ bool process_tapping(keyrecord_t *keyp)                  if (IS_TAPPING_KEY(event.key) && !event.pressed) {                      debug("Tapping: End. last timeout tap release(>0).");                      keyp->tap = tapping_key.tap; -                    process_action(keyp); +                    process_record(keyp);                      tapping_key = (keyrecord_t){};                      return true;                  } @@ -201,7 +201,7 @@ bool process_tapping(keyrecord_t *keyp)                      if (tapping_key.tap.count > 1) {                          debug("Tapping: Start new tap with releasing last timeout tap(>1).\n");                          // unregister key -                        process_action(&(keyrecord_t){ +                        process_record(&(keyrecord_t){                                  .tap = tapping_key.tap,                                  .event.key = tapping_key.event.key,                                  .event.time = event.time, @@ -219,7 +219,7 @@ bool process_tapping(keyrecord_t *keyp)                      if (!IS_NOEVENT(event)) {                          debug("Tapping: key event while last timeout tap(>0).\n");                      } -                    process_action(keyp); +                    process_record(keyp);                      return true;                  }              } @@ -233,7 +233,7 @@ bool process_tapping(keyrecord_t *keyp)                          keyp->tap = tapping_key.tap;                          if (keyp->tap.count < 15) keyp->tap.count += 1;                          debug("Tapping: Tap press("); debug_dec(keyp->tap.count); debug(")\n"); -                        process_action(keyp); +                        process_record(keyp);                          tapping_key = *keyp;                          debug_tapping_key();                          return true; @@ -253,12 +253,12 @@ bool process_tapping(keyrecord_t *keyp)                      // should none in buffer                      // FIX: interrupted when other key is pressed                      tapping_key.tap.interrupted = true; -                    process_action(keyp); +                    process_record(keyp);                      return true;                  }              } else {                  if (!IS_NOEVENT(event)) debug("Tapping: other key just after tap.\n"); -                process_action(keyp); +                process_record(keyp);                  return true;              }          } else { @@ -280,7 +280,7 @@ bool process_tapping(keyrecord_t *keyp)              debug_tapping_key();              return true;          } else { -            process_action(keyp); +            process_record(keyp);              return true;          }      } @@ -347,7 +347,7 @@ void waiting_buffer_scan_tap(void)                  WITHIN_TAPPING_TERM(waiting_buffer[i].event)) {              tapping_key.tap.count = 1;              waiting_buffer[i].tap.count = 1; -            process_action(&tapping_key); +            process_record(&tapping_key);              debug("waiting_buffer_scan_tap: found at ["); debug_dec(i); debug("]\n");              debug_waiting_buffer(); diff --git a/tmk_core/common/action_util.c b/tmk_core/common/action_util.c index a2d6577b2..61ff202be 100644 --- a/tmk_core/common/action_util.c +++ b/tmk_core/common/action_util.c @@ -18,6 +18,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.  #include "report.h"  #include "debug.h"  #include "action_util.h" +#include "action_layer.h"  #include "timer.h"  static inline void add_key_byte(uint8_t code); @@ -47,11 +48,70 @@ report_keyboard_t *keyboard_report = &(report_keyboard_t){};  #ifndef NO_ACTION_ONESHOT  static int8_t oneshot_mods = 0; +static int8_t oneshot_locked_mods = 0; +int8_t get_oneshot_locked_mods(void) { return oneshot_locked_mods; } +void set_oneshot_locked_mods(int8_t mods) { oneshot_locked_mods = mods; } +void clear_oneshot_locked_mods(void) { oneshot_locked_mods = 0; }  #if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0))  static int16_t oneshot_time = 0; +inline bool has_oneshot_mods_timed_out() { +  return TIMER_DIFF_16(timer_read(), oneshot_time) >= ONESHOT_TIMEOUT; +}  #endif  #endif +/* oneshot layer */ +#ifndef NO_ACTION_ONESHOT +/* oneshot_layer_data bits +* LLLL LSSS +* where: +*   L => are layer bits +*   S => oneshot state bits +*/ +static int8_t oneshot_layer_data = 0; + +inline uint8_t get_oneshot_layer(void) { return oneshot_layer_data >> 3; } +inline uint8_t get_oneshot_layer_state(void) { return oneshot_layer_data & 0b111; } + +#if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) +static int16_t oneshot_layer_time = 0; +inline bool has_oneshot_layer_timed_out() { +    return TIMER_DIFF_16(timer_read(), oneshot_layer_time) >= ONESHOT_TIMEOUT && +        !(get_oneshot_layer_state() & ONESHOT_TOGGLED); +} +#endif + +/* Oneshot layer */ +void set_oneshot_layer(uint8_t layer, uint8_t state) +{ +    oneshot_layer_data = layer << 3 | state; +    layer_on(layer); +#if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) +    oneshot_layer_time = timer_read(); +#endif +} +void reset_oneshot_layer(void) { +    oneshot_layer_data = 0; +#if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) +    oneshot_layer_time = 0; +#endif +} +void clear_oneshot_layer_state(oneshot_fullfillment_t state) +{ +    uint8_t start_state = oneshot_layer_data; +    oneshot_layer_data &= ~state; +    if (!get_oneshot_layer_state() && start_state != oneshot_layer_data) { +        layer_off(get_oneshot_layer()); +#if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) +    oneshot_layer_time = 0; +#endif +    } +} +bool is_oneshot_layer_active(void) +{ +    return get_oneshot_layer_state(); +} +#endif  void send_keyboard_report(void) {      keyboard_report->mods  = real_mods; @@ -60,7 +120,7 @@ void send_keyboard_report(void) {  #ifndef NO_ACTION_ONESHOT      if (oneshot_mods) {  #if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) -        if (TIMER_DIFF_16(timer_read(), oneshot_time) >= ONESHOT_TIMEOUT) { +        if (has_oneshot_mods_timed_out()) {              dprintf("Oneshot: timeout\n");              clear_oneshot_mods();          } @@ -70,6 +130,7 @@ void send_keyboard_report(void) {              clear_oneshot_mods();          }      } +  #endif      host_keyboard_send(keyboard_report);  } @@ -143,11 +204,12 @@ void clear_oneshot_mods(void)      oneshot_time = 0;  #endif  } +uint8_t get_oneshot_mods(void) +{ +    return oneshot_mods; +}  #endif - - -  /*   * inspect keyboard state   */ diff --git a/tmk_core/common/action_util.h b/tmk_core/common/action_util.h index 1a95cec10..dd0c4c2bf 100644 --- a/tmk_core/common/action_util.h +++ b/tmk_core/common/action_util.h @@ -56,10 +56,30 @@ void clear_macro_mods(void);  /* oneshot modifier */  void set_oneshot_mods(uint8_t mods); +uint8_t get_oneshot_mods(void);  void clear_oneshot_mods(void);  void oneshot_toggle(void);  void oneshot_enable(void);  void oneshot_disable(void); +bool has_oneshot_mods_timed_out(void); + +int8_t get_oneshot_locked_mods(void); +void set_oneshot_locked_mods(int8_t mods); +void clear_oneshot_locked_mods(void); + +typedef enum { +  ONESHOT_PRESSED = 0b01, +  ONESHOT_OTHER_KEY_PRESSED = 0b10, +  ONESHOT_START = 0b11, +  ONESHOT_TOGGLED = 0b100 +} oneshot_fullfillment_t; +void set_oneshot_layer(uint8_t layer, uint8_t state); +uint8_t get_oneshot_layer(void); +void clear_oneshot_layer_state(oneshot_fullfillment_t state); +void reset_oneshot_layer(void); +bool is_oneshot_layer_active(void); +uint8_t get_oneshot_layer_state(void); +bool has_oneshot_layer_timed_out(void);  /* inspect */  uint8_t has_anykey(void); diff --git a/tmk_core/common/backlight.c b/tmk_core/common/backlight.c index 2f6fc1cd6..c9e8fd3fd 100644 --- a/tmk_core/common/backlight.c +++ b/tmk_core/common/backlight.c @@ -83,3 +83,8 @@ void backlight_level(uint8_t level)      eeconfig_update_backlight(backlight_config.raw);      backlight_set(backlight_config.level);  } + +uint8_t get_backlight_level(void) +{ +    return backlight_config.level; +}
\ No newline at end of file diff --git a/tmk_core/common/backlight.h b/tmk_core/common/backlight.h index 525ec8bbe..f57309267 100644 --- a/tmk_core/common/backlight.h +++ b/tmk_core/common/backlight.h @@ -36,5 +36,6 @@ void backlight_toggle(void);  void backlight_step(void);  void backlight_set(uint8_t level);  void backlight_level(uint8_t level); +uint8_t get_backlight_level(void);  #endif diff --git a/tmk_core/common/command.c b/tmk_core/common/command.c index f06abaf7f..9edcc42a0 100644 --- a/tmk_core/common/command.c +++ b/tmk_core/common/command.c @@ -357,9 +357,11 @@ static bool command_common(uint8_t code)              clear_keyboard(); // clear to prevent stuck keys              print("\n\nJumping to bootloader... ");              #ifdef AUDIO_ENABLE +	            stop_all_notes();                  play_goodbye_tone(); +            #else +	            _delay_ms(1000);              #endif -            _delay_ms(1000);              bootloader_jump(); // not return              break; diff --git a/tmk_core/common/matrix.h b/tmk_core/common/matrix.h index 0b013fc98..ad0871bfb 100644 --- a/tmk_core/common/matrix.h +++ b/tmk_core/common/matrix.h @@ -64,8 +64,8 @@ void matrix_power_up(void);  void matrix_power_down(void);  /* keyboard-specific setup/loop functionality */ -void matrix_init_kb(void); -void matrix_scan_kb(void); +void matrix_init_quantum(void); +void matrix_scan_quantum(void);  #ifdef __cplusplus  } diff --git a/tmk_core/common/nodebug.h b/tmk_core/common/nodebug.h index 93309ada4..5e18656e5 100644 --- a/tmk_core/common/nodebug.h +++ b/tmk_core/common/nodebug.h @@ -16,10 +16,14 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.  */  #ifndef NODEBUG_H -#define NODEBUG_H 1 +#define NODEBUG_H -#define NO_DEBUG -#include "debug.h" -#undef NO_DEBUG +#ifndef NO_DEBUG +	#define NO_DEBUG +	#include "debug.h" +	#undef NO_DEBUG +#else +	#include "debug.h" +#endif  #endif | 
