diff options
author | Tarek Soliman | 2012-02-27 13:28:40 -0600 |
---|---|---|
committer | Tarek Soliman | 2012-02-28 06:34:19 -0600 |
commit | 4d1e6c3d54fc692697144ebe2d4799fa67f30203 (patch) | |
tree | 97c33e986f558d19fc44e465a73d2060eec28194 /backends/keymapper | |
parent | 65c60ef02737f9e6a7e4091b622a6a1e0871d6d7 (diff) | |
download | scummvm-rg350-4d1e6c3d54fc692697144ebe2d4799fa67f30203.tar.gz scummvm-rg350-4d1e6c3d54fc692697144ebe2d4799fa67f30203.tar.bz2 scummvm-rg350-4d1e6c3d54fc692697144ebe2d4799fa67f30203.zip |
KEYMAPPER: Move HardwareInputSet implementation out of header file
Diffstat (limited to 'backends/keymapper')
-rw-r--r-- | backends/keymapper/hardware-input.cpp | 109 | ||||
-rw-r--r-- | backends/keymapper/hardware-input.h | 78 |
2 files changed, 119 insertions, 68 deletions
diff --git a/backends/keymapper/hardware-input.cpp b/backends/keymapper/hardware-input.cpp new file mode 100644 index 0000000000..801c77f4aa --- /dev/null +++ b/backends/keymapper/hardware-input.cpp @@ -0,0 +1,109 @@ +/* ScummVM - Graphic Adventure Engine +* +* ScummVM is the legal property of its developers, whose names +* are too numerous to list here. Please refer to the COPYRIGHT +* file distributed with this source distribution. +* +* This program is free software; you can redistribute it and/or +* modify it under the terms of the GNU General Public License +* as published by the Free Software Foundation; either version 2 +* of the License, or (at your option) any later version. +* +* This program is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +* GNU General Public License for more details. +* +* You should have received a copy of the GNU General Public License +* along with this program; if not, write to the Free Software +* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +* +*/ + +#include "backends/keymapper/hardware-input.h" + +#ifdef ENABLE_KEYMAPPER + +#include "backends/keymapper/keymapper.h" + +namespace Common { + +HardwareInputSet::HardwareInputSet(const KeyTableEntry *keys, const ModifierTableEntry *modifiers) { + addHardwareInputs(keys, modifiers); +} + +HardwareInputSet::~HardwareInputSet() { + List<const HardwareInput *>::const_iterator it; + + for (it = _inputs.begin(); it != _inputs.end(); it++) + delete *it; +} + +void HardwareInputSet::addHardwareInput(const HardwareInput *input) { + checkForInput(input); + _inputs.push_back(input); +} + +const HardwareInput *HardwareInputSet::findHardwareInput(String id) const { + List<const HardwareInput *>::const_iterator it; + + for (it = _inputs.begin(); it != _inputs.end(); it++) { + if ((*it)->id == id) + return (*it); + } + return 0; +} + +const HardwareInput *HardwareInputSet::findHardwareInput(const KeyState& keystate) const { + List<const HardwareInput *>::const_iterator it; + + for (it = _inputs.begin(); it != _inputs.end(); it++) { + if ((*it)->key == keystate) + return (*it); + } + return 0; +} + +void HardwareInputSet::addHardwareInputs(const KeyTableEntry keys[], const ModifierTableEntry modifiers[]) { + const KeyTableEntry *key; + const ModifierTableEntry *mod; + char fullKeyId[50]; + char fullKeyDesc[100]; + uint16 ascii; + + for (mod = modifiers; mod->id; mod++) { + for (key = keys; key->hwId; key++) { + ascii = key->ascii; + + if (mod->shiftable && key->shiftable) { + snprintf(fullKeyId, 50, "%s%c", mod->id, toupper(key->hwId[0])); + snprintf(fullKeyDesc, 100, "%s%c", mod->desc, toupper(key->desc[0])); + ascii = toupper(key->ascii); + } else if (mod->shiftable) { + snprintf(fullKeyId, 50, "S+%s%s", mod->id, key->hwId); + snprintf(fullKeyDesc, 100, "Shift+%s%s", mod->desc, key->desc); + } else { + snprintf(fullKeyId, 50, "%s%s", mod->id, key->hwId); + snprintf(fullKeyDesc, 100, "%s%s", mod->desc, key->desc); + } + + addHardwareInput(new HardwareInput(fullKeyId, KeyState(key->keycode, ascii, mod->flag), fullKeyDesc)); + } + } +} + +void HardwareInputSet::checkForInput(const HardwareInput *input) { + List<const HardwareInput *>::iterator it; + + for (it = _inputs.begin(); it != _inputs.end(); it++) { + if ((*it)->id == input->id) + error("Error adding HardwareInput '%s' - id of %s already in use!", input->description.c_str(), input->id.c_str()); + else if ((*it)->key == input->key) + error("Error adding HardwareInput '%s' - key already in use!", input->description.c_str()); + } +} + +} //namespace Common + +#endif // #ifdef ENABLE_KEYMAPPER + diff --git a/backends/keymapper/hardware-input.h b/backends/keymapper/hardware-input.h index 70e0f986fa..eb165e7b8b 100644 --- a/backends/keymapper/hardware-input.h +++ b/backends/keymapper/hardware-input.h @@ -27,6 +27,9 @@ #ifdef ENABLE_KEYMAPPER +#include "common/keyboard.h" +#include "common/list.h" +#include "common/str.h" #include "common/textconsole.h" namespace Common { @@ -85,43 +88,17 @@ public: * @param keys table of available keys * @param modifiers table of available modifiers */ - HardwareInputSet(const KeyTableEntry keys[], const ModifierTableEntry modifiers[]) { - addHardwareInputs(keys, modifiers); - } + HardwareInputSet(const KeyTableEntry keys[], const ModifierTableEntry modifiers[]); HardwareInputSet() { } - virtual ~HardwareInputSet() { - List<const HardwareInput *>::const_iterator it; - - for (it = _inputs.begin(); it != _inputs.end(); it++) - delete *it; - } - - void addHardwareInput(const HardwareInput *input) { - checkForInput(input); - _inputs.push_back(input); - } + virtual ~HardwareInputSet(); - const HardwareInput *findHardwareInput(String id) const { - List<const HardwareInput *>::const_iterator it; + void addHardwareInput(const HardwareInput *input); - for (it = _inputs.begin(); it != _inputs.end(); it++) { - if ((*it)->id == id) - return (*it); - } - return 0; - } + const HardwareInput *findHardwareInput(String id) const; - const HardwareInput *findHardwareInput(const KeyState& keystate) const { - List<const HardwareInput *>::const_iterator it; - - for (it = _inputs.begin(); it != _inputs.end(); it++) { - if ((*it)->key == keystate) - return (*it); - } - return 0; - } + const HardwareInput *findHardwareInput(const KeyState& keystate) const; const List<const HardwareInput *> &getHardwareInputs() const { return _inputs; @@ -136,46 +113,11 @@ public: * @param keys table of available keys * @param modifiers table of available modifiers */ - void addHardwareInputs(const KeyTableEntry keys[], const ModifierTableEntry modifiers[]) { - const KeyTableEntry *key; - const ModifierTableEntry *mod; - char fullKeyId[50]; - char fullKeyDesc[100]; - uint16 ascii; - - for (mod = modifiers; mod->id; mod++) { - for (key = keys; key->hwId; key++) { - ascii = key->ascii; - - if (mod->shiftable && key->shiftable) { - snprintf(fullKeyId, 50, "%s%c", mod->id, toupper(key->hwId[0])); - snprintf(fullKeyDesc, 100, "%s%c", mod->desc, toupper(key->desc[0])); - ascii = toupper(key->ascii); - } else if (mod->shiftable) { - snprintf(fullKeyId, 50, "S+%s%s", mod->id, key->hwId); - snprintf(fullKeyDesc, 100, "Shift+%s%s", mod->desc, key->desc); - } else { - snprintf(fullKeyId, 50, "%s%s", mod->id, key->hwId); - snprintf(fullKeyDesc, 100, "%s%s", mod->desc, key->desc); - } - - addHardwareInput(new HardwareInput(fullKeyId, KeyState(key->keycode, ascii, mod->flag), fullKeyDesc)); - } - } - } + void addHardwareInputs(const KeyTableEntry keys[], const ModifierTableEntry modifiers[]); private: - void checkForInput(const HardwareInput *input) { - List<const HardwareInput *>::iterator it; - - for (it = _inputs.begin(); it != _inputs.end(); it++) { - if ((*it)->id == input->id) - error("Error adding HardwareInput '%s' - id of %s already in use!", input->description.c_str(), input->id.c_str()); - else if ((*it)->key == input->key) - error("Error adding HardwareInput '%s' - key already in use!", input->description.c_str()); - } - } + void checkForInput(const HardwareInput *input); List<const HardwareInput *> _inputs; }; |