summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-09-02 17:54:11 +0000
committerDana Jansens <danakj@orodu.net>2003-09-02 17:54:11 +0000
commit0223fed117a2c136d7a4001f4758b780c6712918 (patch)
tree0eacb6945ee4745130f6a0646a4532c3330b2c0e
parent67f9061a7a8d28b1859bc19baad5811d5310ae47 (diff)
grab the mouse before any move/resizes in actions, preventing focus from moving when followMouse is on and the window moves/resizes out from under the pointer
-rw-r--r--openbox/action.c28
1 files changed, 24 insertions, 4 deletions
diff --git a/openbox/action.c b/openbox/action.c
index 2d3bf6c3..f037944e 100644
--- a/openbox/action.c
+++ b/openbox/action.c
@@ -9,6 +9,7 @@
#include "screen.h"
#include "action.h"
#include "openbox.h"
+#include "grab.h"
#include <glib.h>
@@ -718,6 +719,9 @@ ObAction *action_from_string(char *name)
actionstrings[i].setup(a);
break;
}
+ if (!a)
+ g_warning("Invalid action '%s' requested. No such action exists.",
+ name);
return a;
}
@@ -916,32 +920,44 @@ void action_toggle_omnipresent(union ActionData *data)
void action_move_relative_horz(union ActionData *data)
{
ObClient *c = data->relative.any.c;
- if (c)
+ if (c) {
+ grab_pointer(TRUE, None);
client_move(c, c->area.x + data->relative.delta, c->area.y);
+ grab_pointer(FALSE, None);
+ }
}
void action_move_relative_vert(union ActionData *data)
{
ObClient *c = data->relative.any.c;
- if (c)
+ if (c) {
+ grab_pointer(TRUE, None);
client_move(c, c->area.x, c->area.y + data->relative.delta);
+ grab_pointer(FALSE, None);
+ }
}
void action_resize_relative_horz(union ActionData *data)
{
ObClient *c = data->relative.any.c;
- if (c)
+ if (c) {
+ grab_pointer(TRUE, None);
client_resize(c,
c->area.width + data->relative.delta * c->size_inc.width,
c->area.height);
+ grab_pointer(FALSE, None);
+ }
}
void action_resize_relative_vert(union ActionData *data)
{
ObClient *c = data->relative.any.c;
- if (c && !c->shaded)
+ if (c && !c->shaded) {
+ grab_pointer(TRUE, None);
client_resize(c, c->area.width, c->area.height +
data->relative.delta * c->size_inc.height);
+ grab_pointer(FALSE, None);
+ }
}
void action_maximize_full(union ActionData *data)
@@ -1140,7 +1156,9 @@ void action_movetoedge(union ActionData *data)
g_assert_not_reached();
}
frame_frame_gravity(c->frame, &x, &y);
+ grab_pointer(TRUE, None);
client_move(c, x, y);
+ grab_pointer(FALSE, None);
}
@@ -1203,7 +1221,9 @@ void action_growtoedge(union ActionData *data)
frame_frame_gravity(c->frame, &x, &y);
width -= c->frame->size.left + c->frame->size.right;
height -= c->frame->size.top + c->frame->size.bottom;
+ grab_pointer(TRUE, None);
client_move_resize(c, x, y, width, height);
+ grab_pointer(FALSE, None);
}
void action_send_to_layer(union ActionData *data)