X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Faction.c;h=4436aec9d2722a6e45429292cd53077ae33357ea;hb=9cb80fc994c09ee62f99f46244b840ce25fd40f4;hp=60af74b5e4723a879b3c97e5038cd149f1ca4925;hpb=5a1a3c2b1274e1992d8cfd0360ce01ed238b86d2;p=chaz%2Fopenbox diff --git a/openbox/action.c b/openbox/action.c index 60af74b5..4436aec9 100644 --- a/openbox/action.c +++ b/openbox/action.c @@ -20,6 +20,7 @@ #include "debug.h" #include "client.h" #include "focus.h" +#include "focus_cycle.h" #include "moveresize.h" #include "menu.h" #include "prop.h" @@ -38,29 +39,25 @@ #include -inline void client_action_start(union ActionData *data) +static void client_action_start(union ActionData *data) { - if (config_focus_follow) - if (data->any.context != OB_FRAME_CONTEXT_CLIENT && !data->any.button) - grab_pointer(FALSE, FALSE, OB_CURSOR_NONE); } -inline void client_action_end(union ActionData *data) +static void client_action_end(union ActionData *data) { if (config_focus_follow) if (data->any.context != OB_FRAME_CONTEXT_CLIENT) { - if (!data->any.button) { - ungrab_pointer(); - } else { - ObClient *c; - - /* usually this is sorta redundant, but with a press action - that moves windows our from under the cursor, the enter - event will come as a GrabNotify which is ignored, so this - makes a fake enter event - */ - if ((c = client_under_pointer())) - event_enter_client(c); + if (!data->any.button && data->any.c) + event_ignore_all_queued_enters(); + else { + /* we USED to create a fake enter event here, so that when you + used a Press context, and the button was still down, + you could still get enter events that weren't + NotifyWhileGrabbed. + + only problem with this is that then the resulting focus + change events can ALSO be NotifyWhileGrabbed. And that is + bad. So, don't create fake enter events anymore. */ } } } @@ -1590,8 +1587,8 @@ void action_send_to_desktop(union ActionData *data) if (data->sendto.desk < screen_num_desktops || data->sendto.desk == DESKTOP_ALL) { client_set_desktop(c, data->sendto.desk, data->sendto.follow); - if (data->sendto.follow) - screen_set_desktop(data->sendto.desk, TRUE); + if (data->sendto.follow && data->sendto.desk != screen_desktop) + screen_set_desktop(data->sendto.desk, c != focus_client); } } @@ -1648,7 +1645,7 @@ void action_send_to_desktop_dir(union ActionData *data) { client_set_desktop(c, d, data->sendtodir.follow); if (data->sendtodir.follow && d != screen_desktop) - screen_set_desktop(d, TRUE); + screen_set_desktop(d, c != focus_client); } }