closes #318
This commit is contained in:
parent
0dc6639637
commit
84654c7f09
2 changed files with 23 additions and 40 deletions
|
@ -10,21 +10,17 @@
|
||||||
local helpers = require("lain.helpers")
|
local helpers = require("lain.helpers")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local string = { format = string.format,
|
local string = { format = string.format, match = string.match }
|
||||||
match = string.match }
|
|
||||||
|
|
||||||
-- Network infos
|
-- Network infos
|
||||||
-- lain.widget.net
|
-- lain.widget.net
|
||||||
|
|
||||||
local function factory(args)
|
local function factory(args)
|
||||||
local net = { widget = wibox.widget.textbox() }
|
local net = { widget = wibox.widget.textbox(), devices = {} }
|
||||||
net.last_t = 0
|
|
||||||
net.last_r = 0
|
|
||||||
net.devices = {}
|
|
||||||
|
|
||||||
local args = args or {}
|
local args = args or {}
|
||||||
local timeout = args.timeout or 2
|
local timeout = args.timeout or 2
|
||||||
local units = args.units or 1024 --kb
|
local units = args.units or 1024 -- KB
|
||||||
local notify = args.notify or "on"
|
local notify = args.notify or "on"
|
||||||
local screen = args.screen or 1
|
local screen = args.screen or 1
|
||||||
local settings = args.settings or function() end
|
local settings = args.settings or function() end
|
||||||
|
@ -42,20 +38,15 @@ local function factory(args)
|
||||||
|
|
||||||
if #net.iface == 0 then net.get_device() end
|
if #net.iface == 0 then net.get_device() end
|
||||||
|
|
||||||
function update()
|
function net.update()
|
||||||
-- These are the totals over all specified interfaces
|
-- These are the totals over all specified interfaces
|
||||||
net_now = {
|
net_now = {
|
||||||
-- New api - Current state of requested devices
|
|
||||||
devices = {},
|
devices = {},
|
||||||
-- Bytes since last iteration
|
-- Bytes since last iteration
|
||||||
sent = 0,
|
sent = 0,
|
||||||
received = 0
|
received = 0
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Total bytes transfered
|
|
||||||
local total_t = 0
|
|
||||||
local total_r = 0
|
|
||||||
|
|
||||||
for i, dev in ipairs(net.iface) do
|
for i, dev in ipairs(net.iface) do
|
||||||
local dev_now = {}
|
local dev_now = {}
|
||||||
local dev_before = net.devices[dev] or { last_t = 0, last_r = 0 }
|
local dev_before = net.devices[dev] or { last_t = 0, last_r = 0 }
|
||||||
|
@ -71,26 +62,22 @@ local function factory(args)
|
||||||
net_now.sent = net_now.sent + dev_now.sent
|
net_now.sent = net_now.sent + dev_now.sent
|
||||||
net_now.received = net_now.received + dev_now.received
|
net_now.received = net_now.received + dev_now.received
|
||||||
|
|
||||||
dev_now.sent = string.format('%.1f', dev_now.sent)
|
dev_now.sent = string.format("%.1f", dev_now.sent)
|
||||||
dev_now.received = string.format('%.1f', dev_now.received)
|
dev_now.received = string.format("%.1f", dev_now.received)
|
||||||
|
|
||||||
dev_now.last_t = now_t
|
dev_now.last_t = now_t
|
||||||
dev_now.last_r = now_r
|
dev_now.last_r = now_r
|
||||||
|
|
||||||
-- This will become dev_before in the next update/iteration
|
|
||||||
net.devices[dev] = dev_now
|
net.devices[dev] = dev_now
|
||||||
|
|
||||||
total_t = total_t + now_t
|
|
||||||
total_r = total_r + now_r
|
|
||||||
|
|
||||||
-- Notify only once when connection is loss
|
-- Notify only once when connection is loss
|
||||||
if string.match(dev_now.carrier, "0") and notify == "on" and helpers.get_map(dev) then
|
if string.match(dev_now.carrier, "0") and notify == "on" and helpers.get_map(dev) then
|
||||||
naughty.notify({
|
naughty.notify {
|
||||||
title = dev,
|
title = dev,
|
||||||
text = "no carrier",
|
text = "No carrier",
|
||||||
icon = helpers.icons_dir .. "no_net.png",
|
icon = helpers.icons_dir .. "no_net.png",
|
||||||
screen = screen
|
screen = screen
|
||||||
})
|
}
|
||||||
helpers.set_map(dev, false)
|
helpers.set_map(dev, false)
|
||||||
elseif string.match(dev_now.carrier, "1") then
|
elseif string.match(dev_now.carrier, "1") then
|
||||||
helpers.set_map(dev, true)
|
helpers.set_map(dev, true)
|
||||||
|
@ -99,22 +86,18 @@ local function factory(args)
|
||||||
net_now.carrier = dev_now.carrier
|
net_now.carrier = dev_now.carrier
|
||||||
net_now.state = dev_now.state
|
net_now.state = dev_now.state
|
||||||
net_now.devices[dev] = dev_now
|
net_now.devices[dev] = dev_now
|
||||||
-- new_now.sent and net_now.received will be the
|
-- new_now.sent and net_now.received will be
|
||||||
-- totals across all specified devices
|
-- the totals across all specified devices
|
||||||
end
|
end
|
||||||
|
|
||||||
if total_t ~= net.last_t or total_r ~= net.last_r then
|
net_now.sent = string.format("%.1f", net_now.sent)
|
||||||
net_now.sent = string.format('%.1f', net_now.sent)
|
net_now.received = string.format("%.1f", net_now.received)
|
||||||
net_now.received = string.format('%.1f', net_now.received)
|
|
||||||
net.last_t = total_t
|
|
||||||
net.last_r = total_r
|
|
||||||
end
|
|
||||||
|
|
||||||
widget = net.widget
|
widget = net.widget
|
||||||
settings()
|
settings()
|
||||||
end
|
end
|
||||||
|
|
||||||
helpers.newtimer("network", timeout, update)
|
helpers.newtimer("network", timeout, net.update)
|
||||||
|
|
||||||
return net
|
return net
|
||||||
end
|
end
|
||||||
|
|
2
wiki
2
wiki
|
@ -1 +1 @@
|
||||||
Subproject commit ebd3fbe8171a6764c9b5fdc916fc4b6f4939a31f
|
Subproject commit 90ccf46ed6ba0b4c468896ef80a3a775494dcea4
|
Loading…
Add table
Reference in a new issue