X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/0ef82f83e0baaa2936b6204a24ee3b3b638fd409..5af7a8c1726862f770b84e46cfa0eee064eac0fb:/widgets/temp.lua?ds=sidebyside diff --git a/widgets/temp.lua b/widgets/temp.lua index e568138..e769b25 100644 --- a/widgets/temp.lua +++ b/widgets/temp.lua @@ -7,12 +7,9 @@ --]] local newtimer = require("lain.helpers").newtimer - local wibox = require("wibox") - -local io = io +local io = { open = io.open } local tonumber = tonumber - local setmetatable = setmetatable -- coretemp @@ -21,22 +18,28 @@ local temp = {} local function worker(args) local args = args or {} - local timeout = args.timeout or 5 + local timeout = args.timeout or 2 + local tempfile = args.tempfile or "/sys/class/thermal/thermal_zone0/temp" local settings = args.settings or function() end - temp.widget = wibox.widget.textbox('') + temp.widget = wibox.widget.textbox() + + function update() + local f = io.open(tempfile) + if f then + coretemp_now = tonumber(f:read("*all")) / 1000 + f:close() + else + coretemp_now = "N/A" + end - function temp.update() - local f = io.open("/sys/class/thermal/thermal_zone0/temp") - coretemp_now = tonumber(f:read("*all")) / 1000 - f:close() widget = temp.widget settings() end - newtimer("coretemp", timeout, temp.update) + newtimer("coretemp", timeout, update) - return temp.widget + return setmetatable(temp, { __index = temp.widget }) end return setmetatable(temp, { __call = function(_, ...) return worker(...) end })