mirror of https://github.com/lcpz/lain.git
parent
bd1c6e20bb
commit
14cab4ebc3
14
helpers.lua
14
helpers.lua
|
@ -49,13 +49,25 @@ end
|
|||
-- list/table if the file does not exist
|
||||
function helpers.lines_from(file)
|
||||
if not helpers.file_exists(file) then return {} end
|
||||
lines = {}
|
||||
local lines = {}
|
||||
for line in io.lines(file) do
|
||||
lines[#lines + 1] = line
|
||||
end
|
||||
return lines
|
||||
end
|
||||
|
||||
-- match all lines from a file, returns an empty
|
||||
-- list/table if the file or match does not exist
|
||||
function helpers.lines_match(regexp, file)
|
||||
local lines = {}
|
||||
for index,line in pairs(helpers.lines_from(file)) do
|
||||
if string.match(line, regexp) then
|
||||
lines[index] = line
|
||||
end
|
||||
end
|
||||
return lines
|
||||
end
|
||||
|
||||
-- get first line of a file, return nil if
|
||||
-- the file does not exist
|
||||
function helpers.first_line(file)
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
--]]
|
||||
|
||||
local first_line = require("lain.helpers").first_line
|
||||
local lines_match = require("lain.helpers").lines_match
|
||||
local newtimer = require("lain.helpers").newtimer
|
||||
|
||||
local wibox = require("wibox")
|
||||
|
@ -21,7 +21,7 @@ local setmetatable = setmetatable
|
|||
|
||||
-- CPU usage
|
||||
-- lain.widgets.cpu
|
||||
local cpu = { last_total = 0, last_active = 0 }
|
||||
local cpu = { core = {} }
|
||||
|
||||
local function worker(args)
|
||||
local args = args or {}
|
||||
|
@ -34,42 +34,54 @@ local function worker(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 = first_line("/proc/stat")
|
||||
local times = lines_match("cpu","/proc/stat")
|
||||
|
||||
for index,time in pairs(times)
|
||||
do
|
||||
local coreid = index - 1
|
||||
local core = cpu.core[coreid] or
|
||||
{ last_active = 0 , last_total = 0, usage = 0 }
|
||||
local at = 1
|
||||
local idle = 0
|
||||
local total = 0
|
||||
for field in string.gmatch(times, "[%s]+([^%s]+)")
|
||||
|
||||
for field in string.gmatch(time, "[%s]+([^%s]+)")
|
||||
do
|
||||
-- 4 = idle, 5 = ioWait. Essentially, the CPUs have done
|
||||
-- nothing during these times.
|
||||
if at == 4 or at == 5
|
||||
then
|
||||
if at == 4 or at == 5 then
|
||||
idle = idle + field
|
||||
end
|
||||
total = total + field
|
||||
at = at + 1
|
||||
end
|
||||
|
||||
local active = total - idle
|
||||
|
||||
if cpu.last_active ~= active or cpu.last_total ~= total then
|
||||
if core.last_active ~= active or core.last_total ~= total then
|
||||
-- Read current data and calculate relative values.
|
||||
local dactive = active - cpu.last_active
|
||||
local dtotal = total - cpu.last_total
|
||||
local dactive = active - core.last_active
|
||||
local dtotal = total - core.last_total
|
||||
|
||||
cpu_now = {}
|
||||
cpu_now.usage = tostring(math.ceil((dactive / dtotal) * 100))
|
||||
local usage = math.ceil((dactive / dtotal) * 100)
|
||||
|
||||
widget = cpu.widget
|
||||
settings()
|
||||
core.last_active = active
|
||||
core.last_total = total
|
||||
core.usage = usage
|
||||
|
||||
-- Save current data for the next run.
|
||||
cpu.last_active = active
|
||||
cpu.last_total = total
|
||||
cpu.core[coreid] = core;
|
||||
end
|
||||
end
|
||||
|
||||
widget = cpu.widget
|
||||
cpu_now = cpu.core
|
||||
cpu_now.usage = cpu_now[0].usage
|
||||
|
||||
settings()
|
||||
end
|
||||
|
||||
newtimer("cpu", timeout, update)
|
||||
|
||||
return cpu.widget
|
||||
end
|
||||
|
||||
|
|
|
@ -66,6 +66,10 @@ local function worker(args)
|
|||
notification_preset.screen = mouse.screen
|
||||
end
|
||||
|
||||
if not weather.notification_text then
|
||||
weather.forecast_update()
|
||||
end
|
||||
|
||||
weather.notification = naughty.notify({
|
||||
text = weather.notification_text,
|
||||
icon = weather.icon_path,
|
||||
|
@ -106,8 +110,6 @@ local function worker(args)
|
|||
weather.notification_text = weather.notification_text .. "\n"
|
||||
end
|
||||
end
|
||||
else
|
||||
weather.notification_text = 0
|
||||
end
|
||||
end)
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue