aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoroga2008-05-19 15:17:50 +0000
committeroga2008-05-19 15:17:50 +0000
commita47b4ccaab4803eba1fb0774e26abd3ed06f9fd4 (patch)
treed464c9dc57d07c9f8085f6e6aa2865ba49f13fcb
parent281da1fba3c4cf7c09351c088ec4f5793f9ce96e (diff)
downloadcwm-a47b4ccaab4803eba1fb0774e26abd3ed06f9fd4.tar.gz
Use the XGrabKeyboard hack in for alt-tabbing as well. This stops the
mru getting the order messed up when gvim/xpdf et all steal key events. While i'm here, change the logic in client_cyclenext() to use break instead of goto, it's nicer that way. Thirdly, instead of two different kbfuncs, just use the one and a flag. "put your cycle diff in so I can pkg_delete gvim" okan@
-rw-r--r--calmwm.h5
-rw-r--r--client.c6
-rw-r--r--conf.c6
-rw-r--r--kbfunc.c14
4 files changed, 17 insertions, 14 deletions
diff --git a/calmwm.h b/calmwm.h
index 9c65680..78c0268 100644
--- a/calmwm.h
+++ b/calmwm.h
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $Id: calmwm.h,v 1.42 2008/05/19 12:56:58 okan Exp $
+ * $Id: calmwm.h,v 1.43 2008/05/19 15:17:50 oga Exp $
*/
#ifndef _CALMWM_H_
@@ -221,6 +221,9 @@ TAILQ_HEAD(winmatch_q, winmatch);
/* for cwm_exec */
#define CWM_EXEC_PROGRAM 0x1
#define CWM_EXEC_WM 0x2
+/* For alt-tab */
+#define CWM_CYCLE 0x0
+#define CWM_RCYCLE 0x1
#define KBFLAG_NEEDCLIENT 0x01
diff --git a/client.c b/client.c
index b869ab5..5d9f185 100644
--- a/client.c
+++ b/client.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $Id: client.c,v 1.24 2008/05/19 12:56:58 okan Exp $
+ * $Id: client.c,v 1.25 2008/05/19 15:17:50 oga Exp $
*/
#include "headers.h"
@@ -620,10 +620,10 @@ client_cyclenext(int reverse)
if (again)
return (NULL); /* No windows visible. */
- goto done;
+ break;
}
}
-done:
+
/* reset when alt is released. XXX I hate this hack */
sc->altpersist = 1;
client_ptrsave(oldcc);
diff --git a/conf.c b/conf.c
index 7197449..3c4adb9 100644
--- a/conf.c
+++ b/conf.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $Id: conf.c,v 1.32 2008/05/19 12:56:58 okan Exp $
+ * $Id: conf.c,v 1.33 2008/05/19 15:17:50 oga Exp $
*/
#include "headers.h"
@@ -209,8 +209,8 @@ struct {
{ "search", kbfunc_client_search, 0, 0 },
{ "menusearch", kbfunc_menu_search, 0, 0 },
{ "hide", kbfunc_client_hide, KBFLAG_NEEDCLIENT, 0 },
- { "cycle", kbfunc_client_cycle, 0, 0 },
- { "rcycle", kbfunc_client_rcycle, 0, 0 },
+ { "cycle", kbfunc_client_cycle, 0, (void *)CWM_CYCLE },
+ { "rcycle", kbfunc_client_cycle, 0, (void *)CWM_RCYCLE },
{ "label", kbfunc_client_label, KBFLAG_NEEDCLIENT, 0 },
{ "delete", kbfunc_client_delete, KBFLAG_NEEDCLIENT, 0 },
{ "group1", kbfunc_client_group, 0, (void *)1 },
diff --git a/kbfunc.c b/kbfunc.c
index ef5d0da..7c98c37 100644
--- a/kbfunc.c
+++ b/kbfunc.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $Id: kbfunc.c,v 1.23 2008/05/19 12:56:58 okan Exp $
+ * $Id: kbfunc.c,v 1.24 2008/05/19 15:17:50 oga Exp $
*/
#include <paths.h>
@@ -176,13 +176,13 @@ kbfunc_menu_search(struct client_ctx *scratch, void *arg)
void
kbfunc_client_cycle(struct client_ctx *scratch, void *arg)
{
- client_cyclenext(0);
-}
+ struct screen_ctx *sc = screen_current();
-void
-kbfunc_client_rcycle(struct client_ctx *scratch, void *arg)
-{
- client_cyclenext(1);
+ /* XXX for X apps that ignore events */
+ XGrabKeyboard(X_Dpy, sc->rootwin, True,
+ GrabModeAsync, GrabModeAsync, CurrentTime);
+
+ client_cyclenext((int)arg);
}
void