all repos — openbox @ 8446e50b7a6af13f2e06b8bdb2784ce2cb11ce5e

openbox fork - make it a bit more like ryudo

use client_activate to activate newly mapping windows. this means that if a window maps on another desktop and is going to be activated, you will end up on that desktop
Dana Jansens danakj@orodu.net
commit

8446e50b7a6af13f2e06b8bdb2784ce2cb11ce5e

parent

0f43a6840550600569ba4fb12cdeeccfa4fd3c1a

1 files changed, 14 insertions(+), 54 deletions(-)

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

@@ -320,6 +320,7 @@ client_restore_session_stacking(self);

/* focus the new window? */ if (ob_state() != OB_STATE_STARTING && + !self->iconic && /* this means focus=true for window is same as config_focus_new=true */ ((config_focus_new || (settings && settings->focus == 1)) || client_search_focus_parent(self)) &&

@@ -332,37 +333,6 @@ (self->type == OB_CLIENT_TYPE_NORMAL ||

self->type == OB_CLIENT_TYPE_DIALOG)) { activate = TRUE; -#if 0 - if (self->desktop != screen_desktop) { - /* activate the window */ - activate = TRUE; - } else { - gboolean group_foc = FALSE; - - if (self->group) { - GSList *it; - - for (it = self->group->members; it; it = g_slist_next(it)) - { - if (client_focused(it->data)) - { - group_foc = TRUE; - break; - } - } - } - if ((group_foc || - (!self->transient_for && (!self->group || - !self->group->members->next))) || - client_search_focus_tree_full(self) || - !focus_client || - !client_normal(focus_client)) - { - /* activate the window */ - activate = TRUE; - } - } -#endif } /* get the current position */

@@ -435,13 +405,7 @@ if (!(focus_client->can_focus || focus_client->focus_notify))

activate = FALSE; } - if (activate) - { - /* since focus can change the stacking orders, if we focus the - window then the standard raise it gets is not enough, we need - to queue one for after the focus change takes place */ - client_raise(self); - } else { + if (!activate) { ob_debug("Focus stealing prevention activated for %s with time %u " "(last time %u)\n", self->title, self->user_time, last_time);

@@ -471,17 +435,8 @@ stuff like switch desktops etc and I'm not interested in all that when

a window maps since its not based on an action from the user like clicking a window to activate it. so keep the new window out of the way but do focus it. */ - if (activate) { - /* if using focus_delay, stop the timer now so that focus doesn't - go moving on us */ - event_halt_focus_delay(); - client_focus(self); - } - - /* client_activate does this but we aren't using it so we have to do it - here as well */ - if (screen_showing_desktop) - screen_show_desktop(FALSE); + if (activate) + client_activate(self, FALSE, TRUE); /* add to client list/map */ client_list = g_list_append(client_list, self);

@@ -1893,6 +1848,7 @@ or removes it entirely, it's not very likely it is going to set one

right away afterwards */ if (self->nicons == 0) { RrPixel32 *icon = ob_rr_theme->def_win_icon; + gulong *data; data = g_new(guint32, 48*48+2); data[0] = data[1] = 48;

@@ -3150,6 +3106,10 @@ !event_time_after(event_curtime, last_time))

{ client_hilite(self, TRUE); } else { + /* if using focus_delay, stop the timer now so that focus doesn't + go moving on us */ + event_halt_focus_delay(); + if (client_normal(self) && screen_showing_desktop) screen_show_desktop(FALSE); if (self->iconic)

@@ -3169,11 +3129,11 @@ client_shade(self, FALSE);

client_focus(self); - /* we do this an action here. this is rather important. this is because - we want the results from the focus change to take place BEFORE we go - about raising the window. when a fullscreen window loses focus, we - need this or else the raise wont be able to raise above the - to-lose-focus fullscreen window. */ + /* we do this as an action here. this is rather important. this is + because we want the results from the focus change to take place + BEFORE we go about raising the window. when a fullscreen window + loses focus, we need this or else the raise wont be able to raise + above the to-lose-focus fullscreen window. */ client_raise(self); } }