it has been a wile

This commit is contained in:
Zastian Pretorius
2022-04-15 16:35:03 +02:00
parent 0286a1de98
commit 20374593b9
20 changed files with 2824 additions and 1949 deletions

View File

@@ -0,0 +1,361 @@
#+title: XMonad config
#+author: mrfluffy
#+PROPERTY: header-args :tangle xmonad.hs
* imports
This is all the imports needed for this config to work.
#+begin_src haskell
import XMonad
import Data.Monoid
import Data.List (sortBy)
import Data.Function (on)
import XMonad.Hooks.DynamicLog
import XMonad.Hooks.StatusBar
import XMonad.Hooks.StatusBar.PP
import XMonad.Hooks.WindowSwallowing
import Control.Monad (forM_, join)
import Control.Monad (liftM2)
import System.Exit
import System.IO
import XMonad.Util.SpawnOnce
import XMonad.Util.Scratchpad
import XMonad.Hooks.ManageDocks
import XMonad.Util.Run
import XMonad.Hooks.EwmhDesktops
import XMonad.Hooks.ManageDocks
import XMonad.Util.NamedWindows (getName)
import XMonad.Layout.NoBorders
import XMonad.Layout.Spiral
import XMonad.Layout.ThreeColumns
import XMonad.Util.EZConfig
import XMonad.Layout.Spacing
import XMonad.Actions.UpdatePointer
import XMonad.Actions.SwapWorkspaces
import qualified XMonad.StackSet as W
import qualified Data.Map as M
#+end_src
* variables
Setting variables that will be used later in the config.
#+begin_src haskell
myTerminal = "kitty"
myFocusFollowsMouse :: Bool
myFocusFollowsMouse = True
myClickJustFocuses :: Bool
myClickJustFocuses = False
myBorderWidth = 3
myModMask = mod1Mask
myWorkspaces = ["1","2","3","4","5","6","7","8","9"]
myNormalBorderColor = "#1A1A1A"
myFocusedBorderColor = "#8218c4"
#+end_src
* fullscreen function
Looks to see if focused window is floating and if it is the places it in the stack
else it makes it floating but as full screen
#+begin_src haskell
toggleFull = withFocused (\windowId -> do
{ floats <- gets (W.floating . windowset);
if windowId `M.member` floats
then withFocused $ windows . W.sink
else withFocused $ windows . (flip W.float $ W.RationalRect 0 0 1 1) })
#+end_src
* Keyboard keybindings
Key bindings. Add, modify or remove key bindings here.
#+begin_src haskell
myKeys conf@(XConfig {XMonad.modMask = modm}) = M.fromList $
[
-- open browser
((modm, xK_b ), spawn "qutebrowser")
-- open calculater
,((modm, xK_c ), spawn "qalculate-gtk")
-- open PcmanFM
, ((modm, xK_f ), spawn "pcmanfm")
-- open kde colour picker
, ((modm, xK_p ), spawn "kcolorchooser")
-- Volume control
, ((0,0x1008ff11), spawn "pamixer --allow-boost -d 5") --Folume down
, ((0,0x1008ff13), spawn "pamixer --allow-boost -i 5") --Folume up
, ((0,0x1008ff12), spawn "pamixer -t") --Mute Toggle
, ((0,0x1008ffb2), spawn "pactl set-source-mute @DEFAULT_SOURCE@ toggle") --Mic Toggle
--Brightness control
, ((0,0x1008ff02), spawn "light -A 10") --Brightness Up
, ((0,0x1008ff03), spawn "light -U 10") --Brightness Up
--Media Control
, ((0,0x1008ff14), spawn "playerctl play-pause") -- Play/Pause
, ((0,0x1008ff16), spawn "playerctl previous") -- Play/Pause
, ((0,0x1008ff17), spawn "playerctl next") -- Play/Pause
-- Take screenshot
, ((0,0xff61), spawn "flameshot gui")
-- Lock screen
, ((mod4Mask, xK_l), spawn "betterlockscreen --lock")
, ((mod4Mask, xK_F5), spawn "/home/$USER/.config/script/refreshXmonad.sh")
, ((mod4Mask, xK_F6), spawn "/home/$USER/.config/script/toggelTuchpad.sh")
, ((mod4Mask, xK_F7), spawn "/home/$USER/.config/script/ariplaneMode.sh")
, ((mod4Mask, xK_F10), spawn "arandr")
-- launch a terminal
, ((modm, xK_Return), spawn $ XMonad.terminal conf)
, ((modm, xK_backslash), scratchpadSpawnActionTerminal "kitty --class=scratchpad")
-- launch rofi
, ((modm, xK_d ), spawn "rofi -no-lazy-greb -show drun -icon-theme 'Papirus' -show-icons")
-- launch a scrachpad
, ((modm .|. shiftMask, xK_s ), spawn "kitty --class=scratchpad")
-- close focused window
, ((modm, xK_q ), kill)
-- Rotate through the available layout algorithms
, ((modm, xK_space ), sendMessage NextLayout)
-- Reset the layouts on the current workspace to default
, ((modm .|. shiftMask, xK_space ), setLayout $ XMonad.layoutHook conf)
-- Resize viewed windows to the correct size
, ((modm, xK_n ), refresh)
-- Move focus to the next window
, ((modm, xK_Tab ), windows W.focusDown)
-- Move focus to the next window
, ((modm, xK_j ), windows W.focusDown)
-- Move focus to the previous window
, ((modm, xK_k ), windows W.focusUp )
-- Move focus to the master window
, ((mod4Mask, xK_m ), windows W.focusMaster )
-- Swap the focused window and the master window
, ((modm .|. shiftMask, xK_m ), windows W.swapMaster)
-- Swap the focused window with the next window
, ((modm .|. shiftMask, xK_j ), windows W.swapDown )
-- Swap the focused window with the previous window
, ((modm .|. shiftMask, xK_k ), windows W.swapUp )
-- Shrink the master area
, ((modm .|. controlMask, xK_h ), sendMessage Shrink)
-- Expand the master area
, ((modm .|. controlMask, xK_l ), sendMessage Expand)
-- toggle between full screen and tieling
, ((modm, xK_t ), toggleFull)
-- Increment the number of windows in the master area
, ((modm , xK_comma ), sendMessage (IncMasterN 1))
-- Deincrement the number of windows in the master area
, ((modm , xK_period), sendMessage (IncMasterN (-1)))
-- Quit xmonad
, ((modm .|. shiftMask, xK_q ), io (exitWith ExitSuccess))
-- Restart xmonad
, ((modm .|. shiftMask, xK_r ), spawn "xmonad --recompile; xmonad --restart")
]
++
-- mod-[1..9], Switch to workspace N
-- mod-shift-[1..9], Move client to workspace N
[((m .|. modm, k), windows $ f i)
| (i, k) <- zip (XMonad.workspaces conf) [xK_1 .. xK_9]
, (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask)]]
++
-- mod-{w,e,r}, Switch to physical/Xinerama screens 1, 2, or 3
-- mod-shift-{w,e,r}, Move client to screen 1, 2, or 3
[((m .|. modm, key), screenWorkspace sc >>= flip whenJust (windows . f))
| (key, sc) <- zip [xK_l, xK_h] [0..]
, (f, m) <- [(W.view, 0), (W.shift, shiftMask)]]
#+end_src
* Mouse bindings
Mouse bindings: default actions bound to mouse events
#+begin_src haskell
myMouseBindings (XConfig {XMonad.modMask = modm}) = M.fromList $
-- mod-button1, Set the window to floating mode and move by dragging
[ ((modm, button1), (\w -> focus w >> mouseMoveWindow w
>> windows W.shiftMaster))
-- mod-button2, Raise the window to the top of the stack
, ((modm, button2), (\w -> focus w >> windows W.shiftMaster))
-- mod-button3, Set the window to floating mode and resize by dragging
, ((modm, button3), (\w -> focus w >> mouseResizeWindow w
>> windows W.shiftMaster))
]
#+end_src
------------------------------------------------------------------------
* Layouts:
You can specify and transform your layouts by modifying these values.
If you change layout bindings be sure to use 'mod-shift-space' after
restarting (with 'mod-q') to reset your layout state to the new
defaults, as xmonad preserves your old layout settings by default.
The available layouts. Note that each layout is separated by |||,
which denotes layout choice.
#+begin_src haskell
myLayout = mySpacing $ avoidStruts ( tiled ||| Mirror tiled ||| noBorders Full ||| spiral (6/7) ||| ThreeCol 1 (3/100) (1/2))
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
#+end_src
* Window spacing (gaps)
sets the spacing of the windows.
#+begin_src haskell
mySpacing = spacingRaw False -- Only for >1 window
-- The bottom edge seems to look narrower than it is
(Border 30 3 3 3) -- Size of screen edge gaps
True -- Enable screen edge gaps
(Border 3 3 3 3) -- Size of window gaps
True -- Enable window gaps
#+end_src
------------------------------------------------------------------------
* Window rules
Execute arbitrary actions and WindowSet manipulations when managing
a new window. You can use this to, for example, always float a
particular program, or have a client always appear on a particular
workspace.
To find the property name associated with a program, use
> xprop | grep WM_CLASS
and click on the client you're interested in.
To match on the WM_NAME, you can use 'title' in the same way that
'className' and 'resource' are used below.
#+begin_src haskell
myManageHook = composeAll
[className =? "Gimp" --> doFloat
, className =? "Qalculate-gtk" --> doFloat
, className =? "Pavucontrol" --> doFloat
, className =? "Minecraft Launcher" --> doShift "8"
, className =? "Microsoft Teams - Preview" --> doShift "7"
, className =? "YouTube Music" --> doShift "9"
, className =? "Thunar" --> viewShift "5"
, resource =? "desktop_window" --> doIgnore
, resource =? "kdesktop" --> doIgnore
]
where viewShift = doF . liftM2 (.) W.greedyView W.shift
#+end_src
------------------------------------------------------------------------
* Event handling
EwmhDesktops users should change this to ewmhDesktopsEventHook
Defines a custom handler function for X Events. The function should
return (All True) if the default handler is to be run afterwards. To
combine event hooks use mappend or mconcat from Data.Monoid.
#+begin_src haskell
myEventHook = swallowEventHook (className =? "kitty" <||> className =? "Termite") (return True)
#+end_src
* Log Hooks
Status bars and logging
Perform an arbitrary action on each internal state change or X event.
See the 'XMonad.Hooks.DynamicLog' extension for examples.
#+begin_src haskell
myLogHook = do
winset <- gets windowset
title <- maybe (return "") (fmap show . getName) . W.peek $ winset
let currWs = W.currentTag winset
let wss = map W.tag $ W.workspaces winset
let wsStr = join $ map (fmt currWs) $ sort' wss
io $ appendFile "/tmp/.xmonad-title-log" (title ++ "\n")
io $ appendFile "/tmp/.xmonad-workspace-log" (wsStr ++ "\n")
where fmt currWs ws
| currWs == ws = "[" ++ ws ++ "]"
| otherwise = " " ++ ws ++ " "
sort' = sortBy (compare `on` (!! 0))
#+end_src
* Window swallowing with kitty
#+begin_src haskell
myHandleEventHook = swallowEventHook (className =? "kitty" <||> className =? "Termite") (return True)
#+end_src
* Start up applications
Perform an arbitrary action each time xmonad starts or is restarted
with mod-q. Used by, e.g., XMonad.Layout.PerWorkspace to initialize
per-workspace layout choices.
By default, do nothing.
#+begin_src haskell
myStartupHook = do
spawnOnce "dunst &"
spawnOnce "pipewire & /usr/bin/pipewire-pulse & /usr/bin/pipewire-media-session &"
spawnOnce "/home/$USER/.config/script/redshift.sh &"
spawnOnce "xss-lock /home/$USER/.config/script/betterlockscreen.sh &"
spawnOnce "nextcloud --background &"
spawnOnce "fcitx -d &"
spawnOnce "copyq --start-server"
spawnOnce "/usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1"
spawnOnce "nm-applet &"
spawnOnce "picom --backend glx &"
spawnOnce "nitrogen --restore &"
#+end_src
* main (starting xmonad)
Now run xmonad with all the defaults we set up.
Run xmonad with the settings you specify. No need to modify this.
#+begin_src haskell
myPP = def {ppCurrent = xmobarColor "black" "whight"}
mainBar = statusBarPropTo "_XMONAD_LOG_1" "polybar MainWithTray" (pure myPP)
secondBar = statusBarPropTo "_XMONAD_LOG_2" "polybar SeconderyWitNoTray" (pure myPP)
barSpawner :: ScreenId -> IO StatusBarConfig
barSpawner 0 = pure $ mainBar
barSpawner 1 = pure $ secondBar
barSpawner _ = mempty
main = do
xmonad $ docks $ ewmhFullscreen $ ewmh $ dynamicSBs barSpawner def {
-- simple stuff
terminal = myTerminal,
focusFollowsMouse = myFocusFollowsMouse,
clickJustFocuses = myClickJustFocuses,
borderWidth = myBorderWidth,
modMask = myModMask,
workspaces = myWorkspaces,
normalBorderColor = myNormalBorderColor,
focusedBorderColor = myFocusedBorderColor,
-- key bindings
keys = myKeys,
mouseBindings = myMouseBindings ,
-- hooks, layouts
layoutHook = smartBorders $ myLayout,
manageHook = myManageHook <+> scratchpadManageHook (W.RationalRect 0.4 0.3 0.6 0.5),
handleEventHook = myEventHook,
logHook = myLogHook >> updatePointer (0.5, 0.5) (0, 0),
startupHook = myStartupHook -- dynStatusBarStartup barInScreen (return ())
}
forM_ [".xmonad-workspace-log", ".xmonad-title-log"] $ \file -> do
safeSpawn "mkfifo" ["/tmp/" ++ file]
#+end_src

View File

@@ -0,0 +1,276 @@
import XMonad
import Data.Monoid
import Data.List (sortBy)
import Data.Function (on)
import XMonad.Hooks.DynamicLog
import XMonad.Hooks.StatusBar
import XMonad.Hooks.StatusBar.PP
import XMonad.Hooks.WindowSwallowing
import Control.Monad (forM_, join)
import Control.Monad (liftM2)
import System.Exit
import System.IO
import XMonad.Util.SpawnOnce
import XMonad.Util.Scratchpad
import XMonad.Hooks.ManageDocks
import XMonad.Util.Run
import XMonad.Hooks.EwmhDesktops
import XMonad.Hooks.ManageDocks
import XMonad.Util.NamedWindows (getName)
import XMonad.Layout.NoBorders
import XMonad.Layout.Spiral
import XMonad.Layout.ThreeColumns
import XMonad.Util.EZConfig
import XMonad.Layout.Spacing
import XMonad.Actions.UpdatePointer
import XMonad.Actions.SwapWorkspaces
import qualified XMonad.StackSet as W
import qualified Data.Map as M
myTerminal = "kitty"
myFocusFollowsMouse :: Bool
myFocusFollowsMouse = True
myClickJustFocuses :: Bool
myClickJustFocuses = False
myBorderWidth = 3
myModMask = mod1Mask
myWorkspaces = ["1","2","3","4","5","6","7","8","9"]
myNormalBorderColor = "#1A1A1A"
myFocusedBorderColor = "#8218c4"
toggleFull = withFocused (\windowId -> do
{ floats <- gets (W.floating . windowset);
if windowId `M.member` floats
then withFocused $ windows . W.sink
else withFocused $ windows . (flip W.float $ W.RationalRect 0 0 1 1) })
myKeys conf@(XConfig {XMonad.modMask = modm}) = M.fromList $
[
-- open browser
((modm, xK_b ), spawn "qutebrowser")
-- open calculater
,((modm, xK_c ), spawn "qalculate-gtk")
-- open PcmanFM
, ((modm, xK_f ), spawn "pcmanfm")
-- open kde colour picker
, ((modm, xK_p ), spawn "kcolorchooser")
-- Volume control
, ((0,0x1008ff11), spawn "pamixer --allow-boost -d 5") --Folume down
, ((0,0x1008ff13), spawn "pamixer --allow-boost -i 5") --Folume up
, ((0,0x1008ff12), spawn "pamixer -t") --Mute Toggle
, ((0,0x1008ffb2), spawn "pactl set-source-mute @DEFAULT_SOURCE@ toggle") --Mic Toggle
--Brightness control
, ((0,0x1008ff02), spawn "light -A 10") --Brightness Up
, ((0,0x1008ff03), spawn "light -U 10") --Brightness Up
--Media Control
, ((0,0x1008ff14), spawn "playerctl play-pause") -- Play/Pause
, ((0,0x1008ff16), spawn "playerctl previous") -- Play/Pause
, ((0,0x1008ff17), spawn "playerctl next") -- Play/Pause
-- Take screenshot
, ((0,0xff61), spawn "flameshot gui")
-- Lock screen
, ((mod4Mask, xK_l), spawn "betterlockscreen --lock")
, ((mod4Mask, xK_F5), spawn "/home/$USER/.config/script/refreshXmonad.sh")
, ((mod4Mask, xK_F6), spawn "/home/$USER/.config/script/toggelTuchpad.sh")
, ((mod4Mask, xK_F7), spawn "/home/$USER/.config/script/ariplaneMode.sh")
, ((mod4Mask, xK_F10), spawn "arandr")
-- launch a terminal
, ((modm, xK_Return), spawn $ XMonad.terminal conf)
, ((modm, xK_backslash), scratchpadSpawnActionTerminal "kitty --class=scratchpad")
-- launch rofi
, ((modm, xK_d ), spawn "rofi -no-lazy-greb -show drun -icon-theme 'Papirus' -show-icons")
-- launch a scrachpad
, ((modm .|. shiftMask, xK_s ), spawn "kitty --class=scratchpad")
-- close focused window
, ((modm, xK_q ), kill)
-- Rotate through the available layout algorithms
, ((modm, xK_space ), sendMessage NextLayout)
-- Reset the layouts on the current workspace to default
, ((modm .|. shiftMask, xK_space ), setLayout $ XMonad.layoutHook conf)
-- Resize viewed windows to the correct size
, ((modm, xK_n ), refresh)
-- Move focus to the next window
, ((modm, xK_Tab ), windows W.focusDown)
-- Move focus to the next window
, ((modm, xK_j ), windows W.focusDown)
-- Move focus to the previous window
, ((modm, xK_k ), windows W.focusUp )
-- Move focus to the master window
, ((mod4Mask, xK_m ), windows W.focusMaster )
-- Swap the focused window and the master window
, ((modm .|. shiftMask, xK_m ), windows W.swapMaster)
-- Swap the focused window with the next window
, ((modm .|. shiftMask, xK_j ), windows W.swapDown )
-- Swap the focused window with the previous window
, ((modm .|. shiftMask, xK_k ), windows W.swapUp )
-- Shrink the master area
, ((modm .|. controlMask, xK_h ), sendMessage Shrink)
-- Expand the master area
, ((modm .|. controlMask, xK_l ), sendMessage Expand)
-- toggle between full screen and tieling
, ((modm, xK_t ), toggleFull)
-- Increment the number of windows in the master area
, ((modm , xK_comma ), sendMessage (IncMasterN 1))
-- Deincrement the number of windows in the master area
, ((modm , xK_period), sendMessage (IncMasterN (-1)))
-- Quit xmonad
, ((modm .|. shiftMask, xK_q ), io (exitWith ExitSuccess))
-- Restart xmonad
, ((modm .|. shiftMask, xK_r ), spawn "xmonad --recompile; xmonad --restart")
]
++
-- mod-[1..9], Switch to workspace N
-- mod-shift-[1..9], Move client to workspace N
[((m .|. modm, k), windows $ f i)
| (i, k) <- zip (XMonad.workspaces conf) [xK_1 .. xK_9]
, (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask)]]
++
-- mod-{w,e,r}, Switch to physical/Xinerama screens 1, 2, or 3
-- mod-shift-{w,e,r}, Move client to screen 1, 2, or 3
[((m .|. modm, key), screenWorkspace sc >>= flip whenJust (windows . f))
| (key, sc) <- zip [xK_l, xK_h] [0..]
, (f, m) <- [(W.view, 0), (W.shift, shiftMask)]]
myMouseBindings (XConfig {XMonad.modMask = modm}) = M.fromList $
-- mod-button1, Set the window to floating mode and move by dragging
[ ((modm, button1), (\w -> focus w >> mouseMoveWindow w
>> windows W.shiftMaster))
-- mod-button2, Raise the window to the top of the stack
, ((modm, button2), (\w -> focus w >> windows W.shiftMaster))
-- mod-button3, Set the window to floating mode and resize by dragging
, ((modm, button3), (\w -> focus w >> mouseResizeWindow w
>> windows W.shiftMaster))
]
myLayout = mySpacing $ avoidStruts ( tiled ||| Mirror tiled ||| noBorders Full ||| spiral (6/7) ||| ThreeCol 1 (3/100) (1/2))
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
mySpacing = spacingRaw False -- Only for >1 window
-- The bottom edge seems to look narrower than it is
(Border 30 3 3 3) -- Size of screen edge gaps
True -- Enable screen edge gaps
(Border 3 3 3 3) -- Size of window gaps
True -- Enable window gaps
myManageHook = composeAll
[className =? "Gimp" --> doFloat
, className =? "Qalculate-gtk" --> doFloat
, className =? "Pavucontrol" --> doFloat
, className =? "Minecraft Launcher" --> doShift "8"
, className =? "Microsoft Teams - Preview" --> doShift "7"
, className =? "YouTube Music" --> doShift "9"
, className =? "Thunar" --> viewShift "5"
, resource =? "desktop_window" --> doIgnore
, resource =? "kdesktop" --> doIgnore
]
where viewShift = doF . liftM2 (.) W.greedyView W.shift
myEventHook = swallowEventHook (className =? "kitty" <||> className =? "Termite") (return True)
myLogHook = do
winset <- gets windowset
title <- maybe (return "") (fmap show . getName) . W.peek $ winset
let currWs = W.currentTag winset
let wss = map W.tag $ W.workspaces winset
let wsStr = join $ map (fmt currWs) $ sort' wss
io $ appendFile "/tmp/.xmonad-title-log" (title ++ "\n")
io $ appendFile "/tmp/.xmonad-workspace-log" (wsStr ++ "\n")
where fmt currWs ws
| currWs == ws = "[" ++ ws ++ "]"
| otherwise = " " ++ ws ++ " "
sort' = sortBy (compare `on` (!! 0))
myHandleEventHook = swallowEventHook (className =? "kitty" <||> className =? "Termite") (return True)
myStartupHook = do
spawnOnce "dunst &"
spawnOnce "pipewire & /usr/bin/pipewire-pulse & /usr/bin/pipewire-media-session &"
spawnOnce "/home/$USER/.config/script/redshift.sh &"
spawnOnce "xss-lock /home/$USER/.config/script/betterlockscreen.sh &"
spawnOnce "nextcloud --background &"
spawnOnce "fcitx -d &"
spawnOnce "copyq --start-server"
spawnOnce "/usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1"
spawnOnce "nm-applet &"
spawnOnce "picom --backend glx &"
spawnOnce "nitrogen --restore &"
myPP = def {ppCurrent = xmobarColor "black" "whight"}
mainBar = statusBarPropTo "_XMONAD_LOG_1" "polybar MainWithTray" (pure myPP)
secondBar = statusBarPropTo "_XMONAD_LOG_2" "polybar SeconderyWitNoTray" (pure myPP)
barSpawner :: ScreenId -> IO StatusBarConfig
barSpawner 0 = pure $ mainBar
barSpawner 1 = pure $ secondBar
barSpawner _ = mempty
main = do
xmonad $ docks $ ewmhFullscreen $ ewmh $ dynamicSBs barSpawner def {
-- simple stuff
terminal = myTerminal,
focusFollowsMouse = myFocusFollowsMouse,
clickJustFocuses = myClickJustFocuses,
borderWidth = myBorderWidth,
modMask = myModMask,
workspaces = myWorkspaces,
normalBorderColor = myNormalBorderColor,
focusedBorderColor = myFocusedBorderColor,
-- key bindings
keys = myKeys,
mouseBindings = myMouseBindings ,
-- hooks, layouts
layoutHook = smartBorders $ myLayout,
manageHook = myManageHook <+> scratchpadManageHook (W.RationalRect 0.4 0.3 0.6 0.5),
handleEventHook = myEventHook,
logHook = myLogHook >> updatePointer (0.5, 0.5) (0, 0),
startupHook = myStartupHook -- dynStatusBarStartup barInScreen (return ())
}
forM_ [".xmonad-workspace-log", ".xmonad-title-log"] $ \file -> do
safeSpawn "mkfifo" ["/tmp/" ++ file]