2003-01-23 09:01:40 +00:00
|
|
|
###########################################################################
|
|
|
|
### Functions for helping out with your window focus. ###
|
|
|
|
###########################################################################
|
|
|
|
|
2003-01-24 09:25:03 +00:00
|
|
|
# raise the window also when it is focused
|
2003-01-23 09:01:40 +00:00
|
|
|
ob_focus_raise = 1
|
2003-01-24 09:25:03 +00:00
|
|
|
# send focus somewhere when nothing is left with the focus if possible
|
2003-01-23 09:01:40 +00:00
|
|
|
ob_focus_fallback = 0
|
2003-01-23 15:46:19 +00:00
|
|
|
|
|
|
|
# maintain a list of clients, stacked in focus order
|
|
|
|
ob_clients = []
|
|
|
|
# maintaint he current focused window
|
2003-01-24 09:25:03 +00:00
|
|
|
ob_doing_stacked = 0
|
2003-01-23 15:46:19 +00:00
|
|
|
|
|
|
|
def ob_new_win(data):
|
|
|
|
global ob_clients
|
2003-01-24 09:25:03 +00:00
|
|
|
global ob_doing_stacked
|
|
|
|
global ob_cyc_w;
|
|
|
|
|
|
|
|
if ob_doing_stacked:
|
|
|
|
ob_clients.insert(ob_clients.index(ob_cyc_w), data.client.window())
|
|
|
|
else:
|
|
|
|
if not len(ob_clients):
|
|
|
|
ob_clients.append(data.client.window())
|
|
|
|
else:
|
|
|
|
ob_clients.insert(1, data.client.window()) # insert in 2nd slot
|
2003-01-23 15:46:19 +00:00
|
|
|
|
|
|
|
def ob_close_win(data):
|
|
|
|
global ob_clients
|
2003-01-24 09:25:03 +00:00
|
|
|
global ob_cyc_w;
|
|
|
|
global ob_doing_stacked
|
|
|
|
|
|
|
|
if not ob_doing_stacked:
|
|
|
|
# not in the middle of stacked cycling, so who cares
|
|
|
|
ob_clients.remove(data.client.window())
|
|
|
|
else:
|
|
|
|
# have to fix the cycling if we remove anything
|
|
|
|
win = data.client.window()
|
|
|
|
if ob_cyc_w == win:
|
|
|
|
do_stacked_cycle(data) # cycle off the window first
|
|
|
|
ob_clients.remove(win)
|
2003-01-23 09:01:40 +00:00
|
|
|
|
|
|
|
def ob_focused(data):
|
2003-01-23 15:46:19 +00:00
|
|
|
global ob_clients
|
2003-01-24 09:25:03 +00:00
|
|
|
global ob_doing_stacked
|
|
|
|
global ob_cyc_w
|
|
|
|
|
2003-01-23 09:01:40 +00:00
|
|
|
if data.client:
|
2003-01-24 09:25:03 +00:00
|
|
|
if not ob_doing_stacked: # only move the window when we're not cycling
|
2003-01-24 07:37:26 +00:00
|
|
|
win = data.client.window()
|
|
|
|
# move it to the top
|
|
|
|
ob_clients.remove(win)
|
|
|
|
ob_clients.insert(0, win)
|
2003-01-24 09:25:03 +00:00
|
|
|
else: # if we are cycling, then update our pointer
|
|
|
|
ob_cyc_w = data.client.window()
|
|
|
|
elif ob_focus_fallback:
|
2003-01-23 09:01:40 +00:00
|
|
|
# pass around focus
|
2003-01-24 09:25:03 +00:00
|
|
|
desktop = openbox.screen(ob_cyc_screen).desktop()
|
2003-01-23 15:46:19 +00:00
|
|
|
for w in ob_clients:
|
2003-01-23 09:01:40 +00:00
|
|
|
client = openbox.findClient(w)
|
2003-01-23 15:46:19 +00:00
|
|
|
if client and (client.desktop() == desktop and \
|
|
|
|
client.normal() and client.focus()):
|
2003-01-23 09:01:40 +00:00
|
|
|
break
|
|
|
|
|
2003-01-23 15:46:19 +00:00
|
|
|
ebind(EventNewWindow, ob_new_win)
|
|
|
|
ebind(EventCloseWindow, ob_close_win)
|
2003-01-23 09:01:40 +00:00
|
|
|
ebind(EventFocus, ob_focused)
|
|
|
|
|
2003-01-24 07:37:26 +00:00
|
|
|
ob_cyc_mask = 0
|
2003-01-24 09:25:03 +00:00
|
|
|
ob_cyc_key = 0
|
|
|
|
ob_cyc_w = 0 # last window cycled to
|
|
|
|
ob_cyc_screen = 0
|
|
|
|
|
|
|
|
def do_stacked_cycle(data):
|
|
|
|
global ob_cyc_w
|
|
|
|
|
|
|
|
try:
|
|
|
|
i = ob_clients.index(ob_cyc_w) + 1
|
|
|
|
except ValueError:
|
|
|
|
i = 0
|
|
|
|
|
|
|
|
clients = ob_clients[i:] + ob_clients[:i]
|
|
|
|
for w in clients:
|
|
|
|
client = openbox.findClient(w)
|
|
|
|
if client and (client.desktop() == desktop and \
|
|
|
|
client.normal() and client.focus()):
|
|
|
|
return
|
2003-01-24 07:37:26 +00:00
|
|
|
|
|
|
|
def focus_next_stacked_grab(data):
|
|
|
|
global ob_cyc_mask;
|
|
|
|
global ob_cyc_key;
|
2003-01-24 09:25:03 +00:00
|
|
|
global ob_cyc_w;
|
|
|
|
global ob_doing_stacked;
|
2003-01-24 07:37:26 +00:00
|
|
|
|
|
|
|
if data.action == EventKeyRelease:
|
|
|
|
# have all the modifiers this started with been released?
|
|
|
|
if not ob_cyc_mask & data.state:
|
|
|
|
kungrab() # ungrab ourself
|
2003-01-24 09:25:03 +00:00
|
|
|
ob_doing_stacked = 0;
|
2003-01-24 07:37:26 +00:00
|
|
|
print "UNGRABBED!"
|
|
|
|
else:
|
|
|
|
if ob_cyc_key == data.key:
|
2003-01-24 09:25:03 +00:00
|
|
|
# the next window to try focusing in ob_clients[ob_cyc_i]
|
2003-01-24 07:37:26 +00:00
|
|
|
print "CYCLING!!"
|
2003-01-24 09:25:03 +00:00
|
|
|
do_stacked_cycle(data)
|
2003-01-24 07:37:26 +00:00
|
|
|
|
|
|
|
def focus_next_stacked(data, forward=1):
|
2003-01-24 09:25:03 +00:00
|
|
|
global ob_cyc_mask
|
|
|
|
global ob_cyc_key
|
|
|
|
global ob_cyc_w
|
|
|
|
global ob_cyc_screen
|
|
|
|
global ob_doing_stacked
|
2003-01-24 07:37:26 +00:00
|
|
|
ob_cyc_mask = data.state
|
|
|
|
ob_cyc_key = data.key
|
2003-01-24 09:25:03 +00:00
|
|
|
ob_cyc_w = 0
|
|
|
|
ob_cyc_screen = data.screen
|
|
|
|
ob_doing_stacked = 1
|
2003-01-24 07:37:26 +00:00
|
|
|
|
2003-01-24 09:25:03 +00:00
|
|
|
kgrab(data.screen, focus_next_stacked_grab)
|
2003-01-24 07:37:26 +00:00
|
|
|
print "GRABBED!"
|
|
|
|
focus_next_stacked_grab(data) # start with the first press
|
|
|
|
|
|
|
|
def focus_prev_stacked(data):
|
|
|
|
return
|
|
|
|
|
2003-01-23 09:01:40 +00:00
|
|
|
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()
|
|
|
|
|
|
|
|
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
|
2003-01-23 23:18:05 +00:00
|
|
|
found = 2
|
2003-01-23 09:01:40 +00:00
|
|
|
break
|
|
|
|
elif screen.client(i).window() == client_win:
|
|
|
|
found = 1
|
2003-01-23 23:18:05 +00:00
|
|
|
if found == 1: # wraparound
|
2003-01-23 09:01:40 +00:00
|
|
|
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:
|
2003-01-23 09:03:06 +00:00
|
|
|
t += num
|
|
|
|
if t >= count: t -= count
|
2003-01-23 09:01:40 +00:00
|
|
|
else:
|
2003-01-23 23:18:05 +00:00
|
|
|
t -= num
|
2003-01-23 09:03:06 +00:00
|
|
|
if t < 0: t += count
|
2003-01-23 09:01:40 +00:00
|
|
|
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)
|
|
|
|
|
|
|
|
|
|
|
|
print "Loaded focus.py"
|