-rw-r--r-- | noncore/apps/keyz-cfg/zkbnames.cpp | 3 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbnames.h | 4 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbxml.cpp | 14 |
3 files changed, 0 insertions, 21 deletions
diff --git a/noncore/apps/keyz-cfg/zkbnames.cpp b/noncore/apps/keyz-cfg/zkbnames.cpp index fec3a2e..c20a114 100644 --- a/noncore/apps/keyz-cfg/zkbnames.cpp +++ b/noncore/apps/keyz-cfg/zkbnames.cpp @@ -1,130 +1,128 @@ -#ifdef USE_ZKB_NAMES - #include <qmap.h> #include <qstring.h> #include "zkbnames.h" QString Null_String((const char*) 0); // Implementation of KeyNames static struct { int key; char *name; } Key_Names[] = { { 32, "Space" }, { 39, "Apostrophe" }, { 44, "Comma" }, { 46, "Period" }, { 47, "Slash" }, { 65, "A" }, { 66, "B" }, { 67, "C" }, { 68, "D" }, { 69, "E" }, { 70, "F" }, { 71, "G" }, { 72, "H" }, { 73, "I" }, { 74, "J" }, { 75, "K" }, { 76, "L" }, { 77, "M" }, { 78, "N" }, { 79, "O" }, { 80, "P" }, { 81, "Q" }, { 82, "R" }, { 83, "S" }, { 84, "T" }, { 85, "U" }, { 86, "V" }, { 87, "W" }, { 88, "X" }, { 89, "Y" }, { 90, "Z" }, { 4096, "Cancel" }, { 4097, "Tab" }, { 4099, "Backspace" }, { 4100, "Enter" }, { 4114, "Left" }, { 4115, "Up" }, { 4116, "Right" }, { 4117, "Down" }, { 4128, "Left Shift" }, { 4130, "Right Shift" }, { 4152, "Calendar" }, { 4153, "Addressbook" }, { 4154, "Menu" }, { 4155, "Home" }, { 4156, "Mail" }, { 4165, "Fn" }, { 4173, "Middle" }, { 4176, "OK" }, { 4177, "Off" }, { 4178, "Light" }, { 0, 0 } }; static QMap<QString, int> kn_map; static QMap<int, QString> kn_rmap; void init_kn_maps() { int i = 0; while (Key_Names[i].name != 0) { int key = Key_Names[i].key; QString name(Key_Names[i].name); kn_map.insert(name, key); kn_rmap.insert(key, name); i++; } } int KeyNames::find(const QString& key) { if (kn_map.isEmpty()) { init_kn_maps(); } QMap<QString, int>::Iterator it = kn_map.find(key); if (it == kn_map.end()) { return -1; } else { return it.data(); } } const QString& KeyNames::find(int k) { if (kn_map.isEmpty()) { init_kn_maps(); } QMap<int, QString>::Iterator it = kn_rmap.find(k); if (it == kn_rmap.end()) { return Null_String; } else { return it.data(); } } // Implementation of ModifierNames struct { int value; char* name; } Modifier_Names[] = { { 8, "Shift" }, { 16, "Control" }, { 32, "Alt" }, { 0x4000, "Keypad" }, { 0, 0 } }; static QMap<QString, int> mn_map; static QMap<int, QString> mn_rmap; void init_mn_maps() { int i = 0; while (Modifier_Names[i].name != 0) { int value = Modifier_Names[i].value; QString name(Modifier_Names[i].name); @@ -322,129 +320,128 @@ struct { { "hyphen", 0x0ad }, { "registered", 0x0ae }, { "macron", 0x0af }, { "degree", 0x0b0 }, { "plusminus", 0x0b1 }, { "twosuperior", 0x0b2 }, { "threesuperior", 0x0b3 }, { "acute", 0x0b4 }, { "mu", 0x0b5 }, { "paragraph", 0x0b6 }, { "periodcentered", 0x0b7 }, { "cedilla", 0x0b8 }, { "onesuperior", 0x0b9 }, { "masculine", 0x0ba }, { "guillemotright", 0x0bb }, { "onequarter", 0x0bc }, { "onehalf", 0x0bd }, { "threequarters", 0x0be }, { "questiondown", 0x0bf }, { "Agrave", 0x0c0 }, { "Aacute", 0x0c1 }, { "Acircumflex", 0x0c2 }, { "Atilde", 0x0c3 }, { "Adiaeresis", 0x0c4 }, { "Aring", 0x0c5 }, { "AE", 0x0c6 }, { "Ccedilla", 0x0c7 }, { "Egrave", 0x0c8 }, { "Eacute", 0x0c9 }, { "Ecircumflex", 0x0ca }, { "Ediaeresis", 0x0cb }, { "Igrave", 0x0cc }, { "Iacute", 0x0cd }, { "Icircumflex", 0x0ce }, { "Idiaeresis", 0x0cf }, { "ETH", 0x0d0 }, { "Ntilde", 0x0d1 }, { "Ograve", 0x0d2 }, { "Oacute", 0x0d3 }, { "Ocircumflex", 0x0d4 }, { "Otilde", 0x0d5 }, { "Odiaeresis", 0x0d6 }, { "multiply", 0x0d7 }, { "Ooblique", 0x0d8 }, { "Ugrave", 0x0d9 }, { "Uacute", 0x0da }, { "Ucircumflex", 0x0db }, { "Udiaeresis", 0x0dc }, { "Yacute", 0x0dd }, { "THORN", 0x0de }, { "ssharp", 0x0df }, { "agrave", 0x0e0 }, { "aacute", 0x0e1 }, { "acircumflex", 0x0e2 }, { "atilde", 0x0e3 }, { "adiaeresis", 0x0e4 }, { "aring", 0x0e5 }, { "ae", 0x0e6 }, { "ccedilla", 0x0e7 }, { "egrave", 0x0e8 }, { "eacute", 0x0e9 }, { "ecircumflex", 0x0ea }, { "ediaeresis", 0x0eb }, { "igrave", 0x0ec }, { "iacute", 0x0ed }, { "icircumflex", 0x0ee }, { "idiaeresis", 0x0ef }, { "eth", 0x0f0 }, { "ntilde", 0x0f1 }, { "ograve", 0x0f2 }, { "oacute", 0x0f3 }, { "ocircumflex", 0x0f4 }, { "otilde", 0x0f5 }, { "odiaeresis", 0x0f6 }, { "division", 0x0f7 }, { "oslash", 0x0f8 }, { "ugrave", 0x0f9 }, { "uacute", 0x0fa }, { "ucircumflex", 0x0fb }, { "udiaeresis", 0x0fc }, { "yacute", 0x0fd }, { "thorn", 0x0fe }, { "ydiaeresis", 0x0ff }, { "unknown", 0xffff }, { 0, 0} }; static QMap<QString, int> kcn_map; static QMap<int, QString> kcn_rmap; void init_kcn_maps() { int i = 0; while (Keycode_Names[i].name != 0) { int keycode = Keycode_Names[i].keycode; QString name(Keycode_Names[i].name); kcn_map.insert(name, keycode); kcn_rmap.insert(keycode, name); i++; } } int KeycodeNames::find(const QString& key) { if (kcn_map.isEmpty()) { init_kcn_maps(); } QMap<QString, int>::Iterator it = kcn_map.find(key); if (it == kcn_map.end()) { return -1; } else { return it.data(); } } const QString& KeycodeNames::find(int k) { if (kcn_map.isEmpty()) { init_kcn_maps(); } QMap<int, QString>::Iterator it = kcn_rmap.find(k); if (it == kcn_rmap.end()) { return Null_String; } else { return it.data(); } } -#endif diff --git a/noncore/apps/keyz-cfg/zkbnames.h b/noncore/apps/keyz-cfg/zkbnames.h index 58462ff..0d1e7f5 100644 --- a/noncore/apps/keyz-cfg/zkbnames.h +++ b/noncore/apps/keyz-cfg/zkbnames.h @@ -1,27 +1,23 @@ #ifndef ZKBNAMES_H #define ZKBNAMES_H -#ifdef USE_ZKB_NAMES - #include <qstring.h> class KeyNames { public: static int find(const QString& key); static const QString& find(int); }; class KeycodeNames { public: static int find(const QString& key); static const QString& find(int); }; class ModifierNames { public: static int find(const QString& key); static const QString& find(int); }; - -#endif #endif diff --git a/noncore/apps/keyz-cfg/zkbxml.cpp b/noncore/apps/keyz-cfg/zkbxml.cpp index 76472cb..5b0084c 100644 --- a/noncore/apps/keyz-cfg/zkbxml.cpp +++ b/noncore/apps/keyz-cfg/zkbxml.cpp @@ -364,224 +364,210 @@ bool ZkbXmlHandler::start_event(const QXmlAttributes& attr) { bool autorepeat = false; if (elements.first() != Map_Tag) { setError("event element should be used only " "within map element"); return false; } if (kidx >= 0) { keycode = str2keycode(attr.value(kidx)); if (!err.isEmpty()) { return false; } nattr++; } else { setError("Missing keycode attribute"); return false; } if (uidx >= 0) { unicode = str2unicode(attr.value(uidx)); if (!err.isEmpty()) { return false; } nattr++; } else { setError("Missing unicode attribute"); return false; } if (midx >= 0) { modifiers = str2modifier(attr.value(midx)); if (!err.isEmpty()) { return false; } nattr++; } if (pidx >= 0) { pressed = str2bool(attr.value(pidx)); if (!err.isEmpty()) { return false; } nattr++; } else { setError("Missing pressed attribute"); return false; } if (aidx >= 0) { autorepeat = str2bool(attr.value(aidx)); if (!err.isEmpty()) { return false; } nattr++; } if (attr.length() > nattr) { setError("Unsupported attributes"); return false; } return startEventElement(keycode, unicode, modifiers, pressed, autorepeat); } bool ZkbXmlHandler::start_next_state(const QXmlAttributes& attr) { int nattr = 0; int nidx = attr.index("name"); QString name; if (elements.first() != Map_Tag) { setError("next-state element should be used only " "within map element"); return false; } if (nidx >= 0) { name = attr.value(nidx); nattr++; } else { setError("Missing name attribute"); return false; } if (attr.length() > nattr) { setError("Unsupported attributes"); return false; } return startNextStateElement(name); } bool ZkbXmlHandler::end_keymap() { return endKeymapElement(); } bool ZkbXmlHandler::end_include() { return endIncludeElement(); } bool ZkbXmlHandler::end_label() { return endLabelElement(); } bool ZkbXmlHandler::end_state() { return endStateElement(); } bool ZkbXmlHandler::end_map() { return endMapElement(); } bool ZkbXmlHandler::end_event() { return endEventElement(); } bool ZkbXmlHandler::end_next_state() { return endNextStateElement(); } void ZkbXmlHandler::setError(const QString& e) { err = e; } int ZkbXmlHandler::str2key(const QString& s) { int ret; -#ifdef USE_ZKB_NAMES ret = KeyNames::find(s); if (ret == -1) { setError("Invalid value: " + s); } -#else - ret = str2uint(s); -#endif - return ret; } int ZkbXmlHandler::str2modifier(const QString& val) { int ret; -#ifdef USE_ZKB_NAMES int n, i; ret = 0; n = 0; do { i = val.find('|', n); if (i < 0) { i = val.length(); } QString s = val.mid(n, i - n); int v = ModifierNames::find(s.stripWhiteSpace()); if (v == -1) { setError("Invalid value: " + val); return -1; } ret |= v; n = i + 1; } while (n < val.length()); -#else - ret = str2uint(val); -#endif return ret; } bool ZkbXmlHandler::str2bool(const QString& s) { if (s == "true") { return true; } else { return false; } } int ZkbXmlHandler::str2unicode(const QString& s) { return str2uint(s); } int ZkbXmlHandler::str2keycode(const QString& s) { int ret; -#ifdef USE_ZKB_NAMES ret = KeycodeNames::find(s); if (ret == -1) { setError("Invalid value: " + s); } -#else - ret = str2uint(s); -#endif - return ret; } int ZkbXmlHandler::str2uint(const QString& s) { int ret; bool ok; QString val = s; int r; if (val.left(2) == "0x") { val = s.mid(2); r = 16; } else if (val.left(1) == "0") { val = s.mid(1); r = 8; } else { r = 10; } ret = val.toInt(&ok, r); if (!ok) { setError("Invalid value: " + s); ret = -1; } return ret; } |