#182 and #184 implemented without tabs; wiki updated

This commit is contained in:
copycat-killer 2016-03-30 16:34:41 +02:00
parent bd1c6e20bb
commit 14cab4ebc3
3 changed files with 65 additions and 39 deletions

View File

@ -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)

View 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

View File

@ -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