mirror of https://github.com/Hilbis/Hilbish
Merge eded38c7b5
into 1a4585aa7a
commit
e38d5616aa
|
@ -1,3 +1,23 @@
|
|||
local fs = require 'fs'
|
||||
|
||||
-- explanation: this specific function gives to us info about
|
||||
-- the currently running source. this includes a path to the
|
||||
-- source file (info.source)
|
||||
-- we will use that to automatically load all commands by reading
|
||||
-- all the files in this dir and just requiring it.
|
||||
local info = debug.getinfo(1)
|
||||
local commandDir = fs.dir(info.source)
|
||||
if commandDir == '.' then return end
|
||||
|
||||
local commands = fs.readdir(commandDir)
|
||||
for _, command in ipairs(commands) do
|
||||
local name = command:gsub('%.lua', '') -- chop off extension
|
||||
if name ~= 'init' then
|
||||
-- skip this file (for obvious reasons)
|
||||
require('nature.completions.' .. name)
|
||||
end
|
||||
end
|
||||
|
||||
function hilbish.completion.handler(line, pos)
|
||||
if type(line) ~= 'string' then error '#1 must be a string' end
|
||||
if type(pos) ~= 'number' then error '#2 must be a number' end
|
|
@ -0,0 +1,53 @@
|
|||
local function curry(f)
|
||||
return function (x) return function (y) return f(x,y) end end
|
||||
end
|
||||
|
||||
local flags = {}
|
||||
local function flag(f, description)
|
||||
flags[f] = {description}
|
||||
end
|
||||
|
||||
local addflag = curry(flag)
|
||||
|
||||
addflag '-A' 'Ask for password via askpass or $SUDO_ASKPASS'
|
||||
addflag '-B' 'Ring the bell as part of the password prompt.'
|
||||
|
||||
hilbish.complete('command.sudo', function(query, ctx, fields)
|
||||
table.remove(fields, 1)
|
||||
local nonflags = table.filter(fields, function(v)
|
||||
if v == '' then
|
||||
return false
|
||||
end
|
||||
return v:match '^%-' == nil
|
||||
end)
|
||||
|
||||
if #fields == 1 or #nonflags == 0 then
|
||||
-- complete commands or sudo flags
|
||||
if query:match ('^%-') then
|
||||
local compFlags = {}
|
||||
for flg, flgstuff in pairs(flags) do
|
||||
if flg:match('^' .. query) then
|
||||
compFlags[flg] = flgstuff
|
||||
end
|
||||
end
|
||||
|
||||
local compGroup = {
|
||||
items = compFlags,
|
||||
type = 'list'
|
||||
}
|
||||
|
||||
return {compGroup}, query
|
||||
end
|
||||
|
||||
local comps, pfx = hilbish.completion.bins(query, ctx, fields)
|
||||
local compGroup = {
|
||||
items = comps,
|
||||
type = 'grid'
|
||||
}
|
||||
|
||||
return {compGroup}, pfx
|
||||
end
|
||||
|
||||
-- otherwise, get command flags
|
||||
return hilbish.completion.call('command.' .. fields[2], query, ctx, fields)
|
||||
end)
|
Loading…
Reference in New Issue