widget.temp: autodetect tempfiles; closes #431

This commit is contained in:
Luca Capezzuto 2019-05-27 13:12:00 +01:00
parent 3328e738bd
commit 025508ce83
4 changed files with 21 additions and 22 deletions

View File

@ -187,7 +187,7 @@ function helpers.trivial_partition_set(set)
return ss
end
-- creates the powerset of a given set
-- create the powerset of a given set
function helpers.powerset(s)
if not s then return {} end
local t = {{}}

View File

@ -25,9 +25,7 @@ local function factory(args)
-- Read the amount of time the CPUs have spent performing
-- different kinds of work. Read the first line of /proc/stat
-- which is the sum of all CPUs.
local times = helpers.lines_match("cpu","/proc/stat")
for index,time in pairs(times) do
for index,time in pairs(helpers.lines_match("cpu","/proc/stat")) do
local coreid = index - 1
local core = cpu.core[coreid] or
{ last_active = 0 , last_total = 0, usage = 0 }

View File

@ -7,33 +7,34 @@
local helpers = require("lain.helpers")
local wibox = require("wibox")
local open = io.open
local tonumber = tonumber
-- coretemp
-- lain.widget.temp
local function factory(args)
local temp = { widget = wibox.widget.textbox() }
local args = args or {}
local timeout = args.timeout or 2
local tempfile = args.tempfile or "/sys/class/thermal/thermal_zone0/temp"
local settings = args.settings or function() end
local temp = { widget = wibox.widget.textbox() }
local args = args or {}
local timeout = args.timeout or 30
local settings = args.settings or function() end
function temp.update()
local f = open(tempfile)
if f then
coretemp_now = tonumber(f:read("*all")) / 1000
f:close()
else
coretemp_now = "N/A"
end
widget = temp.widget
settings()
helpers.async({"find", "/sys/devices", "-name", "temp"}, function(f)
temp_now = {}
local temp_value
for t in f:gmatch("[^\n]+") do
temp_value = helpers.first_line(t)
if temp_value then
temp_now[tonumber(t:match("%d+"))] = temp_value / 1e3
end
end
coretemp_now = temp_now[0] or "N/A"
widget = temp.widget
settings()
end)
end
helpers.newtimer("coretemp", timeout, temp.update)
helpers.newtimer("thermal", timeout, temp.update)
return temp
end

2
wiki

@ -1 +1 @@
Subproject commit e5a195cfc013627f21d242fa5110b3added00eb2
Subproject commit aaeceb1598cbbc27b1ee79d9a8d483fd10a4187a