/* File: \wacker\emu\vt220ini.c (Created: 24-Jan-1998) * * Copyright 1998 by Hilgraeve Inc. -- Monroe, MI * All rights reserved * * $Revision: 1 $ * $Date: 10/05/98 12:28p $ */ #include #pragma hdrstop #include #include #include #include #include #include "emu.h" #include "emu.hh" #include "emuid.h" #include "emudec.hh" #include "keytbls.h" #if defined(INCL_VT220) /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= * vt220_init * * DESCRIPTION: * Initializes the VT220 emulator. * * ARGUMENTS: * * RETURNS: * nothing */ void vt220_init(const HHEMU hhEmu) { PSTDECPRIVATE pstPRI; int iRow; static struct trans_entry const vt220_tbl[] = { {NEW_STATE, 0, 0, 0}, // State 0 #if !defined(FAR_EAST) // Left in from the VT100. {0, ETEXT('\x20'), ETEXT('\x7E'), emuDecGraphic}, // Space - ~ {0, ETEXT('\xA0'), ETEXT('\xFF'), emuDecGraphic}, // #else {0, ETEXT('\x20'), ETEXT('\x7E'), emuDecGraphic}, // Space - ~ {0, ETEXT('\xA0'), 0xFFFF, emuDecGraphic}, // #endif {1, ETEXT('\x1B'), ETEXT('\x1B'), nothing}, // Esc {2, ETEXT('\x9B'), ETEXT('\x9B'), nothing}, // CSI // 7 bit control codes // {13,TEXT('\x01'), ETEXT('\x01'), nothing}, // Ctrl-A {0, ETEXT('\x05'), ETEXT('\x05'), vt100_answerback}, // Ctrl-E {0, ETEXT('\x07'), ETEXT('\x07'), emu_bell}, // Ctrl-G {0, ETEXT('\x08'), ETEXT('\x08'), vt_backspace}, // BackSpace {0, ETEXT('\x09'), ETEXT('\x09'), emuDecTab}, // Tab {0, ETEXT('\x0A'), ETEXT('\x0C'), emuLineFeed}, // NL - FF {0, ETEXT('\x0D'), ETEXT('\x0D'), carriagereturn}, // CR {0, ETEXT('\x0E'), ETEXT('\x0F'), vt_charshift}, // Ctrl-N, Ctrl-O {12,ETEXT('\x18'), ETEXT('\x18'), EmuStdChkZmdm}, // Ctrl-X // 8 bit control codes {0, ETEXT('\x84'), ETEXT('\x84'), emuDecIND}, // Index cursor {0, ETEXT('\x85'), ETEXT('\x85'), ANSI_NEL}, // Next line {0, ETEXT('\x88'), ETEXT('\x88'), ANSI_HTS}, // Set Horizontal Tab {0, ETEXT('\x8D'), ETEXT('\x8D'), emuDecRI}, // Reverse index {0, ETEXT('\x8E'), ETEXT('\x8F'), vt_charshift}, // SingleShift G2,G3 {5, ETEXT('\x90'), ETEXT('\x90'), nothing}, // Device Control String (DCS) // Ignore these codes. They just show what functionality is still missing. {0, ETEXT('\x00'), ETEXT('\x00'), nothing}, // ignore nuls {0, ETEXT('\x1A'), ETEXT('\x1A'), nothing}, // ignore Substitute {0, ETEXT('\x7F'), ETEXT('\x7F'), nothing}, // ignore Delete {0, ETEXT('\x9C'), ETEXT('\x9C'), nothing}, // ignore String Terminator {NEW_STATE, 0, 0, 0}, // State 1 // Esc {2, ETEXT('\x5B'), ETEXT('\x5B'), ANSI_Pn_Clr}, // '[' {7, ETEXT('\x20'), ETEXT('\x20'), nothing}, // Space {3, ETEXT('\x23'), ETEXT('\x23'), nothing}, // # {4, ETEXT('\x28'), ETEXT('\x2B'), vt_scs1}, // ( - + {0, ETEXT('\x37'), ETEXT('\x38'), vt100_savecursor}, // 8 {1, ETEXT('\x3B'), ETEXT('\x3B'), ANSI_Pn_End}, // ; {0, ETEXT('\x3D'), ETEXT('\x3E'), vt_alt_kpmode}, // = - > {0, ETEXT('\x44'), ETEXT('\x44'), emuDecIND}, // D {0, ETEXT('\x45'), ETEXT('\x45'), ANSI_NEL}, // E {0, ETEXT('\x48'), ETEXT('\x48'), ANSI_HTS}, // H {0, ETEXT('\x4D'), ETEXT('\x4D'), emuDecRI}, // M {0, ETEXT('\x4E'), ETEXT('\x4F'), vt_charshift}, // N - O {5, ETEXT('\x50'), ETEXT('\x50'), nothing}, // P {0, ETEXT('\x5A'), ETEXT('\x5A'), vt220_DA}, // Z {0, ETEXT('\\'), ETEXT('\\'), nothing}, // Backslash {0, ETEXT('\x63'), ETEXT('\x63'), vt220_hostreset}, // c {0, ETEXT('\x6E'), ETEXT('\x6F'), vt_charshift}, // n - o {0, ETEXT('\x7D'), ETEXT('\x7E'), vt_charshift}, // } - ~ {NEW_STATE, 0, 0, 0}, // State 2 // ESC [ {8, ETEXT('\x21'), ETEXT('\x21'), nothing}, // ! {2, ETEXT('\x3B'), ETEXT('\x3B'), ANSI_Pn_End}, // ; {9, ETEXT('\x3E'), ETEXT('\x3E'), nothing}, // > {2, ETEXT('\x30'), ETEXT('\x3F'), ANSI_Pn}, // 0 - ? {11,ETEXT('\x22'), ETEXT('\x22'), nothing}, // " // {16,ETEXT('\x24'), ETEXT('\x24'), nothing}, // $ {2, ETEXT('\x27'), ETEXT('\x27'), nothing}, // Eat Esc [ m ; m ; ' z {0, ETEXT('\x40'), ETEXT('\x40'), ANSI_ICH}, // @ {0, ETEXT('\x41'), ETEXT('\x41'), emuDecCUU}, // A {0, ETEXT('\x42'), ETEXT('\x42'), emuDecCUD}, // B {0, ETEXT('\x43'), ETEXT('\x43'), emuDecCUF}, // C {0, ETEXT('\x44'), ETEXT('\x44'), emuDecCUB}, // D {0, ETEXT('\x48'), ETEXT('\x48'), emuDecCUP}, // H {0, ETEXT('\x4A'), ETEXT('\x4A'), emuVT220ED}, // J {0, ETEXT('\x4B'), ETEXT('\x4B'), emuDecEL}, // K {0, ETEXT('\x4C'), ETEXT('\x4C'), vt_IL}, // L {0, ETEXT('\x4D'), ETEXT('\x4D'), vt_DL}, // M {0, ETEXT('\x50'), ETEXT('\x50'), vt_DCH}, // P {0, ETEXT('\x58'), ETEXT('\x58'), vt_DCH}, // X {0, ETEXT('\x63'), ETEXT('\x63'), vt220_DA}, // c {0, ETEXT('\x66'), ETEXT('\x66'), emuDecCUP}, // f {0, ETEXT('\x67'), ETEXT('\x67'), ANSI_TBC}, // g {0, ETEXT('\x68'), ETEXT('\x68'), ANSI_SM}, // h {0, ETEXT('\x69'), ETEXT('\x69'), vt100PrintCommands},// i {0, ETEXT('\x6C'), ETEXT('\x6C'), ANSI_RM}, // l {0, ETEXT('\x6D'), ETEXT('\x6D'), ANSI_SGR}, // m {0, ETEXT('\x6E'), ETEXT('\x6E'), ANSI_DSR}, // n {0, ETEXT('\x71'), ETEXT('\x71'), nothing}, // q {0, ETEXT('\x72'), ETEXT('\x72'), vt_scrollrgn}, // r {0, ETEXT('\x75'), ETEXT('\x75'), nothing}, // u {0, ETEXT('\x79'), ETEXT('\x79'), nothing}, // y {0, ETEXT('\x7A'), ETEXT('\x7A'), nothing}, // z {NEW_STATE, 0, 0, 0}, // State 3 // Esc # {0, ETEXT('\x33'), ETEXT('\x36'), emuSetDoubleAttr}, // 3 - 6 {0, ETEXT('\x38'), ETEXT('\x38'), vt_screen_adjust}, // 8 {NEW_STATE, 0, 0, 0}, // State 4 // Esc ( - + {0, ETEXT('\x01'), ETEXT('\xFF'), vt_scs2}, // All {NEW_STATE, 0, 0, 0}, // State 5 // Esc P {5, ETEXT('\x3B'), ETEXT('\x3B'), ANSI_Pn_End}, // ; {5, ETEXT('\x30'), ETEXT('\x3F'), ANSI_Pn}, // 0 - ? {10,ETEXT('\x7C'), ETEXT('\x7C'), emuDecClearUDK}, // | {NEW_STATE, 0, 0, 0}, // State 6 {6, ETEXT('\x00'), ETEXT('\xFF'), vt100_prnc}, // All {NEW_STATE, 0, 0, 0}, // State 7 // Esc Sapce {0, ETEXT('\x46'), ETEXT('\x47'), nothing}, // F - G {NEW_STATE, 0, 0, 0}, // State 8 // Esc [ ! {0, ETEXT('\x70'), ETEXT('\x70'), vt220_softreset}, // p {NEW_STATE, 0, 0, 0}, // State 9 // Esc [ > {0, ETEXT('\x63'), ETEXT('\x63'), vt220_2ndDA}, // c {NEW_STATE, 0, 0, 0}, // State 10 // Esc P n;n | {10,ETEXT('\x00'), ETEXT('\xFF'), emuDecDefineUDK}, // All {NEW_STATE, 0, 0, 0}, // State 11 // Esc [ " {0, ETEXT('\x70'), ETEXT('\x70'), vt220_level}, // p {0, ETEXT('\x71'), ETEXT('\x71'), vt220_protmode}, // q {NEW_STATE, 0, 0, 0}, // State 12 // Ctrl-X {12,ETEXT('\x00'), ETEXT('\xFF'), EmuStdChkZmdm}, // All // States 13-17 are not used in HT but included for reference. // {NEW_STATE, 0, 0, 0}, // State 13 // Ctrl-A // {14,ETEXT('\x08'), ETEXT('\x08'), emuSerialNbr}, // Backspace // {15,ETEXT('\x48'), ETEXT('\x48'), EmuStdChkHprP}, // H // {NEW_STATE, 0, 0, 0}, // State 14 // Ctrl-A bs // {14,ETEXT('\x00'), ETEXT('\xFF'), emuSerialNbr}, // All // {NEW_STATE, 0, 0, 0}, // State 15 // Ctrl-A H // {15,ETEXT('\x00'), ETEXT('\xFF'), EmuStdChkHprP}, // All // A real VT220/320 does not support the status line sequences. // {NEW_STATE, 0, 0, 0}, // State 16 // Esc [ n $ // {16,ETEXT('\x7E'), ETEXT('\x7E'), emuDecSelectStatusLine}, // ~ // {17,ETEXT('\x7D'), ETEXT('\x7D'), emuDecSelectActiveDisplay}, // } // {NEW_STATE, 0, 0, 0}, // State 17 // {17,ETEXT('\x00'), ETEXT('\xFF'), emuDecStatusLineToss}, // All }; // The following key tables were copied from \shared\emulator\vt220ini.c // because they support user-defined keys. The tables have been modified // so keydef.h is not needed and to match HT's use of keys. rde 2 Feb 98 // The following key tables are defined in the order that they // are searched. // // These are the (standard) F1 thru F4 keys on the top and left of the // keyboard. Note that these keys may be mapped to the top row of the // numeric keypad. In that case, these keys (at the standard locations), // are not mapped to emulator keys. NOTE: HTPE does not use this mapping. // // Please note that the sequences defined in this table are the // 8-bit versions of the responses. The function emuDecSendKeyString // will convert this sequence to the 7-bit equivalent if necessary. // static STEMUKEYDATA const VT220StdPfKeyTable[] = { EMUKEY(VK_F1, 1, 0, 0, 0, 0, "\x8F\x50", 2), // P EMUKEY(VK_F2, 1, 0, 0, 0, 0, "\x8F\x51", 2), // Q EMUKEY(VK_F3, 1, 0, 0, 0, 0, "\x8F\x52", 2), // R EMUKEY(VK_F4, 1, 0, 0, 0, 0, "\x8F\x53", 2), // S EMUKEY(VK_F1, 1, 0, 0, 0, 1, "\x8F\x50", 2), // P EMUKEY(VK_F2, 1, 0, 0, 0, 1, "\x8F\x51", 2), // Q EMUKEY(VK_F3, 1, 0, 0, 0, 1, "\x8F\x52", 2), // R EMUKEY(VK_F4, 1, 0, 0, 0, 1, "\x8F\x53", 2), // S }; // When the user has selected the option to map the top 4 keys of the // numeric keypad to be the same as F1 thru F4, these key sequences are // used. NOTE: This is the mapping HTPE uses. // // Please note that the sequences defined in this table are the // 8-bit versions of the responses. The function emuDecSendKeyString // will convert this sequence to the 7-bit equivalent if necessary. // static STEMUKEYDATA const VT220MovedPfKeyTable[] = { EMUKEY(VK_NUMLOCK, 1, 0, 0, 0, 1, "\x8F\x50", 2), // P EMUKEY(VK_DIVIDE, 1, 0, 0, 0, 1, "\x8F\x51", 2), // Q EMUKEY(VK_MULTIPLY, 1, 0, 0, 0, 1, "\x8F\x52", 2), // R EMUKEY(VK_SUBTRACT, 1, 0, 0, 0, 1, "\x8F\x53", 2), // S }; // VT220 Keypad Numeric Mode. // static STEMUKEYDATA const VT220KeypadNumericMode[] = { // Keypad keys with Numlock off. // EMUKEY(VK_INSERT, 1, 0, 0, 0, 0, "\x30", 1), // 0 EMUKEY(VK_END, 1, 0, 0, 0, 0, "\x31", 1), // 1 EMUKEY(VK_DOWN, 1, 0, 0, 0, 0, "\x32", 1), // 2 EMUKEY(VK_NEXT, 1, 0, 0, 0, 0, "\x33", 1), // 3 EMUKEY(VK_LEFT, 1, 0, 0, 0, 0, "\x34", 1), // 4 EMUKEY(VK_NUMPAD5, 1, 0, 0, 0, 0, "\x35", 1), // 5 EMUKEY(VK_RIGHT, 1, 0, 0, 0, 0, "\x36", 1), // 6 EMUKEY(VK_HOME, 1, 0, 0, 0, 0, "\x37", 1), // 7 EMUKEY(VK_UP, 1, 0, 0, 0, 0, "\x38", 1), // 8 EMUKEY(VK_PRIOR, 1, 0, 0, 0, 0, "\x39", 1), // 9 EMUKEY(VK_DELETE, 1, 0, 0, 0, 0, "\x2E", 1), // . // Keypad keys with Numlock on. // EMUKEY(VK_NUMPAD0, 1, 0, 0, 0, 0, "\x30", 1), // 0 EMUKEY(VK_NUMPAD1, 1, 0, 0, 0, 0, "\x31", 1), // 1 EMUKEY(VK_NUMPAD2, 1, 0, 0, 0, 0, "\x32", 1), // 2 EMUKEY(VK_NUMPAD3, 1, 0, 0, 0, 0, "\x33", 1), // 3 EMUKEY(VK_NUMPAD4, 1, 0, 0, 0, 0, "\x34", 1), // 4 EMUKEY(VK_NUMPAD5, 1, 0, 0, 0, 0, "\x35", 1), // 5 EMUKEY(VK_NUMPAD6, 1, 0, 0, 0, 0, "\x36", 1), // 6 EMUKEY(VK_NUMPAD7, 1, 0, 0, 0, 0, "\x37", 1), // 7 EMUKEY(VK_NUMPAD8, 1, 0, 0, 0, 0, "\x38", 1), // 8 EMUKEY(VK_NUMPAD9, 1, 0, 0, 0, 0, "\x39", 1), // 9 EMUKEY(VK_DECIMAL, 1, 0, 0, 0, 0, "\x2E", 1), // . // Other keypad keys (minus, plus, Enter). // EMUKEY(VK_SUBTRACT, 1, 0, 0, 0, 0, "\x2D", 1), // - EMUKEY(VK_ADD, 1, 0, 0, 0, 0, "\x2C", 1), // , EMUKEY(VK_RETURN, 1, 0, 0, 0, 1, "\x0D", 1), // CR }; // VT220 Keypad Application Mode. // // Please note that the sequences defined in this table are the // 8-bit versions of the responses. The function emuDecSendKeyString // will convert this sequence to the 7-bit equivalent if necessary. // static STEMUKEYDATA const VT220KeypadApplicationMode[] = { // Keypad keys with Numlock off. // EMUKEY(VK_NUMPAD0, 1, 0, 0, 0, 0, "\x8F\x70", 2), // p EMUKEY(VK_NUMPAD1, 1, 0, 0, 0, 0, "\x8F\x71", 2), // q EMUKEY(VK_NUMPAD2, 1, 0, 0, 0, 0, "\x8F\x72", 2), // r EMUKEY(VK_NUMPAD3, 1, 0, 0, 0, 0, "\x8F\x73", 2), // s EMUKEY(VK_NUMPAD4, 1, 0, 0, 0, 0, "\x8F\x74", 2), // t EMUKEY(VK_NUMPAD5, 1, 0, 0, 0, 0, "\x8F\x75", 2), // u EMUKEY(VK_NUMPAD6, 1, 0, 0, 0, 0, "\x8F\x76", 2), // v EMUKEY(VK_NUMPAD7, 1, 0, 0, 0, 0, "\x8F\x77", 2), // w EMUKEY(VK_NUMPAD8, 1, 0, 0, 0, 0, "\x8F\x78", 2), // x EMUKEY(VK_NUMPAD9, 1, 0, 0, 0, 0, "\x8F\x79", 2), // y EMUKEY(VK_DECIMAL, 1, 0, 0, 0, 0, "\x8F\x6E", 2), // n // Keypad keys with Numlock on. // EMUKEY(VK_NUMPAD0, 1, 0, 0, 0, 0, "\x8F\x70", 2), // p EMUKEY(VK_NUMPAD1, 1, 0, 0, 0, 0, "\x8F\x71", 2), // q EMUKEY(VK_NUMPAD2, 1, 0, 0, 0, 0, "\x8F\x72", 2), // r EMUKEY(VK_NUMPAD3, 1, 0, 0, 0, 0, "\x8F\x73", 2), // s EMUKEY(VK_NUMPAD4, 1, 0, 0, 0, 0, "\x8F\x74", 2), // t EMUKEY(VK_NUMPAD5, 1, 0, 0, 0, 0, "\x8F\x75", 2), // u EMUKEY(VK_NUMPAD6, 1, 0, 0, 0, 0, "\x8F\x76", 2), // v EMUKEY(VK_NUMPAD7, 1, 0, 0, 0, 0, "\x8F\x77", 2), // w EMUKEY(VK_NUMPAD8, 1, 0, 0, 0, 0, "\x8F\x78", 2), // x EMUKEY(VK_NUMPAD9, 1, 0, 0, 0, 0, "\x8F\x79", 2), // y EMUKEY(VK_DECIMAL, 1, 0, 0, 0, 0, "\x8F\x6E", 2), // n // Other keypad keys (minus, plus, Enter). // EMUKEY(VK_SUBTRACT, 1, 0, 0, 0, 0, "\x8F\x6D", 2), // m EMUKEY(VK_ADD, 1, 0, 0, 0, 0, "\x8F\x6C", 2), // l EMUKEY(VK_RETURN, 1, 0, 0, 0, 1, "\x8F\x4D", 2), // M }; // VT220 Cursor Key Mode. // // Please note that the sequences defined in this table are the // 8-bit versions of the responses. The function emuDecSendKeyString // will convert this sequence to the 7-bit equivalent if necessary. // static STEMUKEYDATA const VT220CursorKeyMode[] = { // Arrow keys on the numeric keypad. These sequences are used // when the emulator is using Cursor Key Mode (Application Keys). // EMUKEY(VK_UP, 1, 0, 0, 0, 0, "\x8F\x41", 2), // A EMUKEY(VK_DOWN, 1, 0, 0, 0, 0, "\x8F\x42", 2), // B EMUKEY(VK_RIGHT, 1, 0, 0, 0, 0, "\x8F\x43", 2), // C EMUKEY(VK_LEFT, 1, 0, 0, 0, 0, "\x8F\x44", 2), // D // Arrow keys on the edit pad. These sequences are used // when the emulator is using Cursor Key Mode (Application Keys). // EMUKEY(VK_UP, 1, 0, 0, 0, 1, "\x8F\x41", 2), // A EMUKEY(VK_DOWN, 1, 0, 0, 0, 1, "\x8F\x42", 2), // B EMUKEY(VK_RIGHT, 1, 0, 0, 0, 1, "\x8F\x43", 2), // C EMUKEY(VK_LEFT, 1, 0, 0, 0, 1, "\x8F\x44", 2), // D }; // VT220 Standard Key Table. // static STEMUKEYDATA const VT220StandardKeys[] = { // Some keys on the numeric keypad will respond in the same // way the corresponding keys on the edit pad respond. // EMUKEY(VK_HOME, 1, 0, 0, 0, 0, "\x9B\x31\x7E", 3), // 1 ~ EMUKEY(VK_INSERT, 1, 0, 0, 0, 0, "\x9B\x32\x7E", 3), // 2 ~ EMUKEY(VK_DELETE, 1, 0, 0, 0, 0, "\x9B\x33\x7E", 3), // 3 ~ EMUKEY(VK_END, 1, 0, 0, 0, 0, "\x9B\x34\x7E", 3), // 4 ~ EMUKEY(VK_PRIOR, 1, 0, 0, 0, 0, "\x9B\x35\x7E", 3), // 5 ~ EMUKEY(VK_NEXT, 1, 0, 0, 0, 0, "\x9B\x36\x7E", 3), // 6 ~ // These are the keys on the edit pad. // EMUKEY(VK_HOME, 1, 0, 0, 0, 1, "\x9B\x31\x7E", 3), // 1 ~ EMUKEY(VK_INSERT, 1, 0, 0, 0, 1, "\x9B\x32\x7E", 3), // 2 ~ EMUKEY(VK_DELETE, 1, 0, 0, 0, 1, "\x9B\x33\x7E", 3), // 3 ~ EMUKEY(VK_END, 1, 0, 0, 0, 1, "\x9B\x34\x7E", 3), // 4 ~ EMUKEY(VK_PRIOR, 1, 0, 0, 0, 1, "\x9B\x35\x7E", 3), // 5 ~ EMUKEY(VK_NEXT, 1, 0, 0, 0, 1, "\x9B\x36\x7E", 3), // 6 ~ // Arrow keys on the numeric keypad. // EMUKEY(VK_UP, 1, 0, 0, 0, 0, "\x9B\x41", 2), // A EMUKEY(VK_DOWN, 1, 0, 0, 0, 0, "\x9B\x42", 2), // B EMUKEY(VK_RIGHT, 1, 0, 0, 0, 0, "\x9B\x43", 2), // C EMUKEY(VK_LEFT, 1, 0, 0, 0, 0, "\x9B\x44", 2), // D // Arrow keys on the edit pad. // EMUKEY(VK_UP, 1, 0, 0, 0, 1, "\x9B\x41", 2), // A EMUKEY(VK_DOWN, 1, 0, 0, 0, 1, "\x9B\x42", 2), // B EMUKEY(VK_RIGHT, 1, 0, 0, 0, 1, "\x9B\x43", 2), // C EMUKEY(VK_LEFT, 1, 0, 0, 0, 1, "\x9B\x44", 2), // D // Function keys (F5)F6 thru F10. // #if defined(INCL_ULTC_VERSION) EMUKEY(VK_F5, 1, 0, 0, 0, 0, "\x9B\x31\x36\x7E", 4), // 1 6 ~ #endif EMUKEY(VK_F6, 1, 0, 0, 0, 0, "\x9B\x31\x37\x7E", 4), // 1 7 ~ EMUKEY(VK_F7, 1, 0, 0, 0, 0, "\x9B\x31\x38\x7E", 4), // 1 8 ~ EMUKEY(VK_F8, 1, 0, 0, 0, 0, "\x9B\x31\x39\x7E", 4), // 1 9 ~ EMUKEY(VK_F9, 1, 0, 0, 0, 0, "\x9B\x32\x30\x7E", 4), // 2 0 ~ EMUKEY(VK_F10, 1, 0, 0, 0, 0, "\x9B\x32\x31\x7E", 4), // 2 1 ~ #if defined(INCL_ULTC_VERSION) EMUKEY(VK_F5, 1, 0, 0, 0, 1, "\x9B\x31\x36\x7E", 4), // 1 6 ~ #endif EMUKEY(VK_F6, 1, 0, 0, 0, 1, "\x9B\x31\x37\x7E", 4), // 1 7 ~ EMUKEY(VK_F7, 1, 0, 0, 0, 1, "\x9B\x31\x38\x7E", 4), // 1 8 ~ EMUKEY(VK_F8, 1, 0, 0, 0, 1, "\x9B\x31\x39\x7E", 4), // 1 9 ~ EMUKEY(VK_F9, 1, 0, 0, 0, 1, "\x9B\x32\x30\x7E", 4), // 2 0 ~ EMUKEY(VK_F10, 1, 0, 0, 0, 1, "\x9B\x32\x31\x7E", 4), // 2 1 ~ // Function keys F11 thru F20 are invoked by the user pressing // Ctrl-F1 thru Ctrl-F10. // // Function keys Ctrl-F1 thru Ctrl-F10 (Top row). // EMUKEY(VK_F1, 1, 1, 0, 0, 0, "\x9B\x32\x33\x7E", 4), // 2 3 ~ EMUKEY(VK_F2, 1, 1, 0, 0, 0, "\x9B\x32\x34\x7E", 4), // 2 4 ~ EMUKEY(VK_F3, 1, 1, 0, 0, 0, "\x9B\x32\x35\x7E", 4), // 2 5 ~ EMUKEY(VK_F4, 1, 1, 0, 0, 0, "\x9B\x32\x36\x7E", 4), // 2 6 ~ EMUKEY(VK_F5, 1, 1, 0, 0, 0, "\x9B\x32\x38\x7E", 4), // 2 8 ~ EMUKEY(VK_F6, 1, 1, 0, 0, 0, "\x9B\x32\x39\x7E", 4), // 2 9 ~ EMUKEY(VK_F7, 1, 1, 0, 0, 0, "\x9B\x33\x31\x7E", 4), // 3 1 ~ EMUKEY(VK_F8, 1, 1, 0, 0, 0, "\x9B\x33\x32\x7E", 4), // 3 2 ~ EMUKEY(VK_F9, 1, 1, 0, 0, 0, "\x9B\x33\x33\x7E", 4), // 3 3 ~ EMUKEY(VK_F10, 1, 1, 0, 0, 0, "\x9B\x33\x34\x7E", 4), // 3 4 ~ EMUKEY(VK_F1, 1, 1, 0, 0, 1, "\x9B\x32\x33\x7E", 4), // 2 3 ~ EMUKEY(VK_F2, 1, 1, 0, 0, 1, "\x9B\x32\x34\x7E", 4), // 2 4 ~ EMUKEY(VK_F3, 1, 1, 0, 0, 1, "\x9B\x32\x35\x7E", 4), // 2 5 ~ EMUKEY(VK_F4, 1, 1, 0, 0, 1, "\x9B\x32\x36\x7E", 4), // 2 6 ~ EMUKEY(VK_F5, 1, 1, 0, 0, 1, "\x9B\x32\x38\x7E", 4), // 2 8 ~ EMUKEY(VK_F6, 1, 1, 0, 0, 1, "\x9B\x32\x39\x7E", 4), // 2 9 ~ EMUKEY(VK_F7, 1, 1, 0, 0, 1, "\x9B\x33\x31\x7E", 4), // 3 1 ~ EMUKEY(VK_F8, 1, 1, 0, 0, 1, "\x9B\x33\x32\x7E", 4), // 3 2 ~ EMUKEY(VK_F9, 1, 1, 0, 0, 1, "\x9B\x33\x33\x7E", 4), // 3 3 ~ EMUKEY(VK_F10, 1, 1, 0, 0, 1, "\x9B\x33\x34\x7E", 4), // 3 4 ~ EMUKEY(VK_F1, 1, 0, 0, 0, 0, "\x8FP", 2), EMUKEY(VK_F2, 1, 0, 0, 0, 0, "\x8FQ", 2), EMUKEY(VK_F3, 1, 0, 0, 0, 0, "\x8FR", 2), EMUKEY(VK_F4, 1, 0, 0, 0, 0, "\x8FS", 2), EMUKEY(VK_F1, 1, 0, 0, 0, 1, "\x8FP", 2), EMUKEY(VK_F2, 1, 0, 0, 0, 1, "\x8FQ", 2), EMUKEY(VK_F3, 1, 0, 0, 0, 1, "\x8FR", 2), EMUKEY(VK_F4, 1, 0, 0, 0, 1, "\x8FS", 2), EMUKEY(VK_DELETE, 1, 0, 0, 0, 0, "\x7F", 1), // KN_DEL EMUKEY(VK_DELETE, 1, 0, 0, 0, 1, "\x7F", 1), // KN_DEL EMUKEY(VK_ADD, 1, 0, 0, 0, 0, ",", 1), // Ctrl-2. // Ctrl-@. // EMUKEY(0x32, 1, 1, 0, 0, 0, "\x00", 1), EMUKEY(0x32, 1, 1, 0, 1, 0, "\x00", 1), // Ctrl-6. // Ctrl-^. EMUKEY(0x36, 1, 1, 0, 0, 0, "\x1E", 1), EMUKEY(0x36, 1, 1, 0, 1, 0, "\x1E", 1), // Ctrl-Space // EMUKEY(VK_SPACE, 1, 1, 0, 0, 0, "\x00", 1), // Ctrl-- key. // EMUKEY(VK_SUBTRACT, 1, 1, 0, 0, 1, "\x1F", 1), }; // VT220 User Defined keys. static STEMUKEYDATA VT220UserDefinedKeys[MAX_UDK_KEYS] = { // NOTE: Do not change the order of these user defined entries. // emuDecDefineUDK assumes a 1:1 correspondance with this // table and the UDKSelector table defined below. // // Initialize Virtual and Shift flags. // EMUKEY(VK_F6, 1, 0, 0, 1, 0, 0, 0), EMUKEY(VK_F7, 1, 0, 0, 1, 0, 0, 0), EMUKEY(VK_F8, 1, 0, 0, 1, 0, 0, 0), EMUKEY(VK_F9, 1, 0, 0, 1, 0, 0, 0), EMUKEY(VK_F10, 1, 0, 0, 1, 0, 0, 0), // Initialize Virtual and Alt flags. // EMUKEY(VK_F1, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F2, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F3, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F4, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F5, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F6, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F7, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F8, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F9, 1, 0, 1, 0, 0, 0, 0), EMUKEY(VK_F10, 1, 0, 1, 0, 0, 0, 0), }; // NOTE: Do not change the order of these entries. // There is a 1:1 correspondance between this table and the // user defined key table defined above. // static TCHAR const acUDKSelectors[MAX_UDK_KEYS] = { TEXT('\x17'), TEXT('\x18'), TEXT('\x19'), TEXT('\x20'), // F6 - F9 TEXT('\x21'), TEXT('\x23'), TEXT('\x24'), TEXT('\x25'), // F10 - F13 TEXT('\x26'), TEXT('\x28'), TEXT('\x29'), TEXT('\x31'), // F14 - F17 TEXT('\x32'), TEXT('\x33'), TEXT('\x34'), // F18 - F20 }; emuInstallStateTable(hhEmu, vt220_tbl, DIM(vt220_tbl)); // Allocate space for and initialize data that is used only by the // VT220 emulator. // hhEmu->pvPrivate = malloc(sizeof(DECPRIVATE)); if (hhEmu->pvPrivate == 0) { assert(FALSE); return; } pstPRI = (PSTDECPRIVATE)hhEmu->pvPrivate; memset(pstPRI, 0, sizeof(DECPRIVATE)); // NOTE: The order of these definitions directly correspond to the // search order used by the emuDecKeyboardIn function. // Don't change these. // // In shared code, these are all part of hhEmu. pstPRI->pstcEmuKeyTbl1 = VT220StdPfKeyTable; pstPRI->pstcEmuKeyTbl2 = VT220MovedPfKeyTable; pstPRI->pstcEmuKeyTbl3 = VT220KeypadNumericMode; pstPRI->pstcEmuKeyTbl4 = VT220KeypadApplicationMode; pstPRI->pstcEmuKeyTbl5 = VT220CursorKeyMode; pstPRI->pstcEmuKeyTbl6 = VT220StandardKeys; pstPRI->iKeyTable1Entries = DIM(VT220StdPfKeyTable); pstPRI->iKeyTable2Entries = DIM(VT220MovedPfKeyTable); pstPRI->iKeyTable3Entries = DIM(VT220KeypadNumericMode); pstPRI->iKeyTable4Entries = DIM(VT220KeypadApplicationMode); pstPRI->iKeyTable5Entries = DIM(VT220CursorKeyMode); pstPRI->iKeyTable6Entries = DIM(VT220StandardKeys); // Allocate an array to hold line attribute values. // pstPRI->aiLineAttr = malloc(MAX_EMUROWS * sizeof(int) ); if (pstPRI->aiLineAttr == 0) { assert(FALSE); return; } for (iRow = 0; iRow < MAX_EMUROWS; iRow++) pstPRI->aiLineAttr[iRow] = NO_LINE_ATTR; pstPRI->sv_row = 0; pstPRI->sv_col = 0; pstPRI->gn = 0; pstPRI->sv_AWM = RESET; pstPRI->sv_DECOM = RESET; pstPRI->sv_protectmode = FALSE; pstPRI->fAttrsSaved = FALSE; pstPRI->pntr = pstPRI->storage; // Initialize hhEmu values for VT220. // hhEmu->emu_setcurpos = emuDecSetCurPos; hhEmu->emu_deinstall = emuDecUnload; hhEmu->emu_clearline = emuDecClearLine; hhEmu->emu_clearscreen = emuDecClearScreen; hhEmu->emu_kbdin = emuDecKeyboardIn; hhEmu->emuResetTerminal = vt220_reset; hhEmu->emu_graphic = emuDecGraphic; // hhEmu->emu_scroll = emuDecScroll; #if !defined(FAR_EAST) hhEmu->emu_highchar = 0x7E; #else hhEmu->emu_highchar = 0xFFFF; #endif hhEmu->emu_maxcol = VT_MAXCOL_80MODE; hhEmu->fUse8BitCodes = FALSE; hhEmu->mode_vt220 = FALSE; hhEmu->mode_vt320 = FALSE; //hhEmu->vt220_protectmode = FALSE; hhEmu->mode_protect = FALSE; if (hhEmu->nEmuLoaded == EMU_VT220) hhEmu->mode_vt220 = TRUE; else if (hhEmu->nEmuLoaded == EMU_VT320) hhEmu->mode_vt320 = TRUE; else assert(FALSE); // UNDO:rde // pstPRI->vt220_protimg = 0; pstPRI->pstUDK = VT220UserDefinedKeys; pstPRI->iUDKTableEntries= DIM(VT220UserDefinedKeys); pstPRI->pacUDKSelectors = acUDKSelectors; pstPRI->iUDKState = KEY_NUMBER_NEXT; std_dsptbl(hhEmu, TRUE); vt_charset_init(hhEmu); switch(hhEmu->stUserSettings.nEmuId) { case EMU_VT220: hhEmu->mode_vt220 = TRUE; hhEmu->mode_vt320 = FALSE; vt220_reset(hhEmu, FALSE); break; case EMU_VT320: hhEmu->mode_vt220 = FALSE; hhEmu->mode_vt320 = TRUE; break; default: assert(FALSE); break; } backscrlSetShowFlag(sessQueryBackscrlHdl(hhEmu->hSession), TRUE); return; } #endif // INCL_VT220 /* end of vt220ini.c */