X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=scripts%2Ffocus.py;h=5ae40cf273e483aa7cb71295a0d7d8beef15e398;hb=c2c21e9588c00944dfed4cfc7e48d14570444534;hp=d2e851132b9f16262300748952578179e57abdb7;hpb=5559780c26c12a23d3221ca3ecf6574b4b1670a4;p=chaz%2Fopenbox diff --git a/scripts/focus.py b/scripts/focus.py index d2e85113..5ae40cf2 100644 --- a/scripts/focus.py +++ b/scripts/focus.py @@ -17,9 +17,15 @@ fallback = 0 ### ### ### # Provides: ### # def focus_next_stacked(data, forward=1): ### +# """Focus the next (or previous, with forward=0) window in a stacked ### +# order.""" ### # def focus_prev_stacked(data): ### +# """Focus the previous window in a stacked order.""" ### # def focus_next(data, num=1, forward=1): ### +# """Focus the next (or previous, with forward=0) window in a linear ### +# order.""" ### # def focus_prev(data, num=1): ### +# """Focus the previous window in a linear order.""" ### ### ### # All of these functions call be used as callbacks for bindings ### # directly. ### @@ -42,7 +48,7 @@ def _new_win(data): if _doing_stacked: _clients.insert(_clients.index(_cyc_w), data.client.window()) _create_popup_list(data) - _hilite_popup_list() + _hilite_popup_list(data) else: if not len(_clients): _clients.append(data.client.window()) @@ -78,7 +84,7 @@ def _focused(data): _clients.insert(0, win) else: # if we are cycling, then update our pointer _cyc_w = data.client.window() - _hilite_popup_list() + _hilite_popup_list(data) elif fallback: # pass around focus desktop = ob.openbox.screen(_cyc_screen).desktop() @@ -87,6 +93,9 @@ def _focused(data): if client and (client.desktop() == desktop and \ client.normal() and client.focus()): break + if _doing_stacked: + _cyc_w = 0 + _hilite_popup_list(data) _cyc_mask = 0 _cyc_key = 0 @@ -126,27 +135,37 @@ def _focus_stacked_ungrab(data): if data.action == ob.KeyAction.Release: # have all the modifiers this started with been released? if not _cyc_mask & data.state: + _destroy_popup_list() ob.kungrab() # ungrab ourself _doing_stacked = 0; if cycle_raise: client = ob.openbox.findClient(_cyc_w) if client: ob.openbox.screen(data.screen).raiseWindow(client) - _destroy_popup_list() _list_widget = 0 _list_labels = [] _list_windows = [] -def _hilite_popup_list(): - global _cyc_w +def _hilite_popup_list(data): + global _cyc_w, _doing_stacked global _list_widget, _list_labels, _list_windows + found = 0 + + if not _list_widget and _doing_stacked: + _create_popup_list(data) + if _list_widget: i = 0 for w in _list_windows: - if w == _cyc_w: _list_labels[i].focus() - else: _list_labels[i].unfocus() + if w == _cyc_w: + _list_labels[i].focus() + found = 1 + else: + _list_labels[i].unfocus() i += 1 + if not found: + _create_popup_list(data) def _destroy_popup_list(): global _list_widget, _list_labels, _list_windows @@ -175,8 +194,10 @@ def _create_popup_list(data): for c in _clients: client = ob.openbox.findClient(c) desktop = ob.openbox.screen(data.screen).desktop() - if client and (client.desktop() == desktop and \ - client.normal()): + if client and ((client.desktop() == desktop or + client.desktop() == 0xffffffff) and \ + client.normal() and (client.canFocus() or + client.focusNotify())): t = client.title() if len(t) > 50: # limit the length of titles t = t[:24] + "..." + t[-24:] @@ -184,14 +205,13 @@ def _create_popup_list(data): _list_windows.append(c) l = font.measureString(t) + 10 # add margin if l > longest: longest = l - if len(titles): + if len(titles) > 1: for t in titles: w = otk.FocusLabel(_list_widget) w.resize(longest, height) w.setText(t) w.unfocus() _list_labels.append(w) - _list_labels[0].focus() _list_widget.update() area = otk.display.screenInfo(data.screen).rect() _list_widget.move(area.x() + (area.width() - @@ -200,7 +220,7 @@ def _create_popup_list(data): _list_widget.height()) / 2) _list_widget.show(1) else: - _list_widget = 0 #nothing to list + _destroy_popup_list() # nothing (or only 1) to list def focus_next_stacked(data, forward=1): """Focus the next (or previous, with forward=0) window in a stacked