]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/base.lua
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
-local newtimer = require("lain.helpers").newtimer
+local helpers = require("lain.helpers")
local wibox = require("wibox")
local wibox = require("wibox")
local setmetatable = setmetatable
local setmetatable = setmetatable
--- Basic template for custom widgets
+-- Basic template for custom widgets
local function worker(args)
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
+ local base = helpers.make_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 or ""
+ local settings = args.settings or function() end
- base.widget = wibox.widget.textbox('' )
+ base.widget = wibox.widget.textbox()
- 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
- newtimer(cmd, timeout, updat e)
+ base.timer = helpers.newtimer(cmd, timeout, base.update, nostart, stoppabl e)
return setmetatable(base, { __index = base.widget })
end
return setmetatable(base, { __index = base.widget })
end
-return setmetatable(base , { __call = function(_, ...) return worker(...) end })
+return setmetatable({} , { __call = function(_, ...) return worker(...) end })