import XMonad
+-- Necessary for reflectVert.
+import XMonad.Layout.Reflect
+-- Necessary for avoidMaster.
+import qualified XMonad.StackSet as W
+
+
+-- Prevent new windows from spawning in the master pane. Taken from
+-- http://haskell.org/haskellwiki/Xmonad/Frequently_asked_questions on
+-- 2009-06-30. Thanks.
+avoidMaster :: W.StackSet i l a s sd -> W.StackSet i l a s sd
+avoidMaster = W.modify' $ \c -> case c of
+ W.Stack t [] (r:rs) -> W.Stack t [r] rs
+ otherwise -> c
+
+-- Create my custom layout.
+--
+-- Only use horizontal (Mirror tiled) and fullscreen layouts.
+--
+-- The master pane is at the bottom of the screen (reflectVert). To make sure
+-- new windows don't spawn in the master pane avoidMaster (see below) is used.
+--
+-- Thanks to jrick in #xmonad on Freenode (2009-06-29 22:19) for telling me
+-- how to remove the vertical tiled layout.
+myLayoutHook = reflectVert $ Mirror tiled ||| 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
+
+-- Don't spawn new windows in the master pane (which is now at the bottom of
+-- the screen). Thanks to dschoepe, aavogt and especially vav in #xmonad on
+-- Freenode (2009-06-30 02:10f).
+myManageHook = doF avoidMaster
main = xmonad $ defaultConfig
-- Use Windows key as main key so it doesn't conflict with any other key
-- Inactive borders are black - invisible on my black screen.
, normalBorderColor = "#000000"
-- Active border is dark red.
- , focusedBorderColor = "#990000" }
+ , focusedBorderColor = "#990000"
+ -- Use my layout and manage hooks (see above).
+ , layoutHook = myLayoutHook
+ , manageHook = myManageHook
+ }