X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=openbox%2Faction.c;h=85d84798ab991e3eb433afbc01f8887d92671d92;hb=aa81b46ff3f8b17d323605bbf9830bbf1fccc2bb;hp=0a2d2b627b890346b50ac5991317f58f552a1c80;hpb=c8b4710755f5580cb086a9e23d8db0d65c7416e5;p=chaz%2Fopenbox diff --git a/openbox/action.c b/openbox/action.c index 0a2d2b62..85d84798 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" @@ -46,18 +47,17 @@ static void client_action_end(union ActionData *data) { if (config_focus_follow) if (data->any.context != OB_FRAME_CONTEXT_CLIENT) { - if (!data->any.button) { - event_ignore_queued_enters(); - } 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. */ } } }