summaryrefslogtreecommitdiff
path: root/util
diff options
context:
space:
mode:
authorMarius Nita <marius@cs.pdx.edu>2002-10-14 04:07:44 +0000
committerMarius Nita <marius@cs.pdx.edu>2002-10-14 04:07:44 +0000
commit2037631f753753a5c1ee9b2475b55658c3bb6eea (patch)
tree5b13bf732e46b68b2c3e7004815634a5b8972842 /util
parent5bb8616d44345e1f1896d94af9ea257439234179 (diff)
Fixing the stupid case when an invalid key is given and epist would hog the keyboard
Diffstat (limited to 'util')
-rw-r--r--util/epist/keytree.cc34
1 files changed, 24 insertions, 10 deletions
diff --git a/util/epist/keytree.cc b/util/epist/keytree.cc
index 009cb355..5a3515ea 100644
--- a/util/epist/keytree.cc
+++ b/util/epist/keytree.cc
@@ -29,6 +29,7 @@
#include "config.hh"
#include <string>
+#include <iostream>
using std::string;
@@ -84,18 +85,26 @@ void keytree::grabDefaults(screen *scr)
void keytree::ungrabDefaults(screen *scr)
{
+ Action *act;
+
ChildList::const_iterator it, end = _head->children.end();
- for (it = _head->children.begin(); it != end; ++it)
- if ( (*it)->action && (*it)->action->type() != Action::toggleGrabs)
- scr->ungrabKey( (*it)->action->keycode(), (*it)->action->modifierMask() );
+ for (it = _head->children.begin(); it != end; ++it) {
+ act = (*it)->action;
+ if (act && act->type() != Action::toggleGrabs)
+ scr->ungrabKey(act->keycode(), act->modifierMask());
+ }
}
void keytree::grabChildren(keynode *node, screen *scr)
{
+ Action *act;
+
ChildList::const_iterator it, end = node->children.end();
- for (it = node->children.begin(); it != end; ++it)
- if ( (*it)->action )
- scr->grabKey( (*it)->action->keycode(), (*it)->action->modifierMask() );
+ for (it = node->children.begin(); it != end; ++it) {
+ act = (*it)->action;
+ if (act)
+ scr->grabKey(act->keycode(), act->modifierMask());
+ }
}
void keytree::ungrabChildren(keynode *node, screen *scr)
@@ -178,8 +187,6 @@ const Action * keytree::getAction(const XEvent &e, unsigned int state,
void keytree::addAction(Action::ActionType action, unsigned int mask,
string key, string arg)
{
- keynode *tmp = new keynode;
-
if (action == Action::toggleGrabs && _current != _head) {
// the toggleGrabs key can only be set up as a root key, since if
// it was a chain key, we'd have to not ungrab the whole chain up
@@ -187,9 +194,16 @@ void keytree::addAction(Action::ActionType action, unsigned int mask,
return;
}
+ KeySym sym = XStringToKeysym(key.c_str());
+
+ if (sym == 0) {
+ std::cerr << "Key " << key << " is invalid! (Action ignored)\n";
+ return;
+ }
+
+ keynode *tmp = new keynode;
tmp->action = new Action(action,
- XKeysymToKeycode(_display,
- XStringToKeysym(key.c_str())),
+ XKeysymToKeycode(_display, sym),
mask, arg);
tmp->parent = _current;
_current->children.push_back(tmp);