Personal tools

Xmonad/Config archive/Ray's xmonad.hs

From HaskellWiki

< Xmonad | Config archive(Difference between revisions)
Jump to: navigation, search
(updated my config)
(update, again)
 
(3 intermediate revisions by one user not shown)
Line 1: Line 1:
 
<haskell>
 
<haskell>
 
import XMonad
 
import XMonad
import XMonad.Layouts
+
import XMonad.Layout
 
import XMonad.Operations
 
import XMonad.Operations
  +
import XMonad.ManageHook
 
import XMonad.Hooks.DynamicLog
 
import XMonad.Hooks.DynamicLog
 
import XMonad.Layout.NoBorders
 
import XMonad.Layout.NoBorders
Line 8: Line 9:
 
import XMonad.Prompt.Ssh
 
import XMonad.Prompt.Ssh
 
import XMonad.Prompt.XMonad
 
import XMonad.Prompt.XMonad
  +
import XMonad.Util.Run
  +
import XMonad.Actions.NoBorders
  +
import XMonad.Actions.Warp
 
import qualified XMonad.StackSet as W
 
import qualified XMonad.StackSet as W
 
import Graphics.X11
 
import Graphics.X11
Line 15: Line 19:
 
import Data.Bits
 
import Data.Bits
   
main = xmonad rayConfig
+
main = do dzenh <- spawnPipe "dzen2 -bg '#333333'"
  +
xmonad $ rayConfig dzenh
   
rayConfig = defaultConfig
+
rayConfig h = defaultConfig
{ normalBorderColor = "#333333"
+
{ normalBorderColor = "#333333"
, focusedBorderColor = "#0000ff"
+
, focusedBorderColor = "#0000ff"
, workspaces = ["α","β","γ","δ","ε","ζ"]
+
, borderWidth = 1
, terminal = "rayterm"
+
, workspaces = ["α","β","γ","δ","ε","ζ"]
, defaultGaps = [(18,0,0,0)]
+
, terminal = "rayterm"
, modMask = mod4Mask
+
, defaultGaps = [(18,0,0,0)]
, manageHook = rayManageHook
+
, modMask = mod4Mask
, logHook = dynamicLogWithPP rayPP
+
, manageHook = rayManageHook
, keys = \c -> rayKeys c `M.union` keys defaultConfig c
+
, logHook = dynamicLogWithPP $ rayPP h
, layoutHook = Layout
+
, keys = \c -> rayKeys c `M.union` keys defaultConfig c
$ Mirror (Tall 1 0 (1%2))
+
, focusFollowsMouse = False
||| (noBorders Full)
+
, layoutHook = Mirror (Tall 1 0 (1%2))
}
+
||| noBorders Full
  +
}
   
rayManageHook :: Window -- ^ the new window to manage
+
rayManageHook = composeAll . concat $
-> String -- ^ window title
+
[ [ className =? c --> doFloat | c <- floats]
-> String -- ^ window resource name
+
, [ className =? "Opera" --> doF (W.shift "β") ]]
-> String -- ^ window resource class
+
where floats = ["MPlayer", "Gimp","xli","Xmessage"]
-> X (WindowSet -> WindowSet)
 
rayManageHook w _ _ c | c `elem` floats = fmap (W.float w . snd) (floatLocation w)
 
where floats = ["MPlayer", "Gimp", "xli"]
 
rayManageHook _ _ _ "Opera" = return $ W.shift "β"
 
rayManageHook _ _ _ _ = return $ id
 
   
 
rayKeys (XConfig {modMask = modm}) = M.fromList $
 
rayKeys (XConfig {modMask = modm}) = M.fromList $
[ ((modm , xK_s), sshPrompt defaultXPConfig)
+
[ ((modm , xK_s), sshPrompt defaultXPConfig)
, ((modm .|. controlMask, xK_x), xmonadPrompt defaultXPConfig)
+
, ((modm .|. controlMask, xK_x), xmonadPrompt defaultXPConfig)
]
+
, ((modm , xK_x), spawn "xscreensaver-command -lock")
  +
, ((modm .|. shiftMask , xK_b), withFocused toggleBorder)
  +
, ((modm .|. controlMask, xK_b), warpToScreen 0 1 1)
  +
]
   
rayPP = PP { ppCurrent = wrap "^fg(#ff0000)\"" "\"^fg()"
+
rayPP h = PP { ppCurrent = wrap "^fg(#ff0000)\"" "\"^fg()"
, ppVisible = wrap "^fg(#a00000)\"" "\"^fg()"
+
, ppVisible = wrap "^fg(#a00000)\"" "\"^fg()"
, ppHidden = wrap "^fg(#ffffff)\"" "\"^fg()"
+
, ppHidden = wrap "^fg(#ffffff)\"" "\"^fg()"
, ppHiddenNoWindows = wrap "^fg(#555555)\"" "\"^fg()"
+
, ppHiddenNoWindows = wrap "^fg(#555555)\"" "\"^fg()"
, ppSep = " "
+
, ppSep = " "
, ppWsSep = ","
+
, ppWsSep = ","
, ppTitle = shorten 80
+
, ppTitle = shorten 80
, ppLayout = (++) "layout = "
+
, ppLayout = (++) "layout = "
, ppOrder = (take 2) . workspaceTag
+
, ppOrder = (take 2) . workspaceTag
, ppOutput = System.IO.UTF8.putStrLn
+
, ppOutput = System.IO.UTF8.hPutStrLn h
}
+
}
where workspaceTag (x:xs) = ("workspaces = [" ++ x ++ "]") : xs
+
where workspaceTag (x:xs) = ("workspaces = [" ++ x ++ "]") : xs</haskell>
</haskell>
 

Latest revision as of 15:28, 30 January 2008

import XMonad
import XMonad.Layout
import XMonad.Operations
import XMonad.ManageHook
import XMonad.Hooks.DynamicLog
import XMonad.Layout.NoBorders
import XMonad.Prompt
import XMonad.Prompt.Ssh
import XMonad.Prompt.XMonad
import XMonad.Util.Run
import XMonad.Actions.NoBorders
import XMonad.Actions.Warp
import qualified XMonad.StackSet as W
import Graphics.X11
import qualified Data.Map as M
import System.IO.UTF8
import Data.Ratio
import Data.Bits
 
main = do dzenh <- spawnPipe "dzen2 -bg '#333333'"
          xmonad $ rayConfig dzenh
 
rayConfig h = defaultConfig
              { normalBorderColor        = "#333333"
              , focusedBorderColor       = "#0000ff"
              , borderWidth              = 1
              , workspaces               = ["α","β","γ","δ","ε","ζ"]
              , terminal                 = "rayterm"
              , defaultGaps              = [(18,0,0,0)]
              , modMask                  = mod4Mask
              , manageHook               = rayManageHook
              , logHook                  = dynamicLogWithPP $ rayPP h
              , keys                     = \c -> rayKeys c `M.union` keys defaultConfig c
              , focusFollowsMouse        = False
              , layoutHook               = Mirror (Tall 1 0 (1%2))
                                           ||| noBorders Full
              }
 
rayManageHook = composeAll . concat $
                [ [ className =? c --> doFloat | c <- floats]
                , [ className =? "Opera" --> doF (W.shift "β") ]]
    where floats = ["MPlayer", "Gimp","xli","Xmessage"]
 
rayKeys (XConfig {modMask = modm}) = M.fromList $
                                     [ ((modm                , xK_s), sshPrompt defaultXPConfig)
                                     , ((modm .|. controlMask, xK_x), xmonadPrompt defaultXPConfig)
                                     , ((modm                , xK_x), spawn "xscreensaver-command -lock")
                                     , ((modm .|. shiftMask  , xK_b), withFocused toggleBorder)
                                     , ((modm .|. controlMask, xK_b), warpToScreen 0 1 1)
                                     ]
 
rayPP h = PP { ppCurrent         = wrap "^fg(#ff0000)\"" "\"^fg()"
             , ppVisible         = wrap "^fg(#a00000)\"" "\"^fg()"
             , ppHidden          = wrap "^fg(#ffffff)\"" "\"^fg()"
             , ppHiddenNoWindows = wrap "^fg(#555555)\"" "\"^fg()"
             , ppSep             = "   "
             , ppWsSep           = ","
             , ppTitle           = shorten 80
             , ppLayout          = (++) "layout = "
             , ppOrder           = (take 2) . workspaceTag
             , ppOutput          = System.IO.UTF8.hPutStrLn h
             }
    where workspaceTag (x:xs) = ("workspaces = [" ++ x ++ "]") : xs