mirror of
https://github.com/leahneukirchen/cwm.git
synced 2023-08-10 21:13:12 +03:00
Rework the alt-tabbing code to be a lot simpler.
Diff mostly from Edd Barrett, with some minor changes from me. Unfortunately the issue where apps like gvim and xpdf are stealing keyrelease events causing the ordering to be messed up, but this is a lot better. A fix for the aforementioned issue shall be forthcoming, once a good one's been found. ok okan@, also tested by todd@
This commit is contained in:
parent
79569a4d59
commit
cd0ce46817
2
calmwm.h
2
calmwm.h
@ -82,8 +82,6 @@ struct screen_ctx {
|
|||||||
|
|
||||||
struct cycle_entry_q mruq;
|
struct cycle_entry_q mruq;
|
||||||
|
|
||||||
struct client_ctx* cycle_client;
|
|
||||||
|
|
||||||
struct fonthash fonthash;
|
struct fonthash fonthash;
|
||||||
XftDraw *xftdraw;
|
XftDraw *xftdraw;
|
||||||
XftColor xftcolor;
|
XftColor xftcolor;
|
||||||
|
86
client.c
86
client.c
@ -21,8 +21,6 @@
|
|||||||
#include "headers.h"
|
#include "headers.h"
|
||||||
#include "calmwm.h"
|
#include "calmwm.h"
|
||||||
|
|
||||||
static struct client_ctx *client__cycle(struct client_ctx *cc,
|
|
||||||
struct client_ctx *(*iter)(struct client_ctx *));
|
|
||||||
int _inwindowbounds(struct client_ctx *, int, int);
|
int _inwindowbounds(struct client_ctx *, int, int);
|
||||||
|
|
||||||
static char emptystring[] = "";
|
static char emptystring[] = "";
|
||||||
@ -231,9 +229,6 @@ client_delete(struct client_ctx *cc, int sendevent, int ignorewindow)
|
|||||||
if (_curcc == cc)
|
if (_curcc == cc)
|
||||||
_curcc = NULL;
|
_curcc = NULL;
|
||||||
|
|
||||||
if (sc->cycle_client == cc)
|
|
||||||
sc->cycle_client = NULL;
|
|
||||||
|
|
||||||
XFree(cc->size);
|
XFree(cc->size);
|
||||||
|
|
||||||
while ((wn = TAILQ_FIRST(&cc->nameq)) != NULL) {
|
while ((wn = TAILQ_FIRST(&cc->nameq)) != NULL) {
|
||||||
@ -595,50 +590,47 @@ match:
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* TODO: seems to have some issues still on the first invocation
|
|
||||||
* (globally the first)
|
|
||||||
*/
|
|
||||||
|
|
||||||
struct client_ctx *
|
struct client_ctx *
|
||||||
client_cyclenext(int reverse)
|
client_cyclenext(int reverse)
|
||||||
{
|
{
|
||||||
struct screen_ctx *sc;
|
struct client_ctx *oldcc = client_current(), *newcc;
|
||||||
struct client_ctx *cc;
|
struct screen_ctx *sc = screen_current();
|
||||||
struct client_ctx *(*iter)(struct client_ctx *) =
|
int again = 1;
|
||||||
reverse ? &client_mruprev : &client_mrunext;
|
|
||||||
|
|
||||||
/* TODO: maybe this should just be a CIRCLEQ. */
|
/* If no windows then you cant cycle */
|
||||||
|
if (TAILQ_EMPTY(&sc->mruq))
|
||||||
if ((cc = client_current()) == NULL) {
|
|
||||||
if (TAILQ_EMPTY(&Clientq))
|
|
||||||
return(NULL);
|
|
||||||
cc = TAILQ_FIRST(&Clientq);
|
|
||||||
}
|
|
||||||
|
|
||||||
sc = CCTOSC(cc);
|
|
||||||
|
|
||||||
/* if altheld; then reset the iterator to the beginning */
|
|
||||||
if (!sc->altpersist || sc->cycle_client == NULL)
|
|
||||||
sc->cycle_client = TAILQ_FIRST(&sc->mruq);
|
|
||||||
|
|
||||||
if (sc->cycle_client == NULL)
|
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
/*
|
if (oldcc == NULL)
|
||||||
* INVARIANT: as long as sc->cycle_client != NULL here, we
|
oldcc = (reverse ? TAILQ_LAST(&sc->mruq, cycle_entry_q) :
|
||||||
* won't exit with sc->cycle_client == NULL
|
TAILQ_FIRST(&sc->mruq));
|
||||||
*/
|
|
||||||
|
|
||||||
if ((sc->cycle_client = client__cycle(cc, iter)) == NULL)
|
newcc = oldcc;
|
||||||
sc->cycle_client = cc;
|
while (again) {
|
||||||
|
again = 0;
|
||||||
|
|
||||||
/* Do the actual warp. */
|
newcc = (reverse ? client_mruprev(newcc) :
|
||||||
client_ptrsave(cc);
|
client_mrunext(newcc));
|
||||||
client_ptrwarp(sc->cycle_client);
|
|
||||||
sc->altpersist = 1; /* This is reset when alt is let go... */
|
|
||||||
|
|
||||||
return (sc->cycle_client);
|
/* Only cycle visible windows. */
|
||||||
|
if (newcc->flags & CLIENT_HIDDEN)
|
||||||
|
again = 1;
|
||||||
|
|
||||||
|
/* Is oldcc the only non-hidden window? */
|
||||||
|
if (newcc == oldcc) {
|
||||||
|
if (again)
|
||||||
|
return (NULL); /* No windows visible. */
|
||||||
|
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
done:
|
||||||
|
/* reset when alt is released. XXX I hate this hack */
|
||||||
|
sc->altpersist = 1;
|
||||||
|
client_ptrsave(oldcc);
|
||||||
|
client_ptrwarp(newcc);
|
||||||
|
|
||||||
|
return (newcc);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct client_ctx *
|
struct client_ctx *
|
||||||
@ -661,20 +653,6 @@ client_mruprev(struct client_ctx *cc)
|
|||||||
ccc : TAILQ_LAST(&sc->mruq, cycle_entry_q));
|
ccc : TAILQ_LAST(&sc->mruq, cycle_entry_q));
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct client_ctx *
|
|
||||||
client__cycle(struct client_ctx *cc,
|
|
||||||
struct client_ctx *(*iter)(struct client_ctx *))
|
|
||||||
{
|
|
||||||
struct client_ctx *save = cc;
|
|
||||||
|
|
||||||
do {
|
|
||||||
if (!((cc = (*iter)(cc))->flags & CLIENT_HIDDEN))
|
|
||||||
break;
|
|
||||||
} while (cc != save);
|
|
||||||
|
|
||||||
return (cc != save ? cc : NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
client_placecalc(struct client_ctx *cc)
|
client_placecalc(struct client_ctx *cc)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user