Merge branch 'shell' into BetterMemory
This commit is contained in:
commit
e854a92753
|
@ -28,37 +28,44 @@
|
||||||
|
|
||||||
#include "scan.c"
|
#include "scan.c"
|
||||||
|
|
||||||
static bool capsLockActive = 0;
|
#define KEY(code) (table[2*(code)])
|
||||||
static bool leftAltPressed = 0;
|
#define FLAGS(code) (table[2*(code)+1])
|
||||||
static bool leftShiftPressed = 0;
|
|
||||||
static bool leftControlPressed = 0;
|
|
||||||
|
|
||||||
void KeybPrint(uchar _code)
|
static bool capsLockActive = 0;
|
||||||
|
static bool altPressed = 0;
|
||||||
|
static bool shiftPressed = 0;
|
||||||
|
static bool controlPressed = 0;
|
||||||
|
|
||||||
|
static void KeybPrint(uchar _code)
|
||||||
{
|
{
|
||||||
uint code = (uint)_code;
|
uint code = (uint)_code;
|
||||||
|
|
||||||
const uint *table =
|
const uint *table =
|
||||||
(leftAltPressed ? LeftAltScanCodes
|
(altPressed ? LeftAltScanCodes
|
||||||
: (leftShiftPressed ? LeftShiftScanCodes
|
: (controlPressed ? LeftControlScanCodes
|
||||||
: (leftControlPressed ? LeftControlScanCodes
|
: (shiftPressed ? LeftShiftScanCodes
|
||||||
: RegularScanCodes)));
|
: RegularScanCodes)));
|
||||||
|
|
||||||
if (capsLockActive && !leftShiftPressed &&
|
if ((capsLockActive && (FLAGS(code) & CAPSLOCK))
|
||||||
!!(table[2 * code + 1] & CAPSLOCK) && !leftAltPressed)
|
&& !(altPressed || controlPressed)) {
|
||||||
|
if (shiftPressed)
|
||||||
|
table = RegularScanCodes;
|
||||||
|
else
|
||||||
table = LeftShiftScanCodes;
|
table = LeftShiftScanCodes;
|
||||||
|
}
|
||||||
|
|
||||||
uchar ch = table[2 * code];
|
uchar ch = KEY(code);
|
||||||
|
|
||||||
if (!ch) {
|
if (!ch) {
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case 0x38: leftAltPressed = 1; break;
|
case 0x38: altPressed = 1; break;
|
||||||
case 0xB8: leftAltPressed = 0; break;
|
case 0xB8: altPressed = 0; break;
|
||||||
|
|
||||||
case 0x36: case 0x2A: leftShiftPressed = 1; break;
|
case 0x36: case 0x2A: shiftPressed = 1; break;
|
||||||
case 0xB6: case 0xAA: leftShiftPressed = 0; break;
|
case 0xB6: case 0xAA: shiftPressed = 0; break;
|
||||||
|
|
||||||
case 0x1D: leftControlPressed = 1; break;
|
case 0x1D: controlPressed = 1; break;
|
||||||
case 0x9D: leftControlPressed = 0; break;
|
case 0x9D: controlPressed = 0; break;
|
||||||
|
|
||||||
case 0x3A: capsLockActive = !capsLockActive; break;
|
case 0x3A: capsLockActive = !capsLockActive; break;
|
||||||
}
|
}
|
||||||
|
@ -66,7 +73,7 @@ void KeybPrint(uchar _code)
|
||||||
}
|
}
|
||||||
|
|
||||||
bputc(BStdIn, ch);
|
bputc(BStdIn, ch);
|
||||||
if (code && (table[2 * code + 1] & INVISIBLE) == 0) {
|
if (code && (FLAGS(code) & INVISIBLE) == 0) {
|
||||||
bputc(BStdOut, table[2 * code]);
|
bputc(BStdOut, table[2 * code]);
|
||||||
BStdOut->flusher(BStdOut);
|
BStdOut->flusher(BStdOut);
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,7 +94,10 @@ const uint RegularScanCodes[2 * 256] =
|
||||||
ENTRY (0x33, ';', CAPSLOCK),
|
ENTRY (0x33, ';', CAPSLOCK),
|
||||||
ENTRY (0x34, ':', CAPSLOCK),
|
ENTRY (0x34, ':', CAPSLOCK),
|
||||||
ENTRY (0x35, '!', CAPSLOCK),
|
ENTRY (0x35, '!', CAPSLOCK),
|
||||||
|
|
||||||
|
ENTRY (0x39, ' ', NONE),
|
||||||
};
|
};
|
||||||
|
|
||||||
const uint LeftShiftScanCodes[2 * 256] =
|
const uint LeftShiftScanCodes[2 * 256] =
|
||||||
{
|
{
|
||||||
ENTRY (0x00, 0, INVISIBLE|INVALID),
|
ENTRY (0x00, 0, INVISIBLE|INVALID),
|
||||||
|
@ -157,15 +160,10 @@ const uint LeftShiftScanCodes[2 * 256] =
|
||||||
ENTRY (0x33, '.', NONE),
|
ENTRY (0x33, '.', NONE),
|
||||||
ENTRY (0x34, '/', NONE),
|
ENTRY (0x34, '/', NONE),
|
||||||
ENTRY (0x35, '!', NONE),
|
ENTRY (0x35, '!', NONE),
|
||||||
|
|
||||||
|
ENTRY (0x39, ' ', NONE),
|
||||||
};
|
};
|
||||||
|
|
||||||
const uint LeftAltScanCodes[2 * 256];
|
const uint LeftAltScanCodes[2 * 256];
|
||||||
const uint LeftControlScanCodes[2 * 256];
|
const uint LeftControlScanCodes[2 * 256];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue