1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-03-13 02:05:40 +08:00

perf(git): display stderr on exit

This commit is contained in:
wsdjeg 2023-07-29 15:48:52 +08:00 committed by Eric Wong
parent f2f7c8dcc0
commit 9dda2491af

View File

@ -3,28 +3,38 @@ local m = {}
local job = require('spacevim.api.job') local job = require('spacevim.api.job')
local nt = require('spacevim.api.notify') local nt = require('spacevim.api.notify')
local log = require('git.log') local log = require('git.log')
local stddata = {}
local function on_exit(id, code, single) local function on_exit(id, code, single)
log.debug('git-mv exit code:' .. code .. ' single:' .. single) log.debug('git-mv exit code:' .. code .. ' single:' .. single)
if code == 0 and single == 0 then if code == 0 and single == 0 then
nt.notify('git mv successfully') nt.notify('git mv successfully')
else else
nt.notify('failed to run git mv', 'warningmsg') nt.notify(table.concat(stddata, '\n'), 'warningmsg')
end
end
local function on_std(id, data)
for _, v in ipairs(data) do
table.insert(stddata, v)
end end
end end
function m.run(argv) function m.run(argv)
local cmd = {'git', 'mv'} local cmd = { 'git', 'mv' }
if vim.fn.index(argv, '%') ~= -1 then if vim.fn.index(argv, '%') ~= -1 then
argv[vim.fn.index(argv, '%') + 1] = vim.fn.expand('%') argv[vim.fn.index(argv, '%') + 1] = vim.fn.expand('%')
end end
for _, v in ipairs(argv) do table.insert(cmd, v) for _, v in ipairs(argv) do
table.insert(cmd, v)
end end
log.debug('git-mv cmd:' .. vim.inspect(cmd)) log.debug('git-mv cmd:' .. vim.inspect(cmd))
stddata = {}
job.start(cmd, { job.start(cmd, {
on_exit = on_exit on_exit = on_exit,
on_stdout = on_std,
on_stderr = on_std
}) })
end end
return m return m