--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/xmonad.patch Thu Jun 12 10:55:34 2008 +0200
@@ -0,0 +1,206 @@
+xmonad
+
+diff --git a/source/custom-x11/xmonad/FrugalBuild b/source/custom-x11/xmonad/FrugalBuild
+new file mode 100644
+index 0000000..a109bfe
+--- /dev/null
++++ b/source/custom-x11/xmonad/FrugalBuild
+@@ -0,0 +1,36 @@
++pkgname=xmonad
++pkgver=0.7
++pkgrel=1
++pkgdesc="A lightweight X11 tiled window manager written in Haskell"
++arch=(i686 x86_64)
++url="http://xmonad.org/"
++license=('BSD')
++depends=('ghc' 'gmp' 'libxinerama' 'haskell-x11')
++install='xmonad.install'
++source=(http://hackage.haskell.org/packages/archive/$pkgname/$pkgver/$pkgname-$pkgver.tar.gz)
++up2date="lynx -nolist -dump '$url'|grep -A5 'stable release'|grep -m1 '$pkgname'|sed 's/.*$pkgname \([0-9.]*\) .*/\1/'"
++archs=(i686)
++sha1sums=('cf3fb7662c92cadb9ea7bfdc916bbe5cc587ac86')
++
++build() {
++ Fcd
++
++ runhaskell Setup.lhs configure --ghc --prefix=/usr \
++ --libsubdir=\$compiler/site-local/\$pkgid || return 1
++
++ runhaskell Setup.lhs build || return 1
++
++ runhaskell Setup.lhs register --gen-script
++ runhaskell Setup.lhs unregister --gen-script
++
++ install -D -m744 register.sh $Fdestdir/usr/share/haskell/$pkgname/register.sh
++ install -m744 unregister.sh $Fdestdir/usr/share/haskell/$pkgname/unregister.sh
++ runhaskell Setup.lhs copy --destdir=$Fdestdir
++ runhaskell util/GenerateManpage.hs
++
++ install -D -m644 man/xmonad.1 $Fdestdir/usr/man/man1/xmonad.1
++
++ install -d -m755 $Fdestdir/usr/share/xmonad
++ install -m644 $startdir/examples/README $Fdestdir/usr/share/xmonad/
++ install -m644 $startdir/examples/*.hs $Fdestdir/usr/share/xmonad/
++}
+diff --git a/source/custom-x11/xmonad/examples/README b/source/custom-x11/xmonad/examples/README
+new file mode 100644
+index 0000000..ba16abb
+--- /dev/null
++++ b/source/custom-x11/xmonad/examples/README
+@@ -0,0 +1,2 @@
++This directory contains examples for ~/xmonad/xmonad.hs
++
+diff --git a/source/custom-x11/xmonad/examples/vegai.hs b/source/custom-x11/xmonad/examples/vegai.hs
+new file mode 100644
+index 0000000..abcbf37
+--- /dev/null
++++ b/source/custom-x11/xmonad/examples/vegai.hs
+@@ -0,0 +1,119 @@
++-- DynamicLog require xmonad-contrib
++
++import XMonad
++import XMonad.Hooks.DynamicLog
++
++import qualified XMonad.StackSet as W
++import qualified Data.Map as M
++import System.Exit
++import Graphics.X11.Xlib
++
++main = xmonad $ defaultConfig
++ { workspaces = workspaces',
++ modMask = modMask',
++ borderWidth = borderWidth',
++ normalBorderColor = normalBorderColor',
++ focusedBorderColor = focusedBorderColor',
++ defaultGaps = defaultGaps',
++ terminal = terminal',
++ keys = keys',
++ logHook = logHook'
++ }
++
++workspaces' :: [WorkspaceId]
++workspaces' = ["1-code", "2-test", "3-misc", "4-web", "5-mail", "6", "7", "8", "9-irc"]
++
++modMask' :: KeyMask
++modMask' = mod4Mask
++
++borderWidth' :: Dimension
++borderWidth' = 0
++
++normalBorderColor', focusedBorderColor' :: String
++normalBorderColor' = "#000000"
++focusedBorderColor' = "#0f0f0f"
++
++
++defaultGaps' :: [(Int,Int,Int,Int)]
++defaultGaps' = [(15,0,0,0), (15,0,0,0)] -- 15 for default dzen font
++
++logHook' :: X ()
++logHook' = dynamicLogXinerama
++
++terminal' :: String
++terminal' = "urxvt"
++
++
++
++keys' :: XConfig Layout -> M.Map (KeyMask, KeySym) (X ())
++keys' conf@(XConfig {XMonad.modMask = modMask}) = M.fromList $
++ -- launching and killing programs
++ [ ((modMask .|. shiftMask, xK_t), spawn $ XMonad.terminal conf) -- %! Launch terminal
++ , ((modMask, xK_p ), spawn "exe=`dmenu_path | dmenu` && eval \"exec $exe\"") -- %! Launch dmenu
++ , ((modMask .|. shiftMask, xK_p ), spawn "gmrun") -- %! Launch gmrun
++ , ((modMask .|. shiftMask, xK_c ), kill) -- %! Close the focused window
++ , ((modMask .|. shiftMask, xK_e ), spawn "xemacs")
++ , ((modMask .|. shiftMask, xK_w ), spawn "swiftweasel")
++ , ((modMask .|. shiftMask, xK_m ), spawn "claws-mail")
++
++
++ , ((modMask, xK_space ), sendMessage NextLayout) -- %! Rotate through the available layout algorithms
++ , ((modMask .|. shiftMask, xK_space ), setLayout $ XMonad.layoutHook conf) -- %! Reset the layouts on the current workspace to default
++
++ , ((modMask, xK_n ), refresh) -- %! Resize viewed windows to the correct size
++
++ -- move focus up or down the window stack
++ , ((modMask, xK_Tab ), windows W.focusDown) -- %! Move focus to the next window
++ , ((modMask, xK_j ), windows W.focusDown) -- %! Move focus to the next window
++ , ((modMask, xK_k ), windows W.focusUp ) -- %! Move focus to the previous window
++ , ((modMask, xK_m ), windows W.focusMaster ) -- %! Move focus to the master window
++
++ -- mpd controls
++ , ((modMask .|. controlMask, xK_h ), spawn "mpc prev")
++ , ((modMask .|. controlMask, xK_t ), spawn "mpc pause")
++ , ((modMask .|. controlMask, xK_n ), spawn "mpc play")
++ , ((modMask .|. controlMask, xK_s ), spawn "mpc next")
++
++ , ((modMask .|. controlMask, xK_g ), spawn "mpc seek -2%")
++ , ((modMask .|. controlMask, xK_c ), spawn "mpc volume -4")
++ , ((modMask .|. controlMask, xK_r ), spawn "mpc volume +4")
++ , ((modMask .|. controlMask, xK_l ), spawn "mpc seek +2%")
++
++
++ -- modifying the window order
++ , ((modMask, xK_Return), windows W.swapMaster) -- %! Swap the focused window and the master window
++ , ((modMask .|. shiftMask, xK_j ), windows W.swapDown ) -- %! Swap the focused window with the next window
++ , ((modMask .|. shiftMask, xK_k ), windows W.swapUp ) -- %! Swap the focused window with the previous window
++
++ -- resizing the master/slave ratio
++ , ((modMask, xK_h ), sendMessage Shrink) -- %! Shrink the master area
++ , ((modMask, xK_l ), sendMessage Expand) -- %! Expand the master area
++
++ -- floating layer support
++ , ((modMask, xK_t ), withFocused $ windows . W.sink) -- %! Push window back into tiling
++
++ -- increase or decrease number of windows in the master area
++ , ((modMask , xK_comma ), sendMessage (IncMasterN 1)) -- %! Increment the number of windows in the master area
++ , ((modMask , xK_period), sendMessage (IncMasterN (-1))) -- %! Deincrement the number of windows in the master area
++
++ -- toggle the status bar gap
++ , ((modMask , xK_b ), modifyGap (\i n -> let x = (XMonad.defaultGaps conf ++ repeat (0,0,0,0)) !! i in if n == x then (0,0,0,0) else x)) -- %! Toggle the status bar gap
++
++ -- quit, or restart
++ , ((modMask .|. shiftMask, xK_q ), io (exitWith ExitSuccess)) -- %! Quit xmonad
++ , ((modMask , xK_q ), restart "xmonad" True) -- %! Restart xmonad
++ ]
++ ++
++ -- mod-[1..9] %! Switch to workspace N
++ -- mod-shift-[1..9] %! Move client to workspace N
++ [((m .|. modMask, k), windows $ f i)
++ | (i, k) <- zip (XMonad.workspaces conf) [xK_1 .. xK_9]
++ , (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask)]]
++ ++
++ -- mod-{a,o} %! Switch to physical/Xinerama screens 1, 2, or 3
++ -- mod-shift-{a,o} %! Move client to screen 1, 2, or 3
++ [((m .|. modMask, key), screenWorkspace sc >>= flip whenJust (windows . f))
++ | (key, sc) <- zip [xK_a, xK_o] [0..]
++ , (f, m) <- [(W.view, 0), (W.shift, shiftMask)]]
++
++
+diff --git a/source/custom-x11/xmonad/xmonad.install b/source/custom-x11/xmonad/xmonad.install
+new file mode 100644
+index 0000000..ac322b0
+--- /dev/null
++++ b/source/custom-x11/xmonad/xmonad.install
+@@ -0,0 +1,23 @@
++HS_DIR=/usr/share/haskell/xmonad
++
++post_install() {
++ ${HS_DIR}/register.sh
++ echo "xmonad now has dynamic configuration via ~/.xmonad/xmonad.hs"
++ echo "See http://haskell.org/haskellwiki/Xmonad/Config_archive for examples"
++}
++
++pre_upgrade() {
++ ${HS_DIR}/unregister.sh
++}
++
++post_upgrade() {
++ ${HS_DIR}/register.sh
++}
++
++pre_remove() {
++ ${HS_DIR}/unregister.sh
++}
++op=$1
++shift
++
++$op $*