summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorJose Antonio Ortega Ruiz <jao@gnu.org>2012-01-01 22:38:29 +0100
committerJose Antonio Ortega Ruiz <jao@gnu.org>2012-01-01 22:38:29 +0100
commit8271f2c5d540775d5b77ce4e060fc2630101867b (patch)
treeae154a13307ac41f4b90d3bd6f8bc510fbef0f99
parent015ada9c062e1bd3e5c1791c14f5c894fabda00a (diff)
downloadxmobar-8271f2c5d540775d5b77ce4e060fc2630101867b.tar.gz
xmobar-8271f2c5d540775d5b77ce4e060fc2630101867b.tar.bz2
Configurable battery power scale
-rw-r--r--src/Plugins/Monitors/Batt.hs19
1 files changed, 11 insertions, 8 deletions
diff --git a/src/Plugins/Monitors/Batt.hs b/src/Plugins/Monitors/Batt.hs
index 69ce136..132b5a9 100644
--- a/src/Plugins/Monitors/Batt.hs
+++ b/src/Plugins/Monitors/Batt.hs
@@ -1,7 +1,7 @@
-----------------------------------------------------------------------------
-- |
-- Module : Plugins.Monitors.Batt
--- Copyright : (c) 2010, 2011 Jose A Ortega
+-- Copyright : (c) 2010, 2011, 2012 Jose A Ortega
-- (c) 2010 Andrea Rossato, Petr Rockai
-- License : BSD-style (see LICENSE)
--
@@ -32,6 +32,7 @@ data BattOpts = BattOpts
, lowThreshold :: Float
, highThreshold :: Float
, onlineFile :: FilePath
+ , scale :: Float
}
defaultOpts :: BattOpts
@@ -45,6 +46,7 @@ defaultOpts = BattOpts
, lowThreshold = -12
, highThreshold = -10
, onlineFile = "AC/online"
+ , scale = 1e6
}
options :: [OptDescr (BattOpts -> BattOpts)]
@@ -58,6 +60,7 @@ options =
, Option "L" ["lowt"] (ReqArg (\x o -> o { lowThreshold = read x }) "") ""
, Option "H" ["hight"] (ReqArg (\x o -> o { highThreshold = read x }) "") ""
, Option "f" ["online"] (ReqArg (\x o -> o { onlineFile = x }) "") ""
+ , Option "s" ["scale"] (ReqArg (\x o -> o {scale = read x}) "") ""
]
parseOpts :: [String] -> IO BattOpts
@@ -117,21 +120,21 @@ haveAc f =
handle onError $ withFile (sysDir </> f) ReadMode (fmap (== "1") . hGetLine)
where onError = const (return False) :: SomeException -> IO Bool
-readBattery :: Files -> IO Battery
-readBattery NoFiles = return $ Battery 0 0 0
-readBattery files =
+readBattery :: Float -> Files -> IO Battery
+readBattery _ NoFiles = return $ Battery 0 0 0
+readBattery sc files =
do a <- grab $ fFull files
b <- grab $ fNow files
d <- grab $ fCurrent files
- return $ Battery (3600 * a / 1e6) -- wattseconds
- (3600 * b / 1e6) -- wattseconds
- (d / 1e6) -- watts
+ return $ Battery (3600 * a / sc) -- wattseconds
+ (3600 * b / sc) -- wattseconds
+ (d / sc) -- watts
where grab f = handle onError $ withFile f ReadMode (fmap read . hGetLine)
onError = const (return (-1)) :: SomeException -> IO Float
readBatteries :: BattOpts -> [Files] -> IO Result
readBatteries opts bfs =
- do bats <- mapM readBattery (take 3 bfs)
+ do bats <- mapM (readBattery (scale opts)) (take 3 bfs)
ac <- haveAc (onlineFile opts)
let sign = if ac then 1 else -1
ft = sum (map full bats)