Add mechanical locking switch support for NumLock and ScrollLock
This commit is contained in:
		
							parent
							
								
									5b425731c5
								
							
						
					
					
						commit
						2721022078
					
				
					 7 changed files with 75 additions and 28 deletions
				
			
		| 
						 | 
				
			
			@ -336,9 +336,10 @@ void register_code(uint8_t code)
 | 
			
		|||
    if (code == KC_NO) {
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
#ifdef CAPSLOCK_LOCKING_ENABLE
 | 
			
		||||
 | 
			
		||||
#ifdef LOCKING_SUPPORT_ENABLE
 | 
			
		||||
    else if (KC_LOCKING_CAPS == code) {
 | 
			
		||||
#ifdef CAPSLOCK_LOCKING_RESYNC_ENABLE
 | 
			
		||||
#ifdef LOCKING_RESYNC_ENABLE
 | 
			
		||||
        // Resync: ignore if caps lock already is on
 | 
			
		||||
        if (host_keyboard_leds() & (1<<USB_LED_CAPS_LOCK)) return;
 | 
			
		||||
#endif
 | 
			
		||||
| 
						 | 
				
			
			@ -347,7 +348,28 @@ void register_code(uint8_t code)
 | 
			
		|||
        host_del_key(KC_CAPSLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    else if (KC_LOCKING_NUM == code) {
 | 
			
		||||
#ifdef LOCKING_RESYNC_ENABLE
 | 
			
		||||
        if (host_keyboard_leds() & (1<<USB_LED_NUM_LOCK)) return;
 | 
			
		||||
#endif
 | 
			
		||||
        host_add_key(KC_NUMLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
        host_del_key(KC_NUMLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    else if (KC_LOCKING_SCROLL == code) {
 | 
			
		||||
#ifdef LOCKING_RESYNC_ENABLE
 | 
			
		||||
        if (host_keyboard_leds() & (1<<USB_LED_SCROLL_LOCK)) return;
 | 
			
		||||
#endif
 | 
			
		||||
        host_add_key(KC_SCROLLLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
        host_del_key(KC_SCROLLLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
    }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    else if IS_KEY(code) {
 | 
			
		||||
        // TODO: should push command_proc out of this block?
 | 
			
		||||
        if (command_proc(code)) return;
 | 
			
		||||
| 
						 | 
				
			
			@ -386,9 +408,10 @@ void unregister_code(uint8_t code)
 | 
			
		|||
    if (code == KC_NO) {
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
#ifdef CAPSLOCK_LOCKING_ENABLE
 | 
			
		||||
 | 
			
		||||
#ifdef LOCKING_SUPPORT_ENABLE
 | 
			
		||||
    else if (KC_LOCKING_CAPS == code) {
 | 
			
		||||
#ifdef CAPSLOCK_LOCKING_RESYNC_ENABLE
 | 
			
		||||
#ifdef LOCKING_RESYNC_ENABLE
 | 
			
		||||
        // Resync: ignore if caps lock already is off
 | 
			
		||||
        if (!(host_keyboard_leds() & (1<<USB_LED_CAPS_LOCK))) return;
 | 
			
		||||
#endif
 | 
			
		||||
| 
						 | 
				
			
			@ -397,7 +420,28 @@ void unregister_code(uint8_t code)
 | 
			
		|||
        host_del_key(KC_CAPSLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    else if (KC_LOCKING_NUM == code) {
 | 
			
		||||
#ifdef LOCKING_RESYNC_ENABLE
 | 
			
		||||
        if (!(host_keyboard_leds() & (1<<USB_LED_NUM_LOCK))) return;
 | 
			
		||||
#endif
 | 
			
		||||
        host_add_key(KC_NUMLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
        host_del_key(KC_NUMLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    else if (KC_LOCKING_SCROLL == code) {
 | 
			
		||||
#ifdef LOCKING_RESYNC_ENABLE
 | 
			
		||||
        if (!(host_keyboard_leds() & (1<<USB_LED_SCROLL_LOCK))) return;
 | 
			
		||||
#endif
 | 
			
		||||
        host_add_key(KC_SCROLLLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
        host_del_key(KC_SCROLLLOCK);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
    }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    else if IS_KEY(code) {
 | 
			
		||||
        host_del_key(code);
 | 
			
		||||
        host_send_keyboard_report();
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -60,10 +60,11 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
#define KC_DEL  KC_DELETE
 | 
			
		||||
#define KC_INS  KC_INSERT
 | 
			
		||||
#define KC_CAPS KC_CAPSLOCK
 | 
			
		||||
#define KC_CLCK KC_CAPSLOCK
 | 
			
		||||
#define KC_RGHT KC_RIGHT
 | 
			
		||||
#define KC_PGDN KC_PGDOWN
 | 
			
		||||
#define KC_PSCR KC_PSCREEN
 | 
			
		||||
#define KC_SLCK KC_SCKLOCK
 | 
			
		||||
#define KC_SLCK KC_SCROLLLOCK
 | 
			
		||||
#define KC_PAUS KC_PAUSE
 | 
			
		||||
#define KC_BRK  KC_PAUSE
 | 
			
		||||
#define KC_NLCK KC_NUMLOCK
 | 
			
		||||
| 
						 | 
				
			
			@ -82,6 +83,8 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
#define KC_NUHS KC_NONUS_HASH
 | 
			
		||||
#define KC_NUBS KC_NONUS_BSLASH
 | 
			
		||||
#define KC_LCAP KC_LOCKING_CAPS
 | 
			
		||||
#define KC_LNUM KC_LOCKING_NUM
 | 
			
		||||
#define KC_LSCR KC_LOCKING_SCROLL
 | 
			
		||||
#define KC_ERAS KC_ALT_ERASE,
 | 
			
		||||
#define KC_CLR  KC_CLEAR
 | 
			
		||||
/* Japanese specific */
 | 
			
		||||
| 
						 | 
				
			
			@ -230,7 +233,7 @@ enum hid_keyboard_keypad_usage {
 | 
			
		|||
    KC_F11,
 | 
			
		||||
    KC_F12,
 | 
			
		||||
    KC_PSCREEN,
 | 
			
		||||
    KC_SCKLOCK,
 | 
			
		||||
    KC_SCROLLLOCK,
 | 
			
		||||
    KC_PAUSE,
 | 
			
		||||
    KC_INSERT,
 | 
			
		||||
    KC_HOME,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue