forked from mirrors/qmk_userspace
		
	Fix commands
This commit is contained in:
		
					parent
					
						
							
								f7a445e537
							
						
					
				
			
			
				commit
				
					
						e451c05929
					
				
			
		
					 6 changed files with 64 additions and 51 deletions
				
			
		| 
						 | 
					@ -24,9 +24,11 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#include "util.h"
 | 
					#include "util.h"
 | 
				
			||||||
#include "timer.h"
 | 
					#include "timer.h"
 | 
				
			||||||
#include "keyboard.h"
 | 
					#include "keyboard.h"
 | 
				
			||||||
#include "matrix.h"
 | 
					 | 
				
			||||||
#include "bootloader.h"
 | 
					#include "bootloader.h"
 | 
				
			||||||
#include "command.h"
 | 
					#include "command.h"
 | 
				
			||||||
 | 
					#ifdef MOUSEKEY_ENABLE
 | 
				
			||||||
 | 
					#include "mousekey.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef HOST_PJRC
 | 
					#ifdef HOST_PJRC
 | 
				
			||||||
#   include "usb_keyboard.h"
 | 
					#   include "usb_keyboard.h"
 | 
				
			||||||
| 
						 | 
					@ -40,44 +42,45 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static uint8_t command_common(void);
 | 
					static bool command_common(uint8_t code);
 | 
				
			||||||
static void help(void);
 | 
					static void help(void);
 | 
				
			||||||
static void switch_layer(uint8_t layer);
 | 
					static void switch_layer(uint8_t layer);
 | 
				
			||||||
 | 
					static void clear_keyboard(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static bool last_print_enable;
 | 
					static bool last_print_enable;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
uint8_t command_proc(void)
 | 
					
 | 
				
			||||||
 | 
					bool command_proc(uint8_t code)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    uint8_t processed = 0;
 | 
					 | 
				
			||||||
    last_print_enable = print_enable;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if (!IS_COMMAND())
 | 
					    if (!IS_COMMAND())
 | 
				
			||||||
        return 0;
 | 
					        return false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    last_print_enable = print_enable;
 | 
				
			||||||
    print_enable = true;
 | 
					    print_enable = true;
 | 
				
			||||||
    if (command_extra() || command_common()) {
 | 
					    if (command_extra(code) || command_common(code)) {
 | 
				
			||||||
        processed = 1;
 | 
					 | 
				
			||||||
        _delay_ms(500);
 | 
					        _delay_ms(500);
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    print_enable = last_print_enable;
 | 
					    print_enable = last_print_enable;
 | 
				
			||||||
    return processed;
 | 
					    return false;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* This allows to define extra commands. return 0 when not processed. */
 | 
					/* This allows to define extra commands. return 0 when not processed. */
 | 
				
			||||||
uint8_t command_extra(void) __attribute__ ((weak));
 | 
					bool command_extra(uint8_t code) __attribute__ ((weak));
 | 
				
			||||||
uint8_t command_extra(void)
 | 
					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:
 | 
					        case KC_H:
 | 
				
			||||||
            help();
 | 
					            help();
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case KC_B:
 | 
					        case KC_DEL:
 | 
				
			||||||
 | 
					            clear_keyboard();
 | 
				
			||||||
            print("jump to bootloader... ");
 | 
					            print("jump to bootloader... ");
 | 
				
			||||||
            _delay_ms(1000);
 | 
					            _delay_ms(1000);
 | 
				
			||||||
            bootloader_jump(); // not return
 | 
					            bootloader_jump(); // not return
 | 
				
			||||||
| 
						 | 
					@ -179,34 +182,34 @@ static uint8_t command_common(void)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
        case KC_BSPC:
 | 
					 | 
				
			||||||
            matrix_init();
 | 
					 | 
				
			||||||
            print("clear matrix\n");
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        case KC_0:
 | 
					        case KC_0:
 | 
				
			||||||
 | 
					        case KC_F10:
 | 
				
			||||||
            switch_layer(0);
 | 
					            switch_layer(0);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case KC_1:
 | 
					        case KC_1:
 | 
				
			||||||
 | 
					        case KC_F1:
 | 
				
			||||||
            switch_layer(1);
 | 
					            switch_layer(1);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case KC_2:
 | 
					        case KC_2:
 | 
				
			||||||
 | 
					        case KC_F2:
 | 
				
			||||||
            switch_layer(2);
 | 
					            switch_layer(2);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case KC_3:
 | 
					        case KC_3:
 | 
				
			||||||
 | 
					        case KC_F3:
 | 
				
			||||||
            switch_layer(3);
 | 
					            switch_layer(3);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case KC_4:
 | 
					        case KC_4:
 | 
				
			||||||
 | 
					        case KC_F4:
 | 
				
			||||||
            switch_layer(4);
 | 
					            switch_layer(4);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
            return 0;
 | 
					            return false;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return 1;
 | 
					    return true;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void help(void)
 | 
					static void help(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    print("b: jump to bootloader\n");
 | 
					 | 
				
			||||||
    print("d: toggle debug enable\n");
 | 
					    print("d: toggle debug enable\n");
 | 
				
			||||||
    print("x: toggle matrix debug\n");
 | 
					    print("x: toggle matrix debug\n");
 | 
				
			||||||
    print("k: toggle keyboard debug\n");
 | 
					    print("k: toggle keyboard debug\n");
 | 
				
			||||||
| 
						 | 
					@ -215,16 +218,16 @@ static void help(void)
 | 
				
			||||||
    print("v: print version\n");
 | 
					    print("v: print version\n");
 | 
				
			||||||
    print("t: print timer count\n");
 | 
					    print("t: print timer count\n");
 | 
				
			||||||
    print("s: print status\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
 | 
					#ifdef NKRO_ENABLE
 | 
				
			||||||
    print("n: toggle NKRO\n");
 | 
					    print("n: toggle NKRO\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
    print("Backspace: clear matrix\n");
 | 
					    print("DEL: jump to bootloader\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");
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void switch_layer(uint8_t layer)
 | 
					static void switch_layer(uint8_t layer)
 | 
				
			||||||
| 
						 | 
					@ -235,3 +238,17 @@ static void switch_layer(uint8_t layer)
 | 
				
			||||||
    default_layer = layer;
 | 
					    default_layer = layer;
 | 
				
			||||||
    print("switch to Layer: "); phex(layer); print("\n");
 | 
					    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
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -18,8 +18,8 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#ifndef COMMAND_H
 | 
					#ifndef COMMAND_H
 | 
				
			||||||
#define COMMAND
 | 
					#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. */
 | 
					/* This allows to extend commands. Return 0 when command is not processed. */
 | 
				
			||||||
uint8_t command_extra(void);
 | 
					bool command_extra(uint8_t code);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -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(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_hex(c)         if(debug_enable) phex(c)
 | 
				
			||||||
#define debug_hex16(i)       if(debug_enable) phex16(i)
 | 
					#define debug_hex16(i)       if(debug_enable) phex16(i)
 | 
				
			||||||
#define debug_bin(c)         if(debug_enable) pbin(c)
 | 
					#define debug_bin(c)         if(debug_enable) pbin(c)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -28,9 +28,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#ifdef MOUSEKEY_ENABLE
 | 
					#ifdef MOUSEKEY_ENABLE
 | 
				
			||||||
#include "mousekey.h"
 | 
					#include "mousekey.h"
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifdef EXTRAKEY_ENABLE
 | 
					 | 
				
			||||||
#include <util/delay.h>
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define LAYER_DELAY     250
 | 
					#define LAYER_DELAY     250
 | 
				
			||||||
| 
						 | 
					@ -154,8 +151,12 @@ static bool layer_switch_off(uint8_t code)
 | 
				
			||||||
static void register_code(uint8_t code)
 | 
					static void register_code(uint8_t code)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    if IS_KEY(code) {
 | 
					    if IS_KEY(code) {
 | 
				
			||||||
        host_add_key(code);
 | 
					        if (command_proc(code)) {
 | 
				
			||||||
        host_send_keyboard_report();
 | 
					            //clear_keyboard();
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            host_add_key(code);
 | 
				
			||||||
 | 
					            host_send_keyboard_report();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    else if IS_MOD(code) {
 | 
					    else if IS_MOD(code) {
 | 
				
			||||||
        host_add_mod_bit(MOD_BIT(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)
 | 
					 *      Ld: Switch back to default layer(*unregister* all keys but modifiers)
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define NEXT(state)     do { \
 | 
					#define NEXT(state)     do { \
 | 
				
			||||||
    debug("NEXT: "); print_P(state_str(kbdstate)); \
 | 
					    debug("NEXT: "); debug_P(state_str(kbdstate)); \
 | 
				
			||||||
    kbdstate = state; \
 | 
					    kbdstate = state; \
 | 
				
			||||||
    debug(" -> "); print_P(state_str(kbdstate)); debug("\n"); \
 | 
					    debug(" -> "); debug_P(state_str(kbdstate)); debug("\n"); \
 | 
				
			||||||
} while (0)
 | 
					} while (0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static inline void process_key(keyevent_t event)
 | 
					static inline void process_key(keyevent_t event)
 | 
				
			||||||
| 
						 | 
					@ -342,7 +343,7 @@ static inline void process_key(keyevent_t event)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    uint8_t tmp_mods;
 | 
					    uint8_t tmp_mods;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    debug("state: "); print_P(state_str(kbdstate));
 | 
					    debug("state: "); debug_P(state_str(kbdstate));
 | 
				
			||||||
    debug(" kind: "); debug_hex(kind);
 | 
					    debug(" kind: "); debug_hex(kind);
 | 
				
			||||||
    debug(" code: "); debug_hex(code);
 | 
					    debug(" code: "); debug_hex(code);
 | 
				
			||||||
    if (event.pressed) { debug("d"); } else { debug("u"); }
 | 
					    if (event.pressed) { debug("d"); } else { debug("u"); }
 | 
				
			||||||
| 
						 | 
					@ -554,18 +555,11 @@ void keyboard_task(void)
 | 
				
			||||||
    matrix_row_t matrix_change = 0;
 | 
					    matrix_row_t matrix_change = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    matrix_scan();
 | 
					    matrix_scan();
 | 
				
			||||||
    if (command_proc()) {
 | 
					 | 
				
			||||||
        debug("COMMAND\n");
 | 
					 | 
				
			||||||
        // TODO: COMMAND state?
 | 
					 | 
				
			||||||
        clear_keyboard();
 | 
					 | 
				
			||||||
        return;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    for (int r = 0; r < MATRIX_ROWS; r++) {
 | 
					    for (int r = 0; r < MATRIX_ROWS; r++) {
 | 
				
			||||||
        matrix_row = matrix_get_row(r);
 | 
					        matrix_row = matrix_get_row(r);
 | 
				
			||||||
        matrix_change = matrix_row ^ matrix_prev[r];
 | 
					        matrix_change = matrix_row ^ matrix_prev[r];
 | 
				
			||||||
        if (matrix_change) {
 | 
					        if (matrix_change) {
 | 
				
			||||||
            if (debug_matrix) matrix_print();
 | 
					            matrix_debug();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            for (int c = 0; c < MATRIX_COLS; c++) {
 | 
					            for (int c = 0; c < MATRIX_COLS; c++) {
 | 
				
			||||||
                if (matrix_change & (1<<c)) {
 | 
					                if (matrix_change & (1<<c)) {
 | 
				
			||||||
| 
						 | 
					@ -618,7 +612,7 @@ void keyboard_task(void)
 | 
				
			||||||
            current_layer = default_layer;
 | 
					            current_layer = default_layer;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    
 | 
					
 | 
				
			||||||
    return;
 | 
					    return;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -54,7 +54,7 @@ matrix_row_t  matrix_get_row(uint8_t row);
 | 
				
			||||||
/* count keys pressed */
 | 
					/* count keys pressed */
 | 
				
			||||||
uint8_t matrix_key_count(void);
 | 
					uint8_t matrix_key_count(void);
 | 
				
			||||||
/* print matrix for debug */
 | 
					/* print matrix for debug */
 | 
				
			||||||
void matrix_print(void);
 | 
					void matrix_debug(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -103,7 +103,7 @@ static uint8_t wheel_unit(void)
 | 
				
			||||||
    if (mousekey_repeat > mk_time_to_max) {
 | 
					    if (mousekey_repeat > mk_time_to_max) {
 | 
				
			||||||
        unit = MOUSEKEY_WHEEL_DELTA * mk_wheel_max_speed;
 | 
					        unit = MOUSEKEY_WHEEL_DELTA * mk_wheel_max_speed;
 | 
				
			||||||
    } else {
 | 
					    } 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;
 | 
					    if (unit == 0) return 1;
 | 
				
			||||||
    return (unit > MOUSEKEY_WHEEL_MAX ? MOUSEKEY_WHEEL_MAX : unit);
 | 
					    return (unit > MOUSEKEY_WHEEL_MAX ? MOUSEKEY_WHEEL_MAX : unit);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue