X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=scripts%2Fbuiltins.py;h=8bf3cd1df659c8c84c0e08868333c295b2271683;hb=bb303c74047b7d4f13b54170e1d24fbe5662e9f9;hp=e3424001c156c409c8569dd3ce8c46ae297687e6;hpb=28b8f67562bb7eb15134f2bf7a8394f0a009b9ba;p=chaz%2Fopenbox diff --git a/scripts/builtins.py b/scripts/builtins.py index e3424001..8bf3cd1d 100644 --- a/scripts/builtins.py +++ b/scripts/builtins.py @@ -22,6 +22,22 @@ def state_shaded(data, add=2): send_client_msg(display.screenInfo(data.screen).rootWindow(), Property_atoms().net_wm_state, data.client.window(), add, Property_atoms().net_wm_state_shaded) + +def iconify(data): + """Iconifies the window on which the event occured""" + if not data.client: return + send_client_msg(display.screenInfo(data.screen).rootWindow(), + Property_atoms().wm_change_state, + data.client.window(), 3) # IconicState + +def restore(data): + """Un-iconifies the window on which the event occured, but does not focus + if. If you want to focus the window too, it is recommended that you + use the activate() function.""" + if not data.client: return + send_client_msg(display.screenInfo(data.screen).rootWindow(), + Property_atoms().wm_change_state, + data.client.window(), 1) # NormalState def close(data): """Closes the window on which the event occured""" @@ -211,11 +227,12 @@ def setup_click_focus(click_raise = 1): mbind("Left", MC_Handle, MousePress, focus) mbind("Left", MC_Grip, MousePress, focus) mbind("Left", MC_Window, MousePress, focus) + mbind("A-Left", MC_Frame, MousePress, focus) if click_raise: mbind("Left", MC_Titlebar, MousePress, raise_win) mbind("Left", MC_Handle, MousePress, raise_win) mbind("Left", MC_Grip, MousePress, raise_win) - mbind("Left", MC_Window, MousePress, raise_win) + mbind("Left", MC_Window, MousePress, raise_win) def setup_sloppy_focus(click_focus = 1, click_raise = 0): """Sets up for focusing windows when the mouse pointer enters them. @@ -264,6 +281,7 @@ def setup_window_buttons(): """Sets up the default behaviors for the buttons in the window titlebar.""" mbind("Left", MC_AllDesktopsButton, MouseClick, toggle_all_desktops) mbind("Left", MC_CloseButton, MouseClick, close) + mbind("Left", MC_IconifyButton, MouseClick, iconify) def setup_scroll(): """Sets up the default behaviors for the mouse scroll wheel. @@ -287,34 +305,8 @@ def setup_scroll(): def setup_fallback_focus(): """Sets up a focus fallback routine so that when no windows are focused, the last window to have focus on the desktop will be focused.""" - focus_stack = [] - def focused(data): - #global focus_stack - if data.client: - window = data.client.window() - # add to front the stack - if window in focus_stack: - focus_stack.remove(window) - focus_stack.insert(0, window) - else: - # pass around focus - desktop = openbox.screen(data.screen).desktop() - l = len(focus_stack) - i = 0 - while i < l: - w = focus_stack[i] - client = openbox.findClient(w) - if not client: # window is gone, remove it - focus_stack.pop(i) - l = l - 1 - elif client.desktop() == desktop and \ - client.normal() and client.focus(): - break - else: - i = i + 1 - - ebind(EventFocus, focused) - + global ob_focus_fallback # see focus.py + ob_focus_fallback = 1 ############################################################################ ### Window placement algorithms, choose one of these and ebind it to the ### @@ -327,15 +319,15 @@ def placewindows_random(data): if not data.client: return client_area = data.client.area() frame_size = data.client.frame.size() - screen = display.screenInfo(data.screen) - width = screen.width() - (client_area.width() + - frame_size.left + frame_size.right) - height = screen.height() - (client_area.height() + - frame_size.top + frame_size.bottom) + screen_area = openbox.screen(data.screen).area() + width = screen_area.width() - (client_area.width() + + frame_size.left + frame_size.right) + height = screen_area.height() - (client_area.height() + + frame_size.top + frame_size.bottom) global ob_rand if not ob_rand: ob_rand = random.Random() - x = ob_rand.randrange(0, width-1) - y = ob_rand.randrange(0, height-1) + x = ob_rand.randrange(screen_area.x(), width-1) + y = ob_rand.randrange(screen_area.y(), height-1) data.client.move(x, y)