OSDN Git Service

[VM][KEYBOARD] Add ROMAJI-KANA conversion.(When set SUPPORT_ROMA_KANA_CONVERSION...
[csp-qt/common_source_project-fm7.git] / source / src / vm / fm7 / fm7_keyboard.h
index bc8559a..33bdb83 100644 (file)
 
 #include "fm7_common.h"
 
+#if defined(_FM77AV_VARIANTS)  
+class BEEP;
+#endif
 class KEYBOARD : public DEVICE {
  protected:
        VM* p_vm;
        EMU* p_emu;
-       uint8 get_keycode_high(void);
-       uint8 get_keycode_low(void);
+       uint8_t get_keycode_high(void);
+       uint8_t get_keycode_low(void);
        void turn_on_ins_led(void);
        void turn_off_ins_led(void);
        
@@ -35,10 +38,14 @@ class KEYBOARD : public DEVICE {
 #endif
        outputs_t break_line;
        outputs_t int_line;
-       
-       uint32 keycode_7;
+
+       uint32_t keycode_7;
        int keymode;
- private:
+#if defined(SUPPORT_ROMA_KANA_CONVERSION)
+       _TCHAR romakana_buffer[16];
+       int romakana_ptr;
+#endif
+private:
        bool ctrl_pressed; 
        bool lshift_pressed; 
        bool rshift_pressed; 
@@ -47,28 +54,30 @@ class KEYBOARD : public DEVICE {
        bool caps_pressed;
        bool kana_pressed;
        bool break_pressed;
-       uint8 read_data_reg(void);
-       uint8 read_stat_reg(void);
+       uint8_t read_data_reg(void);
+       uint8_t read_stat_reg(void);
        
        int event_keyrepeat;
        int event_key_rtc;
-       uint8 repeat_keycode;
+       
        bool key_pressed_flag[0x70];
-       uint32 scancode;
+       uint8_t scancode;
+       uint8_t autokey_backup;
+       uint8_t repeat_keycode;
        
-       uint8 datareg;
-       uint32 older_vk;
+       uint8_t datareg;
+       uint32_t older_vk;
 #if defined(_FM77AV_VARIANTS)
        cur_time_t cur_time; 
-       uint8 rtc_yy;
-       uint8 rtc_mm;
-       uint8 rtc_dd;
+       uint8_t rtc_yy;
+       uint8_t rtc_mm;
+       uint8_t rtc_dd;
        bool  rtc_count24h;
-       uint8 rtc_dayofweek;
+       uint8_t rtc_dayofweek;
        bool  rtc_ispm;
-       uint8 rtc_hour;
-       uint8 rtc_minute;
-       uint8 rtc_sec;
+       uint8_t rtc_hour;
+       uint8_t rtc_minute;
+       uint8_t rtc_sec;
        bool rtc_set;
        bool rtc_set_flag;
        bool rxrdy_status;
@@ -76,15 +85,24 @@ class KEYBOARD : public DEVICE {
        int cmd_phase;
        FIFO *cmd_fifo;
        FIFO *data_fifo;
-#endif
+       int event_hidden1_av;
+       uint16_t hidden1_ptr;
 
-       uint16 vk2scancode(uint32 vk);
-       bool isModifier(uint16 scancode);
-       void set_modifiers(uint16 scancode, bool flag);
-       uint16 scan2fmkeycode(uint16 scancode);
-       void do_repeatkey(uint16 scancode);
+       DEVICE *beep;
+       bool did_hidden_message_av_1;
+       int beep_phase;
+#endif
+       FIFO *key_fifo;
+       int event_int;
+   
+       uint16_t vk2scancode(uint32_t vk);
+       bool isModifier(uint8_t sc);
+       void set_modifiers(uint8_t sc, bool flag);
+       uint16_t scan2fmkeycode(uint8_t sc);
+       void do_repeatkey(uint8_t sc);
        void reset_unchange_mode(void);
-       void key_down_main(void);
+       void key_down_main(bool repeat_auto_key);
+       void key_up_main(uint8_t bak_scancode);
    
 #if defined(_FM77AV_VARIANTS)   
        void set_mode(void);
@@ -110,44 +128,48 @@ class KEYBOARD : public DEVICE {
        KEYBOARD(VM *parent_vm, EMU *parent_emu);
        ~KEYBOARD();
    
-       void key_up(uint32 vk);
-       void key_down(uint32 vk);
+       void key_up(uint32_t vk);
+       void key_down(uint32_t vk);
        void event_callback(int event_id, int err);
-       void write_signal(int id, uint32 data, uint32 mask);
-       uint32 read_signal(int id);
+       void write_signal(int id, uint32_t data, uint32_t mask);
+       uint32_t read_signal(int id);
 
-       uint32 read_data8(uint32 addr);
-       void write_data8(uint32 addr, uint32 data);
+       uint32_t read_data8(uint32_t addr);
+       void write_data8(uint32_t addr, uint32_t data);
        void reset(void);
        void release(void);
        void save_state(FILEIO *f);
        bool load_state(FILEIO *f);
-       
-       void set_context_rxrdy(DEVICE *p, int id, uint32 mask) {
+       void set_context_rxrdy(DEVICE *p, int id, uint32_t mask) {
 #if defined(_FM77AV_VARIANTS)  
                register_output_signal(&rxrdy, p, id, mask);
 #endif
        }
-       void set_context_key_ack(DEVICE *p, int id, uint32 mask) {
+       void set_context_key_ack(DEVICE *p, int id, uint32_t mask) {
 #if defined(_FM77AV_VARIANTS)  
                register_output_signal(&key_ack, p, id, mask);
 #endif
        }
-       void set_context_caps_led(DEVICE *p, int id, uint32 mask) {
+       void set_context_caps_led(DEVICE *p, int id, uint32_t mask) {
                register_output_signal(&caps_led, p, id, mask);
        }
-       void set_context_kana_led(DEVICE *p, int id, uint32 mask) {
+       void set_context_kana_led(DEVICE *p, int id, uint32_t mask) {
                register_output_signal(&kana_led, p, id, mask);
        }
-       void set_context_ins_led(DEVICE *p, int id, uint32 mask) {
+       void set_context_ins_led(DEVICE *p, int id, uint32_t mask) {
                register_output_signal(&ins_led, p, id, mask);
        }
-       void set_context_break_line(DEVICE *p, int id, uint32 mask) {
+       void set_context_break_line(DEVICE *p, int id, uint32_t mask) {
                register_output_signal(&break_line, p, id, mask);
        }
-       void set_context_int_line(DEVICE *p, int id, uint32 mask) {
+       void set_context_int_line(DEVICE *p, int id, uint32_t mask) {
                register_output_signal(&int_line, p, id, mask);
        }
+#if defined(_FM77AV_VARIANTS)  
+       void set_context_beep(DEVICE *p) {
+               beep = p;
+       }
+#endif
 };