1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411
|
#!/usr/bin/env python
#
# hrwwm.py -- Example PLWM window manager "configuration"
#
# Copyright (C) 1999,2000 Peter Liljenberg <petli@ctrl-c.liu.se>
# Henrik Rindlw <rindlow@lysator.liu.se>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
import sys
import os
###SETUP PATH
sys.path[1:1] = [os.path.join(sys.path[0], '..')]
###END SETUP PATH
from plxlib import plxlib, X
from plwm import wmanager, focus, keys, \
moveresize, deltamove, \
border, color, font, cycle, views, \
modewinctl, modetitle
delta = deltamove.DeltaMove()
class MyClient(wmanager.Client,
focus.FocusClient,
border.BorderClient,
modetitle.ModeTitleClient):
no_border_clients = ['XClock', 'XBiff', 'CDStatus', 'XModeWindow']
start_iconified_clients = ['WMManager']
move_focus_ignore_clients = no_border_clients
default_pointer_pos = {'Emacs': (-1, 0),
'XTerm': (-1, 0)}
class ScreenConfig:
pass
# def __screen_client_init__(self):
# self.set_color('BorderFocusColor', 'grey60')
class MyScreen(wmanager.Screen,
color.Color,
modewinctl.ModeClientControl,
views.XMW_ViewHandler,
keys.KeyGrabber,
ScreenConfig):
view_always_visible_clients = ['XClock', 'XBiff', 'CDStatus', 'XModeWindow']
class WMConfig:
# def __wm_screen_init__(self):
# self.set_font('OutlineNameFont', '-*-lucida-bold-r-*-sans-20-*-*-*-*-*-*-*')
def __wm_init__(self):
BasicKeys(self, self.dispatch)
class PLWM(wmanager.WindowManager,
focus.SloppyFocus,
font.Font,
WMConfig):
client_class = MyClient
screen_class = MyScreen
class BasicKeys(keys.KeyHandler):
# def F5(self, event):
# wins = self.wm.root.QueryTree()[2]
# for w in wins:
# c = self.wm.get_client(w)
# if c and c.is_mapped():
# c.raisewindow()
# c.warppointer()
# return
def F1(self, event):
self.wm.current_screen.view_find_with_client('XTerm')
def S_F1(self, event):
self.wm.system('xterm -geometry 80x50+200+100')
def C_S_F1(self, event):
self.wm.current_screen.view_new()
self.wm.system('xterm -geometry 80x50+200+100')
def F2(self, event):
self.wm.current_screen.view_find_with_client('Emacs')
def S_F2(self, event):
self.wm.system('emacs')
def C_S_F2(self, event):
self.wm.current_screen.view_new()
self.wm.system('emacs')
def F3(self, event):
self.wm.current_screen.view_find_with_client('Netscape')
def S_F3(self, event):
self.wm.system('netscape')
def C_S_F3(self, event):
self.wm.current_screen.view_new()
self.wm.system('netscape')
def F4(self, event):
self.wm.current_screen.view_find_with_client('applix')
def KP_Begin(self, event):
wmanager.debug('keys', 'Entering move-resize mode')
if self.wm.focus_client:
try:
mv = MoveResizeKeys(self.wm, self.dispatch,
self.wm.focus_client, event.time)
except keys.error, status:
wmanager.debug('keys', 'Grabbing keyboard failed: %d', status)
KP_5 = KP_Begin
def C_Tab(self, event):
wmanager.debug('keys', 'Into CycleUnmapped mode')
try:
mv = CycleUMKeys(self.wm, self.dispatch, event.time)
except keys.error, status:
wmanager.debug('keys', 'Grabbing keyboard failed: %d', status)
def KP_Insert(self, event):
wmanager.debug('keys', 'Iconifying')
if self.wm.focus_client:
self.wm.focus_client.iconify()
KP_0 = KP_Insert
def KP_Subtract(self, event):
wmanager.debug('keys', 'Prev view')
self.wm.current_screen.view_prev()
def KP_Add(self, event):
wmanager.debug('keys', 'Next view')
self.wm.current_screen.view_next()
def C_KP_Add(self, event):
wmanager.debug('keys', 'New view')
self.wm.current_screen.view_new()
def KP_Left(self, event):
self.wm.display.WarpPointer(-delta.get(event.time), 0)
KP_4 = KP_Left
def KP_Right(self, event):
self.wm.display.WarpPointer(delta.get(event.time), 0)
KP_6 = KP_Right
def KP_Up(self, event):
self.wm.display.WarpPointer(0, -delta.get(event.time))
KP_8 = KP_Up
def KP_Down(self, event):
self.wm.display.WarpPointer(0, delta.get(event.time))
KP_2 = KP_Down
def KP_Home(self, event):
d = delta.get(event.time)
self.wm.display.WarpPointer(-d, -d)
KP_7 = KP_Home
def KP_End(self, event):
d = delta.get(event.time)
self.wm.display.WarpPointer(-d, d)
KP_1 = KP_End
def KP_Prior(self, event):
d = delta.get(event.time)
self.wm.display.WarpPointer(d, -d)
KP_9 = KP_Prior
def KP_Next(self, event):
d = delta.get(event.time)
self.wm.display.WarpPointer(d, d)
KP_3 = KP_Next
def KP_Enter(self, event):
if self.wm.focus_client:
self.wm.focus_client.configure({'stack_mode': X.Opposite})
def C_KP_Subtract(self, event):
self.wm.system('xlock -mode blank')
def C_M_Escape(self, event):
raise 'PLWMEscape', 'Escaping window manager'
def C_KP_Delete(self, event):
if self.wm.focus_client:
self.wm.focus_client.delete(1)
C_KP_Separator= C_KP_Delete
def C_S_KP_Delete(self, event):
if self.wm.focus_client:
self.wm.focus_client.destroy()
C_S_KP_Separator= C_S_KP_Delete
def C_KP_Left(self, event):
self.wm.move_focus(focus.MOVE_LEFT)
C_KP_ = C_KP_Left
def C_KP_Right(self, event):
self.wm.move_focus(focus.MOVE_RIGHT)
C_KP_6 = C_KP_Right
def C_KP_Up(self, event):
self.wm.move_focus(focus.MOVE_UP)
C_KP_8 = C_KP_Up
def C_KP_Down(self, event):
self.wm.move_focus(focus.MOVE_DOWN)
C_KP_2 = C_KP_Down
def C_less(self, event):
self.wm.move_focus(focus.MOVE_LEFT)
def C_S_less(self, event):
self.wm.move_focus(focus.MOVE_RIGHT)
class MoveResizeKeys(keys.KeyGrabKeyboard):
propagate_keys = 0
timeout = 20
def __init__(self, wm, dispatch, client, time):
keys.KeyGrabKeyboard.__init__(self, wm, dispatch, time)
self.mv = moveresize.MoveResizeOutline(client, delta)
def KP_Left(self, event):
self.mv.move(-delta.get(event.time), 0)
KP_4 = KP_Left
def KP_Right(self, event):
self.mv.move(delta.get(event.time), 0)
KP_6 = KP_Right
def KP_Up(self, event):
self.mv.move(0, -delta.get(event.time))
KP_8 = KP_Up
def KP_Down(self, event):
self.mv.move(0, delta.get(event.time))
KP_2 = KP_Down
def KP_Home(self, event):
d = delta.get(event.time)
self.mv.move(-d, -d)
KP_7 = KP_Home
def KP_End(self, event):
d = delta.get(event.time)
self.mv.move(-d, d)
KP_1 = KP_End
def KP_Prior(self, event):
d = delta.get(event.time)
self.mv.move(d, -d)
KP_9 = KP_Prior
def KP_Next(self, event):
d = delta.get(event.time)
self.mv.move(d, d)
KP_3 = KP_Next
def S_KP_Left(self, event):
self.mv.resizeunits(-1, 0, 1, 0, event.time)
S_KP_4 = S_KP_Left
def S_KP_Right(self, event):
self.mv.resizeunits(0, 0, 1, 0, event.time)
S_KP_6 = S_KP_Right
def S_KP_Up(self, event):
self.mv.resizeunits(0, -1, 0, 1, event.time)
S_KP_8 = S_KP_Up
def S_KP_Down(self, event):
self.mv.resizeunits(0, 0, 0, 1, event.time)
S_KP_2 = S_KP_Down
def S_KP_Home(self, event):
self.mv.resizeunits(-1, -1, 1, 1, event.time)
S_KP_7 = S_KP_Home
def S_KP_End(self, event):
self.mv.resizeunits(-1, 0, 1, 1, event.time)
S_KP_1 = S_KP_End
def S_KP_Prior(self, event):
self.mv.resizeunits(0, -1, 1, 1, event.time)
S_KP_9 = S_KP_Prior
def S_KP_Next(self, event):
self.mv.resizeunits(0, 0, 1, 1, event.time)
S_KP_3 = S_KP_Next
def C_KP_Left(self, event):
self.mv.resizeunits(1, 0, -1, 0, event.time)
C_KP_4 = C_KP_Left
def C_KP_Right(self, event):
self.mv.resizeunits(0, 0, -1, 0, event.time)
C_KP_6 = C_KP_Right
def C_KP_Up(self, event):
self.mv.resizeunits(0, 1, 0, -1, event.time)
C_KP_8 = C_KP_Up
def C_KP_Down(self, event):
self.mv.resizeunits(0, 0, 0, -1, event.time)
C_KP_2 = C_KP_Down
def C_KP_Home(self, event):
self.mv.resizeunits(1, 1, -1, -1, event.time)
C_KP_7 = C_KP_Home
def C_KP_End(self, event):
self.mv.resizeunits(1, 0, -1, -1, event.time)
C_KP_1 = C_KP_End
def C_KP_Prior(self, event):
self.mv.resizeunits(0, 1, -1, -1, event.time)
C_KP_9 = C_KP_Prior
def C_KP_Next(self, event):
self.mv.resizeunits(0, 0, -1, -1, event.time)
C_KP_3 = C_KP_Next
def KP_Begin(self, event):
wmanager.debug('keys', 'Leaving move-resize mode')
self.mv.end()
self._cleanup()
KP_5 = KP_Begin
S_KP_Begin = KP_Begin
C_KP_Begin = KP_Begin
def Escape(self, event):
wmanager.debug('keys', 'Aborting move-resize mode')
self.mv.abort()
self._cleanup()
_timeout = Escape
KP_Delete = Escape
class CycleUMKeys(keys.KeyGrabKeyboard):
propagate_keys = 0
timeout = 10
def __init__(self, wm, dispatch, time):
keys.KeyGrabKeyboard.__init__(self, wm, dispatch, time)
self.cy = cycle.CycleUnmapped(wm.current_screen, 1)
def Tab(self, event):
self.cy.next()
C_Tab = Tab
def S_Tab(self, event):
self.cy.previous()
def Return(self, event):
wmanager.debug('keys', 'Escaping CycleMapped mode')
self._cleanup()
self.cy.end()
def Escape(self, event):
wmanager.debug('keys', 'Aborting CycleMapped mode')
self._cleanup()
self.cy.abort()
_timeout = Escape
if __name__ == '__main__':
sync = 0
while len(sys.argv) > 1:
if sys.argv[1] == '-d':
wmanager.debug = wmanager.do_debug
elif sys.argv[1] == '-s':
sync = 1
del sys.argv[1]
try:
p = PLWM()
except wmanager.error_no_unmanaged_screens:
sys.stderr.write(sys.argv[0] + ': Another window manager already running?\n')
sys.exit(1)
if sync:
p.display.Synchronize(1)
p.brave_loop()
|