Allow asynchronous call (for Awesome4+) ()

This commit is contained in:
getzze 2017-07-13 21:42:26 +01:00 committed by mutlusun
parent 9cd272f3a2
commit c55a430863
3 changed files with 73 additions and 38 deletions

View File

@ -395,9 +395,11 @@ Supported platforms: platform independent.
- Arguments: - Arguments:
* Takes the Linux or BSD distribution name as an argument, i.e. `"Arch"`, * Takes the Linux or BSD distribution name as an argument, i.e. `"Arch"`,
`"FreeBSD"` `"Arch C"`, `"Arch S"`, `"Debian"`, `"Ubuntu"`, `"Fedora"`, `"FreeBSD"`,
`"Mandriva"`
- Returns: - Returns:
* Returns 1st value as the count of available updates * Returns 1st value as the count of available updates, 2nd as the list of
packages to update
**vicious.widgets.raid** **vicious.widgets.raid**

View File

@ -49,27 +49,19 @@ local function update(widget, reg, disablecache)
local t = os.time() local t = os.time()
local data = {} local data = {}
-- Check for chached output newer than the last update local function format_data(data)
if widget_cache[reg.wtype] ~= nil then local ret
local c = widget_cache[reg.wtype]
if (c.time == nil or c.time <= t-reg.timer) or disablecache then
c.time, c.data = t, reg.wtype(reg.format, reg.warg)
end
data = c.data
else
data = reg.wtype and reg.wtype(reg.format, reg.warg)
end
if type(data) == "table" then if type(data) == "table" then
if type(reg.format) == "string" then if type(reg.format) == "string" then
data = helpers.format(reg.format, data) ret = helpers.format(reg.format, data)
elseif type(reg.format) == "function" then elseif type(reg.format) == "function" then
data = reg.format(widget, data) ret = reg.format(widget, data)
end end
end end
return ret or data
end
local function update_value(data, t, cache)
if widget.add_value ~= nil then if widget.add_value ~= nil then
widget:add_value(tonumber(data) and tonumber(data)/100) widget:add_value(tonumber(data) and tonumber(data)/100)
elseif widget.set_value ~= nil then elseif widget.set_value ~= nil then
@ -79,8 +71,30 @@ local function update(widget, reg, disablecache)
else else
widget.text = data widget.text = data
end end
-- Update cache
if t and cache then
cache.time, cache.data = t, data
end
end
return data -- Check for cached output newer than the last update
local c = widget_cache[reg.wtype]
if c and c.time and c.data and t < c.time+reg.timer and not disablecache then
return update_value(format_data(c.data))
elseif reg.wtype then
if reg.wtype.async then
if not reg.lock then
reg.lock = true
return reg.wtype.async(reg.warg,
function(data)
update_value(format_data(data), t, c)
reg.lock=false
end)
end
else
return update_value(format_data(reg.wtype(nil, reg.warg)), t, c)
end
end
end end
-- }}} -- }}}
@ -147,6 +161,7 @@ function vicious.register(widget, wtype, format, timer, warg)
local reg = { local reg = {
-- Set properties -- Set properties
wtype = wtype, wtype = wtype,
lock = false,
format = format, format = format,
timer = timer, timer = timer,
warg = warg, warg = warg,

View File

@ -7,6 +7,7 @@
local io = { popen = io.popen } local io = { popen = io.popen }
local math = { max = math.max } local math = { max = math.max }
local setmetatable = setmetatable local setmetatable = setmetatable
local spawn = require("awful.spawn")
-- }}} -- }}}
@ -16,11 +17,10 @@ local pkg_all = {}
-- {{{ Packages widget type -- {{{ Packages widget type
local function worker(format, warg) function pkg_all.async(warg, callback)
if not warg then return end if not warg then return end
-- Initialize counters -- Initialize counters
local updates = 0
local manager = { local manager = {
["Arch"] = { cmd = "pacman -Qu" }, ["Arch"] = { cmd = "pacman -Qu" },
["Arch C"] = { cmd = "checkupdates" }, ["Arch C"] = { cmd = "checkupdates" },
@ -33,16 +33,34 @@ local function worker(format, warg)
} }
-- Check if updates are available -- Check if updates are available
local _pkg = manager[warg] local function parse(str, skiprows)
local f = io.popen(_pkg.cmd) local size, lines, first = 0, "", skiprows or 0
for line in str:gmatch("[^\r\n]+") do
for line in f:lines() do if size >= first then
updates = updates + 1 lines = lines .. (size == first and "" or "\n") .. line
end
size = size + 1
end
size = math.max(size-first, 0)
return {size, lines}
end end
f:close()
return {_pkg.sub and math.max(updates-_pkg.sub, 0) or updates} -- Select command
local _pkg = manager[warg]
spawn.easy_async(_pkg.cmd, function(stdout) callback(parse(stdout, _pkg.sub)) end)
end end
-- }}} -- }}}
-- {{{ Packages widget type
local function worker(format, warg)
local ret = nil
pkg_all.async(warg, function(data) ret = data end)
while ret==nil do end
return ret
end
-- }}}
return setmetatable(pkg_all, { __call = function(_, ...) return worker(...) end }) return setmetatable(pkg_all, { __call = function(_, ...) return worker(...) end })