summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--app/cwm/xevents.c30
1 files changed, 14 insertions, 16 deletions
diff --git a/app/cwm/xevents.c b/app/cwm/xevents.c
index abdc2b8ea..299993d4e 100644
--- a/app/cwm/xevents.c
+++ b/app/cwm/xevents.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: xevents.c,v 1.21 2008/06/17 20:21:17 oga Exp $
+ * $Id: xevents.c,v 1.22 2008/06/17 20:55:48 oga Exp $
*/
/*
@@ -228,26 +228,24 @@ xev_handle_buttonpress(struct xevent *xev, XEvent *ee)
cc = client_find(e->window);
- if (e->window == sc->rootwin) {
- TAILQ_FOREACH(mb, &Conf.mousebindingq, entry) {
- if (e->button == mb->button && e->state == mb->modmask
- && mb->context == MOUSEBIND_CTX_ROOT) {
- (*mb->callback)(cc, e);
- break;
- }
- }
+ TAILQ_FOREACH(mb, &Conf.mousebindingq, entry) {
+ if (e->button == mb->button && e->state == mb->modmask)
+ break;
}
- if (cc == NULL || e->state == 0)
+ if (mb == NULL)
goto out;
- TAILQ_FOREACH(mb, &Conf.mousebindingq, entry) {
- if (e->button == mb->button && e->state == mb->modmask &&
- mb->context == MOUSEBIND_CTX_ROOT) {
- (*mb->callback)(cc, NULL);
- break;
- }
+ if (mb->context == MOUSEBIND_CTX_ROOT) {
+ if (e->window != sc->rootwin)
+ goto out;
+ } else if (mb->context == MOUSEBIND_CTX_WIN) {
+ cc = client_find(e->window);
+ if (cc == NULL)
+ goto out;
}
+
+ (*mb->callback)(cc, e);
out:
xev_register(xev);
}