]>
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:
--[[
Licensed under GNU General Public License v2
--[[
Licensed under GNU General Public License v2
- * (c) 2013, Luke Bonham
- * (c) 2010-2012, Peter Hofmann
+ * (c) 2013, Luke Bonham
--]]
local debug = require("debug")
--]]
local debug = require("debug")
-local capi = { timer = timer }
-local io = { open = io.open,
- lines = io.lines }
+local capi = { timer = (type(timer) == 'table' and timer or require ("gears.timer")) }
+local io = { open = io.open,
+ lines = io.lines,
+ popen = io.popen }
+local table = { sort = table.sort }
-- Lain helper functions for internal use
-- lain.helpers
-- Lain helper functions for internal use
-- lain.helpers
--- see if the file exists
+-- see if the file exists and is readable
function helpers.file_exists(file)
function helpers.file_exists(file)
- local f = io.open(file, "rb")
- if f then f:close() end
+ local f = io.open(file)
+ if f then
+ local s = f:read()
+ f:close()
+ f = s
+ end
-
--- get all lines from a file, returns an empty
+-- get all lines from a file, returns an empty
-- list/table if the file does not exist
function helpers.lines_from(file)
if not helpers.file_exists(file) then return {} end
-- list/table if the file does not exist
function helpers.lines_from(file)
if not helpers.file_exists(file) then return {} end
- lines = {}
- for line in io.lines(file) do
+ local l ines = {}
+ for line in io.lines(file) do
lines[#lines + 1] = line
end
return lines
end
lines[#lines + 1] = line
end
return lines
end
+-- match all lines from a file, returns an empty
+-- list/table if the file or match does not exist
+function helpers.lines_match(regexp, file)
+ local lines = {}
+ for index,line in pairs(helpers.lines_from(file)) do
+ if string.match(line, regexp) then
+ lines[index] = line
+ end
+ end
+ return lines
+end
+
-- get first line of a file, return nil if
-- the file does not exist
function helpers.first_line(file)
-- get first line of a file, return nil if
-- the file does not exist
function helpers.first_line(file)
-- get first non empty line from a file,
-- returns nil otherwise
function helpers.first_nonempty_line(file)
-- get first non empty line from a file,
-- returns nil otherwise
function helpers.first_nonempty_line(file)
- for k,v in pairs(lines_from(file)) do
- if #v then return v end
+ for k,v in pairs(helpers. lines_from(file)) do
+ if #v then return v end
-function helpers.newtimer(name, timeout, fun, nostart)
- helpers.timer_table[name] = capi.timer({ timeout = timeout })
+function helpers.newtimer(_name, timeout, fun, nostart)
+ local name = timeout
+ if not helpers.timer_table[name] then
+ helpers.timer_table[name] = capi.timer({ timeout = timeout })
+ end
helpers.timer_table[name]:connect_signal("timeout", fun)
helpers.timer_table[name]:start()
if not nostart then
helpers.timer_table[name]:connect_signal("timeout", fun)
helpers.timer_table[name]:start()
if not nostart then
+-- {{{ Pipe operations
+
+-- read the full output of a pipe (command)
+function helpers.read_pipe(cmd)
+ local f = assert(io.popen(cmd))
+ local output = f:read("*all")
+ f:close()
+ return output
+end
+
+-- }}}
+
-- {{{ A map utility
helpers.map_table = {}
-- {{{ A map utility
helpers.map_table = {}
+--{{{ Iterate over table of records sorted by keys
+function helpers.spairs(t)
+ -- collect the keys
+ local keys = {}
+ for k in pairs(t) do keys[#keys+1] = k end
+
+ table.sort(keys)
+
+ -- return the iterator function
+ local i = 0
+ return function()
+ i = i + 1
+ if keys[i] then
+ return keys[i], t[keys[i]]
+ end
+ end
+end
+--}}}
+