mirror of
https://github.com/junegunn/vim-plug.git
synced 2025-12-08 01:44:44 +08:00
Compare commits
78 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
396a534a0a | ||
|
|
a45c3834f8 | ||
|
|
a5c3952380 | ||
|
|
60bda7322f | ||
|
|
05008e7a82 | ||
|
|
2889cb4739 | ||
|
|
61b21068ee | ||
|
|
15da7eb78a | ||
|
|
385a1eb350 | ||
|
|
8c915a5271 | ||
|
|
ee9f0e55b8 | ||
|
|
018adb2aef | ||
|
|
da47e6ee56 | ||
|
|
662274e617 | ||
|
|
4eeff535fa | ||
|
|
c3669836d3 | ||
|
|
eb38fe3d32 | ||
|
|
e7704e6cb3 | ||
|
|
e1e04cabd5 | ||
|
|
afc20ecff3 | ||
|
|
38510a8788 | ||
|
|
a34b06dd54 | ||
|
|
5d910fc9ea | ||
|
|
f31477407a | ||
|
|
0e907d4f38 | ||
|
|
cb08d6036b | ||
|
|
9d63fe6aeb | ||
|
|
0489b5deed | ||
|
|
cac2f9f439 | ||
|
|
115a25de79 | ||
|
|
a64b156682 | ||
|
|
a9fa8f44e5 | ||
|
|
d6590fa883 | ||
|
|
cabaf7b431 | ||
|
|
6e509db6ff | ||
|
|
7b7778d5ba | ||
|
|
f3e2d214df | ||
|
|
5ec1faefab | ||
|
|
6406d73c9a | ||
|
|
ff4cbe23c0 | ||
|
|
681ca2d43a | ||
|
|
adb2413f0d | ||
|
|
dda21b50bf | ||
|
|
537a5321aa | ||
|
|
99f6f36b69 | ||
|
|
3f82808bea | ||
|
|
7474edf13f | ||
|
|
25b0fb7583 | ||
|
|
a868ee4c11 | ||
|
|
49851436ff | ||
|
|
2f9a94e8c0 | ||
|
|
ab3bd3b17c | ||
|
|
3572ffde79 | ||
|
|
18c8b54793 | ||
|
|
1752de5b7c | ||
|
|
2f3225fc60 | ||
|
|
1022acad0b | ||
|
|
68c7fbbf9d | ||
|
|
da24f714e0 | ||
|
|
c1bbbaf3ef | ||
|
|
f7ebba7b9e | ||
|
|
6272f5e289 | ||
|
|
f43067c7a5 | ||
|
|
e6cba28997 | ||
|
|
f1b8832a13 | ||
|
|
d0c94a9b08 | ||
|
|
3a2e406cd0 | ||
|
|
84cdf61730 | ||
|
|
0aeea1db08 | ||
|
|
8289477d18 | ||
|
|
19b12e2216 | ||
|
|
4c9ebe9c31 | ||
|
|
74dcd13575 | ||
|
|
518f20652f | ||
|
|
665ec057d7 | ||
|
|
bc212dca77 | ||
|
|
8da7b50fb2 | ||
|
|
4ae2e879e1 |
@@ -1,4 +1,7 @@
|
|||||||
language: vim
|
language: ruby
|
||||||
|
rvm:
|
||||||
|
- 1.8.7
|
||||||
|
- 2.0.0
|
||||||
|
|
||||||
before_script: |
|
before_script: |
|
||||||
hg clone https://code.google.com/p/vim/
|
hg clone https://code.google.com/p/vim/
|
||||||
|
|||||||
64
README.md
64
README.md
@@ -1,17 +1,18 @@
|
|||||||

|

|
||||||

|
[](https://travis-ci.org/junegunn/vim-plug)
|
||||||
|
|
||||||
A minimalist Vim plugin manager.
|
A minimalist Vim plugin manager.
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Pros.
|
### Pros.
|
||||||
|
|
||||||
- Easier to setup: Single file. No boilerplate code required.
|
- Easier to setup: Single file. No boilerplate code required.
|
||||||
- Easier to use: Concise, intuitive syntax
|
- Easier to use: Concise, intuitive syntax
|
||||||
- [Super-fast](https://raw.github.com/junegunn/i/master/vim-plug/40-in-4.gif)
|
- [Super-fast](https://raw.githubusercontent.com/junegunn/i/master/vim-plug/40-in-4.gif)
|
||||||
parallel installation/update (requires
|
parallel installation/update (requires
|
||||||
[+ruby](https://github.com/junegunn/vim-plug/wiki/ruby))
|
[+ruby](https://github.com/junegunn/vim-plug/wiki/ruby) or
|
||||||
|
[Neovim](http://neovim.org/))
|
||||||
- On-demand loading to achieve
|
- On-demand loading to achieve
|
||||||
[fast startup time](http://junegunn.kr/images/vim-startup-time.png)
|
[fast startup time](http://junegunn.kr/images/vim-startup-time.png)
|
||||||
- Post-update hooks
|
- Post-update hooks
|
||||||
@@ -20,12 +21,13 @@ A minimalist Vim plugin manager.
|
|||||||
|
|
||||||
### Usage
|
### Usage
|
||||||
|
|
||||||
[Download plug.vim](https://raw.github.com/junegunn/vim-plug/master/plug.vim)
|
[Download plug.vim](https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim)
|
||||||
and put it in ~/.vim/autoload
|
and put it in ~/.vim/autoload
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
mkdir -p ~/.vim/autoload
|
mkdir -p ~/.vim/autoload
|
||||||
curl -fLo ~/.vim/autoload/plug.vim https://raw.github.com/junegunn/vim-plug/master/plug.vim
|
curl -fLo ~/.vim/autoload/plug.vim \
|
||||||
|
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
|
||||||
```
|
```
|
||||||
|
|
||||||
Edit your .vimrc
|
Edit your .vimrc
|
||||||
@@ -60,14 +62,15 @@ Reload .vimrc and `:PlugInstall` to install plugins.
|
|||||||
|
|
||||||
### Commands
|
### Commands
|
||||||
|
|
||||||
| Command | Description |
|
| Command | Description |
|
||||||
| --------------------------------- | ------------------------------------------------------------------ |
|
| ----------------------------------- | ------------------------------------------------------------------ |
|
||||||
| PlugInstall [name ...] [#threads] | Install plugins |
|
| `PlugInstall [name ...] [#threads]` | Install plugins |
|
||||||
| PlugUpdate [name ...] [#threads] | Install or update plugins |
|
| `PlugUpdate [name ...] [#threads]` | Install or update plugins |
|
||||||
| PlugClean[!] | Remove unused directories (bang version will clean without prompt) |
|
| `PlugClean[!]` | Remove unused directories (bang version will clean without prompt) |
|
||||||
| PlugUpgrade | Upgrade vim-plug itself |
|
| `PlugUpgrade` | Upgrade vim-plug itself |
|
||||||
| PlugStatus | Check the status of plugins |
|
| `PlugStatus` | Check the status of plugins |
|
||||||
| PlugDiff | See the updated changes from the previous PlugUpdate |
|
| `PlugDiff` | See the updated changes from the previous PlugUpdate |
|
||||||
|
| `PlugSnapshot [output path]` | Generate script for restoring the current snapshot of the plugins |
|
||||||
|
|
||||||
### `Plug` options
|
### `Plug` options
|
||||||
|
|
||||||
@@ -81,20 +84,27 @@ Reload .vimrc and `:PlugInstall` to install plugins.
|
|||||||
| `for` | On-demand loading: File types |
|
| `for` | On-demand loading: File types |
|
||||||
| `frozen` | Do not install/update plugin unless explicitly given as the argument |
|
| `frozen` | Do not install/update plugin unless explicitly given as the argument |
|
||||||
|
|
||||||
### Options for parallel installer
|
### Global options
|
||||||
|
|
||||||
| Flag | Default | Description |
|
| Flag | Default | Description |
|
||||||
| ---------------- | ------- | ------------------------------------ |
|
| ------------------- | --------------------------------- | ----------------------------------------------------------- |
|
||||||
| `g:plug_threads` | 16 | Default number of threads to use |
|
| `g:plug_threads` | 16 | Default number of threads to use |
|
||||||
| `g:plug_timeout` | 60 | Time limit of each task in seconds |
|
| `g:plug_timeout` | 60 | Time limit of each task in seconds (*for Ruby installer*) |
|
||||||
| `g:plug_retries` | 2 | Number of retries in case of timeout |
|
| `g:plug_retries` | 2 | Number of retries in case of timeout (*for Ruby installer*) |
|
||||||
|
| `g:plug_window` | `vertical topleft new` | Command to open plug window |
|
||||||
|
| `g:plug_url_format` | `https://git::@github.com/%s.git` | `printf` format to build repo URL |
|
||||||
|
|
||||||
### Keybindings
|
### Keybindings
|
||||||
|
|
||||||
- `D` - `PlugDiff`
|
- `D` - `PlugDiff`
|
||||||
- `S` - `PlugStatus`
|
- `S` - `PlugStatus`
|
||||||
- `R` - Retry failed update or installation tasks
|
- `R` - Retry failed update or installation tasks
|
||||||
|
- `U` - Update plugins in the selected range
|
||||||
- `q` - Close the window
|
- `q` - Close the window
|
||||||
|
- `:PlugStatus`
|
||||||
|
- `L` - Load plugin
|
||||||
|
- `:PlugDiff`
|
||||||
|
- `X` - Revert the update
|
||||||
|
|
||||||
### Example: A small [sensible](https://github.com/tpope/vim-sensible) Vim configuration
|
### Example: A small [sensible](https://github.com/tpope/vim-sensible) Vim configuration
|
||||||
|
|
||||||
@@ -116,10 +126,17 @@ Plug 'junegunn/vim-github-dashboard', { 'on': ['GHDashboard', 'GHActivity'] }
|
|||||||
" Loaded when clojure file is opened
|
" Loaded when clojure file is opened
|
||||||
Plug 'tpope/vim-fireplace', { 'for': 'clojure' }
|
Plug 'tpope/vim-fireplace', { 'for': 'clojure' }
|
||||||
|
|
||||||
|
" Multiple file types
|
||||||
|
Plug 'kovisoft/paredit', { 'for': ['clojure', 'scheme'] }
|
||||||
|
|
||||||
" On-demand loading on both conditions
|
" On-demand loading on both conditions
|
||||||
Plug 'junegunn/vader.vim', { 'on': 'Vader', 'for': 'vader' }
|
Plug 'junegunn/vader.vim', { 'on': 'Vader', 'for': 'vader' }
|
||||||
```
|
```
|
||||||
|
|
||||||
|
`for` option is generally not needed as most plugins for specific file types
|
||||||
|
usually don't have too much code in `plugin` directory. You might want to
|
||||||
|
examine the output of `vim --startuptime` before applying the option.
|
||||||
|
|
||||||
### Post-update hooks
|
### Post-update hooks
|
||||||
|
|
||||||
There are some plugins that require extra steps after installation or update.
|
There are some plugins that require extra steps after installation or update.
|
||||||
@@ -151,8 +168,9 @@ and only run when the repository has changed, but you can force it to run
|
|||||||
unconditionally with the bang-versions of the commands: `PlugInstall!` and
|
unconditionally with the bang-versions of the commands: `PlugInstall!` and
|
||||||
`PlugUpdate!`.
|
`PlugUpdate!`.
|
||||||
|
|
||||||
Make sure to escape BARs when you write `do` option inline as they are
|
Make sure to escape BARs and double-quotes when you write `do` option inline
|
||||||
mistakenly recognized as command separator for Plug command.
|
as they are mistakenly recognized as command separator or the start of the
|
||||||
|
trailing comment.
|
||||||
|
|
||||||
```vim
|
```vim
|
||||||
Plug 'junegunn/fzf', { 'do': 'yes \| ./install' }
|
Plug 'junegunn/fzf', { 'do': 'yes \| ./install' }
|
||||||
|
|||||||
33
test/run
33
test/run
@@ -15,21 +15,39 @@ if [ ! -d fzf-staged ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
make_dirs() {
|
make_dirs() {
|
||||||
mkdir -p "$1"
|
mkdir -p "temp/$1"
|
||||||
cd "$1"
|
cd "temp/$1"
|
||||||
mkdir -p autoload colors ftdetect ftplugin indent plugin syntax
|
mkdir -p autoload colors ftdetect ftplugin indent plugin syntax
|
||||||
for d in *; do
|
for d in *; do
|
||||||
|
[ -d $d ] || continue
|
||||||
cat > $d/xxx.vim << EOF
|
cat > $d/xxx.vim << EOF
|
||||||
" echom expand('<sfile>')
|
" echom expand('<sfile>')
|
||||||
let g:xxx = get(g:, 'xxx', [])
|
let g:total_order = get(g:, 'total_order', [])
|
||||||
call add(g:xxx, '${1:4}/$d')
|
let g:$2 = get(g:, '$2', [])
|
||||||
|
let s:name = join(filter(['$2', '${1:4}', '$d'], '!empty(v:val)'), '/')
|
||||||
|
call add(g:$2, s:name)
|
||||||
|
call add(g:total_order, s:name)
|
||||||
EOF
|
EOF
|
||||||
done
|
done
|
||||||
cd - > /dev/null
|
cd - > /dev/null
|
||||||
}
|
}
|
||||||
|
|
||||||
make_dirs xxx/
|
init() {
|
||||||
make_dirs xxx/after
|
rm -rf temp/{xxx,yyy,z1,z2}
|
||||||
|
|
||||||
|
make_dirs xxx/ xxx
|
||||||
|
make_dirs xxx/after xxx
|
||||||
|
mkdir -p temp/xxx/doc
|
||||||
|
cat > temp/xxx/doc/xxx.txt << DOC
|
||||||
|
hello *xxx*
|
||||||
|
DOC
|
||||||
|
|
||||||
|
make_dirs yyy/ yyy
|
||||||
|
make_dirs yyy/after yyy
|
||||||
|
|
||||||
|
make_dirs z1/ z1
|
||||||
|
make_dirs z2/ z2
|
||||||
|
}
|
||||||
|
|
||||||
cat > /tmp/mini-vimrc << VIMRC
|
cat > /tmp/mini-vimrc << VIMRC
|
||||||
set rtp+=vader.vim
|
set rtp+=vader.vim
|
||||||
@@ -37,8 +55,11 @@ set shell=/bin/bash
|
|||||||
source $PLUG_SRC
|
source $PLUG_SRC
|
||||||
VIMRC
|
VIMRC
|
||||||
|
|
||||||
|
[ -z "$TMPDIR" ] && export TMPDIR=/tmp/
|
||||||
|
init
|
||||||
if [ "$1" = '!' ]; then
|
if [ "$1" = '!' ]; then
|
||||||
/usr/local/bin/vim -Nu /tmp/mini-vimrc -c 'Vader! workflow.vader' > /dev/null &&
|
/usr/local/bin/vim -Nu /tmp/mini-vimrc -c 'Vader! workflow.vader' > /dev/null &&
|
||||||
|
init &&
|
||||||
/usr/local/bin/vim -Nu /tmp/mini-vimrc -c 'let g:plug_threads = 1 | Vader! workflow.vader' > /dev/null
|
/usr/local/bin/vim -Nu /tmp/mini-vimrc -c 'let g:plug_threads = 1 | Vader! workflow.vader' > /dev/null
|
||||||
else
|
else
|
||||||
/usr/local/bin/vim -Nu /tmp/mini-vimrc -c 'Vader workflow.vader'
|
/usr/local/bin/vim -Nu /tmp/mini-vimrc -c 'Vader workflow.vader'
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
Execute (Initialize test environment):
|
Execute (Initialize test environment):
|
||||||
Save &rtp, g:plugs, g:plug_home
|
Save &rtp, g:plugs, g:plug_home, g:plug_window
|
||||||
|
|
||||||
let first_rtp = split(&rtp, ',')[0]
|
let first_rtp = split(&rtp, ',')[0]
|
||||||
let last_rtp = split(&rtp, ',')[-1]
|
let last_rtp = split(&rtp, ',')[-1]
|
||||||
@@ -11,8 +11,7 @@ Execute (Initialize test environment):
|
|||||||
execute 'set rtp^='.plug
|
execute 'set rtp^='.plug
|
||||||
let basertp = &rtp
|
let basertp = &rtp
|
||||||
|
|
||||||
unlet! g:plugs
|
unlet! g:plugs g:plug_home g:plug_window
|
||||||
unlet! g:plug_home
|
|
||||||
|
|
||||||
set t_Co=256
|
set t_Co=256
|
||||||
colo default
|
colo default
|
||||||
@@ -28,11 +27,23 @@ Execute (Initialize test environment):
|
|||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! AssertExpect(bang, pat, cnt)
|
function! AssertExpect(bang, pat, cnt)
|
||||||
let op = a:bang ? '==' : '=~'
|
let op = a:bang ? '==#' : '=~#'
|
||||||
AssertEqual a:cnt, len(filter(getline(1, '$'), "v:val ".op." '".a:pat."'"))
|
AssertEqual a:cnt, len(filter(getline(1, '$'), "v:val ".op." '".a:pat."'"))
|
||||||
endfunction
|
endfunction
|
||||||
command! -nargs=+ -bang AssertExpect call AssertExpect('<bang>' == '!', <args>)
|
command! -nargs=+ -bang AssertExpect call AssertExpect('<bang>' == '!', <args>)
|
||||||
|
|
||||||
|
function! EnsureLoaded()
|
||||||
|
if has('vim_starting')
|
||||||
|
runtime! plugin/**/*.vim
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
Execute (Print Ruby version):
|
||||||
|
redir => out
|
||||||
|
silent ruby puts RUBY_VERSION
|
||||||
|
redir END
|
||||||
|
Log substitute(out, '\n', '', 'g')
|
||||||
|
|
||||||
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()
|
||||||
@@ -69,7 +80,7 @@ Execute (Subsequent plug#begin() calls will reuse g:plug_home):
|
|||||||
Execute (Test Plug command):
|
Execute (Test Plug command):
|
||||||
" Git repo with branch
|
" Git repo with branch
|
||||||
Plug 'junegunn/seoul256.vim', 'yes-t_co'
|
Plug 'junegunn/seoul256.vim', 'yes-t_co'
|
||||||
AssertEqual 'https://git:@github.com/junegunn/seoul256.vim.git', g:plugs['seoul256.vim'].uri
|
AssertEqual 'https://git::@github.com/junegunn/seoul256.vim.git', g:plugs['seoul256.vim'].uri
|
||||||
AssertEqual join([temp_plugged, 'seoul256.vim/'], '/'), g:plugs['seoul256.vim'].dir
|
AssertEqual join([temp_plugged, 'seoul256.vim/'], '/'), g:plugs['seoul256.vim'].dir
|
||||||
AssertEqual 'yes-t_co', g:plugs['seoul256.vim'].branch
|
AssertEqual 'yes-t_co', g:plugs['seoul256.vim'].branch
|
||||||
|
|
||||||
@@ -78,7 +89,7 @@ Execute (Test Plug command):
|
|||||||
|
|
||||||
" Git repo with tag
|
" Git repo with tag
|
||||||
Plug 'junegunn/goyo.vim', '1.5.2'
|
Plug 'junegunn/goyo.vim', '1.5.2'
|
||||||
AssertEqual 'https://git:@github.com/junegunn/goyo.vim.git', g:plugs['goyo.vim'].uri
|
AssertEqual 'https://git::@github.com/junegunn/goyo.vim.git', g:plugs['goyo.vim'].uri
|
||||||
AssertEqual join([temp_plugged, 'goyo.vim/'], '/'), g:plugs['goyo.vim'].dir
|
AssertEqual join([temp_plugged, 'goyo.vim/'], '/'), g:plugs['goyo.vim'].dir
|
||||||
AssertEqual '1.5.2', g:plugs['goyo.vim'].branch
|
AssertEqual '1.5.2', g:plugs['goyo.vim'].branch
|
||||||
|
|
||||||
@@ -93,7 +104,7 @@ Execute (Test Plug command):
|
|||||||
|
|
||||||
" vim-scripts/
|
" vim-scripts/
|
||||||
Plug 'beauty256'
|
Plug 'beauty256'
|
||||||
AssertEqual 'https://git:@github.com/vim-scripts/beauty256.git', g:plugs.beauty256.uri
|
AssertEqual 'https://git::@github.com/vim-scripts/beauty256.git', g:plugs.beauty256.uri
|
||||||
AssertEqual 'master', g:plugs.beauty256.branch
|
AssertEqual 'master', g:plugs.beauty256.branch
|
||||||
|
|
||||||
AssertEqual 4, len(g:plugs)
|
AssertEqual 4, len(g:plugs)
|
||||||
@@ -193,8 +204,8 @@ Execute (PlugStatus):
|
|||||||
call PlugStatusSorted()
|
call PlugStatusSorted()
|
||||||
|
|
||||||
Expect:
|
Expect:
|
||||||
Expected: https://git:@github.com/junegunn.choi/seoul256.vim.git
|
Expected: https://git::@github.com/junegunn.choi/seoul256.vim.git
|
||||||
Invalid URI: https://git:@github.com/junegunn/seoul256.vim.git
|
Invalid URI: https://git::@github.com/junegunn/seoul256.vim.git
|
||||||
PlugClean required.
|
PlugClean required.
|
||||||
- vim-emoji: OK
|
- vim-emoji: OK
|
||||||
Finished. 1 error(s).
|
Finished. 1 error(s).
|
||||||
@@ -227,7 +238,7 @@ Execute (PlugStatus):
|
|||||||
call PlugStatusSorted()
|
call PlugStatusSorted()
|
||||||
|
|
||||||
Expect:
|
Expect:
|
||||||
Expected: https://git:@github.com/junegunn/vim-emoji.git
|
Expected: https://git::@github.com/junegunn/vim-emoji.git
|
||||||
Invalid URI: https://bitbucket.org/junegunn/vim-emoji.git
|
Invalid URI: https://bitbucket.org/junegunn/vim-emoji.git
|
||||||
Not found. Try PlugInstall.
|
Not found. Try PlugInstall.
|
||||||
PlugClean required.
|
PlugClean required.
|
||||||
@@ -301,6 +312,13 @@ Execute (Rollback recent updates, PlugUpdate, then PlugDiff):
|
|||||||
AssertEqual lnum, line('.')
|
AssertEqual lnum, line('.')
|
||||||
AssertEqual 3, col('.')
|
AssertEqual 3, col('.')
|
||||||
|
|
||||||
|
" X key to revert the update
|
||||||
|
AssertExpect '^- ', 2
|
||||||
|
execute "normal Xn\<cr>"
|
||||||
|
AssertExpect '^- ', 2
|
||||||
|
execute "normal Xy\<cr>"
|
||||||
|
AssertExpect '^- ', 1
|
||||||
|
|
||||||
" q will close preview window as well
|
" q will close preview window as well
|
||||||
normal q
|
normal q
|
||||||
|
|
||||||
@@ -311,6 +329,7 @@ Execute (Rollback recent updates, PlugUpdate, then PlugDiff):
|
|||||||
" q should not close preview window if it's already open
|
" q should not close preview window if it's already open
|
||||||
pedit
|
pedit
|
||||||
PlugDiff
|
PlugDiff
|
||||||
|
AssertExpect '^- ', 1
|
||||||
execute "normal ]]j\<cr>"
|
execute "normal ]]j\<cr>"
|
||||||
normal q
|
normal q
|
||||||
|
|
||||||
@@ -318,16 +337,17 @@ Execute (Rollback recent updates, PlugUpdate, then PlugDiff):
|
|||||||
AssertEqual 1, &previewwindow
|
AssertEqual 1, &previewwindow
|
||||||
pclose
|
pclose
|
||||||
|
|
||||||
Execute (Plug window in a new tab):
|
Execute (Reuse Plug window in another tab):
|
||||||
|
let tabnr = tabpagenr()
|
||||||
PlugDiff
|
PlugDiff
|
||||||
tab new new-tab
|
tab new new-tab
|
||||||
set buftype=nofile
|
set buftype=nofile
|
||||||
PlugUpdate
|
PlugUpdate
|
||||||
normal D
|
normal D
|
||||||
AssertEqual 'No updates.', getline(1)
|
AssertExpect '^- ', 1
|
||||||
q
|
normal q
|
||||||
AssertEqual 'new-tab', expand('%')
|
AssertEqual tabnr, tabpagenr()
|
||||||
q
|
normal! gt
|
||||||
q
|
q
|
||||||
|
|
||||||
**********************************************************************
|
**********************************************************************
|
||||||
@@ -375,10 +395,7 @@ Given (Unaligned code):
|
|||||||
aa=2
|
aa=2
|
||||||
|
|
||||||
Execute (Check installed plugins):
|
Execute (Check installed plugins):
|
||||||
if has('vim_starting')
|
call EnsureLoaded()
|
||||||
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(':RedisExecute'), 'RedisExecute command still should not be found'
|
Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
|
||||||
|
|
||||||
@@ -506,15 +523,15 @@ Execute (Frozen plugin are not installed nor updated):
|
|||||||
Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
|
Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
|
||||||
call plug#end()
|
call plug#end()
|
||||||
|
|
||||||
redir => output
|
redir => out
|
||||||
silent PlugInstall
|
silent PlugInstall
|
||||||
redir END
|
redir END
|
||||||
Assert output =~ 'No plugin to install'
|
Assert out =~ 'No plugin to install'
|
||||||
|
|
||||||
redir => output
|
redir => out
|
||||||
silent PlugUpdate
|
silent PlugUpdate
|
||||||
redir END
|
redir END
|
||||||
Assert output =~ 'No plugin to update'
|
Assert out =~ 'No plugin to update'
|
||||||
|
|
||||||
Execute (But you can still install it if the name is given as the argument):
|
Execute (But you can still install it if the name is given as the argument):
|
||||||
PlugInstall vim-easy-align
|
PlugInstall vim-easy-align
|
||||||
@@ -715,56 +732,330 @@ Execute (Using custom dir):
|
|||||||
**********************************************************************
|
**********************************************************************
|
||||||
Before (Clear global vars):
|
Before (Clear global vars):
|
||||||
let g:xxx = []
|
let g:xxx = []
|
||||||
set rtp-=$PWD/xxx/
|
set rtp-=$PWD/temp/xxx/
|
||||||
set rtp-=$PWD/xxx/after
|
set rtp-=$PWD/temp/xxx/after
|
||||||
|
|
||||||
Execute (Immediate loading):
|
Execute (Immediate loading):
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
Plug '$PWD/xxx'
|
Plug '$PWD/temp/xxx'
|
||||||
call plug#end()
|
call plug#end()
|
||||||
|
|
||||||
" FIXME:
|
" FIXME:
|
||||||
" Different result when Vader is run from commandline with `-c` option
|
" Different result when Vader is run from commandline with `-c` option
|
||||||
Log g:xxx
|
Log g:xxx
|
||||||
if has('vim_starting')
|
if has('vim_starting')
|
||||||
AssertEqual ['/ftdetect', 'after/ftdetect'], g:xxx
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
|
||||||
else
|
else
|
||||||
AssertEqual ['/plugin', 'after/plugin', '/ftdetect', 'after/ftdetect'], g:xxx
|
AssertEqual ['xxx/plugin', 'xxx/after/plugin', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
|
||||||
endif
|
endif
|
||||||
|
|
||||||
Execute (Command-based on-demand loading):
|
Execute (Command-based on-demand loading):
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
Plug '$PWD/xxx', { 'on': 'XXX' }
|
Plug '$PWD/temp/xxx', { 'on': 'XXX' }
|
||||||
call plug#end()
|
call plug#end()
|
||||||
|
|
||||||
AssertEqual [], g:xxx
|
AssertEqual [], g:xxx
|
||||||
|
|
||||||
silent! XXX
|
silent! XXX
|
||||||
AssertEqual ['/ftdetect', 'after/ftdetect', '/plugin', 'after/plugin'], g:xxx
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin'], g:xxx
|
||||||
|
|
||||||
setf xxx
|
setf xxx
|
||||||
AssertEqual ['/ftdetect', 'after/ftdetect', '/plugin', 'after/plugin', '/ftplugin', 'after/ftplugin', '/indent', 'after/indent', '/syntax', 'after/syntax'], g:xxx
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin', 'xxx/ftplugin', 'xxx/after/ftplugin', 'xxx/indent', 'xxx/after/indent', 'xxx/syntax', 'xxx/after/syntax'], g:xxx
|
||||||
|
|
||||||
Execute (Filetype-based on-demand loading):
|
Execute (Filetype-based on-demand loading):
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
Plug '$PWD/xxx', { 'for': 'xxx' }
|
Plug '$PWD/temp/xxx', { 'for': 'xxx' }
|
||||||
call plug#end()
|
call plug#end()
|
||||||
|
|
||||||
AssertEqual ['/ftdetect', 'after/ftdetect'], g:xxx
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
|
||||||
|
|
||||||
setf xxx
|
setf xxx
|
||||||
AssertEqual ['/ftdetect', 'after/ftdetect', '/plugin', 'after/plugin', '/ftplugin', 'after/ftplugin', '/indent', 'after/indent', '/syntax', 'after/syntax'], g:xxx
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin', 'xxx/ftplugin', 'xxx/after/ftplugin', 'xxx/indent', 'xxx/after/indent', 'xxx/syntax', 'xxx/after/syntax'], g:xxx
|
||||||
|
|
||||||
Before:
|
Before:
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
~ plug#helptags()
|
||||||
|
**********************************************************************
|
||||||
|
|
||||||
|
Execute (plug#helptags):
|
||||||
|
silent! call delete(expand('$PWD/temp/xxx/doc/tags'))
|
||||||
|
Assert !filereadable(expand('$PWD/temp/xxx/doc/tags'))
|
||||||
|
AssertEqual 1, plug#helptags()
|
||||||
|
Assert filereadable(expand('$PWD/temp/xxx/doc/tags'))
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
~ Manual loading
|
||||||
|
**********************************************************************
|
||||||
|
|
||||||
|
Execute (plug#load - invalid arguments):
|
||||||
|
AssertEqual 0, plug#load()
|
||||||
|
AssertEqual 0, plug#load('non-existent-plugin')
|
||||||
|
AssertEqual 0, plug#load('non-existent-plugin', 'another-non-existent-plugin')
|
||||||
|
AssertEqual 1, plug#load('xxx')
|
||||||
|
AssertEqual 0, plug#load('xxx', 'non-existent-plugin')
|
||||||
|
AssertEqual 0, plug#load('non-existent-plugin', 'xxx')
|
||||||
|
|
||||||
|
Execute (on: []):
|
||||||
|
call plug#begin()
|
||||||
|
Plug 'junegunn/rust.vim', { 'on': [] }
|
||||||
|
call plug#end()
|
||||||
|
PlugInstall
|
||||||
|
q
|
||||||
|
|
||||||
|
Execute (PlugStatus reports (not loaded)):
|
||||||
|
PlugStatus
|
||||||
|
AssertExpect 'not loaded', 1
|
||||||
|
q
|
||||||
|
|
||||||
|
Execute (plug#load to load it):
|
||||||
|
tabnew test.rs
|
||||||
|
" Vader will switch tab to [Vader-workbench] after Log
|
||||||
|
" Log &filetype
|
||||||
|
AssertEqual 1, plug#load('rust.vim')
|
||||||
|
AssertEqual 'rust', &filetype
|
||||||
|
q
|
||||||
|
|
||||||
|
Execute (PlugStatus should not contain (not loaded)):
|
||||||
|
PlugStatus
|
||||||
|
AssertExpect 'not loaded', 0
|
||||||
|
q
|
||||||
|
|
||||||
|
Execute (Load plugin from PlugStatus screen with L key in normal mode):
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/temp/yyy', { 'on': [] }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
PlugStatus
|
||||||
|
AssertExpect 'not loaded', 1
|
||||||
|
Assert !exists('g:yyy'), 'yyy not loaded'
|
||||||
|
/not loaded
|
||||||
|
normal L
|
||||||
|
AssertExpect 'not loaded', 0
|
||||||
|
Assert exists('g:yyy'), 'yyy loaded'
|
||||||
|
q
|
||||||
|
|
||||||
|
Execute (Load plugin from PlugStatus screen with L key in visual mode):
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/temp/z1', { 'on': [] }
|
||||||
|
Plug '$PWD/temp/z2', { 'for': [] }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
PlugStatus
|
||||||
|
AssertExpect 'not loaded', 2
|
||||||
|
Assert !exists('g:z1'), 'z1 not loaded'
|
||||||
|
Assert !exists('g:z2'), 'z2 not loaded'
|
||||||
|
normal ggVGL
|
||||||
|
AssertExpect 'not loaded', 0
|
||||||
|
Assert exists('g:z1'), 'z1 loaded'
|
||||||
|
Assert exists('g:z2'), 'z2 loaded'
|
||||||
|
q
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
~ g:plug_window
|
||||||
|
**********************************************************************
|
||||||
|
Execute (Open plug window in a new tab):
|
||||||
|
" Without g:plug_window, plug window is open on the left split
|
||||||
|
let tabnr = tabpagenr()
|
||||||
|
PlugStatus
|
||||||
|
AssertEqual tabnr, tabpagenr()
|
||||||
|
AssertEqual 1, winnr()
|
||||||
|
|
||||||
|
" PlugStatus again inside the window should not change the view
|
||||||
|
normal S
|
||||||
|
AssertEqual tabnr, tabpagenr()
|
||||||
|
AssertEqual 1, winnr()
|
||||||
|
q
|
||||||
|
|
||||||
|
" Define g:plug_window so that plug window is open in a new tab
|
||||||
|
let g:plug_window = 'tabnew'
|
||||||
|
PlugStatus
|
||||||
|
AssertNotEqual tabnr, tabpagenr()
|
||||||
|
|
||||||
|
" PlugStatus again inside the window should not change the view
|
||||||
|
let tabnr = tabpagenr()
|
||||||
|
normal S
|
||||||
|
AssertEqual tabnr, tabpagenr()
|
||||||
|
q
|
||||||
|
unlet g:plug_window
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
~ g:plug_url_format
|
||||||
|
**********************************************************************
|
||||||
|
Execute (Using g:plug_url_format):
|
||||||
|
call plug#begin()
|
||||||
|
let g:plug_url_format = 'git@bitbucket.org:%s.git'
|
||||||
|
Plug 'junegunn/seoul256.vim'
|
||||||
|
let g:plug_url_format = 'git@bitsocket.org:%s.git'
|
||||||
|
Plug 'beauty256'
|
||||||
|
AssertEqual 'git@bitbucket.org:junegunn/seoul256.vim.git', g:plugs['seoul256.vim'].uri
|
||||||
|
AssertEqual 'git@bitsocket.org:vim-scripts/beauty256.git', g:plugs['beauty256'].uri
|
||||||
|
unlet g:plug_url_format
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
~ U
|
||||||
|
**********************************************************************
|
||||||
|
Execute (Plug block):
|
||||||
|
call plug#begin()
|
||||||
|
Plug 'junegunn/vim-easy-align'
|
||||||
|
Plug 'junegunn/vim-emoji'
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
Execute (Update plugin with U key in normal mode):
|
||||||
|
PlugStatus
|
||||||
|
/emoji
|
||||||
|
normal U
|
||||||
|
Log getline(1, '$')
|
||||||
|
AssertExpect 'Updated', 1
|
||||||
|
AssertExpect 'vim-emoji', 1
|
||||||
|
AssertExpect 'vim-easy-align', 0
|
||||||
|
AssertExpect! '[=]', 1
|
||||||
|
|
||||||
|
" From PlugInstall screen
|
||||||
|
PlugInstall
|
||||||
|
/easy-align
|
||||||
|
normal U
|
||||||
|
AssertExpect 'Updated', 1
|
||||||
|
AssertExpect 'vim-emoji', 0
|
||||||
|
AssertExpect 'vim-easy-align', 1
|
||||||
|
AssertExpect! '[=]', 1
|
||||||
|
q
|
||||||
|
|
||||||
|
Execute (Update plugins with U key in visual mode):
|
||||||
|
silent! call system('rm -rf '.g:plugs['vim-easy-align'].dir)
|
||||||
|
|
||||||
|
PlugStatus
|
||||||
|
normal VGU
|
||||||
|
Log getline(1, '$')
|
||||||
|
AssertExpect 'Updated', 1
|
||||||
|
AssertExpect 'vim-emoji', 1
|
||||||
|
AssertExpect 'vim-easy-align', 1
|
||||||
|
AssertExpect! '[==]', 1
|
||||||
|
|
||||||
|
" From PlugUpdate screen
|
||||||
|
normal VGU
|
||||||
|
Log getline(1, '$')
|
||||||
|
AssertExpect 'Updated', 1
|
||||||
|
AssertExpect 'vim-emoji', 1
|
||||||
|
AssertExpect 'vim-easy-align', 1
|
||||||
|
AssertExpect! '[==]', 1
|
||||||
|
q
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (plug#begin should expand env vars):
|
||||||
|
AssertNotEqual '$HOME/.emacs/plugged', expand('$HOME/.emacs/plugged')
|
||||||
|
call plug#begin('$HOME/.emacs/plugged')
|
||||||
|
AssertEqual expand('$HOME/.emacs/plugged'), g:plug_home
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (Plug directory with comma):
|
||||||
|
call plug#begin(temp_plugged . '/p,l,u,g,g,e,d')
|
||||||
|
Plug 'junegunn/vim-emoji'
|
||||||
|
call plug#end()
|
||||||
|
Log &rtp
|
||||||
|
|
||||||
|
PlugInstall
|
||||||
|
q
|
||||||
|
let found = filter(split(globpath(&rtp, 'README.md'), '\n'), 'v:val =~ ","')
|
||||||
|
Log found
|
||||||
|
AssertEqual 1, len(found)
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (Strict load order):
|
||||||
|
let g:total_order = []
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/temp/xxx'
|
||||||
|
Plug '$PWD/temp/yyy', { 'for': ['xxx'] }
|
||||||
|
call plug#end()
|
||||||
|
call EnsureLoaded()
|
||||||
|
setf xxx
|
||||||
|
Log 'Case 1: ' . &rtp
|
||||||
|
AssertEqual ['yyy/ftdetect', 'yyy/after/ftdetect', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:total_order[0:3]
|
||||||
|
Assert index(g:total_order, 'xxx/plugin') < index(g:total_order, 'yyy/plugin')
|
||||||
|
Assert index(g:total_order, 'xxx/after/plugin') < index(g:total_order, 'yyy/after/plugin')
|
||||||
|
let len = len(split(&rtp, ','))
|
||||||
|
|
||||||
|
let g:total_order = []
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/temp/xxx', { 'for': ['xxx'] }
|
||||||
|
Plug '$PWD/temp/yyy'
|
||||||
|
call plug#end()
|
||||||
|
call EnsureLoaded()
|
||||||
|
set rtp^=manually-prepended
|
||||||
|
set rtp+=manually-appended
|
||||||
|
setf xxx
|
||||||
|
Log 'Case 2: ' . &rtp
|
||||||
|
AssertEqual 'manually-prepended', split(&rtp, ',')[3]
|
||||||
|
AssertEqual 'manually-appended', split(&rtp, ',')[-4]
|
||||||
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'yyy/ftdetect', 'yyy/after/ftdetect'], g:total_order[0:3]
|
||||||
|
Assert index(g:total_order, 'yyy/plugin') < index(g:total_order, 'xxx/plugin')
|
||||||
|
Assert index(g:total_order, 'yyy/after/plugin') < index(g:total_order, 'xxx/after/plugin')
|
||||||
|
AssertEqual len + 2, len(split(&rtp, ','))
|
||||||
|
|
||||||
|
let g:total_order = []
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PWD/temp/xxx', { 'for': ['xxx'] }
|
||||||
|
Plug '$PWD/temp/yyy', { 'for': ['xxx'] }
|
||||||
|
call plug#end()
|
||||||
|
call EnsureLoaded()
|
||||||
|
setf xxx
|
||||||
|
Log 'Case 3: ' . &rtp
|
||||||
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'yyy/ftdetect', 'yyy/after/ftdetect'], g:total_order[0:3]
|
||||||
|
Assert index(g:total_order, 'xxx/plugin') < index(g:total_order, 'yyy/plugin')
|
||||||
|
Assert index(g:total_order, 'xxx/after/plugin') < index(g:total_order, 'yyy/after/plugin')
|
||||||
|
AssertEqual len + 2, len(split(&rtp, ','))
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (PlugClean should not try to remove unmanaged plugins inside g:plug_home):
|
||||||
|
call plug#begin('$PWD/temp')
|
||||||
|
Plug '$PWD/temp/xxx'
|
||||||
|
Plug '$PWD/temp/yyy'
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
" Remove z1, z2
|
||||||
|
PlugClean!
|
||||||
|
AssertExpect '^- ', 2
|
||||||
|
AssertExpect 'Already clean', 0
|
||||||
|
|
||||||
|
PlugClean!
|
||||||
|
AssertExpect '^- ', 0
|
||||||
|
AssertExpect 'Already clean', 1
|
||||||
|
q
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (PlugSnapshot):
|
||||||
|
call plug#begin('$TMPDIR/plugged')
|
||||||
|
Plug 'junegunn/vim-emoji'
|
||||||
|
Plug 'junegunn/seoul256.vim'
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
PlugInstall
|
||||||
|
PlugSnapshot
|
||||||
|
AssertEqual '#!/bin/bash', getline(1)
|
||||||
|
AssertEqual '# Generated by vim-plug', getline(2)
|
||||||
|
AssertEqual 'vim +PlugUpdate +qa', getline(5)
|
||||||
|
AssertEqual 'PLUG_HOME=$TMPDIR/plugged', getline(7)
|
||||||
|
AssertEqual 0, stridx(getline(9), 'cd $PLUG_HOME/seoul256.vim/ && git reset --hard')
|
||||||
|
AssertEqual 0, stridx(getline(10), 'cd $PLUG_HOME/vim-emoji/ && git reset --hard')
|
||||||
|
AssertEqual 'sh', &filetype
|
||||||
|
|
||||||
|
execute 'PlugSnapshot' g:plug_home.'/snapshot.sh'
|
||||||
|
AssertEqual 'sh', &filetype
|
||||||
|
AssertEqual 'snapshot.sh', fnamemodify(expand('%'), ':t')
|
||||||
|
q
|
||||||
|
|
||||||
Execute (Cleanup):
|
Execute (Cleanup):
|
||||||
|
silent! call system('rm -rf '.temp_plugged)
|
||||||
silent! call system('rm -rf '.temp_plugged)
|
silent! call system('rm -rf '.temp_plugged)
|
||||||
silent! call rename('fzf', 'fzf-staged')
|
silent! call rename('fzf', 'fzf-staged')
|
||||||
silent! unlet g:plugs
|
silent! unlet g:plugs
|
||||||
silent! unlet g:plug_home
|
silent! unlet g:plug_home
|
||||||
silent! unlet temp_plugged vader plug basertp save_rtp repo lnum fzf out
|
silent! unlet g:plug_url_format
|
||||||
|
silent! unlet temp_plugged vader plug basertp save_rtp repo lnum fzf out tabnr found len
|
||||||
silent! delf PlugStatusSorted
|
silent! delf PlugStatusSorted
|
||||||
silent! delf AssertExpect
|
silent! delf AssertExpect
|
||||||
silent! delf PlugUpdated
|
silent! delf PlugUpdated
|
||||||
|
silent! delf EnsureLoaded
|
||||||
silent! delc AssertExpect
|
silent! delc AssertExpect
|
||||||
silent! unmap /
|
silent! unmap /
|
||||||
silent! unmap ?
|
silent! unmap ?
|
||||||
|
|||||||
Reference in New Issue
Block a user