summaryrefslogtreecommitdiffhomepage
path: root/Plugins
diff options
context:
space:
mode:
authorAndrea Rossato <andrea.rossato@ing.unitn.it>2007-07-24 13:40:47 +0200
committerAndrea Rossato <andrea.rossato@ing.unitn.it>2007-07-24 13:40:47 +0200
commitbcb7793d5444be36bcb999409771d4493ec157a9 (patch)
tree65131f918d4718e0f4c0d9a3ca6c54ab61f5c295 /Plugins
parent4dc0696751355817a5cb35d41f4c9c2daa25f5bc (diff)
downloadxmobar-bcb7793d5444be36bcb999409771d4493ec157a9.tar.gz
xmobar-bcb7793d5444be36bcb999409771d4493ec157a9.tar.bz2
Batt: better error handling
darcs-hash:20070724114047-d6583-3006b98cf7421b40d1723047ea3c7fc89136ce7b.gz
Diffstat (limited to 'Plugins')
-rw-r--r--Plugins/Monitors/Batt.hs16
1 files changed, 11 insertions, 5 deletions
diff --git a/Plugins/Monitors/Batt.hs b/Plugins/Monitors/Batt.hs
index 0c2219a..c4e463a 100644
--- a/Plugins/Monitors/Batt.hs
+++ b/Plugins/Monitors/Batt.hs
@@ -17,6 +17,9 @@ module Plugins.Monitors.Batt where
import qualified Data.ByteString.Lazy.Char8 as B
import Plugins.Monitors.Common
+data Batt = Batt Float
+ | NA
+
battConfig :: IO MConfig
battConfig = mkMConfig
"Batt: <left>" -- template
@@ -34,7 +37,7 @@ readFileBatt (i,s) =
b <- catch (B.readFile s) (const $ return B.empty)
return (a,b)
-parseBATT :: IO Float
+parseBATT :: IO Batt
parseBATT =
do (a1,b1) <- readFileBatt fileB1
(a2,b2) <- readFileBatt fileB2
@@ -43,8 +46,9 @@ parseBATT =
x -> read x
(f1, p1) = (sp (3,2) a1, sp (2,4) b1)
(f2, p2) = (sp (3,2) a2, sp (2,4) b2)
- return $ (p1 + p2) / (f1 + f2) --present / full
-
+ left = (p1 + p2) / (f1 + f2) --present / full
+ return $ if isNaN left then NA else Batt left
+
formatBatt :: Float -> Monitor [String]
formatBatt x =
do let f s = floatToPercent (s / 100)
@@ -54,5 +58,7 @@ formatBatt x =
runBatt :: [String] -> Monitor String
runBatt _ =
do c <- io $ parseBATT
- l <- formatBatt c
- parseTemplate l
+ case c of
+ Batt x -> do l <- formatBatt x
+ parseTemplate l
+ NA -> return "N/A"