better skipping of focus events while stackedcycling, fixes bug where esc would still change the order.
This commit is contained in:
parent
4ef1514836
commit
82d147b5d7
2 changed files with 9 additions and 5 deletions
|
@ -24,7 +24,7 @@ import ob
|
|||
|
||||
# maintain a list of clients, stacked in focus order
|
||||
_clients = []
|
||||
_disable = 0
|
||||
_skip = 0
|
||||
|
||||
def _focusable(client, desktop):
|
||||
if not client.normal(): return 0
|
||||
|
@ -50,9 +50,13 @@ def _remove(client):
|
|||
def _focused(data):
|
||||
global _clients
|
||||
|
||||
if _disable: return
|
||||
if _skip:
|
||||
global _skip
|
||||
_skip -= 1
|
||||
return
|
||||
|
||||
if data.client:
|
||||
print data.client.window()
|
||||
# move it to the top
|
||||
try:
|
||||
_remove(data.client)
|
||||
|
|
|
@ -167,6 +167,8 @@ class _cycledata:
|
|||
ob.send_client_msg(self.screeninfo.rootWindow(),
|
||||
otk.atoms.openbox_active_window,
|
||||
client.window(), final, r)
|
||||
if not final:
|
||||
focus._skip += 1
|
||||
|
||||
def cycle(self, data, forward):
|
||||
if not self.cycling:
|
||||
|
@ -177,7 +179,6 @@ class _cycledata:
|
|||
ob.mgrab(data.screen)
|
||||
|
||||
self.cycling = 1
|
||||
focus._disable = 1
|
||||
self.state = data.state
|
||||
self.screen = ob.openbox.screen(data.screen)
|
||||
self.screeninfo = otk.display.screenInfo(data.screen)
|
||||
|
@ -215,11 +216,10 @@ class _cycledata:
|
|||
self.menupos = 0
|
||||
|
||||
if done:
|
||||
self.cycling = 0
|
||||
focus._disable = 0
|
||||
# activate, and deiconify/unshade/raise
|
||||
self.activatetarget(notreverting)
|
||||
self.destroypopup()
|
||||
self.cycling = 0
|
||||
ob.kungrab()
|
||||
ob.mungrab()
|
||||
|
||||
|
|
Loading…
Reference in a new issue