summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-05-27 22:50:40 +0000
committerDana Jansens <danakj@orodu.net>2007-05-27 22:50:40 +0000
commitb8fded742abad3c43c708ee935f5b58237170a01 (patch)
tree460eda8e5419796c4667bcb5b02db918ba28e5ee
parent568ca95bc222b1c694fbd77ce417fd04630846ae (diff)
make focuslast only apply to switching desktops, like 3.3.1
-rw-r--r--openbox/action.c2
-rw-r--r--openbox/event.c4
-rw-r--r--openbox/focus.c10
-rw-r--r--openbox/focus.h3
-rw-r--r--openbox/screen.c8
5 files changed, 16 insertions, 11 deletions
diff --git a/openbox/action.c b/openbox/action.c
index 6e4cd186..a01f4d06 100644
--- a/openbox/action.c
+++ b/openbox/action.c
@@ -1311,7 +1311,7 @@ void action_focus(union ActionData *data)
void action_unfocus (union ActionData *data)
{
if (data->client.any.c == focus_client)
- focus_fallback(FALSE);
+ focus_fallback(FALSE, FALSE);
}
void action_iconify(union ActionData *data)
diff --git a/openbox/event.c b/openbox/event.c
index ac5919ed..9eaec027 100644
--- a/openbox/event.c
+++ b/openbox/event.c
@@ -516,7 +516,7 @@ static void event_process(const XEvent *ec, gpointer data)
*/
if (!focus_left_screen)
- focus_fallback(TRUE);
+ focus_fallback(TRUE, FALSE);
}
}
else if (!client)
@@ -570,7 +570,7 @@ static void event_process(const XEvent *ec, gpointer data)
ob_debug_type(OB_DEBUG_FOCUS,
"Focus went to an unmanaged window 0x%x !\n",
ce.xfocus.window);
- focus_fallback(TRUE);
+ focus_fallback(TRUE, FALSE);
}
}
diff --git a/openbox/focus.c b/openbox/focus.c
index 6713d98d..59dd0d0d 100644
--- a/openbox/focus.c
+++ b/openbox/focus.c
@@ -95,13 +95,15 @@ void focus_set_client(ObClient *client)
}
}
-static ObClient* focus_fallback_target(gboolean allow_refocus, ObClient *old)
+static ObClient* focus_fallback_target(gboolean allow_refocus,
+ gboolean allow_pointer,
+ ObClient *old)
{
GList *it;
ObClient *c;
ob_debug_type(OB_DEBUG_FOCUS, "trying pointer stuff\n");
- if (config_focus_follow && !config_focus_last)
+ if (allow_pointer && config_focus_follow)
if ((c = client_under_pointer()) &&
(allow_refocus || c != old) &&
(client_normal(c) &&
@@ -153,7 +155,7 @@ static ObClient* focus_fallback_target(gboolean allow_refocus, ObClient *old)
return NULL;
}
-ObClient* focus_fallback(gboolean allow_refocus)
+ObClient* focus_fallback(gboolean allow_refocus, gboolean allow_pointer)
{
ObClient *new;
ObClient *old = focus_client;
@@ -163,7 +165,7 @@ ObClient* focus_fallback(gboolean allow_refocus)
event at all for them. */
focus_nothing();
- new = focus_fallback_target(allow_refocus, old);
+ new = focus_fallback_target(allow_refocus, allow_pointer, old);
return new;
}
diff --git a/openbox/focus.h b/openbox/focus.h
index 9bd4f206..be7a042d 100644
--- a/openbox/focus.h
+++ b/openbox/focus.h
@@ -44,7 +44,8 @@ void focus_set_client(struct _ObClient *client);
void focus_nothing();
/*! Call this when you need to focus something! */
-struct _ObClient* focus_fallback(gboolean allow_refocus);
+struct _ObClient* focus_fallback(gboolean allow_refocus,
+ gboolean allow_pointer);
/*! Add a new client into the focus order */
void focus_order_add_new(struct _ObClient *c);
diff --git a/openbox/screen.c b/openbox/screen.c
index deaf55ee..11d527ee 100644
--- a/openbox/screen.c
+++ b/openbox/screen.c
@@ -539,12 +539,14 @@ void screen_set_desktop(guint num, gboolean dofocus)
dofocus = FALSE;
/* have to try focus here because when you leave an empty desktop
- there is no focus out to watch for
+ there is no focus out to watch for. also, we have different rules
+ here. we always allow it to look under the mouse pointer if
+ config_focus_last is FALSE
do this before hiding the windows so if helper windows are coming
with us, they don't get hidden
*/
- if (dofocus && (c = focus_fallback(TRUE)))
+ if (dofocus && (c = focus_fallback(TRUE, !config_focus_last)))
{
/* only do the flicker reducing stuff ahead of time if we are going
to call xsetinputfocus on the window ourselves. otherwise there is
@@ -1007,7 +1009,7 @@ void screen_show_desktop(gboolean show, ObClient *show_only)
else if (!show_only) {
ObClient *c;
- if ((c = focus_fallback(TRUE))) {
+ if ((c = focus_fallback(TRUE, FALSE))) {
/* only do the flicker reducing stuff ahead of time if we are going
to call xsetinputfocus on the window ourselves. otherwise there
is no guarantee the window will actually take focus.. */