all repos — openbox @ 41aeb42af13774c11e5a23e51bf56fa053678b5a

openbox fork - make it a bit more like ryudo

Create fake enter events in fewer situations - avoiding times that you don't actually want them.  Ignore event serials without using XSync, so that we aren't doing an XSync 100 times per minute - slow!
Dana Jansens danakj@orodu.net
commit

41aeb42af13774c11e5a23e51bf56fa053678b5a

parent

1d9991a0cd9b04dfa96a19bc73b40f01651de478

2 files changed, 6 insertions(+), 9 deletions(-)

jump to
M openbox/actions.copenbox/actions.c

@@ -339,9 +339,7 @@ ignore_start = event_start_ignore_all_enters();

else if (config_focus_follow && data->context != OB_FRAME_CONTEXT_CLIENT) { - if (!data->button && data->client && !config_focus_under_mouse) - event_end_ignore_all_enters(ignore_start); - else { + if (data->button && config_focus_under_mouse) { struct _ObClient *c; /* usually this is sorta redundant, but with a press action

@@ -355,6 +353,7 @@ "Generating fake enter because we did a "

"mouse-event action"); event_enter_client(c); } - } + } else + event_end_ignore_all_enters(ignore_start); } }
M openbox/event.copenbox/event.c

@@ -1928,8 +1928,7 @@ }

gulong event_start_ignore_all_enters(void) { - XSync(ob_display, FALSE); - return LastKnownRequestProcessed(ob_display); + return NextRequest(ob_display); } static void event_ignore_enter_range(gulong start, gulong end)

@@ -1948,13 +1947,12 @@ ob_debug_type(OB_DEBUG_FOCUS, "ignoring enters from %lu until %lu\n",

r->start, r->end); /* increment the serial so we don't ignore events we weren't meant to */ - XSync(ob_display, FALSE); + PROP_ERASE(screen_support_win, motif_wm_hints); } void event_end_ignore_all_enters(gulong start) { - XSync(ob_display, FALSE); - event_ignore_enter_range(start, LastKnownRequestProcessed(ob_display)); + event_ignore_enter_range(start, NextRequest(ob_display)); } static gboolean is_enter_focus_event_ignored(XEvent *e)