toggleGrabs action added
authorMarius Nita <marius@cs.pdx.edu>
Thu, 22 Aug 2002 18:19:57 +0000 (18:19 +0000)
committerMarius Nita <marius@cs.pdx.edu>
Thu, 22 Aug 2002 18:19:57 +0000 (18:19 +0000)
util/epist/actions.hh
util/epist/keytree.cc
util/epist/parser.cc
util/epist/screen.cc
util/epist/screen.hh

index 89b99ec..6fdd48f 100644 (file)
@@ -89,6 +89,7 @@ public:
     showWorkspaceMenu,
     toggleDecorations,
 
+    toggleGrabs,
     stringChain, 
     keyChain,
     numberChain,
index e9fa2ca..6dcba31 100644 (file)
@@ -82,7 +82,7 @@ void keytree::ungrabDefaults(screen *scr)
 {
   ChildList::const_iterator it, end = _head->children.end();
   for (it = _head->children.begin(); it != end; ++it)
-    if ( (*it)->action )
+    if ( (*it)->action && (*it)->action->type() != Action::toggleGrabs)
       scr->ungrabKey( (*it)->action->keycode(), (*it)->action->modifierMask() );
 }
 
@@ -175,6 +175,14 @@ 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
+    // to that key. which kinda defeats the purpose of this function.
+    return;
+  }
+
   tmp->action = new Action(action,
                            XKeysymToKeycode(_display,
                                             XStringToKeysym(key.c_str())),
index 548212c..d7ac2c1 100644 (file)
@@ -102,6 +102,7 @@ void parser::setAction(string act)
     { "showrootmenu", Action::showRootMenu },
     { "showworkspacemenu", Action::showWorkspaceMenu },
     { "toggledecorations", Action::toggleDecorations },
+    { "togglegrabs", Action::toggleGrabs },
     { "stringchain", Action::stringChain },
     { "keychain", Action::keyChain },
     { "numberchain", Action::numberChain },
index 2862b87..0f8dfa5 100644 (file)
@@ -59,6 +59,7 @@ screen::screen(epist *epist, int number)
   _number = number;
   _info = _epist->getScreenInfo(_number);
   _root = _info->getRootWindow();
+  _grabbed = true;
 
   // find a window manager supporting NETWM, waiting for it to load if we must
   int count = 20;  // try for 20 seconds
@@ -151,8 +152,9 @@ void screen::handleKeypress(const XEvent &e) {
   // Mask out the lock modifiers. We want our keys to always work
   // This should be made an option
   unsigned int state = e.xkey.state & ~(LockMask|scrolllockMask|numlockMask);
-  const Action *it = _epist->getKeyTree().getAction(e, state, this);
-  
+  keytree &ktree = _epist->getKeyTree();
+  const Action *it = ktree.getAction(e, state, this);
+
   if (!it)
     return;
 
@@ -252,6 +254,17 @@ void screen::handleKeypress(const XEvent &e) {
                               None);
     return;
 
+  case Action::toggleGrabs: {
+    if (_grabbed) {
+      ktree.ungrabDefaults(this);
+      _grabbed = false;
+    } else {
+      ktree.grabDefaults(this);
+      _grabbed = true;
+    }
+    return;
+  }
+
   default:
     break;
   }
index 98f8a35..34e3c77 100644 (file)
@@ -53,6 +53,7 @@ class screen {
   unsigned int _num_desktops;
 
   bool _managed;
+  bool _grabbed; // used for keygrab toggle function
 
   XWindow *findWindow(const XEvent &e) const;
   void updateNumDesktops();