support caps with shift but not with caps lock
This commit is contained in:
@ -1,3 +1,5 @@
|
||||
#include <stdbool.h>
|
||||
|
||||
#include "keyboard.h"
|
||||
#include "kprintf.h"
|
||||
#include "sys/io.h"
|
||||
@ -5,13 +7,18 @@
|
||||
|
||||
uint8_t terminal_getkey(void)
|
||||
{
|
||||
static bool caps = false;
|
||||
static uint8_t prev_scan_code = 0;
|
||||
uint8_t scan_code;
|
||||
|
||||
scan_code = inb(KEYBOARD_PORT);
|
||||
if (scan_code != prev_scan_code && prev_scan_code != 0) {
|
||||
if (scan_code == KEY_RIGHT_SHIFT || scan_code == KET_LEFT_SHIFT) // || scan_code == KEY_CAPSLOCK)
|
||||
caps = true;
|
||||
else if (scan_code == KEY_RIGHT_SHIFT + 128 || scan_code == KET_LEFT_SHIFT + 128) // || scan_code == KEY_CAPSLOCK + 128)
|
||||
caps = false;
|
||||
else if (scan_code != prev_scan_code && prev_scan_code != 0) {
|
||||
if (scan_code < 128 && keymap[scan_code])
|
||||
kprintf(0, "%c", keymap[scan_code][0]);
|
||||
kprintf(0, "%c", keymap[scan_code][caps]);
|
||||
if (scan_code >= KEY_F1 && scan_code <= KEY_F10)
|
||||
terminal_set_screen(scan_code - KEY_F1);
|
||||
}
|
||||
|
Reference in New Issue
Block a user