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.
4 Licensed under GNU General Public License v2
5 * (c) 2013, Luke Bonham
10 local debug = require("debug")
11 local io = { lines = io.lines,
15 local table = { sort = table.sort }
17 local easy_async = require("awful.spawn").easy_async
18 local timer = require("gears.timer")
19 local wibox = require("wibox")
21 -- Lain helper functions for internal use
25 helpers.lain_dir = debug.getinfo(1, 'S').source:match[[^@(.*/).*$]]
26 helpers.icons_dir = helpers.lain_dir .. 'icons/'
27 helpers.scripts_dir = helpers.lain_dir .. 'scripts/'
31 function helpers.wrequire(table, key)
32 local module = rawget(table, key)
33 return module or require(table._NAME .. '.' .. key)
38 -- {{{ File operations
40 -- see if the file exists and is readable
41 function helpers.file_exists(file)
42 local f = io.open(file)
51 -- get all lines from a file, returns an empty
52 -- list/table if the file does not exist
53 function helpers.lines_from(file)
54 if not helpers.file_exists(file) then return {} end
56 for line in io.lines(file) do
57 lines[#lines + 1] = line
62 -- match all lines from a file, returns an empty
63 -- list/table if the file or match does not exist
64 function helpers.lines_match(regexp, file)
66 for index,line in pairs(helpers.lines_from(file)) do
67 if string.match(line, regexp) then
74 -- get first line of a file, return nil if
75 -- the file does not exist
76 function helpers.first_line(file)
77 return helpers.lines_from(file)[1]
80 -- get first non empty line from a file,
81 -- returns nil otherwise
82 function helpers.first_nonempty_line(file)
83 for k,v in pairs(helpers.lines_from(file)) do
84 if #v then return v end
93 helpers.timer_table = {}
95 function helpers.newtimer(name, timeout, fun, nostart, stoppable)
96 if not name or #name == 0 then return end
97 name = (stoppable and name) or timeout
98 if not helpers.timer_table[name] then
99 helpers.timer_table[name] = timer({ timeout = timeout })
100 helpers.timer_table[name]:start()
102 helpers.timer_table[name]:connect_signal("timeout", fun)
104 helpers.timer_table[name]:emit_signal("timeout")
106 return stoppable and helpers.timer_table[name]
111 -- {{{ Pipe operations
113 -- return the full output of an input command (synchronous pipe)
114 -- @param cmd the input command
115 -- @return command output (string)
116 function helpers.read_pipe(cmd)
117 local f = io.popen(cmd)
118 local output = f:read("*all")
123 -- run a command and execute a function on its output (asynchronous pipe)
124 -- @param cmd the input command
125 -- @param callback function to execute on cmd output
127 function helpers.async(cmd, callback)
128 return easy_async(cmd,
129 function (stdout, stderr, reason, exit_code)
138 helpers.map_table = {}
140 function helpers.set_map(element, value)
141 helpers.map_table[element] = value
144 function helpers.get_map(element)
145 return helpers.map_table[element]
152 -- check if an element exist on a table
153 function helpers.element_in_table(element, tbl)
154 for _, i in pairs(tbl) do
162 -- iterate over table of records sorted by keys
163 function helpers.spairs(t)
166 for k in pairs(t) do keys[#keys+1] = k end
170 -- return the iterator function
175 return keys[i], t[keys[i]]
180 -- create a textbox with no spacing issues
181 function helpers.make_widget_textbox()
182 local w = wibox.widget.textbox()
183 local t = wibox.widget.base.make_widget(w)
188 -- shallow copy a table
189 function helpers.table_shallowcopy(orig)
190 local orig_type = type(orig)
192 if orig_type == 'table' then
194 for orig_key, orig_value in pairs(orig) do
195 copy[orig_key] = orig_value
197 else -- number, string, boolean, etc