Diff for /np2/keystat.c between versions 1.11 and 1.13

version 1.11, 2004/03/31 11:59:17 version 1.13, 2004/04/02 19:31:26
Line 18  typedef struct { Line 18  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 27  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 161  kstbl_err:
   
 // ----  // ----
   
 void keystat_ctrlinit(void) {  static REG8 getledstat(void) {
   
         ZeroMemory(&keyctrl, sizeof(keyctrl));          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];
 }  }
   
 void keystat_ctrlreset(void) {  void keystat_ctrlreset(void) {
   
         keyctrl.reqparam = 0;          keyctrl.reqparam = 0;
           keystat.ref[0x72] = keyctrl.kanaref;
           keystat.ref[0x71] = keyctrl.capsref;
 }  }
   
 void keystat_ctrlsend(REG8 dat) {  void keystat_ctrlsend(REG8 dat) {
   
 //      return;                                 // まだテスト          return;
   
         if (!keyctrl.reqparam) {          if (!keyctrl.reqparam) {
                 keyctrl.mode = dat;                  keyctrl.mode = dat;
Line 213  void keystat_ctrlsend(REG8 dat) { Line 234  void keystat_ctrlsend(REG8 dat) {
                         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 272  void keystat_down(const UINT8 *key, REG8 Line 306  void keystat_down(const UINT8 *key, REG8
                                 }                                  }
                                 keyboard_send(data);                                  keyboard_send(data);
                         }                          }
                           if ((keycode == 0x71) || (keycode == 0x72)) {
                                   reloadled();
                           }
                 }                  }
         }          }
 }  }
Line 312  void keystat_up(const UINT8 *key, REG8 k Line 349  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 404  void keystat_resetjoykey(void) { Line 444  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));
                   }
         }          }
 }  }
   

Removed from v.1.11  
changed lines
  Added in v.1.13


RetroPC.NET-CVS <cvs@retropc.net>