2010-02-13 18:31:17 +01:00
|
|
|
import XMonad
|
|
|
|
import XMonad.Config.Desktop
|
|
|
|
import XMonad.Actions.CycleWS
|
|
|
|
import XMonad.Actions.NoBorders
|
2010-02-16 13:40:28 +01:00
|
|
|
import XMonad.Actions.PhysicalScreens
|
|
|
|
import XMonad.Actions.Warp
|
2010-02-13 18:31:17 +01:00
|
|
|
import XMonad.Hooks.ManageDocks
|
|
|
|
import XMonad.Hooks.ManageHelpers
|
2011-02-22 19:40:54 +01:00
|
|
|
import XMonad.Hooks.SetWMName
|
2010-02-16 11:45:32 +01:00
|
|
|
import XMonad.Layout.ResizableTile
|
2010-02-13 18:31:17 +01:00
|
|
|
import qualified XMonad.StackSet as W
|
|
|
|
import XMonad.Util.EZConfig
|
|
|
|
|
|
|
|
import Control.Monad
|
|
|
|
import Control.Monad.Trans
|
2011-02-22 19:40:54 +01:00
|
|
|
import Data.Maybe
|
2010-02-13 18:31:17 +01:00
|
|
|
import Data.Monoid
|
2010-02-16 13:40:28 +01:00
|
|
|
import Ratio((%))
|
2011-07-18 14:05:19 +02:00
|
|
|
import System.Exit
|
2010-02-13 18:31:17 +01:00
|
|
|
|
2010-08-02 01:43:13 +02:00
|
|
|
--import ConfigurableBorders
|
2011-07-18 14:05:19 +02:00
|
|
|
import DynamicPerScreenWorkspaces
|
|
|
|
import EwmhDesktops
|
2010-02-13 18:31:17 +01:00
|
|
|
import FullscreenManager
|
|
|
|
import NoBorders
|
2011-02-25 19:44:32 +01:00
|
|
|
import ProcessWorkspaces
|
2010-02-13 18:31:17 +01:00
|
|
|
|
|
|
|
|
2010-02-18 12:52:34 +01:00
|
|
|
modm = mod4Mask
|
2010-02-16 11:45:32 +01:00
|
|
|
|
2011-07-18 14:05:19 +02:00
|
|
|
main = xmonad $ ewmh $ defaultConfig
|
2010-02-18 12:52:34 +01:00
|
|
|
{ modMask = modm
|
2010-02-13 18:31:17 +01:00
|
|
|
, manageHook = myManageHook
|
2011-07-18 15:20:40 +02:00
|
|
|
, unmanageHook = myUnmanageHook
|
2010-02-13 18:31:17 +01:00
|
|
|
, layoutHook = desktopLayoutModifiers myLayoutHook
|
2011-02-22 19:40:54 +01:00
|
|
|
, startupHook = myStartupHook
|
2010-02-13 19:14:15 +01:00
|
|
|
, handleEventHook = myEventHook
|
2011-02-28 22:08:02 +01:00
|
|
|
, workspaces = myWorkspaces
|
2011-07-18 14:05:19 +02:00
|
|
|
, borderWidth = 0
|
|
|
|
, logHook = ewmhDesktopsLogHook
|
2010-02-13 18:31:17 +01:00
|
|
|
}
|
2011-02-27 21:20:00 +01:00
|
|
|
`additionalKeysP` (
|
2010-02-16 11:45:32 +01:00
|
|
|
[ ("M-a", sendMessage MirrorShrink)
|
|
|
|
, ("M-y", sendMessage MirrorExpand)
|
|
|
|
, ("M-<Left>", prevWS)
|
|
|
|
, ("M-<Right>", nextWS)
|
|
|
|
, ("M-S-<Left>", shiftToPrev)
|
|
|
|
, ("M-S-<Right>", shiftToNext)
|
2010-02-13 18:31:17 +01:00
|
|
|
, ("M-S-b", withFocused toggleBorder >> refresh)
|
2010-02-16 13:40:28 +01:00
|
|
|
, ("M-<F1>", viewOrWarp 0)
|
|
|
|
, ("M-<F2>", viewOrWarp 1)
|
|
|
|
, ("M-<F3>", viewOrWarp 2)
|
2011-02-27 16:18:48 +01:00
|
|
|
, ("M-b", banishScreen LowerRight)
|
2011-02-25 19:44:32 +01:00
|
|
|
, ("M-p", spawnOnCurrent "exe=`dmenu_path | /home/neoraider/bin/dmemu -b` && eval \"exec $exe\"")
|
2011-02-28 22:56:39 +01:00
|
|
|
, ("M-g", gets (W.currentTag . windowset) >>= regroupProcess)
|
2011-07-18 14:05:19 +02:00
|
|
|
, ("M-S-q", io (exitWith ExitSuccess))
|
|
|
|
, ("C-M1-l", spawn "gnome-screensaver-command --lock")
|
|
|
|
, ("M-`", spawn "xclip -o | qrencode -s 10 -o- | display -geometry +0+0")
|
|
|
|
, ("M1-<F4>", kill)
|
2011-02-28 22:08:02 +01:00
|
|
|
]
|
|
|
|
++ [ (("M-" ++ show n, windows $ W.greedyView ws)) | (ws, n) <- zip myWorkspaces ([1..9]++[0])]
|
|
|
|
++ [ (("M-S-" ++ show n, shiftGroup ws)) | (ws, n) <- zip myWorkspaces ([1..9]++[0])]
|
|
|
|
++ [ (("M-C-" ++ show n, shiftIgnoreGroup ws)) | (ws, n) <- zip myWorkspaces ([1..9]++[0])]
|
2011-02-27 21:20:00 +01:00
|
|
|
)
|
2010-02-16 11:45:32 +01:00
|
|
|
`additionalMouseBindings`
|
2010-02-18 12:52:34 +01:00
|
|
|
[ ((modm, button4), \_ -> sendMessage Shrink)
|
|
|
|
, ((modm, button5), \_ -> sendMessage Expand)
|
|
|
|
, ((modm .|. shiftMask, button4), \_ -> sendMessage MirrorExpand)
|
|
|
|
, ((modm .|. shiftMask, button5), \_ -> sendMessage MirrorShrink)
|
2010-02-16 11:45:32 +01:00
|
|
|
]
|
2010-02-13 18:31:17 +01:00
|
|
|
|
|
|
|
|
2011-07-18 14:05:19 +02:00
|
|
|
myWorkspaces = map (show . flip mod 10) [1..10]
|
2011-02-28 22:08:02 +01:00
|
|
|
|
|
|
|
|
2010-02-16 13:40:28 +01:00
|
|
|
viewOrWarp :: Int -> X ()
|
|
|
|
viewOrWarp n = do
|
2010-02-18 12:52:34 +01:00
|
|
|
wset <- gets windowset
|
2010-02-16 13:40:28 +01:00
|
|
|
i <- getScreen $ P n
|
|
|
|
whenJust i $ \s -> do
|
|
|
|
ws <- screenWorkspace s
|
|
|
|
whenJust ws $ \w -> windows . W.view $ w
|
|
|
|
when (s == (W.screen . W.current $ wset)) $ warpToScreen s (1%2) (1%2)
|
|
|
|
|
|
|
|
|
2010-08-02 01:43:13 +02:00
|
|
|
--myStartupHook :: X ()
|
|
|
|
--myStartupHook = do
|
|
|
|
-- startupHook gnomeConfig
|
|
|
|
-- spawn "killall -u `id -un` -q xcompmgr; exec xcompmgr"
|
2010-02-13 18:31:17 +01:00
|
|
|
|
2011-07-18 14:05:19 +02:00
|
|
|
|
|
|
|
setFullscreenSupported :: X ()
|
|
|
|
setFullscreenSupported = withDisplay $ \dpy -> do
|
|
|
|
r <- asks theRoot
|
|
|
|
a <- getAtom "_NET_SUPPORTED"
|
|
|
|
c <- getAtom "ATOM"
|
|
|
|
f <- getAtom "_NET_WM_STATE_FULLSCREEN"
|
|
|
|
io $ changeProperty32 dpy r a c propModeAppend [fromIntegral f]
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-02-22 19:40:54 +01:00
|
|
|
myStartupHook :: X ()
|
|
|
|
myStartupHook = do
|
2011-07-18 14:05:19 +02:00
|
|
|
startupHook desktopConfig
|
2011-02-22 19:40:54 +01:00
|
|
|
setWMName "LG3D"
|
2011-07-18 14:05:19 +02:00
|
|
|
setFullscreenSupported
|
|
|
|
spawn "ibus-daemon -r -x"
|
2011-02-22 19:40:54 +01:00
|
|
|
|
2011-02-27 21:20:00 +01:00
|
|
|
isUtility :: Query Bool
|
2011-02-28 23:51:55 +01:00
|
|
|
isUtility = isInProperty "_NET_WM_WINDOW_TYPE" "_NET_WM_WINDOW_TYPE_UTILITY"
|
2011-02-27 21:20:00 +01:00
|
|
|
|
2011-07-18 15:20:40 +02:00
|
|
|
stackHook :: (Window -> W.Stack Window -> W.Stack Window) -> ManageHook
|
|
|
|
stackHook f = ask >>= \w -> doF $ \s -> s { W.current = mapScreen w (W.current s)
|
|
|
|
, W.visible = map (mapScreen w) (W.visible s)
|
|
|
|
, W.hidden = map (mapWorkspace w) (W.hidden s)
|
|
|
|
}
|
|
|
|
where
|
|
|
|
mapWorkspace w ws = ws { W.stack = fmap (f w) $ W.stack ws }
|
|
|
|
mapScreen w scr = scr { W.workspace = mapWorkspace w (W.workspace scr) }
|
|
|
|
|
|
|
|
moveDown1 :: ManageHook
|
|
|
|
moveDown1 = stackHook down
|
|
|
|
where
|
|
|
|
down w (W.Stack c u (d:dx)) | c == w = W.Stack c (d:u) dx
|
|
|
|
down _ stack = stack
|
|
|
|
|
|
|
|
moveUp1 :: ManageHook
|
|
|
|
moveUp1 = stackHook up
|
|
|
|
where
|
|
|
|
up w (W.Stack c (u:ux) d) | c == w = W.Stack c ux (u:d)
|
|
|
|
up _ stack = stack
|
|
|
|
|
2011-07-18 14:05:19 +02:00
|
|
|
|
2010-02-13 18:31:17 +01:00
|
|
|
myManageHook :: ManageHook
|
2011-02-23 17:45:27 +01:00
|
|
|
myManageHook = composeAll
|
2011-07-18 15:20:40 +02:00
|
|
|
[ moveDown1
|
|
|
|
, isDialog --> doFloat
|
2011-02-28 22:08:02 +01:00
|
|
|
, composeOne
|
2011-03-01 02:31:21 +01:00
|
|
|
[ className =? "Guake.py" -?> doFloatMaybeFullscreen -- <+> doConfigBorderOff)
|
|
|
|
--, className =? "Do" -?> (doFloat <+> doConfigBorderOff)
|
2011-02-23 17:45:27 +01:00
|
|
|
, className =? "MPlayer" -?> doCenterFloat
|
2011-03-01 02:31:21 +01:00
|
|
|
, className =? "Gnome-session" -?> doIgnoreProcessWorkspace
|
2011-02-23 17:45:27 +01:00
|
|
|
, className =? "Gimp" -?> doFloat
|
2011-07-18 14:05:19 +02:00
|
|
|
, className =? "jrummikub-JRummikub" -?> doFloat
|
|
|
|
, className =? "Stjerm" -?> doFloatMaybeFullscreen
|
2011-02-23 17:45:27 +01:00
|
|
|
, className =? "Display" -?> doFloat
|
|
|
|
, className =? "Wine" -?> doFloat
|
|
|
|
, className =? "Pcsx2" -?> doFloat
|
|
|
|
, stringProperty "WM_ICON_NAME" =? "ZeroGS" -?> doFloat
|
|
|
|
, isFullscreen -?> doFullscreen
|
|
|
|
]
|
2011-02-27 21:20:00 +01:00
|
|
|
, isUtility =? False --> doAutoShift
|
2011-07-18 14:05:19 +02:00
|
|
|
, manageHook desktopConfig
|
2011-02-23 17:45:27 +01:00
|
|
|
]
|
2011-07-18 15:20:40 +02:00
|
|
|
|
|
|
|
myUnmanageHook :: ManageHook
|
|
|
|
myUnmanageHook = moveUp1
|
|
|
|
|
2010-02-13 18:31:17 +01:00
|
|
|
|
2011-03-01 02:31:21 +01:00
|
|
|
myLayoutHook = processWorkspaceManager $ manageFullscreen $ smartBorders (Full ||| tiled ||| Mirror tiled)
|
2010-02-13 18:31:17 +01:00
|
|
|
where
|
|
|
|
-- default tiling algorithm partitions the screen into two panes
|
2010-02-16 11:45:32 +01:00
|
|
|
tiled = ResizableTall nmaster delta ratio []
|
2010-02-13 18:31:17 +01:00
|
|
|
|
|
|
|
-- The default number of windows in the master pane
|
|
|
|
nmaster = 1
|
|
|
|
|
|
|
|
-- Default proportion of screen occupied by master pane
|
2010-02-16 11:45:32 +01:00
|
|
|
ratio = 3/5
|
2010-02-13 18:31:17 +01:00
|
|
|
|
|
|
|
-- Percent of screen to increment by when resizing panes
|
|
|
|
delta = 3/100
|
2010-02-13 19:14:15 +01:00
|
|
|
|
|
|
|
myEventHook :: Event -> X All
|
|
|
|
myEventHook ev = do
|
2011-03-01 02:31:21 +01:00
|
|
|
handleForgetEmptyWindowGroups ev
|
2010-02-13 19:14:15 +01:00
|
|
|
handleFullscreen ev
|
2011-07-18 14:05:19 +02:00
|
|
|
handleEventHook defaultConfig ev
|