]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/abase.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 helpers = require("lain.helpers")
-local async = require("lain.asyncshell")
-local wibox = require("wibox")
-
+local helpers = require("lain.helpers")
+local wibox = require("wibox")
local setmetatable = setmetatable
local setmetatable = setmetatable
--- Basic template for custom widgets
--- Asynchronous version
+-- Basic template for custom widgets (asynchronous version)
-- lain.widgets.abase
local function worker(args)
-- lain.widgets.abase
local function worker(args)
- local abase = {}
- local args = args or {}
- local timeout = args.timeout or 1
- local cmd = args.cmd or ""
- local settings = args.settings or function() end
-
- abase.widget = wibox.widget.textbox('')
- helpers.set_map(cmd, '')
+ local abase = 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
- async.request (cmd, function(f)
+ helpers.async (cmd, function(f)
-
- if helpers.get_map(cmd) ~= output then
+ if output ~= abase.prev then
widget = abase.widget
settings()
widget = abase.widget
settings()
- helpers.set_map(cmd, output)
- helpers.newtimer(cmd, timeout, abase.updat e)
+ abase.timer = helpers.newtimer(cmd, timeout, abase.update, nostart, stoppabl e)
- return setmetatable(abase, { __index = abase.widget })
end
return setmetatable({}, { __call = function(_, ...) return worker(...) end })
end
return setmetatable({}, { __call = function(_, ...) return worker(...) end })