|
|
| version 1.10, 2004/03/30 20:01:29 | version 1.15, 2004/04/07 14:55:46 |
|---|---|
| Line 5 | Line 5 |
| #include "iocore.h" | #include "iocore.h" |
| #include "keystat.h" | #include "keystat.h" |
| #include "keystat.tbl" | #include "keystat.tbl" |
| #include "softkbd.h" | |
| typedef struct { | typedef struct { |
| Line 18 typedef struct { | Line 19 typedef struct { |
| UINT8 d_rt; | UINT8 d_rt; |
| } KEYSTAT; | } KEYSTAT; |
| NKEYTBL nkeytbl; | NKEYTBL nkeytbl; |
| KEYCTRL keyctrl; | KEYCTRL keyctrl; |
| static KEYSTAT keystat; | static KEYSTAT keystat; |
| Line 28 void keystat_initialize(void) { | Line 28 void keystat_initialize(void) { |
| char path[MAX_PATH]; | char path[MAX_PATH]; |
| ZeroMemory(&keyctrl, sizeof(keyctrl)); | |
| keyctrl.keyrep = 0x21; | |
| keyctrl.capsref = NKEYREF_NC; | |
| keyctrl.kanaref = NKEYREF_NC; | |
| ZeroMemory(&keystat, sizeof(keystat)); | ZeroMemory(&keystat, sizeof(keystat)); |
| FillMemory(keystat.ref, sizeof(keystat.ref), NKEYREF_NC); | FillMemory(keystat.ref, sizeof(keystat.ref), NKEYREF_NC); |
| keystat_tblreset(); | keystat_tblreset(); |
| Line 157 kstbl_err: | Line 162 kstbl_err: |
| // ---- | // ---- |
| static REG8 getledstat(void) { | |
| REG8 ret; | |
| ret = 0; | |
| if (keyctrl.kanaref != NKEYREF_NC) { | |
| ret |= 8; | |
| } | |
| if (keyctrl.capsref != NKEYREF_NC) { | |
| ret |= 4; | |
| } | |
| return(ret); | |
| } | |
| static void reloadled(void) { | |
| keyctrl.kanaref = keystat.ref[0x72]; | |
| keyctrl.capsref = keystat.ref[0x71]; | |
| #if defined(SUPPORT_SOFTKBD) | |
| softkbd_led(getledstat()); | |
| #endif | |
| } | |
| void keystat_ctrlreset(void) { | void keystat_ctrlreset(void) { |
| ZeroMemory(&keyctrl, sizeof(keyctrl)); | keyctrl.reqparam = 0; |
| keystat.ref[0x72] = keyctrl.kanaref; | |
| keystat.ref[0x71] = keyctrl.capsref; | |
| #if defined(SUPPORT_SOFTKBD) | |
| softkbd_led(getledstat()); | |
| #endif | |
| } | } |
| void keystat_ctrlsend(REG8 dat) { | void keystat_ctrlsend(REG8 dat) { |
| // return; // まだテスト | |
| if (!keyctrl.reqparam) { | if (!keyctrl.reqparam) { |
| keyctrl.mode = dat; | keyctrl.mode = dat; |
| switch(dat) { | switch(dat) { |
| Line 202 void keystat_ctrlsend(REG8 dat) { | Line 233 void keystat_ctrlsend(REG8 dat) { |
| #if defined(SUPPORT_PC9801_119) | #if defined(SUPPORT_PC9801_119) |
| case 0x95: | case 0x95: |
| keyctrl.kbdtype = dat; | keyctrl.kbdtype = dat; |
| keyboard_ctrl(0xfa); | |
| break; | break; |
| #endif | #endif |
| case 0x9c: | case 0x9c: |
| keyboard_ctrl(0xfa); | keyboard_ctrl(0xfa); |
| break; | break; |
| case 0x9d: | |
| if (dat == 0x60) { | |
| keyboard_ctrl(0xfa); | |
| keyboard_ctrl((REG8)(0x70 + getledstat())); | |
| } | |
| else if ((dat & 0xf0) == 0x70) { | |
| keyboard_ctrl(0xfa); | |
| keystat.ref[0x72] = (dat & 8)?NKEYREF_uPD8255:NKEYREF_NC; | |
| keystat.ref[0x71] = (dat & 4)?NKEYREF_uPD8255:NKEYREF_NC; | |
| reloadled(); | |
| } | |
| break; | |
| } | } |
| keyctrl.reqparam = 0; | keyctrl.reqparam = 0; |
| } | } |
| Line 233 void keystat_down(const UINT8 *key, REG8 | Line 278 void keystat_down(const UINT8 *key, REG8 |
| } | } |
| else { | else { |
| #if defined(SUPPORT_PC9801_119) | #if defined(SUPPORT_PC9801_119) |
| if ((keyctrl.kbdtype != 0x03) && (keycode >= 0x75)) { | if (keyctrl.kbdtype != 0x03) |
| continue; | |
| } | |
| #else | |
| if (keycode >= 0x75) { | |
| continue; | |
| } | |
| #endif | #endif |
| { | |
| if (keycode == 0x7d) { | |
| keycode = 0x70; | |
| } | |
| else if (keycode >= 0x75) { | |
| continue; | |
| } | |
| } | |
| if ((np2cfg.XSHIFT) && | if ((np2cfg.XSHIFT) && |
| (((keycode == 0x70) && (np2cfg.XSHIFT & 1)) || | (((keycode == 0x70) && (np2cfg.XSHIFT & 1)) || |
| ((keycode == 0x74) && (np2cfg.XSHIFT & 2)) || | ((keycode == 0x74) && (np2cfg.XSHIFT & 2)) || |
| Line 264 void keystat_down(const UINT8 *key, REG8 | Line 311 void keystat_down(const UINT8 *key, REG8 |
| } | } |
| keyboard_send(data); | keyboard_send(data); |
| } | } |
| if ((keycode == 0x71) || (keycode == 0x72)) { | |
| reloadled(); | |
| } | |
| } | } |
| } | } |
| } | } |
| Line 284 void keystat_up(const UINT8 *key, REG8 k | Line 334 void keystat_up(const UINT8 *key, REG8 k |
| } | } |
| else { | else { |
| #if defined(SUPPORT_PC9801_119) | #if defined(SUPPORT_PC9801_119) |
| if ((keyctrl.kbdtype != 0x03) && (keycode >= 0x75)) { | if (keyctrl.kbdtype != 0x03) |
| continue; | |
| } | |
| #else | |
| if (keycode >= 0x75) { | |
| continue; | |
| } | |
| #endif | #endif |
| { | |
| if (keycode == 0x7d) { | |
| keycode = 0x70; | |
| } | |
| else if (keycode >= 0x75) { | |
| continue; | |
| } | |
| } | |
| if ((np2cfg.XSHIFT) && | if ((np2cfg.XSHIFT) && |
| (((keycode == 0x70) && (np2cfg.XSHIFT & 1)) || | (((keycode == 0x70) && (np2cfg.XSHIFT & 1)) || |
| ((keycode == 0x74) && (np2cfg.XSHIFT & 2)) || | ((keycode == 0x74) && (np2cfg.XSHIFT & 2)) || |
| Line 302 void keystat_up(const UINT8 *key, REG8 k | Line 354 void keystat_up(const UINT8 *key, REG8 k |
| if (keystat.ref[keycode] != NKEYREF_NC) { | if (keystat.ref[keycode] != NKEYREF_NC) { |
| keystat.ref[keycode] = NKEYREF_NC; | keystat.ref[keycode] = NKEYREF_NC; |
| keyboard_send((REG8)(keycode + 0x80)); | keyboard_send((REG8)(keycode + 0x80)); |
| if ((keycode == 0x71) || (keycode == 0x72)) { | |
| reloadled(); | |
| } | |
| } | } |
| } | } |
| } | } |
| Line 394 void keystat_resetjoykey(void) { | Line 449 void keystat_resetjoykey(void) { |
| void keystat_releasekey(REG8 key) { | void keystat_releasekey(REG8 key) { |
| key &= 0x7f; | key &= 0x7f; |
| if (keystat.ref[key] != NKEYREF_NC) { | if ((key != 0x71) && (key != 0x72)) { |
| keystat.ref[key] = NKEYREF_NC; | if (keystat.ref[key] != NKEYREF_NC) { |
| keyboard_send((REG8)(key + 0x80)); | keystat.ref[key] = NKEYREF_NC; |
| keyboard_send((REG8)(key + 0x80)); | |
| } | |
| } | } |
| } | } |