dots/xmonad.hs

52 lines
1.5 KiB
Haskell
Raw Normal View History

2008-11-10 13:07:17 -06:00
import XMonad
import qualified XMonad.StackSet as W
import XMonad.Layout.Grid
2009-01-07 00:57:27 -05:00
import XMonad.Layout.NoBorders(smartBorders)
2008-11-10 13:07:17 -06:00
import XMonad.Hooks.DynamicLog
import XMonad.Hooks.ManageDocks
import XMonad.Util.Run(spawnPipe)
import XMonad.Util.EZConfig(additionalKeysP)
import XMonad.Util.Scratchpad
import XMonad.Prompt
2009-01-07 00:57:27 -05:00
import XMonad.Prompt.Shell(shellPrompt)
2009-03-30 00:44:06 -05:00
import XMonad.Prompt.Window
2009-01-07 00:57:27 -05:00
import System.IO(hPutStrLn)
2008-11-10 13:07:17 -06:00
myLayoutHook = tiled ||| Mirror tiled ||| Grid ||| Full
where
-- default tiling algorithm partitions the screen into two panes
tiled = Tall nmaster delta ratio
-- The default number of windows in the master pane
nmaster = 1
-- Default proportion of screen occupied by master pane
ratio = 1/2
-- Percent of screen to increment by when resizing panes
delta = 3/100
2008-11-10 13:07:17 -06:00
main = do
2009-04-06 15:22:14 -05:00
xmproc <- spawnPipe "xmobar"
xmonad $ defaultConfig
{ manageHook = manageDocks <+> manageHook defaultConfig <+> scratchpadManageHook (W.RationalRect 0.25 0.25 0.5 0.5)
, layoutHook = avoidStruts $ smartBorders $ myLayoutHook
, logHook = dynamicLogWithPP $ xmobarPP
{ ppOutput = hPutStrLn xmproc
2009-05-11 10:26:38 -05:00
, ppTitle = xmobarColor "#8AE234" ""
}
}
`additionalKeysP`
[ ("M-p", shellPrompt defaultXPConfig { position = Top })
2009-03-30 00:44:06 -05:00
, ("M-S-a", windowPromptGoto defaultXPConfig { position = Top })
, ("M-a", windowPromptBring defaultXPConfig { position = Top })
2009-04-17 16:11:19 -05:00
, ("M-x", sendMessage ToggleStruts)
, ("M-S-l", spawn "~/bin/lock")
, ("M-g", scratchpadSpawnAction defaultConfig)
]