~ruther/qmk_firmware

e451c059296a4c9af7a476577fee64afb9965bca — tmk 12 years ago f7a445e
Fix commands
6 files changed, 64 insertions(+), 51 deletions(-)

M common/command.c
M common/command.h
M common/debug.h
M common/keyboard.c
M common/matrix.h
M common/mousekey.c
M common/command.c => common/command.c +47 -30
@@ 24,9 24,11 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#include "util.h"
#include "timer.h"
#include "keyboard.h"
#include "matrix.h"
#include "bootloader.h"
#include "command.h"
#ifdef MOUSEKEY_ENABLE
#include "mousekey.h"
#endif

#ifdef HOST_PJRC
#   include "usb_keyboard.h"


@@ 40,44 42,45 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#endif


static uint8_t command_common(void);
static bool command_common(uint8_t code);
static void help(void);
static void switch_layer(uint8_t layer);
static void clear_keyboard(void);

static bool last_print_enable;

uint8_t command_proc(void)
{
    uint8_t processed = 0;
    last_print_enable = print_enable;

bool command_proc(uint8_t code)
{
    if (!IS_COMMAND())
        return 0;
        return false;

    last_print_enable = print_enable;
    print_enable = true;
    if (command_extra() || command_common()) {
        processed = 1;
    if (command_extra(code) || command_common(code)) {
        _delay_ms(500);
        return true;
    }
    print_enable = last_print_enable;
    return processed;
    return false;
}

/* This allows to define extra commands. return 0 when not processed. */
uint8_t command_extra(void) __attribute__ ((weak));
uint8_t command_extra(void)
bool command_extra(uint8_t code) __attribute__ ((weak));
bool command_extra(uint8_t code)
{
    return 0;
    return false;
}


static uint8_t command_common(void)
static bool command_common(uint8_t code)
{
    switch (host_get_first_key()) {
    switch (code) {
        case KC_H:
            help();
            break;
        case KC_B:
        case KC_DEL:
            clear_keyboard();
            print("jump to bootloader... ");
            _delay_ms(1000);
            bootloader_jump(); // not return


@@ 179,34 182,34 @@ static uint8_t command_common(void)
#endif
            break;
#endif
        case KC_BSPC:
            matrix_init();
            print("clear matrix\n");
            break;
        case KC_0:
        case KC_F10:
            switch_layer(0);
            break;
        case KC_1:
        case KC_F1:
            switch_layer(1);
            break;
        case KC_2:
        case KC_F2:
            switch_layer(2);
            break;
        case KC_3:
        case KC_F3:
            switch_layer(3);
            break;
        case KC_4:
        case KC_F4:
            switch_layer(4);
            break;
        default:
            return 0;
            return false;
    }
    return 1;
    return true;
}

static void help(void)
{
    print("b: jump to bootloader\n");
    print("d: toggle debug enable\n");
    print("x: toggle matrix debug\n");
    print("k: toggle keyboard debug\n");


@@ 215,16 218,16 @@ static void help(void)
    print("v: print version\n");
    print("t: print timer count\n");
    print("s: print status\n");
    print("ESC: power down/wake up\n");
    print("0/F10: switch to Layer0 \n");
    print("1/F1: switch to Layer1 \n");
    print("2/F2: switch to Layer2 \n");
    print("3/F3: switch to Layer3 \n");
    print("4/F4: switch to Layer4 \n");
#ifdef NKRO_ENABLE
    print("n: toggle NKRO\n");
#endif
    print("Backspace: clear matrix\n");
    print("ESC: power down/wake up\n");
    print("0: switch to Layer0 \n");
    print("1: switch to Layer1 \n");
    print("2: switch to Layer2 \n");
    print("3: switch to Layer3 \n");
    print("4: switch to Layer4 \n");
    print("DEL: jump to bootloader\n");
}

static void switch_layer(uint8_t layer)


@@ 235,3 238,17 @@ static void switch_layer(uint8_t layer)
    default_layer = layer;
    print("switch to Layer: "); phex(layer); print("\n");
}

static void clear_keyboard(void)
{
    host_clear_keys();
    host_send_keyboard_report();

    host_system_send(0);
    host_consumer_send(0);

#ifdef MOUSEKEY_ENABLE
    mousekey_clear();
    mousekey_send();
#endif
}

M common/command.h => common/command.h +2 -2
@@ 18,8 18,8 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#ifndef COMMAND_H
#define COMMAND

uint8_t command_proc(void);
bool command_proc(uint8_t code);
/* This allows to extend commands. Return 0 when command is not processed. */
uint8_t command_extra(void);
bool command_extra(uint8_t code);

#endif

M common/debug.h => common/debug.h +2 -0
@@ 23,6 23,8 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.


#define debug(s)             if(debug_enable) print_P(PSTR(s))
#define debug_P(s)           if(debug_enable) print_P(s)
#define debug_S(s)           if(debug_enable) print_S(s)
#define debug_hex(c)         if(debug_enable) phex(c)
#define debug_hex16(i)       if(debug_enable) phex16(i)
#define debug_bin(c)         if(debug_enable) pbin(c)

M common/keyboard.c => common/keyboard.c +11 -17
@@ 28,9 28,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#ifdef MOUSEKEY_ENABLE
#include "mousekey.h"
#endif
#ifdef EXTRAKEY_ENABLE
#include <util/delay.h>
#endif


#define LAYER_DELAY     250


@@ 154,8 151,12 @@ static bool layer_switch_off(uint8_t code)
static void register_code(uint8_t code)
{
    if IS_KEY(code) {
        host_add_key(code);
        host_send_keyboard_report();
        if (command_proc(code)) {
            //clear_keyboard();
        } else {
            host_add_key(code);
            host_send_keyboard_report();
        }
    }
    else if IS_MOD(code) {
        host_add_mod_bit(MOD_BIT(code));


@@ 330,9 331,9 @@ static void unregister_code(uint8_t code)
 *      Ld: Switch back to default layer(*unregister* all keys but modifiers)
 */
#define NEXT(state)     do { \
    debug("NEXT: "); print_P(state_str(kbdstate)); \
    debug("NEXT: "); debug_P(state_str(kbdstate)); \
    kbdstate = state; \
    debug(" -> "); print_P(state_str(kbdstate)); debug("\n"); \
    debug(" -> "); debug_P(state_str(kbdstate)); debug("\n"); \
} while (0)

static inline void process_key(keyevent_t event)


@@ 342,7 343,7 @@ static inline void process_key(keyevent_t event)

    uint8_t tmp_mods;

    debug("state: "); print_P(state_str(kbdstate));
    debug("state: "); debug_P(state_str(kbdstate));
    debug(" kind: "); debug_hex(kind);
    debug(" code: "); debug_hex(code);
    if (event.pressed) { debug("d"); } else { debug("u"); }


@@ 554,18 555,11 @@ void keyboard_task(void)
    matrix_row_t matrix_change = 0;

    matrix_scan();
    if (command_proc()) {
        debug("COMMAND\n");
        // TODO: COMMAND state?
        clear_keyboard();
        return;
    }

    for (int r = 0; r < MATRIX_ROWS; r++) {
        matrix_row = matrix_get_row(r);
        matrix_change = matrix_row ^ matrix_prev[r];
        if (matrix_change) {
            if (debug_matrix) matrix_print();
            matrix_debug();

            for (int c = 0; c < MATRIX_COLS; c++) {
                if (matrix_change & (1<<c)) {


@@ 618,7 612,7 @@ void keyboard_task(void)
            current_layer = default_layer;
        }
    }
    

    return;
}


M common/matrix.h => common/matrix.h +1 -1
@@ 54,7 54,7 @@ matrix_row_t  matrix_get_row(uint8_t row);
/* count keys pressed */
uint8_t matrix_key_count(void);
/* print matrix for debug */
void matrix_print(void);
void matrix_debug(void);


#endif

M common/mousekey.c => common/mousekey.c +1 -1
@@ 103,7 103,7 @@ static uint8_t wheel_unit(void)
    if (mousekey_repeat > mk_time_to_max) {
        unit = MOUSEKEY_WHEEL_DELTA * mk_wheel_max_speed;
    } else {
        unit = (MOUSEKEY_WHEEL_DELTA * mk_wheel_max_speed * mousekey_repeat) / mk_time_to_max;
        unit = (MOUSEKEY_WHEEL_DELTA * mk_wheel_max_speed * mousekey_repeat) / mk_wheel_time_to_max;
    }
    if (unit == 0) return 1;
    return (unit > MOUSEKEY_WHEEL_MAX ? MOUSEKEY_WHEEL_MAX : unit);