]>
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 debug = require("debug")
-local capi = { timer = (type(timer) == 'table' and timer or require ("gears.timer")) }
+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 io = { open = io.open,
lines = io.lines,
popen = io.popen }
local rawget = rawget
local table = { sort = table.sort }
+local wibox = require("wibox")
+
-- Lain helper functions for internal use
-- lain.helpers
local helpers = {}
-- Lain helper functions for internal use
-- lain.helpers
local helpers = {}
function helpers.lines_match(regexp, file)
local lines = {}
for index,line in pairs(helpers.lines_from(file)) do
function helpers.lines_match(regexp, file)
local lines = {}
for index,line in pairs(helpers.lines_from(file)) do
- if string.match(line, regexp) then
+ if string.match(line, regexp) then
local name = timeout
if not helpers.timer_table[name] then
helpers.timer_table[name] = capi.timer({ timeout = timeout })
local name = timeout
if not helpers.timer_table[name] then
helpers.timer_table[name] = capi.timer({ timeout = timeout })
+ helpers.timer_table[name]:start()
end
helpers.timer_table[name]:connect_signal("timeout", fun)
end
helpers.timer_table[name]:connect_signal("timeout", fun)
- helpers.timer_table[name]:start()
if not nostart then
helpers.timer_table[name]:emit_signal("timeout")
end
if not nostart then
helpers.timer_table[name]:emit_signal("timeout")
end
--- read the full output of a pipe (command)
+-- read the full output of a command output
function helpers.read_pipe(cmd)
local f = assert(io.popen(cmd))
local output = f:read("*all")
function helpers.read_pipe(cmd)
local f = assert(io.popen(cmd))
local output = f:read("*all")
+-- 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
+end
+
-- }}}
-- {{{ A map utility
-- }}}
-- {{{ A map utility
---{{{ Iterate over table of records sorted by keys
+-- {{{ Misc
+
+-- check if an element exist on a table
+function helpers.element_in_table(element, tbl)
+ for _, i in pairs(tbl) do
+ if i == element then
+ return true
+ end
+ end
+ return false
+end
+
+-- iterate over table of records sorted by keys
function helpers.spairs(t)
-- collect the keys
local keys = {}
function helpers.spairs(t)
-- collect the keys
local keys = {}
+
+-- create a lain textbox widget
+function helpers.make_widget_textbox()
+ local w = wibox.widget.textbox('')
+ local t = wibox.widget.base.make_widget(w)
+ t.widget = w
+ return t
+end
+
+-- }}}