mirror of
https://github.com/junegunn/vim-plug.git
synced 2025-12-10 02:41:50 +08:00
Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
61b77bc8e8 | ||
|
|
fe7c7e7b40 | ||
|
|
25afdf138c | ||
|
|
b36fd34da0 |
85
plug.vim
85
plug.vim
@@ -73,7 +73,7 @@ let s:plug_buf = -1
|
|||||||
let s:mac_gui = has('gui_macvim') && has('gui_running')
|
let s:mac_gui = has('gui_macvim') && has('gui_running')
|
||||||
let s:is_win = has('win32') || has('win64')
|
let s:is_win = has('win32') || has('win64')
|
||||||
let s:me = expand('<sfile>:p')
|
let s:me = expand('<sfile>:p')
|
||||||
let s:base_spec = { 'branch': 'master', 'frozen': 0, 'local': 0 }
|
let s:base_spec = { 'branch': 'master', 'frozen': 0 }
|
||||||
let s:TYPE = {
|
let s:TYPE = {
|
||||||
\ 'string': type(''),
|
\ 'string': type(''),
|
||||||
\ 'list': type([]),
|
\ 'list': type([]),
|
||||||
@@ -123,7 +123,16 @@ function! s:to_a(v)
|
|||||||
return type(a:v) == s:TYPE.list ? a:v : [a:v]
|
return type(a:v) == s:TYPE.list ? a:v : [a:v]
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
function! s:source(from, ...)
|
||||||
|
for pattern in a:000
|
||||||
|
for vim in split(globpath(a:from, pattern), '\n')
|
||||||
|
execute 'source '.vim
|
||||||
|
endfor
|
||||||
|
endfor
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! plug#end()
|
function! plug#end()
|
||||||
|
let reload = !has('vim_starting')
|
||||||
if !exists('g:plugs')
|
if !exists('g:plugs')
|
||||||
return s:err('Call plug#begin() first')
|
return s:err('Call plug#begin() first')
|
||||||
endif
|
endif
|
||||||
@@ -144,13 +153,16 @@ function! plug#end()
|
|||||||
for name in reverse(copy(g:plugs_order))
|
for name in reverse(copy(g:plugs_order))
|
||||||
let plug = g:plugs[name]
|
let plug = g:plugs[name]
|
||||||
if !has_key(plug, 'on') && !has_key(plug, 'for')
|
if !has_key(plug, 'on') && !has_key(plug, 'for')
|
||||||
call s:add_rtp(s:rtp(plug))
|
let rtp = s:rtp(plug)
|
||||||
|
call s:add_rtp(rtp)
|
||||||
|
if reload
|
||||||
|
call s:source(rtp, 'plugin/**/*.vim', 'after/plugin/**/*.vim')
|
||||||
|
endif
|
||||||
continue
|
continue
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if has_key(plug, 'on')
|
if has_key(plug, 'on')
|
||||||
let commands = s:to_a(plug.on)
|
for cmd in s:to_a(plug.on)
|
||||||
for cmd in commands
|
|
||||||
if cmd =~ '^<Plug>.\+'
|
if cmd =~ '^<Plug>.\+'
|
||||||
if empty(mapcheck(cmd)) && empty(mapcheck(cmd, 'i'))
|
if empty(mapcheck(cmd)) && empty(mapcheck(cmd, 'i'))
|
||||||
for [mode, map_prefix, key_prefix] in
|
for [mode, map_prefix, key_prefix] in
|
||||||
@@ -169,9 +181,7 @@ function! plug#end()
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
if has_key(plug, 'for')
|
if has_key(plug, 'for')
|
||||||
for vim in split(globpath(s:rtp(plug), 'ftdetect/**/*.vim'), '\n')
|
call s:source(s:rtp(plug), 'ftdetect/**/*.vim', 'after/ftdetect/**/*.vim')
|
||||||
execute 'source '.vim
|
|
||||||
endfor
|
|
||||||
for key in s:to_a(plug.for)
|
for key in s:to_a(plug.for)
|
||||||
if !has_key(lod, key)
|
if !has_key(lod, key)
|
||||||
let lod[key] = []
|
let lod[key] = []
|
||||||
@@ -264,24 +274,23 @@ function! s:lod(plug, types)
|
|||||||
let rtp = s:rtp(a:plug)
|
let rtp = s:rtp(a:plug)
|
||||||
call s:add_rtp(rtp)
|
call s:add_rtp(rtp)
|
||||||
for dir in a:types
|
for dir in a:types
|
||||||
for vim in split(globpath(rtp, dir.'/**/*.vim'), '\n')
|
call s:source(rtp, dir.'/**/*.vim')
|
||||||
execute 'source '.vim
|
|
||||||
endfor
|
|
||||||
endfor
|
endfor
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:lod_ft(pat, names)
|
function! s:lod_ft(pat, names)
|
||||||
for name in a:names
|
for name in a:names
|
||||||
call s:lod(g:plugs[name], ['plugin', 'after'])
|
call s:lod(g:plugs[name], ['plugin', 'after/plugin'])
|
||||||
endfor
|
endfor
|
||||||
call s:reorg_rtp()
|
call s:reorg_rtp()
|
||||||
execute 'autocmd! PlugLOD FileType ' . a:pat
|
execute 'autocmd! PlugLOD FileType ' . a:pat
|
||||||
silent! doautocmd filetypeplugin FileType
|
silent! doautocmd filetypeplugin FileType
|
||||||
|
silent! doautocmd filetypeindent FileType
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:lod_cmd(cmd, bang, l1, l2, args, name)
|
function! s:lod_cmd(cmd, bang, l1, l2, args, name)
|
||||||
execute 'delc '.a:cmd
|
execute 'delc '.a:cmd
|
||||||
call s:lod(g:plugs[a:name], ['plugin', 'ftdetect', 'after'])
|
call s:lod(g:plugs[a:name], ['ftdetect', 'after/ftdetect', 'plugin', 'after/plugin'])
|
||||||
call s:reorg_rtp()
|
call s:reorg_rtp()
|
||||||
execute printf('%s%s%s %s', (a:l1 == a:l2 ? '' : (a:l1.','.a:l2)), a:cmd, a:bang, a:args)
|
execute printf('%s%s%s %s', (a:l1 == a:l2 ? '' : (a:l1.','.a:l2)), a:cmd, a:bang, a:args)
|
||||||
endfunction
|
endfunction
|
||||||
@@ -289,7 +298,7 @@ endfunction
|
|||||||
function! s:lod_map(map, name, prefix)
|
function! s:lod_map(map, name, prefix)
|
||||||
execute 'unmap '.a:map
|
execute 'unmap '.a:map
|
||||||
execute 'iunmap '.a:map
|
execute 'iunmap '.a:map
|
||||||
call s:lod(g:plugs[a:name], ['plugin', 'ftdetect', 'after'])
|
call s:lod(g:plugs[a:name], ['ftdetect', 'after/ftdetect', 'plugin', 'after/plugin'])
|
||||||
call s:reorg_rtp()
|
call s:reorg_rtp()
|
||||||
let extra = ''
|
let extra = ''
|
||||||
while 1
|
while 1
|
||||||
@@ -311,7 +320,7 @@ function! s:add(repo, ...)
|
|||||||
let repo = s:trim(a:repo)
|
let repo = s:trim(a:repo)
|
||||||
let name = fnamemodify(repo, ':t:s?\.git$??')
|
let name = fnamemodify(repo, ':t:s?\.git$??')
|
||||||
let spec = extend(s:infer_properties(name, repo),
|
let spec = extend(s:infer_properties(name, repo),
|
||||||
\ a:0 == 1 ? s:parse_options(a:1) : copy(s:base_spec))
|
\ a:0 == 1 ? s:parse_options(a:1) : s:base_spec)
|
||||||
let g:plugs[name] = spec
|
let g:plugs[name] = spec
|
||||||
let g:plugs_order += [name]
|
let g:plugs_order += [name]
|
||||||
catch
|
catch
|
||||||
@@ -341,7 +350,7 @@ endfunction
|
|||||||
function! s:infer_properties(name, repo)
|
function! s:infer_properties(name, repo)
|
||||||
let repo = a:repo
|
let repo = a:repo
|
||||||
if s:is_local_plug(repo)
|
if s:is_local_plug(repo)
|
||||||
let properties = { 'dir': s:dirpath(expand(repo)), 'local': 1 }
|
return { 'dir': s:dirpath(expand(repo)) }
|
||||||
else
|
else
|
||||||
if repo =~ ':'
|
if repo =~ ':'
|
||||||
let uri = repo
|
let uri = repo
|
||||||
@@ -352,9 +361,8 @@ function! s:infer_properties(name, repo)
|
|||||||
let uri = 'https://git:@github.com/' . repo . '.git'
|
let uri = 'https://git:@github.com/' . repo . '.git'
|
||||||
endif
|
endif
|
||||||
let dir = s:dirpath( fnamemodify(join([g:plug_home, a:name], '/'), ':p') )
|
let dir = s:dirpath( fnamemodify(join([g:plug_home, a:name], '/'), ':p') )
|
||||||
let properties = { 'dir': dir, 'uri': uri }
|
return { 'dir': dir, 'uri': uri }
|
||||||
endif
|
endif
|
||||||
return properties
|
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:install(...)
|
function! s:install(...)
|
||||||
@@ -365,16 +373,13 @@ function! s:update(...)
|
|||||||
call s:update_impl(1, a:000)
|
call s:update_impl(1, a:000)
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:apply()
|
function! s:helptags()
|
||||||
for spec in values(g:plugs)
|
for spec in values(g:plugs)
|
||||||
let docd = join([spec.dir, 'doc'], '/')
|
let docd = join([spec.dir, 'doc'], '/')
|
||||||
if isdirectory(docd)
|
if isdirectory(docd)
|
||||||
silent! execute 'helptags '. join([spec.dir, 'doc'], '/')
|
silent! execute 'helptags '. join([spec.dir, 'doc'], '/')
|
||||||
endif
|
endif
|
||||||
endfor
|
endfor
|
||||||
runtime! plugin/*.vim
|
|
||||||
runtime! after/*.vim
|
|
||||||
silent! source $MYVIMRC
|
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:syntax()
|
function! s:syntax()
|
||||||
@@ -505,10 +510,11 @@ endfunction
|
|||||||
function! s:finish(pull)
|
function! s:finish(pull)
|
||||||
call append(3, '- Finishing ... ')
|
call append(3, '- Finishing ... ')
|
||||||
redraw
|
redraw
|
||||||
call s:apply()
|
call s:helptags()
|
||||||
call s:syntax()
|
call plug#end()
|
||||||
call setline(4, getline(4) . 'Done!')
|
call setline(4, getline(4) . 'Done!')
|
||||||
normal! gg
|
normal! gg
|
||||||
|
call s:syntax()
|
||||||
redraw
|
redraw
|
||||||
let msgs = []
|
let msgs = []
|
||||||
if !empty(s:prev_update.errors)
|
if !empty(s:prev_update.errors)
|
||||||
@@ -562,7 +568,6 @@ function! s:update_impl(pull, args) abort
|
|||||||
if !isdirectory(g:plug_home)
|
if !isdirectory(g:plug_home)
|
||||||
call mkdir(g:plug_home, 'p')
|
call mkdir(g:plug_home, 'p')
|
||||||
endif
|
endif
|
||||||
let len = len(g:plugs)
|
|
||||||
let s:prev_update = { 'errors': [], 'pull': a:pull, 'new': {}, 'threads': threads }
|
let s:prev_update = { 'errors': [], 'pull': a:pull, 'new': {}, 'threads': threads }
|
||||||
if has('ruby') && threads > 1
|
if has('ruby') && threads > 1
|
||||||
try
|
try
|
||||||
@@ -594,9 +599,6 @@ function! s:update_impl(pull, args) abort
|
|||||||
call s:update_serial(a:pull, todo)
|
call s:update_serial(a:pull, todo)
|
||||||
endif
|
endif
|
||||||
call s:do(a:pull, filter(copy(todo), 'has_key(v:val, "do")'))
|
call s:do(a:pull, filter(copy(todo), 'has_key(v:val, "do")'))
|
||||||
if len(g:plugs) > len
|
|
||||||
call plug#end()
|
|
||||||
endif
|
|
||||||
call s:finish(a:pull)
|
call s:finish(a:pull)
|
||||||
call setline(1, 'Updated. Elapsed time: ' . split(reltimestr(reltime(st)))[0] . ' sec.')
|
call setline(1, 'Updated. Elapsed time: ' . split(reltimestr(reltime(st)))[0] . ' sec.')
|
||||||
endfunction
|
endfunction
|
||||||
@@ -674,6 +676,20 @@ function! s:update_parallel(pull, todo, threads)
|
|||||||
%["#{arg.gsub('"', '\"')}"]
|
%["#{arg.gsub('"', '\"')}"]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def killall pid
|
||||||
|
pids = [pid]
|
||||||
|
unless `which pgrep`.empty?
|
||||||
|
children = pids
|
||||||
|
until children.empty?
|
||||||
|
children = children.map { |pid|
|
||||||
|
`pgrep -P #{pid}`.lines.map { |l| l.chomp }
|
||||||
|
}.flatten
|
||||||
|
pids += children
|
||||||
|
end
|
||||||
|
end
|
||||||
|
pids.each { |pid| Process.kill 'TERM', pid.to_i rescue nil }
|
||||||
|
end
|
||||||
|
|
||||||
require 'thread'
|
require 'thread'
|
||||||
require 'fileutils'
|
require 'fileutils'
|
||||||
require 'timeout'
|
require 'timeout'
|
||||||
@@ -681,7 +697,7 @@ function! s:update_parallel(pull, todo, threads)
|
|||||||
iswin = VIM::evaluate('s:is_win').to_i == 1
|
iswin = VIM::evaluate('s:is_win').to_i == 1
|
||||||
pull = VIM::evaluate('a:pull').to_i == 1
|
pull = VIM::evaluate('a:pull').to_i == 1
|
||||||
base = VIM::evaluate('g:plug_home')
|
base = VIM::evaluate('g:plug_home')
|
||||||
all = VIM::evaluate('copy(a:todo)')
|
all = VIM::evaluate('a:todo')
|
||||||
limit = VIM::evaluate('get(g:, "plug_timeout", 60)')
|
limit = VIM::evaluate('get(g:, "plug_timeout", 60)')
|
||||||
tries = VIM::evaluate('get(g:, "plug_retries", 2)') + 1
|
tries = VIM::evaluate('get(g:, "plug_retries", 2)') + 1
|
||||||
nthr = VIM::evaluate('a:threads').to_i
|
nthr = VIM::evaluate('a:threads').to_i
|
||||||
@@ -756,17 +772,7 @@ function! s:update_parallel(pull, todo, threads)
|
|||||||
[$? == 0, data.chomp]
|
[$? == 0, data.chomp]
|
||||||
rescue Timeout::Error, Interrupt => e
|
rescue Timeout::Error, Interrupt => e
|
||||||
if fd && !fd.closed?
|
if fd && !fd.closed?
|
||||||
pids = [fd.pid]
|
killall fd.pid
|
||||||
unless `which pgrep`.empty?
|
|
||||||
children = pids
|
|
||||||
until children.empty?
|
|
||||||
children = children.map { |pid|
|
|
||||||
`pgrep -P #{pid}`.lines.map { |l| l.chomp }
|
|
||||||
}.flatten
|
|
||||||
pids += children
|
|
||||||
end
|
|
||||||
end
|
|
||||||
pids.each { |pid| Process.kill 'TERM', pid.to_i rescue nil }
|
|
||||||
fd.close
|
fd.close
|
||||||
end
|
end
|
||||||
if e.is_a?(Timeout::Error) && tried < tries
|
if e.is_a?(Timeout::Error) && tried < tries
|
||||||
@@ -1028,7 +1034,6 @@ endfunction
|
|||||||
function! s:upgrade_specs()
|
function! s:upgrade_specs()
|
||||||
for spec in values(g:plugs)
|
for spec in values(g:plugs)
|
||||||
let spec.frozen = get(spec, 'frozen', 0)
|
let spec.frozen = get(spec, 'frozen', 0)
|
||||||
let spec.local = get(spec, 'local', 0)
|
|
||||||
endfor
|
endfor
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
|||||||
17
test/run
17
test/run
@@ -14,6 +14,23 @@ if [ ! -d fzf-staged ]; then
|
|||||||
git clone https://github.com/junegunn/fzf.git fzf-staged
|
git clone https://github.com/junegunn/fzf.git fzf-staged
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
make_dirs() {
|
||||||
|
mkdir -p "$1"
|
||||||
|
cd "$1"
|
||||||
|
mkdir -p autoload colors ftdetect ftplugin indent plugin syntax
|
||||||
|
for d in *; do
|
||||||
|
cat > $d/xxx.vim << EOF
|
||||||
|
" echom expand('<sfile>')
|
||||||
|
let g:xxx = get(g:, 'xxx', [])
|
||||||
|
call add(g:xxx, '${1:4}/$d')
|
||||||
|
EOF
|
||||||
|
done
|
||||||
|
cd - > /dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
make_dirs xxx/
|
||||||
|
make_dirs xxx/after
|
||||||
|
|
||||||
cat > /tmp/mini-vimrc << VIMRC
|
cat > /tmp/mini-vimrc << VIMRC
|
||||||
set rtp+=vader.vim
|
set rtp+=vader.vim
|
||||||
source $PLUG_SRC
|
source $PLUG_SRC
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
Execute (Initialize test environment):
|
Execute (Initialize test environment):
|
||||||
Save &rtp, g:plugs, g:plug_home, $MYVIMRC
|
Save &rtp, g:plugs, g:plug_home
|
||||||
|
|
||||||
let first_rtp = split(&rtp, ',')[0]
|
let first_rtp = split(&rtp, ',')[0]
|
||||||
let last_rtp = split(&rtp, ',')[-1]
|
let last_rtp = split(&rtp, ',')[-1]
|
||||||
@@ -33,11 +33,6 @@ Execute (Initialize test environment):
|
|||||||
endfunction
|
endfunction
|
||||||
command! -nargs=+ -bang AssertExpect call AssertExpect('<bang>' == '!', <args>)
|
command! -nargs=+ -bang AssertExpect call AssertExpect('<bang>' == '!', <args>)
|
||||||
|
|
||||||
let g:vimrc_reloaded = 0
|
|
||||||
let vimrc = tempname()
|
|
||||||
call writefile(['let g:vimrc_reloaded += 1'], vimrc)
|
|
||||||
let $MYVIMRC = vimrc
|
|
||||||
|
|
||||||
Execute (plug#end() before plug#begin() should fail):
|
Execute (plug#end() before plug#begin() should fail):
|
||||||
redir => out
|
redir => out
|
||||||
AssertEqual 0, plug#end()
|
AssertEqual 0, plug#end()
|
||||||
@@ -133,7 +128,6 @@ Execute (Yet, plugins are not available):
|
|||||||
|
|
||||||
Execute (PlugInstall):
|
Execute (PlugInstall):
|
||||||
PlugInstall
|
PlugInstall
|
||||||
AssertEqual 1, g:vimrc_reloaded
|
|
||||||
q
|
q
|
||||||
|
|
||||||
Execute (Plugin available after installation):
|
Execute (Plugin available after installation):
|
||||||
@@ -167,7 +161,6 @@ Expect:
|
|||||||
Execute (PlugUpdate to set the right branch):
|
Execute (PlugUpdate to set the right branch):
|
||||||
PlugUpdate
|
PlugUpdate
|
||||||
call PlugStatusSorted()
|
call PlugStatusSorted()
|
||||||
AssertEqual 2, g:vimrc_reloaded
|
|
||||||
|
|
||||||
Expect:
|
Expect:
|
||||||
- goyo.vim: OK
|
- goyo.vim: OK
|
||||||
@@ -254,7 +247,6 @@ Execute (PlugClean! to remove vim-emoji):
|
|||||||
Execute (PlugUpdate to install both again):
|
Execute (PlugUpdate to install both again):
|
||||||
PlugUpdate
|
PlugUpdate
|
||||||
AssertExpect '^- [^:]*:', 2
|
AssertExpect '^- [^:]*:', 2
|
||||||
AssertEqual 3, g:vimrc_reloaded
|
|
||||||
Assert !empty(globpath(&rtp, 'colors/seoul256.vim')), 'seoul256.vim should be found'
|
Assert !empty(globpath(&rtp, 'colors/seoul256.vim')), 'seoul256.vim should be found'
|
||||||
Assert !empty(globpath(&rtp, 'autoload/emoji.vim')), 'vim-emoji should be found'
|
Assert !empty(globpath(&rtp, 'autoload/emoji.vim')), 'vim-emoji should be found'
|
||||||
q
|
q
|
||||||
@@ -262,7 +254,6 @@ Execute (PlugUpdate to install both again):
|
|||||||
Execute (PlugUpdate only to find out plugins are up-to-date, D key to check):
|
Execute (PlugUpdate only to find out plugins are up-to-date, D key to check):
|
||||||
PlugUpdate
|
PlugUpdate
|
||||||
AssertExpect 'Already up-to-date', 2
|
AssertExpect 'Already up-to-date', 2
|
||||||
AssertEqual 4, g:vimrc_reloaded
|
|
||||||
normal D
|
normal D
|
||||||
AssertEqual 'No updates.', getline(1)
|
AssertEqual 'No updates.', getline(1)
|
||||||
q
|
q
|
||||||
@@ -384,9 +375,14 @@ Given (Unaligned code):
|
|||||||
aa=2
|
aa=2
|
||||||
|
|
||||||
Execute (Check installed plugins):
|
Execute (Check installed plugins):
|
||||||
|
if has('vim_starting')
|
||||||
|
Log 'Vader is run from commandline'
|
||||||
|
runtime! plugin/**/*.vim
|
||||||
|
endif
|
||||||
Assert exists(':FNR'), 'FNR command should be found'
|
Assert exists(':FNR'), 'FNR command should be found'
|
||||||
Assert exists(':EasyAlign'), 'EasyAlign command should be found'
|
|
||||||
Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
|
Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
|
||||||
|
|
||||||
|
Assert exists(':EasyAlign'), 'EasyAlign command should be found'
|
||||||
%EasyAlign=
|
%EasyAlign=
|
||||||
|
|
||||||
Expect (Aligned code):
|
Expect (Aligned code):
|
||||||
@@ -683,19 +679,64 @@ Execute (Using custom dir):
|
|||||||
q
|
q
|
||||||
Assert isdirectory(g:plugs['vim-easy-align'].dir)
|
Assert isdirectory(g:plugs['vim-easy-align'].dir)
|
||||||
|
|
||||||
Execute (Cleanup):
|
**********************************************************************
|
||||||
call system('rm -rf '.temp_plugged)
|
~ On-demand loading load order
|
||||||
call rename('fzf', 'fzf-staged')
|
**********************************************************************
|
||||||
|
Before (Clear global vars):
|
||||||
|
let g:xxx = []
|
||||||
|
set rtp-=$PWD/xxx/
|
||||||
|
set rtp-=$PWD/xxx/after
|
||||||
|
|
||||||
unlet g:plugs
|
Execute (Immediate loading):
|
||||||
unlet g:plug_home
|
call plug#begin()
|
||||||
unlet g:vimrc_reloaded
|
Plug '$PWD/xxx'
|
||||||
unlet temp_plugged vader plug basertp save_rtp repo lnum fzf out
|
call plug#end()
|
||||||
delf PlugStatusSorted
|
|
||||||
delf AssertExpect
|
" FIXME:
|
||||||
delf PlugUpdated
|
" Different result when Vader is run from commandline with `-c` option
|
||||||
delc AssertExpect
|
Log g:xxx
|
||||||
unmap /
|
if has('vim_starting')
|
||||||
unmap ?
|
AssertEqual ['/ftdetect', 'after/ftdetect'], g:xxx
|
||||||
|
else
|
||||||
|
AssertEqual ['/plugin', 'after/plugin', '/ftdetect', 'after/ftdetect'], g:xxx
|
||||||
|
endif
|
||||||
|
|
||||||
|
Execute (Command-based on-demand loading):
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/xxx', { 'on': 'XXX' }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
AssertEqual [], g:xxx
|
||||||
|
|
||||||
|
silent! XXX
|
||||||
|
AssertEqual ['/ftdetect', 'after/ftdetect', '/plugin', 'after/plugin'], g:xxx
|
||||||
|
|
||||||
|
setf xxx
|
||||||
|
AssertEqual ['/ftdetect', 'after/ftdetect', '/plugin', 'after/plugin', '/ftplugin', 'after/ftplugin', '/indent', 'after/indent', '/syntax', 'after/syntax'], g:xxx
|
||||||
|
|
||||||
|
Execute (Filetype-based on-demand loading):
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/xxx', { 'for': 'xxx' }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
AssertEqual ['/ftdetect', 'after/ftdetect'], g:xxx
|
||||||
|
|
||||||
|
setf xxx
|
||||||
|
AssertEqual ['/ftdetect', 'after/ftdetect', '/plugin', 'after/plugin', '/ftplugin', 'after/ftplugin', '/indent', 'after/indent', '/syntax', 'after/syntax'], g:xxx
|
||||||
|
|
||||||
|
Before:
|
||||||
|
Execute (Cleanup):
|
||||||
|
silent! call system('rm -rf '.temp_plugged)
|
||||||
|
silent! call rename('fzf', 'fzf-staged')
|
||||||
|
silent! unlet g:plugs
|
||||||
|
silent! unlet g:plug_home
|
||||||
|
silent! unlet temp_plugged vader plug basertp save_rtp repo lnum fzf out
|
||||||
|
silent! delf PlugStatusSorted
|
||||||
|
silent! delf AssertExpect
|
||||||
|
silent! delf PlugUpdated
|
||||||
|
silent! delc AssertExpect
|
||||||
|
silent! unmap /
|
||||||
|
silent! unmap ?
|
||||||
|
|
||||||
Restore
|
Restore
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user