lain/helpers.lua

208 lines
4.7 KiB
Lua
Raw Normal View History

2013-09-07 12:06:42 +02:00
--[[
Licensed under GNU General Public License v2
* (c) 2013, Luca CPZ
--]]
2013-09-13 00:07:44 +02:00
local spawn = require("awful.spawn")
2017-01-26 20:53:55 +01:00
local timer = require("gears.timer")
local debug = require("debug")
local io = { lines = io.lines,
2017-01-29 14:45:15 +01:00
open = io.open }
local rawget = rawget
local table = { sort = table.sort }
2013-09-07 12:06:42 +02:00
-- Lain helper functions for internal use
-- lain.helpers
local helpers = {}
helpers.lain_dir = debug.getinfo(1, 'S').source:match[[^@(.*/).*$]]
helpers.icons_dir = helpers.lain_dir .. 'icons/'
helpers.scripts_dir = helpers.lain_dir .. 'scripts/'
-- {{{ Modules loader
function helpers.wrequire(table, key)
local module = rawget(table, key)
return module or require(table._NAME .. '.' .. key)
end
-- }}}
2014-01-29 11:56:32 +01:00
-- {{{ File operations
2013-09-07 12:06:42 +02:00
2014-02-09 10:36:40 +01:00
-- see if the file exists and is readable
2014-01-29 11:56:32 +01:00
function helpers.file_exists(file)
2014-02-08 12:10:13 +01:00
local f = io.open(file)
2014-02-09 10:36:40 +01:00
if f then
local s = f:read()
f:close()
f = s
end
2014-01-29 11:56:32 +01:00
return f ~= nil
end
2015-07-03 12:17:31 +02:00
-- get all lines from a file, returns an empty
2014-01-29 11:56:32 +01:00
-- list/table if the file does not exist
function helpers.lines_from(file)
if not helpers.file_exists(file) then return {} end
local lines = {}
2015-07-03 12:17:31 +02:00
for line in io.lines(file) do
2014-01-29 11:56:32 +01:00
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
2016-09-13 16:29:17 +02:00
if string.match(line, regexp) then
lines[index] = line
2016-09-13 16:29:17 +02:00
end
end
return lines
end
2014-01-29 11:56:32 +01:00
-- get first line of a file, return nil if
-- the file does not exist
function helpers.first_line(file)
return helpers.lines_from(file)[1]
end
2013-09-07 12:06:42 +02:00
2014-01-29 11:56:32 +01:00
-- get first non empty line from a file,
-- returns nil otherwise
function helpers.first_nonempty_line(file)
2014-01-29 20:08:16 +01:00
for k,v in pairs(helpers.lines_from(file)) do
2015-07-03 12:17:31 +02:00
if #v then return v end
2014-01-29 11:56:32 +01:00
end
return nil
2013-09-07 12:06:42 +02:00
end
-- }}}
2013-09-13 18:15:25 +02:00
-- {{{ Timer maker
2013-09-10 23:02:11 +02:00
helpers.timer_table = {}
function helpers.newtimer(name, timeout, fun, nostart, stoppable)
if not name or #name == 0 then return end
name = (stoppable and name) or timeout
2016-03-02 13:48:55 +01:00
if not helpers.timer_table[name] then
helpers.timer_table[name] = timer({ timeout = timeout })
2016-08-11 13:43:35 +02:00
helpers.timer_table[name]:start()
2016-03-02 13:48:55 +01:00
end
2013-09-10 23:02:11 +02:00
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]
2013-09-10 23:02:11 +02:00
end
-- }}}
-- {{{ Pipe operations
-- 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)
2017-12-19 17:20:59 +01:00
return spawn.easy_async(cmd,
function (stdout, stderr, reason, exit_code)
callback(stdout, exit_code)
2017-12-19 17:20:59 +01:00
end)
end
-- like above, but call spawn.easy_async with a shell
function helpers.async_with_shell(cmd, callback)
return spawn.easy_async_with_shell(cmd,
function (stdout, stderr, reason, exit_code)
callback(stdout, exit_code)
end)
2016-11-06 12:18:34 +01:00
end
-- run a command and execute a function on its output line by line
function helpers.line_callback(cmd, callback)
return spawn.with_line_callback(cmd, {
stdout = function (line)
callback(line)
end,
})
end
-- }}}
2013-09-07 12:06:42 +02:00
-- {{{ A map utility
helpers.map_table = {}
function helpers.set_map(element, value)
helpers.map_table[element] = value
end
function helpers.get_map(element)
return helpers.map_table[element]
end
-- }}}
2017-01-03 12:21:50 +01:00
-- {{{ Misc
2017-01-09 20:21:56 +01:00
-- 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
2017-01-03 12:21:50 +01:00
-- iterate over table of records sorted by keys
2015-11-18 09:02:16 +01:00
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
-- create trivial partition of a set. The trivial partition set is the simplest
-- partition of a set. For e.g., the trivial partition set of {a, b, c}, is
-- simply {{a}, {b}, {c}}.
function helpers.trivial_partition_set(set)
local ss = {}
for _,e in pairs(set) do
ss[#ss+1] = {e}
end
return ss
end
-- creates the powerset of a given set
function helpers.powerset(s)
if not s then return {} end
local t = {{}}
for i = 1, #s do
for j = 1, #t do
t[#t+1] = {s[i],unpack(t[j])}
end
end
return t
end
2017-01-03 12:21:50 +01:00
-- }}}
2016-11-06 12:18:34 +01:00
2013-09-07 12:06:42 +02:00
return helpers