]>
git.madduck.net Git - etc/awesome.git/blobdiff - helpers.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 debug = require("debug")
-local assert = assert
-local capi = { timer = require("gears.timer") }
-local io = { open = io.open,
- lines = io.lines,
- popen = io.popen }
-local rawget = rawget
-local table = { sort = table.sort }
+local debug = require("debug")
+local io = { lines = io.lines,
+ open = io.open,
+ popen = io.popen }
+local rawget = rawget
+local table = { sort = table.sort }
-local wibox = require("wibox")
+local easy_async = require("awful.spawn").easy_async
+local timer = require("gears.timer")
+local wibox = require("wibox")
-- Lain helper functions for internal use
-- lain.helpers
-- Lain helper functions for internal use
-- lain.helpers
-function helpers.newtimer(_name, timeout, fun, nostart)
- local name = timeout
+function helpers.newtimer(name, timeout, fun, nostart, stoppable)
+ if not name or #name == 0 then return end
+ name = (stoppable and name) or timeout
if not helpers.timer_table[name] then
if not helpers.timer_table[name] then
- helpers.timer_table[name] = capi. timer({ timeout = timeout })
+ helpers.timer_table[name] = timer({ timeout = timeout })
helpers.timer_table[name]:start()
end
helpers.timer_table[name]:connect_signal("timeout", fun)
if not nostart then
helpers.timer_table[name]:emit_signal("timeout")
end
helpers.timer_table[name]:start()
end
helpers.timer_table[name]:connect_signal("timeout", fun)
if not nostart then
helpers.timer_table[name]:emit_signal("timeout")
end
+ return stoppable and helpers.timer_table[name]
end
-- }}}
-- {{{ Pipe operations
end
-- }}}
-- {{{ Pipe operations
--- read the full output of a command output
+-- return the full output of an input command (synchronous pipe)
+-- @param cmd the input command
+-- @return command output (string)
function helpers.read_pipe(cmd)
function helpers.read_pipe(cmd)
- local f = assert(io.popen(cmd) )
+ local f = io.popen(cmd )
local output = f:read("*all")
f:close()
return output
end
local output = f:read("*all")
f:close()
return output
end
--- return line iterator of a command output
-function helpers.pipelines(...)
- local f = assert(io.popen(...))
- return function () -- iterator
- local data = f:read()
- if data == nil then f:close() end
- return data
- end
+-- run a command and execute a function on its output (asynchronous pipe)
+-- @param cmd the input command
+-- @param callback function to execute on cmd output
+-- @return cmd PID
+function helpers.async(cmd, callback)
+ return easy_async(cmd,
+ function (stdout, stderr, reason, exit_code)
+ callback(stdout)
+ end)
--- create a lain textbox widget
+-- create a textbox with no spacing issues
function helpers.make_widget_textbox()
function helpers.make_widget_textbox()
- local w = wibox.widget.textbox('')
- local t = wibox.widget.base.make_widget(w)
- t.widget = w
- return t
+ local w = wibox.widget.textbox()
+ --local t = wibox.widget.base.make_widget(w)
+ --t.widget = w
+ --return t
+ return setmetatable({ widget = w }, { __index = w })