really fix focus_last?

This commit is contained in:
Mikael Magnusson 2006-08-04 19:56:42 +00:00
parent e3c52da8c3
commit dce6247e69
4 changed files with 8 additions and 3 deletions

View file

@ -1071,7 +1071,8 @@ void action_focus(union ActionData *data)
void action_unfocus (union ActionData *data)
{
client_unfocus(data->client.any.c);
if (data->client.any.c == focus_client);
focus_fallback(OB_FOCUS_FALLBACK_UNFOCUSING);
}
void action_iconify(union ActionData *data)

View file

@ -2833,13 +2833,15 @@ gboolean client_focus(ObClient *self)
return TRUE;
}
/* Used when the current client is closed, focus_last will then prevent
* focus from going to the mouse pointer */
void client_unfocus(ObClient *self)
{
if (focus_client == self) {
#ifdef DEBUG_FOCUS
ob_debug("client_unfocus for %lx\n", self->window);
#endif
focus_fallback(OB_FOCUS_FALLBACK_UNFOCUSING);
focus_fallback(OB_FOCUS_FALLBACK_CLOSED);
}
}

View file

@ -249,7 +249,8 @@ ObClient* focus_fallback_target(ObFocusFallbackType type)
old = focus_client;
if (type == OB_FOCUS_FALLBACK_UNFOCUSING && old) {
if ((type == OB_FOCUS_FALLBACK_UNFOCUSING
|| type == OB_FOCUS_FALLBACK_CLOSED) && old) {
if (old->transient_for) {
gboolean trans = FALSE;

View file

@ -48,6 +48,7 @@ void focus_set_client(struct _ObClient *client);
typedef enum {
OB_FOCUS_FALLBACK_UNFOCUSING, /*!< forcefully remove focus from the
current window */
OB_FOCUS_FALLBACK_CLOSED, /*!< closed the window with focus */
OB_FOCUS_FALLBACK_NOFOCUS /*!< nothing has focus for some reason */
} ObFocusFallbackType;