----------------------------------------------------------------------------- -- | -- Module : XMobar.Commands -- Copyright : (c) Andrea Rossato -- License : BSD-style (see LICENSE) -- -- Maintainer : Andrea Rossato -- Stability : unstable -- Portability : unportable -- -- The 'Exec' class and the 'Command' data type. -- -- The 'Exec' class rappresents the executable types, whose constructors may -- appear in the 'Config.commands' field of the 'Config.Config' data type. -- -- The 'Command' data type stores the monitors to be run internally by -- XMobar. -- ----------------------------------------------------------------------------- module Commands where import System.Process import System.Exit import System.IO (hClose, hGetLine) import Monitors.Common ( runM ) import Monitors.Weather import Monitors.Net import Monitors.Mem import Monitors.Swap import Monitors.Cpu import Monitors.Batt class Exec e where run :: e -> IO String rate :: e -> Int alias :: e -> String data Command = Com Program Args Alias Rate | Weather Station Args Rate | Network Interface Args Rate | Memory Args Rate | Swap Args Rate | Cpu Args Rate | Battery Args Rate deriving (Show,Read,Eq) type Args = [String] type Program = String type Alias = String type Station = String type Interface = String type Rate = Int instance Exec Command where alias (Weather s _ _) = s alias (Network i _ _) = i alias (Memory _ _) = "memory" alias (Swap _ _) = "swap" alias (Cpu _ _) = "cpu" alias (Battery _ _) = "battery" alias (Com p _ a _) | p /= "" = if a == "" then p else a | otherwise = "" rate (Weather _ _ r) = r rate (Network _ _ r) = r rate (Memory _ r) = r rate (Swap _ r) = r rate (Cpu _ r) = r rate (Battery _ r) = r rate (Com _ _ _ r) = r run (Weather s a _) = runM (a ++ [s]) weatherConfig runWeather run (Network i a _) = runM (a ++ [i]) netConfig runNet run (Memory args _) = runM args memConfig runMem run (Swap args _) = runM args swapConfig runSwap run (Cpu args _) = runM args cpuConfig runCpu run (Battery args _) = runM args battConfig runBatt run (Com prog args _ _) = do (i,o,e,p) <- runInteractiveCommand (prog ++ concat (map (' ':) args)) exit <- waitForProcess p let closeHandles = do hClose o hClose i hClose e case exit of ExitSuccess -> do str <- hGetLine o closeHandles return str _ -> do closeHandles return $ "Could not execute command " ++ prog