X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/377b316f5d179d03378d9fa69b246f441d54fb5e..229d2545dd399b52c6128a823657c6266fbbe8a9:/widgets/base.lua diff --git a/widgets/base.lua b/widgets/base.lua index 198b6f7..2a8f507 100644 --- a/widgets/base.lua +++ b/widgets/base.lua @@ -6,35 +6,34 @@ --]] -local newtimer = require("lain.helpers").newtimer +local helpers = require("lain.helpers") local wibox = require("wibox") - -local io = io local setmetatable = setmetatable --- Basic template for custom widgets +-- Basic template for custom widgets -- lain.widgets.base -local base = {} local function worker(args) - local args = args or {} - local timeout = args.timeout or 5 - local cmd = args.cmd or "" - local settings = args.settings or function() end - - base.widget = wibox.widget.textbox('') + local base = { widget = wibox.widget.textbox() } + local args = args or {} + local timeout = args.timeout or 5 + local nostart = args.nostart or false + local stoppable = args.stoppable or false + local cmd = args.cmd + local settings = args.settings or function() end function base.update() - local f = assert(io.popen(cmd)) - output = f:read("*all") - f:close() - widget = base.widget - settings() + output = helpers.read_pipe(cmd) + if output ~= base.prev then + widget = base.widget + settings() + base.prev = output + end end - newtimer(cmd, timeout, update) + base.timer = helpers.newtimer(cmd, timeout, base.update, nostart, stoppable) - return setmetatable(base, { __index = base.widget }) + return base end -return setmetatable(base, { __call = function(_, ...) return worker(...) end }) +return setmetatable({}, { __call = function(_, ...) return worker(...) end })