--]]
-local first_line = require("lain.helpers").first_line
-local newtimer = require("lain.helpers").newtimer
-
+local helpers = require("lain.helpers")
local wibox = require("wibox")
local math = { ceil = math.ceil }
local string = { format = string.format,
gmatch = string.gmatch }
local tostring = tostring
-
local setmetatable = setmetatable
-- CPU usage
local function worker(args)
local args = args or {}
- local timeout = args.timeout or 5
+ local timeout = args.timeout or 1
local settings = args.settings or function() end
cpu.widget = wibox.widget.textbox('')
+ helpers.set_map("cpuactive", 0)
+ helpers.set_map("cputotal", 0)
- function cpu.update()
+ function update()
-- 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 = helpers.first_line("/proc/stat")
local at = 1
local idle = 0
local total = 0
for field in string.gmatch(times, "[%s]+([^%s]+)")
do
- -- 3 = idle, 4 = ioWait. Essentially, the CPUs have done
+ -- 4 = idle, 5 = ioWait. Essentially, the CPUs have done
-- nothing during these times.
- if at == 3 or at == 4
+ if at == 4 or at == 5
then
idle = idle + field
end
end
local active = total - idle
- -- Read current data and calculate relative values.
- local dactive = active - cpu.last_active
- local dtotal = total - cpu.last_total
+ if helpers.get_map("cpuactive") ~= active
+ or helpers.get_map("cputotal") ~= total
+ then
+ -- Read current data and calculate relative values.
+ local dactive = active - cpu.last_active
+ local dtotal = total - cpu.last_total
- usage = tostring(math.ceil((dactive / dtotal) * 100))
+ cpu_now = {}
+ cpu_now.usage = tostring(math.ceil((dactive / dtotal) * 100))
- widget = cpu.widget
- settings()
+ widget = cpu.widget
+ settings()
- -- Save current data for the next run.
- cpu.last_active = active
- cpu.last_total = total
+ -- Save current data for the next run.
+ helpers.set_map("cpuactive", active)
+ helpers.set_map("cputotal", total)
+ end
end
- newtimer("cpu", timeout, cpu.update)
+ helpers.newtimer("cpu", timeout, update)
return cpu.widget
end