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
|
-- list/table if the file does not exist
|
||||||
function helpers.lines_from(file)
|
function helpers.lines_from(file)
|
||||||
if not helpers.file_exists(file) then return {} end
|
if not helpers.file_exists(file) then return {} end
|
||||||
lines = {}
|
local lines = {}
|
||||||
for line in io.lines(file) do
|
for line in io.lines(file) do
|
||||||
lines[#lines + 1] = line
|
lines[#lines + 1] = line
|
||||||
end
|
end
|
||||||
return lines
|
return lines
|
||||||
end
|
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
|
-- get first line of a file, return nil if
|
||||||
-- the file does not exist
|
-- the file does not exist
|
||||||
function helpers.first_line(file)
|
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 newtimer = require("lain.helpers").newtimer
|
||||||
|
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
|
@ -21,55 +21,67 @@ local setmetatable = setmetatable
|
||||||
|
|
||||||
-- CPU usage
|
-- CPU usage
|
||||||
-- lain.widgets.cpu
|
-- lain.widgets.cpu
|
||||||
local cpu = { last_total = 0, last_active = 0 }
|
local cpu = { core = {} }
|
||||||
|
|
||||||
local function worker(args)
|
local function worker(args)
|
||||||
local args = args or {}
|
local args = args or {}
|
||||||
local timeout = args.timeout or 2
|
local timeout = args.timeout or 2
|
||||||
local settings = args.settings or function() end
|
local settings = args.settings or function() end
|
||||||
|
|
||||||
cpu.widget = wibox.widget.textbox('')
|
cpu.widget = wibox.widget.textbox('')
|
||||||
|
|
||||||
function update()
|
function update()
|
||||||
-- Read the amount of time the CPUs have spent performing
|
-- Read the amount of time the CPUs have spent performing
|
||||||
-- different kinds of work. Read the first line of /proc/stat
|
-- different kinds of work. Read the first line of /proc/stat
|
||||||
-- which is the sum of all CPUs.
|
-- which is the sum of all CPUs.
|
||||||
local times = first_line("/proc/stat")
|
local times = lines_match("cpu","/proc/stat")
|
||||||
local at = 1
|
|
||||||
local idle = 0
|
for index,time in pairs(times)
|
||||||
local total = 0
|
|
||||||
for field in string.gmatch(times, "[%s]+([^%s]+)")
|
|
||||||
do
|
do
|
||||||
-- 4 = idle, 5 = ioWait. Essentially, the CPUs have done
|
local coreid = index - 1
|
||||||
-- nothing during these times.
|
local core = cpu.core[coreid] or
|
||||||
if at == 4 or at == 5
|
{ last_active = 0 , last_total = 0, usage = 0 }
|
||||||
then
|
local at = 1
|
||||||
idle = idle + field
|
local idle = 0
|
||||||
|
local total = 0
|
||||||
|
|
||||||
|
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
|
||||||
|
idle = idle + field
|
||||||
|
end
|
||||||
|
total = total + field
|
||||||
|
at = at + 1
|
||||||
|
end
|
||||||
|
|
||||||
|
local active = total - idle
|
||||||
|
|
||||||
|
if core.last_active ~= active or core.last_total ~= total then
|
||||||
|
-- Read current data and calculate relative values.
|
||||||
|
local dactive = active - core.last_active
|
||||||
|
local dtotal = total - core.last_total
|
||||||
|
|
||||||
|
local usage = math.ceil((dactive / dtotal) * 100)
|
||||||
|
|
||||||
|
core.last_active = active
|
||||||
|
core.last_total = total
|
||||||
|
core.usage = usage
|
||||||
|
|
||||||
|
-- Save current data for the next run.
|
||||||
|
cpu.core[coreid] = core;
|
||||||
end
|
end
|
||||||
total = total + field
|
|
||||||
at = at + 1
|
|
||||||
end
|
end
|
||||||
local active = total - idle
|
|
||||||
|
|
||||||
if cpu.last_active ~= active or cpu.last_total ~= total then
|
|
||||||
-- Read current data and calculate relative values.
|
|
||||||
local dactive = active - cpu.last_active
|
|
||||||
local dtotal = total - cpu.last_total
|
|
||||||
|
|
||||||
cpu_now = {}
|
widget = cpu.widget
|
||||||
cpu_now.usage = tostring(math.ceil((dactive / dtotal) * 100))
|
cpu_now = cpu.core
|
||||||
|
cpu_now.usage = cpu_now[0].usage
|
||||||
|
|
||||||
widget = cpu.widget
|
settings()
|
||||||
settings()
|
|
||||||
|
|
||||||
-- Save current data for the next run.
|
|
||||||
cpu.last_active = active
|
|
||||||
cpu.last_total = total
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
newtimer("cpu", timeout, update)
|
newtimer("cpu", timeout, update)
|
||||||
|
|
||||||
return cpu.widget
|
return cpu.widget
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -66,6 +66,10 @@ local function worker(args)
|
||||||
notification_preset.screen = mouse.screen
|
notification_preset.screen = mouse.screen
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if not weather.notification_text then
|
||||||
|
weather.forecast_update()
|
||||||
|
end
|
||||||
|
|
||||||
weather.notification = naughty.notify({
|
weather.notification = naughty.notify({
|
||||||
text = weather.notification_text,
|
text = weather.notification_text,
|
||||||
icon = weather.icon_path,
|
icon = weather.icon_path,
|
||||||
|
@ -106,8 +110,6 @@ local function worker(args)
|
||||||
weather.notification_text = weather.notification_text .. "\n"
|
weather.notification_text = weather.notification_text .. "\n"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
|
||||||
weather.notification_text = 0
|
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue