aboutsummaryrefslogtreecommitdiff
path: root/backends/keymapper
diff options
context:
space:
mode:
authorTarek Soliman2012-02-27 13:28:40 -0600
committerTarek Soliman2012-02-28 06:34:19 -0600
commit4d1e6c3d54fc692697144ebe2d4799fa67f30203 (patch)
tree97c33e986f558d19fc44e465a73d2060eec28194 /backends/keymapper
parent65c60ef02737f9e6a7e4091b622a6a1e0871d6d7 (diff)
downloadscummvm-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.cpp109
-rw-r--r--backends/keymapper/hardware-input.h78
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;
};