Added caps lock support to readline
This commit is contained in:
parent
d9d3abbf62
commit
8f1e13e749
21
keyboard.c
21
keyboard.c
@ -1,6 +1,5 @@
|
||||
#include "keyboard.h"
|
||||
|
||||
|
||||
char key_to_char[128] = {
|
||||
0, 0, '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', 0, 0,
|
||||
'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', 0,
|
||||
@ -60,9 +59,8 @@ void readline(int max, char* buffer) {
|
||||
int index = 0;
|
||||
|
||||
|
||||
uint8_t scancode = current_scancode;
|
||||
while (scancode != 0x1c || index == 0) {
|
||||
while (scancode == current_scancode);
|
||||
uint8_t scancode = 0;
|
||||
while (scancode != 0x1c && index < max) {
|
||||
scancode = current_scancode;
|
||||
|
||||
char decoded = 0;
|
||||
@ -70,21 +68,28 @@ void readline(int max, char* buffer) {
|
||||
if ((scancode&0x7f) == 0x2a)
|
||||
shift_on = !(scancode&0x80);
|
||||
|
||||
if (scancode == 0x3a)
|
||||
caps_on ^= 1;
|
||||
|
||||
if (scancode == 0x0e && index > 0) {
|
||||
set_curpos_raw(get_curpos()-1);
|
||||
non_moving_put(' ');
|
||||
index--;
|
||||
buffer[--index] = 0;
|
||||
}
|
||||
|
||||
if (!shift_on)
|
||||
decoded = key_to_char[scancode&0x7f];
|
||||
else
|
||||
if (shift_on)
|
||||
decoded = key_to_char_shift[scancode&0x7f];
|
||||
else if (caps_on)
|
||||
decoded = key_to_char_caps[scancode&0x7f];
|
||||
else
|
||||
decoded = key_to_char[scancode&0x7f];
|
||||
|
||||
if (decoded && scancode < 0x80) {
|
||||
buffer[index++] = decoded;
|
||||
printf("%c", decoded);
|
||||
}
|
||||
|
||||
while (scancode == current_scancode);
|
||||
}
|
||||
printf("\n");
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user