aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad
diff options
context:
space:
mode:
Diffstat (limited to 'XMonad')
-rw-r--r--XMonad/Util/SpawnNamedPipe.hs42
1 files changed, 42 insertions, 0 deletions
diff --git a/XMonad/Util/SpawnNamedPipe.hs b/XMonad/Util/SpawnNamedPipe.hs
new file mode 100644
index 0000000..f1477ce
--- /dev/null
+++ b/XMonad/Util/SpawnNamedPipe.hs
@@ -0,0 +1,42 @@
+{-# LANGUAGE DeriveDataTypeable #-}
+
+-----------------------------------------------------------------------------
+-- |
+-- Module : XMonad.Util.SpawnNamedPipe
+-- Copyright : (c) Christian Wills 2014
+-- License : BSD3-style (see LICENSE)
+--
+-- Maintainer : cwills.dev@gmail.com
+-- Stability : unstable
+-- Portability : not portable
+--
+-- A module for spawning a pipe whose handle lives in the Xmonad state. This
+-- makes is possible to start dzen in the startup hook and pipe stuff to it in
+-- the logHook cleanly.
+--
+-----------------------------------------------------------------------------
+
+module XMonad.Util.SpawnNamedPipe (spawnNamedPipe, getNamedPipeHandle) where
+
+import XMonad
+import XMonad.Util.Run
+import System.IO
+import qualified XMonad.Util.ExtensibleState as XS
+import Control.Monad
+import qualified Data.Map.Strict as Map
+
+data NamedPipes = NamedPipes { pipeMap :: (Map.Map String Handle) }
+ deriving (Show, Typeable)
+
+instance ExtensionClass NamedPipes where
+ initialValue = NamedPipes Map.empty
+
+spawnNamedPipe :: String -> String -> X ()
+spawnNamedPipe cmd name = do
+ b <- XS.gets (Map.member name . pipeMap)
+ when (not b) $ do
+ h <- spawnPipe cmd
+ XS.modify (NamedPipes . Map.insert name h . pipeMap)
+
+getNamedPipeHandle :: String -> X (Maybe Handle)
+getNamedPipeHandle name = XS.gets (Map.lookup name . pipeMap)