1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-03-29 22:40:36 +08:00

Compare commits

..

No commits in common. "eacd71c78477902883845ddaf367ada49fdaf6dc" and "a0b86e67e879ada18c28f9d953114568f702c116" have entirely different histories.

16 changed files with 230 additions and 339 deletions

View File

@ -6,6 +6,8 @@
[![twitter](https://img.spacevim.org/twitter.svg)](https://twitter.com/SpaceVim) [![twitter](https://img.spacevim.org/twitter.svg)](https://twitter.com/SpaceVim)
[![GPLv3 License](https://img.spacevim.org/license-GPLv3-blue.svg)](development/#license) [![GPLv3 License](https://img.spacevim.org/license-GPLv3-blue.svg)](development/#license)
[![reddit](https://img.spacevim.org/reddit.svg)](https://www.reddit.com/r/SpaceVim/)
[![matrix](https://img.spacevim.org/spacevim-matrix.svg)](https://app.element.io/#/room/#spacevim:matrix.org)
![work-flow](https://img.spacevim.org/workflow.png) ![work-flow](https://img.spacevim.org/workflow.png)

View File

@ -2872,6 +2872,10 @@ endfunction
" send email to spacevim@googlegroups.com " send email to spacevim@googlegroups.com
" "
" To subscribe the maillist, send anything tospacevim+subscribe@googlegroups.com " To subscribe the maillist, send anything tospacevim+subscribe@googlegroups.com
"
" @subsection Forum
"
" - Reddit: https://www.reddit.com/r/SpaceVim/
"" ""
" @section Roadmap, roadmap " @section Roadmap, roadmap

View File

@ -1,71 +1,47 @@
"============================================================================= let s:JOB = SpaceVim#api#import('job')
" fetch.vim --- Git fetch command
" Copyright 2021 Eric Wong
" Author: Eric Wong < wsdjeg@outlook.com >
" URL: https://spacevim.org
" License: GPLv3
"=============================================================================
function! git#fetch#run(args)
if has('nvim-0.9.0')
function! git#fetch#complete(ArgLead, CmdLine, CursorPos) abort
return luaeval('require("git.command.fetch").complete(vim.api.nvim_eval("a:ArgLead"), vim.api.nvim_eval("a:CmdLine"), vim.api.nvim_eval("a:CursorPos"))')
endfunction
else
""
" @section git-fetch, fetch
" @parentsection commands
" This commands is to fetch remote repo.
" >
" :Git fetch --all
" <
let s:JOB = SpaceVim#api#import('job')
function! git#fetch#run(args)
let cmd = ['git', 'fetch'] + a:args let cmd = ['git', 'fetch'] + a:args
call git#logger#debug('git-fetch cmd:' . string(cmd)) call git#logger#debug('git-fetch cmd:' . string(cmd))
call s:JOB.start(cmd, call s:JOB.start(cmd,
\ { \ {
\ 'on_exit' : function('s:on_exit'), \ 'on_exit' : function('s:on_exit'),
\ } \ }
\ ) \ )
endfunction endfunction
function! s:on_exit(id, data, event) abort function! s:on_exit(id, data, event) abort
call git#logger#debug('git-fetch exit data:' . string(a:data)) call git#logger#debug('git-fetch exit data:' . string(a:data))
if a:data ==# 0 if a:data ==# 0
echo 'fetch done!' echo 'fetch done!'
else else
echo 'fetch failed!' echo 'fetch failed!'
endif endif
endfunction endfunction
function! git#fetch#complete(ArgLead, CmdLine, CursorPos) function! git#fetch#complete(ArgLead, CmdLine, CursorPos)
if a:ArgLead =~# '^-' if a:ArgLead =~# '^-'
return s:options() return s:options()
endif endif
let str = a:CmdLine[:a:CursorPos-1] let str = a:CmdLine[:a:CursorPos-1]
if str =~# '^Git\s\+fetch\s\+[^ ]*$' if str =~# '^Git\s\+fetch\s\+[^ ]*$'
return join(s:remotes(), "\n") return join(s:remotes(), "\n")
else else
return '' return ''
endif endif
endfunction endfunction
function! s:remotes() abort function! s:remotes() abort
return map(systemlist('git remote'), 'trim(v:val)') return map(systemlist('git remote'), 'trim(v:val)')
endfunction endfunction
function! s:options() abort function! s:options() abort
return join([ return join([
\ '--all', \ '--all',
\ '--multiple', \ '--multiple',
\ ], "\n") \ ], "\n")
endfunction endfunction
endif

View File

@ -1,50 +1,37 @@
"============================================================================= let s:JOB = SpaceVim#api#import('job')
" reset.vim --- git reset command
" Copyright (c) 2016-2019 Wang Shidong & Contributors
" Author: Wang Shidong < wsdjeg@outlook.com >
" URL: https://spacevim.org
" License: GPLv3
"=============================================================================
if has('nvim-0.9.0')
function! git#reset#complete(ArgLead, CmdLine, CursorPos) abort
return luaeval('require("git.command.reset").complete(vim.api.nvim_eval("a:ArgLead"), vim.api.nvim_eval("a:CmdLine"), vim.api.nvim_eval("a:CursorPos"))')
endfunction
else
let s:JOB = SpaceVim#api#import('job')
function! git#reset#run(args) function! git#reset#run(args)
if len(a:args) == 1 && a:args[0] ==# '%' if len(a:args) == 1 && a:args[0] ==# '%'
let cmd = ['git', 'reset', 'HEAD', expand('%')] let cmd = ['git', 'reset', 'HEAD', expand('%')]
else else
let cmd = ['git', 'reset'] + a:args let cmd = ['git', 'reset'] + a:args
endif endif
call git#logger#debug('git-reset cmd:' . string(cmd)) call git#logger#debug('git-reset cmd:' . string(cmd))
call s:JOB.start(cmd, call s:JOB.start(cmd,
\ { \ {
\ 'on_exit' : function('s:on_exit'), \ 'on_exit' : function('s:on_exit'),
\ } \ }
\ ) \ )
endfunction endfunction
function! s:on_exit(id, data, event) abort function! s:on_exit(id, data, event) abort
call git#logger#debug('git-reset exit data:' . string(a:data)) call git#logger#debug('git-reset exit data:' . string(a:data))
if a:data ==# 0 if a:data ==# 0
if exists(':GitGutter') if exists(':GitGutter')
GitGutter GitGutter
endif endif
echo 'done!' echo 'done!'
else else
echo 'failed!' echo 'failed!'
endif endif
endfunction endfunction
function! git#reset#complete(ArgLead, CmdLine, CursorPos) function! git#reset#complete(ArgLead, CmdLine, CursorPos)
return "%\n" . join(getcompletion(a:ArgLead, 'file'), "\n") return "%\n" . join(getcompletion(a:ArgLead, 'file'), "\n")
endfunction endfunction
endif

View File

@ -7,44 +7,38 @@
" :Git rm % " :Git rm %
" < " <
if has('nvim-0.9.0') let s:JOB = SpaceVim#api#import('job')
function! git#rm#complete(ArgLead, CmdLine, CursorPos) abort
return luaeval('require("git.command.rm").complete(vim.api.nvim_eval("a:ArgLead"), vim.api.nvim_eval("a:CmdLine"), vim.api.nvim_eval("a:CursorPos"))')
endfunction
else
let s:JOB = SpaceVim#api#import('job')
function! git#rm#run(files) abort function! git#rm#run(files) abort
if len(a:files) == 1 && a:files[0] ==# '%' if len(a:files) == 1 && a:files[0] ==# '%'
let cmd = ['git', 'rm', expand('%')] let cmd = ['git', 'rm', expand('%')]
else else
let cmd = ['git', 'rm'] + a:files let cmd = ['git', 'rm'] + a:files
endif endif
call git#logger#debug('git-rm cmd:' . string(cmd)) call git#logger#debug('git-rm cmd:' . string(cmd))
call s:JOB.start(cmd, call s:JOB.start(cmd,
\ { \ {
\ 'on_exit' : function('s:on_exit'), \ 'on_exit' : function('s:on_exit'),
\ } \ }
\ ) \ )
endfunction endfunction
function! s:on_exit(id, data, event) abort function! s:on_exit(id, data, event) abort
call git#logger#debug('git-rm exit data:' . string(a:data)) call git#logger#debug('git-rm exit data:' . string(a:data))
if a:data ==# 0 if a:data ==# 0
if exists(':GitGutter') if exists(':GitGutter')
GitGutter GitGutter
endif endif
echo 'done!' echo 'done!'
else else
echo 'failed!' echo 'failed!'
endif endif
endfunction endfunction
function! git#rm#complete(ArgLead, CmdLine, CursorPos) abort function! git#rm#complete(ArgLead, CmdLine, CursorPos) abort
return "%\n" . join(getcompletion(a:ArgLead, 'file'), "\n") return "%\n" . join(getcompletion(a:ArgLead, 'file'), "\n")
endfunction endfunction
endif

View File

@ -6,109 +6,104 @@
" :Git stash list " :Git stash list
" < " <
if has('nvim-0.9.0') let s:JOB = SpaceVim#api#import('job')
function! git#stash#complete(ArgLead, CmdLine, CursorPos) abort let s:NOTI = SpaceVim#api#import('notify')
return luaeval('require("git.command.stash").complete(vim.api.nvim_eval("a:ArgLead"), vim.api.nvim_eval("a:CmdLine"), vim.api.nvim_eval("a:CursorPos"))') let s:BUFFER = SpaceVim#api#import('vim#buffer')
endfunction
else
let s:JOB = SpaceVim#api#import('job')
let s:NOTI = SpaceVim#api#import('notify')
let s:BUFFER = SpaceVim#api#import('vim#buffer')
let s:stash_show_bufnr = -1 let s:stash_show_bufnr = -1
" @todo rewrite Git stash in lua " @todo rewrite Git stash in lua
function! git#stash#run(args) abort function! git#stash#run(args) abort
let cmd = ['git', 'stash'] + a:args let cmd = ['git', 'stash'] + a:args
let subcmd = get(a:args, 0, '') let subcmd = get(a:args, 0, '')
if !empty(subcmd) && index(['drop', 'show'], subcmd) > -1 if !empty(subcmd) && index(['drop', 'show'], subcmd) > -1
let subcmd = subcmd . '_' let subcmd = subcmd . '_'
else else
let subcmd = '' let subcmd = ''
endif endif
call git#logger#debug('git-stash cmd:' . string(cmd)) call git#logger#debug('git-stash cmd:' . string(cmd))
let s:lines = [] let s:lines = []
call s:JOB.start(cmd, call s:JOB.start(cmd,
\ { \ {
\ 'on_stderr' : function('s:on_' . subcmd . 'stderr'), \ 'on_stderr' : function('s:on_' . subcmd . 'stderr'),
\ 'on_stdout' : function('s:on_' . subcmd . 'stdout'), \ 'on_stdout' : function('s:on_' . subcmd . 'stdout'),
\ 'on_exit' : function('s:on_' . subcmd . 'exit'), \ 'on_exit' : function('s:on_' . subcmd . 'exit'),
\ } \ }
\ ) \ )
endfunction endfunction
function! s:on_stdout(id, data, event) abort function! s:on_stdout(id, data, event) abort
for line in filter(a:data, '!empty(v:val)') for line in filter(a:data, '!empty(v:val)')
call git#logger#debug('git-stash stdout:' . line) call git#logger#debug('git-stash stdout:' . line)
call s:NOTI.notify(line, 'Normal') call s:NOTI.notify(line, 'Normal')
endfor endfor
endfunction endfunction
function! s:on_stderr(id, data, event) abort function! s:on_stderr(id, data, event) abort
for data in a:data for data in a:data
call git#logger#debug('git-stash stderr:' . data) call git#logger#debug('git-stash stderr:' . data)
endfor endfor
endfunction endfunction
function! s:on_exit(id, data, event) abort function! s:on_exit(id, data, event) abort
call git#logger#debug('git-stash exit data:' . string(a:data)) call git#logger#debug('git-stash exit data:' . string(a:data))
if a:data ==# 0 if a:data ==# 0
" echo 'done!' " echo 'done!'
else else
" echo 'failed!' " echo 'failed!'
endif endif
endfunction endfunction
function! s:on_drop_stdout(id, data, event) abort function! s:on_drop_stdout(id, data, event) abort
for line in filter(a:data, '!empty(v:val)') for line in filter(a:data, '!empty(v:val)')
call git#logger#debug('git-stash stdout:' . line) call git#logger#debug('git-stash stdout:' . line)
call s:NOTI.notify(line, 'Normal') call s:NOTI.notify(line, 'Normal')
endfor endfor
endfunction endfunction
function! s:on_drop_stderr(id, data, event) abort function! s:on_drop_stderr(id, data, event) abort
for line in filter(a:data, '!empty(v:val)') for line in filter(a:data, '!empty(v:val)')
call git#logger#debug('git-stash stdout:' . line) call git#logger#debug('git-stash stdout:' . line)
call s:NOTI.notify(line, 'WarningMsg') call s:NOTI.notify(line, 'WarningMsg')
endfor endfor
endfunction endfunction
function! s:on_drop_exit(id, data, event) abort function! s:on_drop_exit(id, data, event) abort
call git#logger#debug('git-stash exit data:' . string(a:data)) call git#logger#debug('git-stash exit data:' . string(a:data))
if a:data ==# 0 if a:data ==# 0
" echo 'done!' " echo 'done!'
else else
" echo 'failed!' " echo 'failed!'
endif endif
endfunction endfunction
function! s:on_show_stdout(id, data, event) abort function! s:on_show_stdout(id, data, event) abort
for data in a:data for data in a:data
call git#logger#debug('git-stash stdout:' . data) call git#logger#debug('git-stash stdout:' . data)
endfor endfor
let s:lines += a:data let s:lines += a:data
endfunction endfunction
function! s:on_show_stderr(id, data, event) abort function! s:on_show_stderr(id, data, event) abort
for line in filter(a:data, '!empty(v:val)') for line in filter(a:data, '!empty(v:val)')
call git#logger#debug('git-stash stdout:' . line) call git#logger#debug('git-stash stdout:' . line)
call s:NOTI.notify(line, 'WarningMsg') call s:NOTI.notify(line, 'WarningMsg')
endfor endfor
endfunction endfunction
function! s:on_show_exit(id, data, event) abort function! s:on_show_exit(id, data, event) abort
call git#logger#debug('git-stash exit data:' . string(a:data)) call git#logger#debug('git-stash exit data:' . string(a:data))
if a:data ==# 0 if a:data ==# 0
if !bufexists(s:stash_show_bufnr) if !bufexists(s:stash_show_bufnr)
let s:stash_show_bufnr = s:openStashShowBuffer() let s:stash_show_bufnr = s:openStashShowBuffer()
endif endif
call s:BUFFER.buf_set_lines(s:stash_show_bufnr, 0 , -1, 0, s:lines) call s:BUFFER.buf_set_lines(s:stash_show_bufnr, 0 , -1, 0, s:lines)
endif endif
endfunction endfunction
function! s:openStashShowBuffer() abort function! s:openStashShowBuffer() abort
edit git://blame edit git://blame
normal! "_dd normal! "_dd
setl nobuflisted setl nobuflisted
@ -119,31 +114,30 @@ else
setl syntax=diff setl syntax=diff
nnoremap <buffer><silent> q :bd!<CR> nnoremap <buffer><silent> q :bd!<CR>
return bufnr('%') return bufnr('%')
endfunction endfunction
function! s:sub_commands() abort function! s:sub_commands() abort
return join([ return join([
\ 'list', \ 'list',
\ 'show', \ 'show',
\ 'drop', \ 'drop',
\ 'pop', 'apply', \ 'pop', 'apply',
\ 'branch', \ 'branch',
\ 'clear', \ 'clear',
\ 'save', \ 'save',
\ 'push', \ 'push',
\ ], \ ],
\ "\n") \ "\n")
endfunction endfunction
function! git#stash#complete(ArgLead, CmdLine, CursorPos) abort function! git#stash#complete(ArgLead, CmdLine, CursorPos) abort
let str = a:CmdLine[:a:CursorPos-1] let str = a:CmdLine[:a:CursorPos-1]
if str =~# '^Git\s\+stash\s\+[a-z]\=$' if str =~# '^Git\s\+stash\s\+[a-z]\=$'
return s:sub_commands() return s:sub_commands()
else else
return '' return ''
endif endif
endfunction endfunction
endif

View File

@ -6,94 +6,88 @@
" :Git tag --list " :Git tag --list
" < " <
if has('nvim-0.9.0') let s:JOB = SpaceVim#api#import('job')
function! git#tag#complete(ArgLead, CmdLine, CursorPos) abort let s:NT = SpaceVim#api#import('notify')
return luaeval('require("git.command.tag").complete(vim.api.nvim_eval("a:ArgLead"), vim.api.nvim_eval("a:CmdLine"), vim.api.nvim_eval("a:CursorPos"))') let s:jobid = -1
endfunction let s:stderr_data = []
else
let s:JOB = SpaceVim#api#import('job') function! git#tag#run(argvs) abort
let s:NT = SpaceVim#api#import('notify')
let s:jobid = -1 if s:jobid != -1
call s:NT.notify('previous tag command is not finished')
return
endif
let s:NT.notify_max_width = float2nr(&columns * 0.3)
let s:stderr_data = [] let s:stderr_data = []
function! git#tag#run(argvs) abort let cmd = ['git', 'tag'] + a:argvs
call git#logger#debug('git-tag cmd:' . string(cmd))
let s:jobid = s:JOB.start(cmd,
\ {
\ 'on_stdout' : function('s:on_stdout'),
\ 'on_stderr' : function('s:on_stderr'),
\ 'on_exit' : function('s:on_exit'),
\ }
\ )
if s:jobid != -1 if s:jobid == -1
call s:NT.notify('previous tag command is not finished') call s:NT.notify('`git` is not executable', 'WarningMsg')
return endif
endif
let s:NT.notify_max_width = float2nr(&columns * 0.3) endfunction
let s:stderr_data = [] function! s:on_stdout(id, data, event) abort
if a:id != s:jobid
return
endif
for line in a:data
call s:NT.notify(line)
endfor
endfunction
let cmd = ['git', 'tag'] + a:argvs function! s:on_stderr(id, data, event) abort
call git#logger#debug('git-tag cmd:' . string(cmd)) if a:id != s:jobid
let s:jobid = s:JOB.start(cmd, return
\ { endif
\ 'on_stdout' : function('s:on_stdout'), for line in a:data
\ 'on_stderr' : function('s:on_stderr'), call add(s:stderr_data, line)
\ 'on_exit' : function('s:on_exit'), endfor
\ } endfunction
\ )
if s:jobid == -1 function! s:on_exit(id, data, event) abort
call s:NT.notify('`git` is not executable', 'WarningMsg') call git#logger#debug('git-tag exit data:' . string(a:data))
endif if a:id != s:jobid
return
endfunction endif
if a:data ==# 0
function! s:on_stdout(id, data, event) abort for line in s:stderr_data
if a:id != s:jobid
return
endif
for line in a:data
call s:NT.notify(line) call s:NT.notify(line)
endfor endfor
endfunction else
for line in s:stderr_data
function! s:on_stderr(id, data, event) abort call s:NT.notify(line, 'WarningMsg')
if a:id != s:jobid
return
endif
for line in a:data
call add(s:stderr_data, line)
endfor endfor
endfunction endif
let s:jobid = -1
endfunction
function! s:on_exit(id, data, event) abort function! s:options() abort
call git#logger#debug('git-tag exit data:' . string(a:data)) return [
if a:id != s:jobid \ '--list',
return \ ]
endif endfunction
if a:data ==# 0
for line in s:stderr_data
call s:NT.notify(line)
endfor
else
for line in s:stderr_data
call s:NT.notify(line, 'WarningMsg')
endfor
endif
let s:jobid = -1
endfunction
function! s:options() abort function! git#tag#complete(ArgLead, CmdLine, CursorPos) abort
return [ let str = a:CmdLine[:a:CursorPos-1]
\ '--list', if str =~# '^Git\s\+tag\s\+-$'
\ ] return join(s:options(), "\n")
endfunction elseif str =~# '^Git\s\+tag\s\+[^ ]*$'
return join(s:options(), "\n")
else
return ''
endif
function! git#tag#complete(ArgLead, CmdLine, CursorPos) abort endfunction
let str = a:CmdLine[:a:CursorPos-1]
if str =~# '^Git\s\+tag\s\+-$'
return join(s:options(), "\n")
elseif str =~# '^Git\s\+tag\s\+[^ ]*$'
return join(s:options(), "\n")
else
return ''
endif
endfunction
endif

View File

@ -10,12 +10,11 @@ CONTENTS *git-contents*
3. git-checkout............................................ |git-checkout| 3. git-checkout............................................ |git-checkout|
4. git-cherry-pick...................................... |git-cherry-pick| 4. git-cherry-pick...................................... |git-cherry-pick|
5. git-clean.................................................. |git-clean| 5. git-clean.................................................. |git-clean|
6. git-fetch.................................................. |git-fetch| 6. git-mv........................................................ |git-mv|
7. git-mv........................................................ |git-mv| 7. git-reflog................................................ |git-reflog|
8. git-reflog................................................ |git-reflog| 8. git-rm........................................................ |git-rm|
9. git-rm........................................................ |git-rm| 9. git-stash.................................................. |git-stash|
10. git-stash................................................. |git-stash| 10. git-tag..................................................... |git-tag|
11. git-tag..................................................... |git-tag|
3. Functions.................................................. |git-functions| 3. Functions.................................................. |git-functions|
============================================================================== ==============================================================================
@ -71,14 +70,6 @@ This commands is to run `git clean`.
:Git clean -f :Git clean -f
< <
==============================================================================
GIT-FETCH *git-fetch*
This commands is to fetch remote repo.
>
:Git fetch --all
<
============================================================================== ==============================================================================
GIT-MV *git-mv* GIT-MV *git-mv*

View File

@ -1,12 +1,12 @@
--============================================================================= --=============================================================================
-- fetch.lua --- Git fetch -- fetch.lua --- :Git fetch
-- Copyright 2023 Eric Wong -- Copyright (c) 2016-2022 Wang Shidong & Contributors
-- Author: Eric Wong < wsdjeg@outlook.com > -- Author: Wang Shidong < wsdjeg@outlook.com >
-- URL: https://spacevim.org -- URL: https://spacevim.org
-- License: GPLv3 -- License: GPLv3
--============================================================================= --=============================================================================
local M = {} 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')
@ -28,7 +28,7 @@ local function on_std(id, data)
end end
end end
function M.run(argv) function m.run(argv)
local cmd = { 'git', 'fetch' } local cmd = { 'git', 'fetch' }
for _, v in ipairs(argv) do for _, v in ipairs(argv) do
table.insert(cmd, v) table.insert(cmd, v)
@ -38,27 +38,8 @@ function M.run(argv)
job.start(cmd, { job.start(cmd, {
on_exit = on_exit, on_exit = on_exit,
on_stdout = on_std, on_stdout = on_std,
on_stderr = on_std, on_stderr = on_std
}) })
end end
local function get_remotes() return m
return vim.tbl_map(function(t)
return vim.fn.trim(t)
end, vim.fn.systemlist('git remote'))
end
function M.complete(ArgLead, CmdLine, CursorPos)
if vim.startswith(ArgLead, '-') then
return table.concat({ '--all', '--multiple' }, '\n')
end
local str = string.sub(CmdLine, 1, CursorPos)
if vim.regex([[^Git\s\+fetch\s\+[^ ]*$]]):match_str(str) then
return table.concat(get_remotes(), '\n')
else
return ''
end
end
return M

View File

@ -5,7 +5,7 @@
-- URL: https://spacevim.org -- URL: https://spacevim.org
-- License: GPLv3 -- License: GPLv3
--============================================================================= --=============================================================================
local M = {} 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')
@ -23,7 +23,7 @@ local function on_exit(id, code, single)
end end
end end
function M.run(argv) function m.run(argv)
local cmd = { 'git', 'reset' } local cmd = { 'git', 'reset' }
if #argv == 1 and argv[1] == '%' then if #argv == 1 and argv[1] == '%' then
cmd = { 'git', 'reset', 'HEAD', vim.fn.expand('%') } cmd = { 'git', 'reset', 'HEAD', vim.fn.expand('%') }
@ -38,9 +38,4 @@ function M.run(argv)
}) })
end end
function M.complete(ArgLead, CmdLine, CursorPos) return m
local rst = vim.fn.getcompletion(ArgLead, 'file')
return table.concat(rst, '\n')
end
return M

View File

@ -47,9 +47,4 @@ function m.run(argv)
}) })
end end
function M.complete(ArgLead, CmdLine, CursorPos)
local rst = vim.fn.getcompletion(ArgLead, 'file')
return table.concat(rst, '\n')
end
return m return m

View File

@ -97,27 +97,4 @@ function M.run(argv)
end end
end end
local function sub_commands()
return {
'list',
'show',
'drop',
'pop',
'apply',
'branch',
'clear',
'save',
'push',
}
end
function M.complete(ArgLead, CmdLine, CursorPos)
local str = string.sub(CmdLine, 1, CursorPos)
if vim.regex([[^Git\s\+stash\s\+[a-z]\+$]]):match_str(str) then
return table.concat(sub_commands(), '\n')
else
return ''
end
end
return M return M

View File

@ -72,14 +72,7 @@ function M.run(argv)
end end
end end
function M.complete(ArgLead, CmdLine, CursorPos) function M.complete(ArgLead, CmdLine, CursorPos) end
local str = string.sub(CmdLine, 1, CursorPos)
if vim.regex([[^Git\s\+tag\s\+-\+$]]):match_str(str) then
return table.concat({'--list'}, '\n')
else
return ''
end
end
return M return M

View File

@ -8465,6 +8465,10 @@ send email to spacevim@googlegroups.com
To subscribe the maillist, send anything To subscribe the maillist, send anything
tospacevim+subscribe@googlegroups.com tospacevim+subscribe@googlegroups.com
FORUM
Reddit: https://www.reddit.com/r/SpaceVim/
============================================================================== ==============================================================================
FAQ *SpaceVim-faq* FAQ *SpaceVim-faq*

View File

@ -6,6 +6,8 @@ lang: zh
[![twitter](https://img.spacevim.org/twitter.svg)](https://twitter.com/SpaceVim) [![twitter](https://img.spacevim.org/twitter.svg)](https://twitter.com/SpaceVim)
[![GPLv3 License](https://img.spacevim.org/license-GPLv3-blue.svg)](development/#证书) [![GPLv3 License](https://img.spacevim.org/license-GPLv3-blue.svg)](development/#证书)
[![reddit](https://img.spacevim.org/reddit.svg)](https://www.reddit.com/r/SpaceVim/)
-[![matrix](https://img.spacevim.org/spacevim-cn-matrix.svg)](https://app.element.io/#/room/#spacevim-cn:matrix.org)
![work-flow](https://img.spacevim.org/workflow.png) ![work-flow](https://img.spacevim.org/workflow.png)

View File

@ -5,6 +5,8 @@ description: "SpaceVim is a modular Vim/Neovim configuration that seeks to provi
[![twitter](https://img.spacevim.org/twitter.svg)](https://twitter.com/SpaceVim) [![twitter](https://img.spacevim.org/twitter.svg)](https://twitter.com/SpaceVim)
[![GPLv3 License](https://img.spacevim.org/license-GPLv3-blue.svg)](development/#license) [![GPLv3 License](https://img.spacevim.org/license-GPLv3-blue.svg)](development/#license)
[![reddit](https://img.spacevim.org/reddit.svg)](https://www.reddit.com/r/SpaceVim/)
[![matrix](https://img.spacevim.org/spacevim-matrix.svg)](https://app.element.io/#/room/#spacevim:matrix.org)
![work-flow](https://img.spacevim.org/workflow.png) ![work-flow](https://img.spacevim.org/workflow.png)