aboutsummaryrefslogtreecommitdiffstats
path: root/Dzen.hs
blob: 4e63bfb42fccbe261b13df02c09d7c7e2a04e163 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
-----------------------------------------------------------------------------
-- |
-- Module      :  XMonadContrib.Dzen
-- Copyright   :  (c) glasser@mit.edu
-- License     :  BSD
--
-- Maintainer  :  glasser@mit.edu
-- Stability   :  unstable
-- Portability :  unportable
--
-- Handy wrapper for dzen.
--
-----------------------------------------------------------------------------

module XMonadContrib.Dzen (dzen, dzenScreen) where

import Control.Monad.State
import qualified StackSet as W
import XMonad
import XMonadContrib.Run

curScreen :: X ScreenId
curScreen =  (W.screen . W.current) `liftM` gets windowset

toXineramaArg :: ScreenId -> String
toXineramaArg n = show ( ((fromIntegral n)+1)::Int )

-- Requires dzen >= 0.2.4.

dzen :: String -> X ()
dzen str = curScreen >>= \sc -> dzenScreen sc str

dzenScreen :: ScreenId -> String -> X()
dzenScreen sc str = io $ (runProcessWithInputAndWait "dzen2" ["-xs", screen] str 5000000)
    where screen = toXineramaArg sc