mirror of
https://github.com/zoriya/telescope.nvim.git
synced 2025-12-05 22:36:13 +00:00
* something kind of works already * yayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayaya * use async for everything besides live jobs * fix: fixup autocmds previewer * fix: lints for prime * temp: Add example of how we can think about async sorters * feat: Allow picker to decide when to cancel * fix: simplify scoring logic and tests * fixup: name * fix: Move back towards more backwards compat methods * fixup: Remove results from opts * fixup: remove trailing quote * fixup: Attempt to clean up some more async items. Next is status * wip: Add todo for when bfredl implements extmarks over the EOL * wip * fixup: got em * fixup: cleaning * fixup: docs
82 lines
2.0 KiB
Lua
82 lines
2.0 KiB
Lua
local async_lib = require('plenary.async_lib')
|
|
local async = async_lib.async
|
|
local await = async_lib.await
|
|
local void = async_lib.void
|
|
|
|
local AWAITABLE = 1000
|
|
|
|
local make_entry = require('telescope.make_entry')
|
|
|
|
local Job = require('plenary.job')
|
|
|
|
return function(opts)
|
|
opts = opts or {}
|
|
|
|
local entry_maker = opts.entry_maker or make_entry.from_string
|
|
local cwd = opts.cwd
|
|
local fn_command = assert(opts.fn_command, "Must pass `fn_command`")
|
|
|
|
local results = {}
|
|
local num_results = 0
|
|
|
|
local job_started = false
|
|
local job_completed = false
|
|
return setmetatable({
|
|
close = function() results = {}; job_started = false end,
|
|
results = results,
|
|
}, {
|
|
__call = void(async(function(_, prompt, process_result, process_complete)
|
|
if not job_started then
|
|
local job_opts = fn_command()
|
|
|
|
local writer
|
|
if job_opts.writer and Job.is_job(job_opts.writer) then
|
|
writer = job_opts.writer
|
|
elseif job_opts.writer then
|
|
writer = Job:new(job_opts.writer)
|
|
end
|
|
|
|
local job = Job:new {
|
|
command = job_opts.command,
|
|
args = job_opts.args,
|
|
cwd = job_opts.cwd or cwd,
|
|
maximum_results = opts.maximum_results,
|
|
writer = writer,
|
|
enable_recording = false,
|
|
|
|
on_stdout = vim.schedule_wrap(function(_, line)
|
|
num_results = num_results + 1
|
|
|
|
local v = entry_maker(line)
|
|
results[num_results] = v
|
|
process_result(v)
|
|
end),
|
|
|
|
on_exit = function()
|
|
process_complete()
|
|
job_completed = true
|
|
end,
|
|
}
|
|
|
|
job:start()
|
|
job_started = true
|
|
end
|
|
|
|
local current_count = num_results
|
|
for index = 1, current_count do
|
|
if process_result(results[index]) then
|
|
break
|
|
end
|
|
|
|
if index % AWAITABLE == 0 then
|
|
await(async_lib.scheduler())
|
|
end
|
|
end
|
|
|
|
if job_completed then
|
|
process_complete()
|
|
end
|
|
end)),
|
|
})
|
|
end
|