From a7705024c6a9934123e8249143671b08483f47cd Mon Sep 17 00:00:00 2001 From: Dana Jansens Date: Wed, 19 Mar 2003 08:40:00 +0000 Subject: [PATCH] all the old ob2 mouse bindings are workin --- plugins/focus.c | 4 ++ plugins/mouse/mouse.c | 94 ++++++++++++++++++++++++++++++++----------- 2 files changed, 75 insertions(+), 23 deletions(-) diff --git a/plugins/focus.c b/plugins/focus.c index f50d9c4b..8a43c759 100644 --- a/plugins/focus.c +++ b/plugins/focus.c @@ -21,9 +21,13 @@ static void focus_fallback(guint desk, gboolean warp) doesn't skip briefly to what was under the pointer */ if (XCheckTypedEvent(ob_display, EnterNotify, &e)) { XPutBackEvent(ob_display, &e); + /* XXX WERE NOT SKIPPING THEM ALL@&*)! */ + g_message("Skip"); ++skip_enter; } + /* I have to do this warp twice! Otherwise windows dont get + Enter/Leave events when i warp on a desktop switch! */ XWarpPointer(ob_display, None, c->window, 0, 0, 0, 0, c->area.width / 2, c->area.height / 2); XWarpPointer(ob_display, None, c->window, 0, 0, 0, 0, diff --git a/plugins/mouse/mouse.c b/plugins/mouse/mouse.c index df27dd55..9fc111a9 100644 --- a/plugins/mouse/mouse.c +++ b/plugins/mouse/mouse.c @@ -197,9 +197,7 @@ static void event(ObEvent *e, void *foo) case Event_X_ButtonPress: if (!button) { - if (e->data.x.client == NULL) - corner = Corner_TopLeft; - else { + if (e->data.x.client != NULL) { cx = e->data.x.client->frame->area.x; cy = e->data.x.client->frame->area.y; cw = e->data.x.client->frame->area.width; @@ -207,8 +205,8 @@ static void event(ObEvent *e, void *foo) px = e->data.x.e->xbutton.x_root; py = e->data.x.e->xbutton.y_root; corner = pick_corner(px, py, cx, cy, cw, ch); - button = e->data.x.e->xbutton.button; } + button = e->data.x.e->xbutton.button; } fire_button(MouseAction_Press, engine_get_context(e->data.x.client, @@ -228,26 +226,29 @@ static void event(ObEvent *e, void *foo) e->data.x.e->xbutton.button, cx, cy, cw, ch, dx, dy, TRUE, corner); drag = FALSE; - } - - /* clicks are only valid if its released over the window */ - if (e->data.x.e->xbutton.x >= 0 && e->data.x.e->xbutton.y >= 0) { - int junk; - Window wjunk; - guint ujunk, w, h; - XGetGeometry(ob_display, e->data.x.e->xbutton.window, - &wjunk, &junk, &junk, &w, &h, &ujunk, &ujunk); - if (e->data.x.e->xbutton.x < (signed)w && - e->data.x.e->xbutton.y < (signed)h) { - click =TRUE; - /* double clicks happen if there were 2 in a row! */ - if (lbutton == button && - e->data.x.e->xbutton.time - 300 <= ltime) - dclick = TRUE; - } - lbutton = button; - } else + lbutton = 0; + } else { + /* clicks are only valid if its released over the window */ + if (e->data.x.e->xbutton.x >= 0 && + e->data.x.e->xbutton.y >= 0) { + int junk; + Window wjunk; + guint ujunk, w, h; + XGetGeometry(ob_display, e->data.x.e->xbutton.window, + &wjunk, &junk, &junk, &w, &h, &ujunk, &ujunk); + if (e->data.x.e->xbutton.x < (signed)w && + e->data.x.e->xbutton.y < (signed)h) { + click =TRUE; + /* double clicks happen if there were 2 in a row! */ + if (lbutton == button && + e->data.x.e->xbutton.time - 300 <= ltime) + dclick = TRUE; + } + lbutton = button; + } else + lbutton = 0; + } button = 0; ltime = e->data.x.e->xbutton.time; @@ -366,12 +367,59 @@ static void binddef() a = action_new(action_resize); mbind("A-3", "frame", MouseAction_Motion, a); + a = action_new(action_raise); + mbind("1", "titlebar", MouseAction_Press, a); + a = action_new(action_raise); + mbind("1", "handle", MouseAction_Press, a); + a = action_new(action_lower); + mbind("2", "titlebar", MouseAction_Press, a); + a = action_new(action_lower); + mbind("2", "handle", MouseAction_Press, a); + a = action_new(action_raise); + mbind("A-1", "frame", MouseAction_Click, a); + a = action_new(action_lower); + mbind("A-3", "frame", MouseAction_Click, a); + a = action_new(action_toggle_shade); mbind("1", "titlebar", MouseAction_DClick, a); a = action_new(action_shade); mbind("4", "titlebar", MouseAction_Press, a); a = action_new(action_unshade); mbind("5", "titlebar", MouseAction_Click, a); + + a = action_new(action_toggle_maximize_full); + mbind("1", "maximize", MouseAction_Click, a); + a = action_new(action_toggle_maximize_vert); + mbind("2", "maximize", MouseAction_Click, a); + a = action_new(action_toggle_maximize_horz); + mbind("3", "maximize", MouseAction_Click, a); + a = action_new(action_iconify); + mbind("1", "iconify", MouseAction_Click, a); + a = action_new(action_close); + mbind("1", "icon", MouseAction_DClick, a); + a = action_new(action_close); + mbind("1", "close", MouseAction_Click, a); + a = action_new(action_toggle_omnipresent); + mbind("1", "alldesktops", MouseAction_Click, a); + + a = action_new(action_next_desktop); + a->data.nextprevdesktop.wrap = TRUE; + mbind("4", "root", MouseAction_Click, a); + a = action_new(action_previous_desktop); + a->data.nextprevdesktop.wrap = TRUE; + mbind("5", "root", MouseAction_Click, a); + a = action_new(action_next_desktop); + a->data.nextprevdesktop.wrap = TRUE; + mbind("A-4", "root", MouseAction_Click, a); + a = action_new(action_previous_desktop); + a->data.nextprevdesktop.wrap = TRUE; + mbind("A-5", "root", MouseAction_Click, a); + a = action_new(action_next_desktop); + a->data.nextprevdesktop.wrap = TRUE; + mbind("A-4", "frame", MouseAction_Click, a); + a = action_new(action_previous_desktop); + a->data.nextprevdesktop.wrap = TRUE; + mbind("A-5", "frame", MouseAction_Click, a); } void plugin_startup()