X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/705c3cea9b982ec0e50c4cef18d1da0b31d4cb03..00b0609e34dfa69ed889f2e9e557f5b9b80589c1:/widgets/base.lua diff --git a/widgets/base.lua b/widgets/base.lua index 3d4ce9e..642a858 100644 --- a/widgets/base.lua +++ b/widgets/base.lua @@ -7,16 +7,16 @@ --]] local newtimer = require("lain.helpers").newtimer +local read_pipe = require("lain.helpers").read_pipe 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 base = {} local args = args or {} local timeout = args.timeout or 5 local cmd = args.cmd or "" @@ -25,11 +25,12 @@ local function worker(args) base.widget = wibox.widget.textbox('') function base.update() - local f = assert(io.popen(cmd)) - output = f:read("*all") - f:close() - widget = base.widget - settings() + output = read_pipe(cmd) + if output ~= base.prev then + widget = base.widget + settings() + base.prev = output + end end newtimer(cmd, timeout, base.update) @@ -37,4 +38,4 @@ local function worker(args) return setmetatable(base, { __index = base.widget }) end -return setmetatable(base, { __call = function(_, ...) return worker(...) end }) +return setmetatable({}, { __call = function(_, ...) return worker(...) end })