mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-02-14 05:17:59 +08:00
feat(rebase): complete after :Git rebase
This commit is contained in:
parent
3829f764fa
commit
21315be59f
@ -119,6 +119,8 @@ function! git#complete(ArgLead, CmdLine, CursorPos) abort
|
|||||||
return git#reflog#complete(a:ArgLead, a:CmdLine, a:CursorPos)
|
return git#reflog#complete(a:ArgLead, a:CmdLine, a:CursorPos)
|
||||||
elseif str =~# '^Git\s\+clean\s\+.*$'
|
elseif str =~# '^Git\s\+clean\s\+.*$'
|
||||||
return git#clean#complete(a:ArgLead, a:CmdLine, a:CursorPos)
|
return git#clean#complete(a:ArgLead, a:CmdLine, a:CursorPos)
|
||||||
|
elseif str =~# '^Git\s\+rebase\s\+.*$'
|
||||||
|
return git#rebase#complete(a:ArgLead, a:CmdLine, a:CursorPos)
|
||||||
else
|
else
|
||||||
return ''
|
return ''
|
||||||
endif
|
endif
|
||||||
|
@ -1,104 +1,109 @@
|
|||||||
let s:JOB = SpaceVim#api#import('job')
|
if has('nvim-0.9.0')
|
||||||
let s:BUFFER = SpaceVim#api#import('vim#buffer')
|
function! git#rebase#complete(ArgLead, CmdLine, CursorPos) abort
|
||||||
" @todo rewrite Git rebase in lua
|
return luaeval('require("git.command.rebase").complete(vim.api.nvim_eval("a:ArgLead"), vim.api.nvim_eval("a:CmdLine"), vim.api.nvim_eval("a:CursorPos"))')
|
||||||
function! git#rebase#run(...) abort
|
endfunction
|
||||||
let s:bufnr = s:openRebaseCommitBuffer()
|
else
|
||||||
let s:lines = []
|
let s:JOB = SpaceVim#api#import('job')
|
||||||
if !empty(a:1)
|
let s:BUFFER = SpaceVim#api#import('vim#buffer')
|
||||||
let cmd = ['git', '--no-pager', '-c',
|
" @todo rewrite Git rebase in lua
|
||||||
\ 'core.editor=cat', '-c',
|
function! git#rebase#run(...) abort
|
||||||
\ 'color.status=always',
|
let s:bufnr = s:openRebaseCommitBuffer()
|
||||||
\ '-C',
|
let s:lines = []
|
||||||
\ expand(getcwd(), ':p'),
|
if !empty(a:1)
|
||||||
\ 'rebase'] + a:1
|
let cmd = ['git', '--no-pager', '-c',
|
||||||
else
|
\ 'core.editor=cat', '-c',
|
||||||
finish
|
\ 'color.status=always',
|
||||||
endif
|
\ '-C',
|
||||||
call git#logger#debug('git-rebase cmd:' . string(cmd))
|
\ expand(getcwd(), ':p'),
|
||||||
call s:JOB.start(cmd,
|
\ 'rebase'] + a:1
|
||||||
\ {
|
else
|
||||||
\ 'on_stderr' : function('s:on_stderr'),
|
finish
|
||||||
\ 'on_stdout' : function('s:on_stdout'),
|
endif
|
||||||
\ 'on_exit' : function('s:on_exit'),
|
|
||||||
\ }
|
|
||||||
\ )
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! s:on_stdout(id, data, event) abort
|
|
||||||
for data in a:data
|
|
||||||
call git#logger#debug('git-rebase stdout:' . data)
|
|
||||||
endfor
|
|
||||||
let s:lines += a:data
|
|
||||||
endfunction
|
|
||||||
function! s:on_stderr(id, data, event) abort
|
|
||||||
for data in a:data
|
|
||||||
call git#logger#debug('git-rebase stderr:' . data)
|
|
||||||
endfor
|
|
||||||
" stderr should not be added to commit buffer
|
|
||||||
" let s:lines += a:data
|
|
||||||
endfunction
|
|
||||||
function! s:on_exit(id, data, event) abort
|
|
||||||
call git#logger#debug('git-rebase exit data:' . string(a:data))
|
|
||||||
call s:BUFFER.buf_set_lines(s:bufnr, 0 , -1, 0, s:lines)
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! s:openRebaseCommitBuffer() abort
|
|
||||||
10split git://rebase
|
|
||||||
normal! "_dd
|
|
||||||
setlocal nobuflisted
|
|
||||||
setlocal buftype=acwrite
|
|
||||||
setlocal bufhidden=wipe
|
|
||||||
setlocal noswapfile
|
|
||||||
setlocal modifiable
|
|
||||||
setf git-rebase
|
|
||||||
nnoremap <buffer><silent> q :bd!<CR>
|
|
||||||
let b:git_rebase_quitpre = 0
|
|
||||||
|
|
||||||
augroup git_commit_buffer
|
|
||||||
autocmd! * <buffer>
|
|
||||||
autocmd BufWriteCmd <buffer> call s:BufWriteCmd()
|
|
||||||
autocmd QuitPre <buffer> call s:QuitPre()
|
|
||||||
autocmd WinLeave <buffer> call s:WinLeave()
|
|
||||||
autocmd WinEnter <buffer> let b:git_rebase_quitpre = 0
|
|
||||||
augroup END
|
|
||||||
return bufnr('%')
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
" NOTE:
|
|
||||||
" :w -- BufWriteCmd
|
|
||||||
" <C-w>p -- WinLeave
|
|
||||||
" :wq -- QuitPre -> BufWriteCmd -> WinLeave
|
|
||||||
" when run `:wq` the commit window will not be closed
|
|
||||||
" :q -- QuitPre -> WinLeave
|
|
||||||
function! s:BufWriteCmd() abort
|
|
||||||
let commit_file = '.git\COMMIT_EDITMSG'
|
|
||||||
call writefile(getline(1, '$'), commit_file)
|
|
||||||
setlocal nomodified
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! s:QuitPre() abort
|
|
||||||
let b:git_rebase_quitpre = 1
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! s:WinLeave() abort
|
|
||||||
if b:git_rebase_quitpre == 1
|
|
||||||
let cmd = ['git', 'rebase', '--continue']
|
|
||||||
call git#logger#debug('git-rebase cmd:' . string(cmd))
|
call git#logger#debug('git-rebase cmd:' . string(cmd))
|
||||||
let id = s:JOB.start(cmd,
|
call s:JOB.start(cmd,
|
||||||
\ {
|
\ {
|
||||||
\ 'on_exit' : function('s:on_rebase_continue'),
|
\ 'on_stderr' : function('s:on_stderr'),
|
||||||
|
\ 'on_stdout' : function('s:on_stdout'),
|
||||||
|
\ 'on_exit' : function('s:on_exit'),
|
||||||
\ }
|
\ }
|
||||||
\ )
|
\ )
|
||||||
" line start with # should be ignored
|
endfunction
|
||||||
endif
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! s:on_rebase_continue(id, data, event) abort
|
function! s:on_stdout(id, data, event) abort
|
||||||
call git#logger#debug('git-rebase exit data:' . string(a:data))
|
for data in a:data
|
||||||
if a:data ==# 0
|
call git#logger#debug('git-rebase stdout:' . data)
|
||||||
echo 'done!'
|
endfor
|
||||||
else
|
let s:lines += a:data
|
||||||
echo 'failed!'
|
endfunction
|
||||||
endif
|
function! s:on_stderr(id, data, event) abort
|
||||||
endfunction
|
for data in a:data
|
||||||
|
call git#logger#debug('git-rebase stderr:' . data)
|
||||||
|
endfor
|
||||||
|
" stderr should not be added to commit buffer
|
||||||
|
" let s:lines += a:data
|
||||||
|
endfunction
|
||||||
|
function! s:on_exit(id, data, event) abort
|
||||||
|
call git#logger#debug('git-rebase exit data:' . string(a:data))
|
||||||
|
call s:BUFFER.buf_set_lines(s:bufnr, 0 , -1, 0, s:lines)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:openRebaseCommitBuffer() abort
|
||||||
|
10split git://rebase
|
||||||
|
normal! "_dd
|
||||||
|
setlocal nobuflisted
|
||||||
|
setlocal buftype=acwrite
|
||||||
|
setlocal bufhidden=wipe
|
||||||
|
setlocal noswapfile
|
||||||
|
setlocal modifiable
|
||||||
|
setf git-rebase
|
||||||
|
nnoremap <buffer><silent> q :bd!<CR>
|
||||||
|
let b:git_rebase_quitpre = 0
|
||||||
|
|
||||||
|
augroup git_commit_buffer
|
||||||
|
autocmd! * <buffer>
|
||||||
|
autocmd BufWriteCmd <buffer> call s:BufWriteCmd()
|
||||||
|
autocmd QuitPre <buffer> call s:QuitPre()
|
||||||
|
autocmd WinLeave <buffer> call s:WinLeave()
|
||||||
|
autocmd WinEnter <buffer> let b:git_rebase_quitpre = 0
|
||||||
|
augroup END
|
||||||
|
return bufnr('%')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" NOTE:
|
||||||
|
" :w -- BufWriteCmd
|
||||||
|
" <C-w>p -- WinLeave
|
||||||
|
" :wq -- QuitPre -> BufWriteCmd -> WinLeave
|
||||||
|
" when run `:wq` the commit window will not be closed
|
||||||
|
" :q -- QuitPre -> WinLeave
|
||||||
|
function! s:BufWriteCmd() abort
|
||||||
|
let commit_file = '.git\COMMIT_EDITMSG'
|
||||||
|
call writefile(getline(1, '$'), commit_file)
|
||||||
|
setlocal nomodified
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:QuitPre() abort
|
||||||
|
let b:git_rebase_quitpre = 1
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:WinLeave() abort
|
||||||
|
if b:git_rebase_quitpre == 1
|
||||||
|
let cmd = ['git', 'rebase', '--continue']
|
||||||
|
call git#logger#debug('git-rebase cmd:' . string(cmd))
|
||||||
|
let id = s:JOB.start(cmd,
|
||||||
|
\ {
|
||||||
|
\ 'on_exit' : function('s:on_rebase_continue'),
|
||||||
|
\ }
|
||||||
|
\ )
|
||||||
|
" line start with # should be ignored
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:on_rebase_continue(id, data, event) abort
|
||||||
|
call git#logger#debug('git-rebase exit data:' . string(a:data))
|
||||||
|
if a:data ==# 0
|
||||||
|
echo 'done!'
|
||||||
|
else
|
||||||
|
echo 'failed!'
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
endif
|
||||||
|
@ -135,5 +135,8 @@ function m.run(argv)
|
|||||||
on_stderr = on_std,
|
on_stderr = on_std,
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
function m.complete(ArgLead, CmdLine, CursorPos)
|
||||||
|
return table.concat({'-i', '--abort'}, '\n')
|
||||||
|
end
|
||||||
|
|
||||||
return m
|
return m
|
||||||
|
Loading…
Reference in New Issue
Block a user