--- np2/win9x/winkbd.cpp 2003/10/16 17:58:51 1.1 +++ np2/win9x/winkbd.cpp 2004/04/16 06:14:57 1.9 @@ -1,15 +1,12 @@ #include "compiler.h" #include "np2.h" -#include "dosio.h" -#include "memory.h" -#include "pccore.h" -#include "iocore.h" #include "winkbd.h" +#include "keystat.h" #define NC 0xff -static const BYTE key106[256] = { +static UINT8 key106[256] = { // , , ,STOP, , , , ; 0x00 NC, NC, NC,0x60, NC, NC, NC, NC, // BS, TAB, , , CLR, ENT, , ; 0x08 @@ -37,11 +34,11 @@ static const BYTE key106[256] = { // <£°>,<£±>,<£²>,<£³>,<£´>,<£µ>,<£¶>,<£·> ; 0x60 0x4e,0x4a,0x4b,0x4c,0x46,0x47,0x48,0x42, // <£¸>,<£¹>,<¡ö>,<¡Ü>,<¡¤>,<¡Ý>,<¡¥>,<¡¿> ; 0x68 - 0x43,0x44,0x45,0x49, NC,0x40,0x50,0x41, + 0x43,0x44,0x45,0x49,0x4f,0x40,0x50,0x41, // f.1, f.2, f.3, f.4, f.5, f.6, f.7, f.8 ; 0x70 0x62,0x63,0x64,0x65,0x66,0x67,0x68,0x69, // f.9, f10, f11, f12, f13, f14, f15, f16 ; 0x78 - 0x6a,0x6b, NC,0x7f, NC, NC, NC, NC, + 0x6a,0x6b, NC, NC, NC, NC, NC, NC, // , , , , , , , ; 0x80 NC, NC, NC, NC, NC, NC, NC, NC, // , , , , , , , ; 0x88 @@ -64,8 +61,8 @@ static const BYTE key106[256] = { NC, NC, NC, NC, NC, NC, NC, NC, // , , , , , , , ; 0xd0 NC, NC, NC, NC, NC, NC, NC, NC, - // , , , ¡Î, ¡ï, ¡Ï, ¡°, ; 0xd8 - NC, NC, NC,0x1b,0x0d,0x28,0x0c, NC, + // , , , ¡Î, ¡ï, ¡Ï, ¡°, ¡² ; 0xd8 + NC, NC, NC,0x1b,0x0d,0x28,0x0c,0x33, // , , ¡², , , , , ; 0xe0 NC, NC,0x33, NC, NC, NC, NC, NC, // , , , , , , , ; 0xe8 @@ -75,7 +72,7 @@ static const BYTE key106[256] = { // , , , , , , , ; 0xf8 NC, NC, NC, NC, NC, NC, NC, NC}; -static const BYTE key106ext[256] = { +static const UINT8 key106ext[256] = { // , , ,STOP, , , , ; 0x00 NC, NC, NC, NC, NC, NC, NC, NC, // BS, TAB, , , CLR, ENT, , ; 0x08 @@ -141,22 +138,17 @@ static const BYTE key106ext[256] = { // , , , , , , , ; 0xf8 NC, NC, NC, NC, NC, NC, NC, NC}; +static const UINT8 f12keys[] = { + 0x61, 0x60, 0x4d, 0x4f, 0x76, 0x77}; + -void winkeydown106(WPARAM wParam, LPARAM lParam) { // ver0.28 +void winkbd_keydown(WPARAM wParam, LPARAM lParam) { BYTE data; data = key106[wParam & 0xff]; if (data != NC) { - if (data == 0x7f) { - if (np2oscfg.F12COPY == 1) { - data = 0x61; - } - else { - data = 0x60; - } - } - else if ((data == 0x73) && + if ((data == 0x73) && (np2oscfg.KEYBOARD == KEY_KEY101) && (lParam & 0x01000000)) { data = 0x72; @@ -177,21 +169,13 @@ void winkeydown106(WPARAM wParam, LPARAM } } -void winkeyup106(WPARAM wParam, LPARAM lParam) { +void winkbd_keyup(WPARAM wParam, LPARAM lParam) { BYTE data; data = key106[wParam & 0xff]; if (data != NC) { - if (data == 0x7f) { - if (np2oscfg.F12COPY == 1) { - data = 0x61; - } - else { - data = 0x60; - } - } - else if ((data == 0x73) && + if ((data == 0x73) && (np2oscfg.KEYBOARD == KEY_KEY101) && (lParam & 0x01000000)) { ; // none ! @@ -212,3 +196,38 @@ void winkeyup106(WPARAM wParam, LPARAM l } } +void winkbd_roll(BOOL pcat) { + + if (pcat) { + key106[0x21] = 0x36; + key106[0x22] = 0x37; + } + else { + key106[0x21] = 0x37; + key106[0x22] = 0x36; + } +} + +void winkbd_setf12(UINT f12key) { + + UINT8 key; + + f12key--; + if (f12key < (sizeof(f12keys)/sizeof(UINT8))) { + key = f12keys[f12key]; + } + else { + key = NC; + } + key106[0x7b] = key; +} + +void winkbd_resetf12(void) { + + UINT i; + + for (i=0; i<(sizeof(f12keys)/sizeof(UINT8)); i++) { + keystat_forcerelease(f12keys[i]); + } +} +