1 /////////////////////////////////////////////////////////////////// 2 // // 3 // File format : // 4 // // 5 // Comments with a ; in column 1 // 6 // Empty Lines ignored // 7 // The words are separated by a space, a tab, or a plus ("+") // 8 // // 9 // First a [GLOBAL] section : // 10 // [GLOBAL] // 11 // VK_F1 112 // 12 // . // 13 // . // 14 // [END_GLOBAL] // 15 // // 16 // The GLOBAL section defines the names of the keys // 17 // and the virtual key code they have. // 18 // If you repeat a name you'll overwrite the code. // 19 // You can name the keys anything you like // 20 // The Virtual key nymber must be in Decimal // 21 // After the number you can put anything : it is ignored // 22 // Here you must put ALL the keys you'll use in the // 23 // other sections. // 24 // // 25 // Then the emulations sections : // 26 // // 27 // [SCO_ANSI] // 28 // // 29 // VK_F1 \027[M or // 30 // VK_F1 ^[[M or // 31 // VK_F1 SHIFT ^[[W etc // 32 // . // 33 // . // 34 // [SCO_ANSI_END] // 35 // // 36 // There are three parts : // 37 // a) the key name // 38 // b) the shift state // 39 // here you put compination of the words : // 40 // // 41 // RIGHT_ALT // 42 // LEFT_ALT // 43 // RIGHT_CTRL // 44 // LEFT_CTRL // 45 // SHIFT // 46 // NUMLOCK // 47 // SCROLLLOCK // 48 // CAPSLOCK // 49 // ENHANCED // 50 // APP_KEY // 51 // c) the assigned string : // 52 // you can use the ^ for esc (^[ = 0x1b) // 53 // \ and a three digit decimal number // 54 // (\027) // 55 // You can't use the NULL !!! // 56 // Also (for the moment) you can't use spaces // 57 // in the string : everything after the 3rd word is // 58 // ignored - use unsderscore instead. // 59 // // 60 // for example : // 61 // // 62 // VK_F4 SHIFT+LEFT_ALT \0274m^[[M = 0x1b 4 m 0x1b [ M // 63 // VK_F1 RIGHT_CTRL This_is_ctrl_f1 // 64 // // 65 // You may have as many sections as you like // 66 // If you repeat any section (even the GLOBAL) you'll overwrite // 67 // the common parts. // 68 // // 69 /////////////////////////////////////////////////////////////////// 70 71 #pragma once 72 73 //#include "keytrans.h" 74 //#include "tcharmap.h" 75 76 // AVS 77 typedef TArrayAsVector<string> stringArray; 78 79 class TMapLoader { 80 public: TMapLoader(KeyTranslator & RefKeyTrans,TCharmap & RefCharmap)81 TMapLoader(KeyTranslator &RefKeyTrans, TCharmap &RefCharmap): 82 KeyTrans(RefKeyTrans), Charmap(RefCharmap) {} ~TMapLoader()83 ~TMapLoader() {} 84 85 // If called more than once the new map replaces the old one. 86 // load with a different KeysetName to change keysets 87 // Return 0 on error 88 int Load(const char * filename, const char * szKeysetName); 89 90 void Display(); 91 private: 92 KeyTranslator &KeyTrans; 93 TCharmap &Charmap; 94 95 int LookForPart(stringArray& sa, const char* partType, const char* partName); 96 char* ParseKeyDef(const char* buf, WORD& vk_code, DWORD& control); 97 98 int LoadGlobal(string& buf); 99 int LoadKeyMap(string buf); 100 int LoadCharMap(string buf); 101 102 }; 103