]> Dogcows Code - chaz/openbox/blobdiff - scripts/focus.py
don't raise the window when reverting from Escape
[chaz/openbox] / scripts / focus.py
index c0d60b1ee7bb06308f05cd65d5ea268e3738a42a..970300131051137b1690c0d01bf58c0ee629dfa2 100644 (file)
@@ -2,85 +2,68 @@
 ###          Functions for helping out with your window focus.          ###
 ###########################################################################
 
-ob_focus_raise = 1
-ob_focus_fallback = 0
-ob_focus_stack = []
+###########################################################################
+###         Options that affect the behavior of the focus module.       ###
+###########################################################################
+avoid_skip_taskbar = 1
+"""Don't focus windows which have requested to not be displayed in taskbars.
+   You will still be able to focus the windows, but not through cycling, and
+   they won't be focused as a fallback if 'fallback' is enabled."""
+fallback = 0
+"""Send focus somewhere when nothing is left with the focus, if possible."""
+###########################################################################
 
-def ob_focused(data):
-    global ob_focus_raise
-    global ob_focus_fallback
-    global ob_focus_stack
-    if data.client:
-        window = data.client.window()
-        # add/move to front the stack
-        if window in ob_focus_stack:
-            ob_focus_stack.remove(window)
-        ob_focus_stack.insert(0, window)
-    elif ob_focus_fallback:
-        # pass around focus
-        desktop = openbox.screen(data.screen).desktop()
-        l = len(ob_focus_stack)
-        i = 0
-        while i < l:
-            w = ob_focus_stack[i]
-            client = openbox.findClient(w)
-            if not client: # window is gone, remove it
-                ob_focus_stack.pop(i)
-                l = l - 1
-            elif client.desktop() == desktop and \
-                     client.normal() and client.focus():
-                break
-            else:
-                i = i + 1
+###########################################################################
+###########################################################################
+
+###########################################################################
+###      Internal stuff, should not be accessed outside the module.     ###
+###########################################################################
+
+import ob
+
+# maintain a list of clients, stacked in focus order
+_clients = []
+_disable = 0
+
+def _focusable(client, desktop):
+    if not client.normal(): return 0
+    if not (client.canFocus() or client.focusNotify()): return 0
+    if avoid_skip_taskbar and client.skipTaskbar(): return 0
 
-ebind(EventFocus, ob_focused)
+    desk = client.desktop()
+    if not (desk == 0xffffffff or desk == desktop): return 0
 
-def focus_next(data, num=1, forward=1):
-    """Focus the next (or previous, with forward=0) window in a linear
-       order."""
-    screen = openbox.screen(data.screen)
-    count = screen.clientCount()
+    return 1
+
+def _focused(data):
+    global _clients
+
+    if _disable: return
 
-    if not count: return # no clients
-    
-    target = 0
     if data.client:
-        client_win = data.client.window()
-        found = 0
-        r = range(count)
-        if not forward:
-            r.reverse()
-        for i in r:
-            if found:
-                target = i
+        win = data.client.window()
+        # move it to the top
+        _clients.remove(win)
+        _clients.insert(0, win)
+    elif fallback:
+        # pass around focus
+        desktop = ob.openbox.screen(data.screen).desktop()
+        for w in _clients:
+            client = ob.openbox.findClient(w)
+            if client and _focusable(client, desktop) and client.focus():
                 break
-            elif screen.client(i).window() == client_win:
-                found = 1
-        if not found: # wraparound
-            if forward: target = 0
-            else: target = count - 1
-
-    t = target
-    curdesk = screen.desktop()
-    while 1:
-        client = screen.client(t)
-        if client.normal() and \
-               (client.desktop() == curdesk or client.desktop() == 0xffffffff)\
-               and client.focus():
-            if ob_focus_raise:
-                screen.raiseWindow(client)
-            return
-        if forward:
-            t += num
-            if t >= count: t -= count
-        else:
-            t -= 1
-            if t < 0: t += count
-        if t == target: return # nothing to focus
 
-def focus_prev(data, num=1):
-    """Focus the previous window in a linear order."""
-    focus_next(data, num, forward=0)
+def _newwindow(data):
+    _clients.append(data.client.window())
+        
+def _closewindow(data):
+    try:
+        _clients.remove(data.client.window())
+    except ValueError: pass
 
+ob.ebind(ob.EventAction.NewWindow, _newwindow)
+ob.ebind(ob.EventAction.CloseWindow, _closewindow)
+ob.ebind(ob.EventAction.Focus, _focused)
 
 print "Loaded focus.py"
This page took 0.027404 seconds and 4 git commands to generate.