2009-11-05 23:35:50 +01:00
|
|
|
---------------------------------------------------
|
|
|
|
-- Licensed under the GNU General Public License v2
|
|
|
|
-- * (c) 2009, Adrian C. <anrxc@sysphere.org>
|
|
|
|
---------------------------------------------------
|
|
|
|
|
|
|
|
-- {{{ Grab environment
|
2009-11-10 15:40:11 +01:00
|
|
|
local tonumber = tonumber
|
2009-11-05 23:35:50 +01:00
|
|
|
local io = { open = io.open }
|
2009-11-10 15:40:11 +01:00
|
|
|
local setmetatable = setmetatable
|
2009-11-05 23:35:50 +01:00
|
|
|
local math = {
|
|
|
|
min = math.min,
|
|
|
|
floor = math.floor
|
|
|
|
}
|
2009-12-07 00:42:47 +01:00
|
|
|
local string = {
|
|
|
|
find = string.find,
|
|
|
|
match = string.match,
|
|
|
|
format = string.format
|
|
|
|
}
|
2009-11-05 23:35:50 +01:00
|
|
|
-- }}}
|
|
|
|
|
|
|
|
|
2009-12-07 00:42:47 +01:00
|
|
|
-- Batproc: provides state, charge, and remaining time for a requested battery using procfs
|
|
|
|
module("vicious.widgets.batproc")
|
2009-11-05 23:35:50 +01:00
|
|
|
|
|
|
|
|
|
|
|
-- {{{ Battery widget type
|
|
|
|
local function worker(format, batid)
|
|
|
|
local battery_state = {
|
2009-12-07 00:42:47 +01:00
|
|
|
["full"] = "↯",
|
|
|
|
["unknown"] = "⌁",
|
|
|
|
["charged"] = "↯",
|
|
|
|
["charging"] = "+",
|
|
|
|
["discharging"] = "-"
|
2009-11-05 23:35:50 +01:00
|
|
|
}
|
|
|
|
|
2009-12-07 00:42:47 +01:00
|
|
|
-- Get /proc/acpi/battery info
|
|
|
|
local f = io.open("/proc/acpi/battery/"..batid.."/info")
|
|
|
|
-- Handler for incompetent users
|
|
|
|
if not f then return {battery_state["unknown"], 0, "N/A"} end
|
|
|
|
local infofile = f:read("*all")
|
|
|
|
f:close()
|
|
|
|
|
2009-11-05 23:35:50 +01:00
|
|
|
-- Check if the battery is present
|
2009-12-07 00:42:47 +01:00
|
|
|
if infofile == nil or string.find(infofile, "present:[%s]+no") then
|
|
|
|
return {battery_state["unknown"], 0, "N/A"}
|
2009-11-05 23:35:50 +01:00
|
|
|
end
|
|
|
|
|
2009-12-07 00:42:47 +01:00
|
|
|
-- Get capacity information
|
|
|
|
local capacity = string.match(infofile, "last full capacity:[%s]+([%d]+).*")
|
2009-11-05 23:35:50 +01:00
|
|
|
|
|
|
|
|
2009-12-07 00:42:47 +01:00
|
|
|
-- Get /proc/acpi/battery state
|
|
|
|
local f = io.open("/proc/acpi/battery/"..batid.."/state")
|
|
|
|
local statefile = f:read("*all")
|
|
|
|
f:close()
|
|
|
|
|
|
|
|
-- Get state information
|
|
|
|
local state = string.match(statefile, "charging state:[%s]+([%a]+).*")
|
|
|
|
local state = battery_state[state] or battery_state["unknown"]
|
2009-11-05 23:35:50 +01:00
|
|
|
|
2009-11-10 15:40:11 +01:00
|
|
|
-- Get charge information
|
2009-12-07 00:42:47 +01:00
|
|
|
local rate = string.match(statefile, "present rate:[%s]+([%d]+).*")
|
|
|
|
local remaining = string.match(statefile, "remaining capacity:[%s]+([%d]+).*")
|
2009-11-09 17:35:45 +01:00
|
|
|
|
2009-11-05 23:35:50 +01:00
|
|
|
|
2009-11-10 15:40:11 +01:00
|
|
|
-- Calculate percentage (but work around broken BAT/ACPI implementations)
|
|
|
|
local percent = math.min(math.floor(remaining / capacity * 100), 100)
|
2009-11-05 23:35:50 +01:00
|
|
|
|
|
|
|
-- Calculate remaining (charging or discharging) time
|
2009-12-07 00:42:47 +01:00
|
|
|
if state == "+" then
|
2009-11-10 15:40:11 +01:00
|
|
|
timeleft = (tonumber(capacity) - tonumber(remaining)) / tonumber(rate)
|
|
|
|
elseif state == "-" then
|
|
|
|
timeleft = tonumber(remaining) / tonumber(rate)
|
2009-11-05 23:35:50 +01:00
|
|
|
else
|
2009-11-10 15:40:11 +01:00
|
|
|
return {state, percent, "N/A"}
|
2009-11-05 23:35:50 +01:00
|
|
|
end
|
2009-11-10 15:40:11 +01:00
|
|
|
local hoursleft = math.floor(timeleft)
|
|
|
|
local minutesleft = math.floor((timeleft - hoursleft) * 60 )
|
|
|
|
local time = string.format("%02d:%02d", hoursleft, minutesleft)
|
2009-11-05 23:35:50 +01:00
|
|
|
|
2009-11-10 15:40:11 +01:00
|
|
|
return {state, percent, time}
|
2009-11-05 23:35:50 +01:00
|
|
|
end
|
|
|
|
-- }}}
|
|
|
|
|
|
|
|
setmetatable(_M, { __call = function(_, ...) return worker(...) end })
|