xmonad-0.7
authorTomas Zeman <tzeman@volny.cz>
Thu, 12 Jun 2008 10:55:34 +0200
changeset 38 e56829be0d34
parent 37 8435b9bef8e6
child 39 93b33cb1d5f4
xmonad-0.7
series
xmonad.patch
--- a/series	Thu Jun 12 10:54:18 2008 +0200
+++ b/series	Thu Jun 12 10:55:34 2008 +0200
@@ -46,3 +46,4 @@
 firehol.patch
 vim.patch
 haskel-x11.patch
+xmonad.patch
--- /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 $*