Remove urgent state for already focused client

- Remove urgent state in `client_focus_update` always.
- Make `client_focus_update` indicate if focus changed and use this from
`client_focus` to update `globalconf.focus.need_update`.

Fixes: https://awesome.naquadah.org/bugs/index.php?do=details&task_id=1310
This commit is contained in:
Daniel Hahler 2014-11-06 19:48:35 +01:00
parent 2e286a45d8
commit dea5a23eac
2 changed files with 16 additions and 16 deletions

View File

@ -294,21 +294,18 @@ client_restore_enterleave_events(void)
/** Record that a client got focus. /** Record that a client got focus.
* \param c The client. * \param c The client.
* \return true if the client focus changed, false otherwise.
*/ */
void bool
client_focus_update(client_t *c) client_focus_update(client_t *c)
{ {
lua_State *L = globalconf_get_lua_State(); lua_State *L = globalconf_get_lua_State();
if(!client_maybevisible(c)) if(!client_maybevisible(c))
return; return false;
if(globalconf.focus.client) if(globalconf.focus.client && globalconf.focus.client != c)
{ {
if (globalconf.focus.client == c)
/* Already focused */
return;
/* When we are called due to a FocusIn event (=old focused client /* When we are called due to a FocusIn event (=old focused client
* already unfocused), we don't want to cause a SetInputFocus, * already unfocused), we don't want to cause a SetInputFocus,
* because the client which has focus now could be using globally * because the client which has focus now could be using globally
@ -317,14 +314,20 @@ client_focus_update(client_t *c)
client_unfocus_internal(globalconf.focus.client); client_unfocus_internal(globalconf.focus.client);
} }
bool focused_new = globalconf.focus.client != c;
globalconf.focus.client = c; globalconf.focus.client = c;
/* according to EWMH, we have to remove the urgent state from a client */ /* According to EWMH, we have to remove the urgent state from a client.
* This should be done also for the current/focused client (FS#1310). */
luaA_object_push(L, c); luaA_object_push(L, c);
client_set_urgent(L, -1, false); client_set_urgent(L, -1, false);
if(focused_new)
luaA_object_emit_signal(L, -1, "focus", 0); luaA_object_emit_signal(L, -1, "focus", 0);
lua_pop(L, 1); lua_pop(L, 1);
return focused_new;
} }
/** Give focus to client, or to first client if client is NULL. /** Give focus to client, or to first client if client is NULL.
@ -337,10 +340,7 @@ client_focus(client_t *c)
if(!c && globalconf.clients.len && !(c = globalconf.clients.tab[0])) if(!c && globalconf.clients.len && !(c = globalconf.clients.tab[0]))
return; return;
if(!client_maybevisible(c) || c == globalconf.focus.client) if(client_focus_update(c))
return;
client_focus_update(c);
globalconf.focus.need_update = true; globalconf.focus.need_update = true;
} }

View File

@ -170,7 +170,7 @@ void client_set_icon(client_t *, cairo_surface_t *);
void client_set_icon_from_pixmaps(client_t *, xcb_pixmap_t, xcb_pixmap_t); void client_set_icon_from_pixmaps(client_t *, xcb_pixmap_t, xcb_pixmap_t);
void client_set_skip_taskbar(lua_State *, int, bool); void client_set_skip_taskbar(lua_State *, int, bool);
void client_focus(client_t *); void client_focus(client_t *);
void client_focus_update(client_t *); bool client_focus_update(client_t *);
bool client_hasproto(client_t *, xcb_atom_t); bool client_hasproto(client_t *, xcb_atom_t);
void client_ignore_enterleave_events(void); void client_ignore_enterleave_events(void);
void client_restore_enterleave_events(void); void client_restore_enterleave_events(void);