diff options
Diffstat (limited to 'Plugins')
| -rw-r--r-- | Plugins/Monitors.hs | 12 | ||||
| -rw-r--r-- | Plugins/Monitors/Wireless.hs | 31 | 
2 files changed, 43 insertions, 0 deletions
diff --git a/Plugins/Monitors.hs b/Plugins/Monitors.hs index cba7332..2aff132 100644 --- a/Plugins/Monitors.hs +++ b/Plugins/Monitors.hs @@ -1,3 +1,5 @@ +{-# LANGUAGE CPP #-} +  -----------------------------------------------------------------------------  -- |  -- Module      :  Xmobar.Plugins.Monitors @@ -29,6 +31,9 @@ import Plugins.Monitors.CpuFreq  import Plugins.Monitors.CoreTemp  import Plugins.Monitors.Disk  import Plugins.Monitors.Top +#ifdef IWLIB +import Plugins.Monitors.Wireless +#endif  data Monitors = Weather  Station    Args Rate                | Network  Interface  Args Rate @@ -45,6 +50,9 @@ data Monitors = Weather  Station    Args Rate                | CoreTemp Args       Rate                | TopCpu   Args       Rate                | TopMem   Args       Rate +#ifdef IWLIB +              | Wireless Interface  Args Rate +#endif                  deriving (Show,Read,Eq)  type Args      = [String] @@ -72,6 +80,10 @@ instance Exec Monitors where      alias (CoreTemp   _ _) = "coretemp"      alias (DiskU    _ _ _) = "disku"      alias (DiskIO   _ _ _) = "diskio" +#ifdef IWLIB +    alias (Wireless i _ _) = i ++ "wi" +    start (Wireless i a r) = runM (a ++ [i]) wirelessConfig  runWireless  r +#endif      start (Weather  s a r) = runM (a ++ [s]) weatherConfig  runWeather    r      start (Network  i a r) = runM (a ++ [i]) netConfig      runNet        r      start (Thermal  z a r) = runM (a ++ [z]) thermalConfig  runThermal    r diff --git a/Plugins/Monitors/Wireless.hs b/Plugins/Monitors/Wireless.hs new file mode 100644 index 0000000..167a48f --- /dev/null +++ b/Plugins/Monitors/Wireless.hs @@ -0,0 +1,31 @@ +----------------------------------------------------------------------------- +-- | +-- Module      :  Plugins.Monitors.Wireless +-- Copyright   :  (c) Jose Antonio Ortega Ruiz +-- License     :  BSD-style (see LICENSE) +-- +-- Maintainer  :  Jose Antonio Ortega Ruiz +-- Stability   :  unstable +-- Portability :  unportable +-- +-- A monitor reporting ESSID and link quality for wireless interfaces +-- +----------------------------------------------------------------------------- + +module Plugins.Monitors.Wireless (wirelessConfig, runWireless)  where + +import Plugins.Monitors.Common +import IWlib + +wirelessConfig :: IO MConfig +wirelessConfig = mkMConfig "<essid> <quality>" ["essid", "quality"] + +runWireless :: [String] -> Monitor String +runWireless (iface:_) = do +  wi <- io $ getWirelessInfo iface +  let essid = wiEssid wi +      quality = wiQuality wi +      e = if essid == "" then "N/A" else essid +  q <- if quality >= 0 then showWithColors show quality else return "N/A" +  parseTemplate [e, q] +runWireless _ = return ""
\ No newline at end of file  | 
