mirror of
https://github.com/junegunn/vim-plug.git
synced 2025-12-08 18:04:46 +08:00
Compare commits
111 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3606c294de | ||
|
|
06f903d8af | ||
|
|
1f704deb76 | ||
|
|
3ebf6361bf | ||
|
|
9b99c1f885 | ||
|
|
53cc8a53d9 | ||
|
|
2ee153d610 | ||
|
|
7019171737 | ||
|
|
044c3a67c4 | ||
|
|
48514768c2 | ||
|
|
68ad02c5c3 | ||
|
|
12bc2ea1da | ||
|
|
ade7fb95b1 | ||
|
|
9c55223869 | ||
|
|
495becf442 | ||
|
|
425ef39db2 | ||
|
|
bd2cb9d2de | ||
|
|
0263370bd1 | ||
|
|
4b3fbd1592 | ||
|
|
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 | ||
|
|
93628b1c3d | ||
|
|
01e126469b | ||
|
|
a7477f04b7 | ||
|
|
0fdb56ba72 | ||
|
|
d89949f16c | ||
|
|
19b8221c14 | ||
|
|
336fadd236 | ||
|
|
a216e38a59 | ||
|
|
d930594686 | ||
|
|
f4261711ae | ||
|
|
61b77bc8e8 | ||
|
|
fe7c7e7b40 | ||
|
|
25afdf138c | ||
|
|
b36fd34da0 |
@@ -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/
|
||||||
|
|||||||
190
README.md
190
README.md
@@ -1,34 +1,33 @@
|
|||||||

|
<img src="https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.png" height="56" alt="vim-plug">
|
||||||

|
[](https://travis-ci.org/junegunn/vim-plug)
|
||||||
|
|
||||||
A single-file Vim plugin manager.
|
A minimalist Vim plugin manager.
|
||||||
|
|
||||||
Somewhere between [Pathogen](https://github.com/tpope/vim-pathogen) and
|
<img src="https://raw.githubusercontent.com/junegunn/i/master/vim-plug/installer.gif" height="450">
|
||||||
[Vundle](https://github.com/gmarik/vundle), but with faster parallel installer.
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
### Pros.
|
### Pros.
|
||||||
|
|
||||||
- Easier to setup
|
- Easier to setup: Single file. No boilerplate code required.
|
||||||
- Parallel installation/update (requires
|
- Easier to use: Concise, intuitive syntax
|
||||||
[+ruby](http://junegunn.kr/2013/09/installing-vim-with-ruby-support/))
|
- [Super-fast](https://raw.githubusercontent.com/junegunn/i/master/vim-plug/40-in-4.gif)
|
||||||
- Smallest possible feature set
|
parallel installation/update (requires
|
||||||
- Branch/tag support
|
[+ruby](https://github.com/junegunn/vim-plug/wiki/ruby) or
|
||||||
- On-demand loading
|
[Neovim](http://neovim.org/))
|
||||||
|
- On-demand loading to achieve
|
||||||
### Cons.
|
[fast startup time](http://junegunn.kr/images/vim-startup-time.png)
|
||||||
|
- Post-update hooks
|
||||||
- Everything else
|
- Can choose a specific branch or tag for each plugin
|
||||||
|
- Support for externally managed plugins
|
||||||
|
|
||||||
### 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
|
||||||
@@ -63,41 +62,49 @@ 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
|
||||||
|
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| -------------- | -------------------------------------------------------------------- |
|
| -------------- | ------------------------------------------------ |
|
||||||
| `branch`/`tag` | Branch or tag of the repository to use |
|
| `branch`/`tag` | Branch or tag of the repository to use |
|
||||||
| `rtp` | Subdirectory that contains Vim plugin |
|
| `rtp` | Subdirectory that contains Vim plugin |
|
||||||
| `dir` | Custom directory for the plugin |
|
| `dir` | Custom directory for the plugin |
|
||||||
| `do` | Post-update hook (string or funcref) |
|
| `do` | Post-update hook (string or funcref) |
|
||||||
| `on` | On-demand loading: Commands or `<Plug>`-mappings |
|
| `on` | On-demand loading: Commands or `<Plug>`-mappings |
|
||||||
| `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 update unless explicitly specified |
|
||||||
|
|
||||||
### 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
|
||||||
|
|
||||||
@@ -119,11 +126,18 @@ 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' }
|
||||||
```
|
```
|
||||||
|
|
||||||
### Post-installation/update hooks
|
`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
|
||||||
|
|
||||||
There are some plugins that require extra steps after installation or update.
|
There are some plugins that require extra steps after installation or update.
|
||||||
In that case, use `do` option to describe the task to be performed.
|
In that case, use `do` option to describe the task to be performed.
|
||||||
@@ -137,10 +151,11 @@ takes a single argument.
|
|||||||
|
|
||||||
```vim
|
```vim
|
||||||
function! BuildYCM(info)
|
function! BuildYCM(info)
|
||||||
" info is a dictionary with two fields
|
" info is a dictionary with 3 fields
|
||||||
" - name: name of the plugin
|
" - name: name of the plugin
|
||||||
" - status: 'installed' or 'updated'
|
" - status: 'installed', 'updated', or 'unchanged'
|
||||||
if a:info.status == 'installed'
|
" - force: set on PlugInstall! or PlugUpdate!
|
||||||
|
if a:info.status == 'installed' || a:info.force
|
||||||
!./install.sh
|
!./install.sh
|
||||||
endif
|
endif
|
||||||
endfunction
|
endfunction
|
||||||
@@ -148,10 +163,14 @@ endfunction
|
|||||||
Plug 'Valloric/YouCompleteMe', { 'do': function('BuildYCM') }
|
Plug 'Valloric/YouCompleteMe', { 'do': function('BuildYCM') }
|
||||||
```
|
```
|
||||||
|
|
||||||
Both forms of post-update hook are executed inside the directory of the plugin.
|
Both forms of post-update hook are executed inside the directory of the plugin
|
||||||
|
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
|
||||||
|
`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' }
|
||||||
@@ -165,75 +184,16 @@ let g:fzf_install = 'yes | ./install'
|
|||||||
Plug 'junegunn/fzf', { 'do': g:fzf_install }
|
Plug 'junegunn/fzf', { 'do': g:fzf_install }
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### FAQ/Troubleshooting
|
||||||
|
|
||||||
|
See [FAQ/Troubleshooting](https://github.com/junegunn/vim-plug/wiki/faq).
|
||||||
|
|
||||||
### Articles
|
### Articles
|
||||||
|
|
||||||
- [Writing my own Vim plugin manager](http://junegunn.kr/2013/09/writing-my-own-vim-plugin-manager)
|
- [Writing my own Vim plugin manager](http://junegunn.kr/2013/09/writing-my-own-vim-plugin-manager)
|
||||||
- [Thoughts on Vim plugin dependency](http://junegunn.kr/2013/09/thoughts-on-vim-plugin-dependency)
|
|
||||||
- *Support for Plugfile has been removed since 0.5.0*
|
|
||||||
- [Vim plugins and startup time](http://junegunn.kr/2014/07/vim-plugins-and-startup-time)
|
- [Vim plugins and startup time](http://junegunn.kr/2014/07/vim-plugins-and-startup-time)
|
||||||
|
- ~~[Thoughts on Vim plugin dependency](http://junegunn.kr/2013/09/thoughts-on-vim-plugin-dependency)~~
|
||||||
### FAQ/Troubleshooting
|
- *Support for Plugfile has been removed since 0.5.0*
|
||||||
|
|
||||||
#### Plugins are not installed/updated in parallel
|
|
||||||
|
|
||||||
Your Vim does not support Ruby interface. `:echo has('ruby')` should print 1.
|
|
||||||
In order to setup Vim with Ruby support, you may refer to [this
|
|
||||||
article](http://junegunn.kr/2013/09/installing-vim-with-ruby-support).
|
|
||||||
|
|
||||||
#### *Vim: Caught deadly signal SEGV*
|
|
||||||
|
|
||||||
If your Vim crashes with the above message, first check if its Ruby interface is
|
|
||||||
working correctly with the following command:
|
|
||||||
|
|
||||||
```vim
|
|
||||||
:ruby puts RUBY_VERSION
|
|
||||||
```
|
|
||||||
|
|
||||||
If Vim crashes even with this command, it is likely that Ruby interface is
|
|
||||||
broken, and you have to rebuild Vim with a working version of Ruby.
|
|
||||||
(`brew remove vim && brew install vim` or `./configure && make ...`)
|
|
||||||
|
|
||||||
If you're on OS X, one possibility is that you had installed Vim with
|
|
||||||
[Homebrew](http://brew.sh/) while using a Ruby installed with
|
|
||||||
[RVM](http://rvm.io/) or [rbenv](https://github.com/sstephenson/rbenv) and later
|
|
||||||
removed that version of Ruby.
|
|
||||||
|
|
||||||
[Please let me know](https://github.com/junegunn/vim-plug/issues) if you can't
|
|
||||||
resolve the problem. In the meantime, you can set `g:plug_threads` to 1, so that
|
|
||||||
Ruby installer is not used at all.
|
|
||||||
|
|
||||||
#### Errors on fish shell
|
|
||||||
|
|
||||||
If vim-plug doesn't work correctly on fish shell, you might need to add `set
|
|
||||||
shell=/bin/sh` to your .vimrc.
|
|
||||||
|
|
||||||
Refer to the following links for the details:
|
|
||||||
- http://badsimplicity.com/vim-fish-e484-cant-open-file-tmpvrdnvqe0-error/
|
|
||||||
- https://github.com/junegunn/vim-plug/issues/12
|
|
||||||
|
|
||||||
#### Freezing plugin version with commit hash
|
|
||||||
|
|
||||||
vim-plug does not allow you to freeze the version of a plugin with its commit
|
|
||||||
hash. This is by design. I don't believe a user of a plugin should be looking
|
|
||||||
at its individual commits. Instead, one should be choosing the right version
|
|
||||||
using release tags or versioned branches (e.g. 1.2.3, stable, devel, etc.)
|
|
||||||
|
|
||||||
```vim
|
|
||||||
Plug 'junegunn/vim-easy-align', '2.9.2'
|
|
||||||
```
|
|
||||||
|
|
||||||
If the repository doesn't come with such tags or branches, you should think of
|
|
||||||
it as "unstable" or "in development", and always use its latest revision.
|
|
||||||
|
|
||||||
If you really must choose a certain untagged revision, consider forking the
|
|
||||||
repository.
|
|
||||||
|
|
||||||
#### Migrating from other plugin managers
|
|
||||||
|
|
||||||
vim-plug does not require any extra statement other than `plug#begin()` and
|
|
||||||
`plug#end()`. You can remove `filetype off`, `filetype plugin indent on` and
|
|
||||||
`syntax on` from your .vimrc as they are automatically handled by
|
|
||||||
`plug#end()`.
|
|
||||||
|
|
||||||
### License
|
### License
|
||||||
|
|
||||||
|
|||||||
5
test/fixtures/.gitignore
vendored
Normal file
5
test/fixtures/.gitignore
vendored
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
fzf*
|
||||||
|
xxx
|
||||||
|
yyy
|
||||||
|
z1
|
||||||
|
z2
|
||||||
1
test/fixtures/ftplugin-msg/ftplugin/c.vim
vendored
Normal file
1
test/fixtures/ftplugin-msg/ftplugin/c.vim
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
echomsg 'ftplugin'
|
||||||
45
test/run
45
test/run
@@ -5,22 +5,63 @@ cd ..
|
|||||||
PLUG_SRC=$(pwd)/plug.vim
|
PLUG_SRC=$(pwd)/plug.vim
|
||||||
cd - > /dev/null
|
cd - > /dev/null
|
||||||
|
|
||||||
|
export PLUG_FIXTURES=$(pwd)/fixtures
|
||||||
|
|
||||||
if [ ! -d vader.vim ]; then
|
if [ ! -d vader.vim ]; then
|
||||||
git clone https://github.com/junegunn/vader.vim.git
|
git clone https://github.com/junegunn/vader.vim.git
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm -rf fzf
|
rm -rf $PLUG_FIXTURES/fzf
|
||||||
if [ ! -d fzf-staged ]; then
|
if [ ! -d fzf-staged ]; then
|
||||||
git clone https://github.com/junegunn/fzf.git fzf-staged
|
git clone https://github.com/junegunn/fzf.git $PLUG_FIXTURES/fzf-staged
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
make_dirs() {
|
||||||
|
mkdir -p "$PLUG_FIXTURES/$1"
|
||||||
|
cd "$PLUG_FIXTURES/$1"
|
||||||
|
mkdir -p autoload colors ftdetect ftplugin indent plugin syntax
|
||||||
|
for d in *; do
|
||||||
|
[ -d $d ] || continue
|
||||||
|
cat > $d/xxx.vim << EOF
|
||||||
|
" echom expand('<sfile>')
|
||||||
|
let g:total_order = get(g:, 'total_order', [])
|
||||||
|
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
|
||||||
|
done
|
||||||
|
cd - > /dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
init() {
|
||||||
|
rm -rf $PLUG_FIXTURES/{xxx,yyy,z1,z2}
|
||||||
|
|
||||||
|
make_dirs xxx/ xxx
|
||||||
|
make_dirs xxx/after xxx
|
||||||
|
mkdir -p $PLUG_FIXTURES/xxx/doc
|
||||||
|
cat > $PLUG_FIXTURES/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
|
||||||
|
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, $MYVIMRC
|
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,15 +27,22 @@ 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>)
|
||||||
|
|
||||||
let g:vimrc_reloaded = 0
|
function! EnsureLoaded()
|
||||||
let vimrc = tempname()
|
if has('vim_starting')
|
||||||
call writefile(['let g:vimrc_reloaded += 1'], vimrc)
|
runtime! plugin/**/*.vim
|
||||||
let $MYVIMRC = vimrc
|
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
|
||||||
@@ -74,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
|
||||||
|
|
||||||
@@ -83,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
|
||||||
|
|
||||||
@@ -98,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)
|
||||||
@@ -133,7 +139,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 +172,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
|
||||||
@@ -200,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).
|
||||||
@@ -234,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.
|
||||||
@@ -254,7 +258,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 +265,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
|
||||||
@@ -302,7 +304,8 @@ Execute (Rollback recent updates, PlugUpdate, then PlugDiff):
|
|||||||
|
|
||||||
" ]] motion
|
" ]] motion
|
||||||
execute 'normal $]]'
|
execute 'normal $]]'
|
||||||
AssertEqual lnum + 4, line('.')
|
Assert index([lnum + 4, lnum + 5], line('.')) >= 0
|
||||||
|
" +5 for merge commit
|
||||||
AssertEqual 3, col('.')
|
AssertEqual 3, col('.')
|
||||||
|
|
||||||
" [[ motion
|
" [[ motion
|
||||||
@@ -310,6 +313,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
|
||||||
|
|
||||||
@@ -320,6 +330,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
|
||||||
|
|
||||||
@@ -327,16 +338,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
|
||||||
|
|
||||||
**********************************************************************
|
**********************************************************************
|
||||||
@@ -384,9 +396,11 @@ Given (Unaligned code):
|
|||||||
aa=2
|
aa=2
|
||||||
|
|
||||||
Execute (Check installed plugins):
|
Execute (Check installed plugins):
|
||||||
|
call EnsureLoaded()
|
||||||
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):
|
||||||
@@ -408,7 +422,7 @@ Execute (On-demand loading based on filetypes):
|
|||||||
**********************************************************************
|
**********************************************************************
|
||||||
|
|
||||||
Execute (Add unmanaged plugin):
|
Execute (Add unmanaged plugin):
|
||||||
let fzf = fnamemodify(g:vader_file, ':h') . '/fzf'
|
let fzf = expand('$PLUG_FIXTURES/fzf')
|
||||||
Log fzf
|
Log fzf
|
||||||
|
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
@@ -438,6 +452,7 @@ Execute (Plug block for following tests):
|
|||||||
call plug#end()
|
call plug#end()
|
||||||
" Remove plugins from previous tests
|
" Remove plugins from previous tests
|
||||||
PlugClean!
|
PlugClean!
|
||||||
|
q
|
||||||
|
|
||||||
Execute (PlugInstall will only install vim-easy-align):
|
Execute (PlugInstall will only install vim-easy-align):
|
||||||
PlugInstall
|
PlugInstall
|
||||||
@@ -466,7 +481,7 @@ Execute (PlugStatus should point out that the plugin is missing):
|
|||||||
|
|
||||||
Execute (Deploy unmanaged plugin):
|
Execute (Deploy unmanaged plugin):
|
||||||
Assert !exists(':FZF'), ':FZF command should not exist'
|
Assert !exists(':FZF'), ':FZF command should not exist'
|
||||||
call rename('fzf-staged', 'fzf')
|
call rename(expand('$PLUG_FIXTURES/fzf-staged'), fzf)
|
||||||
|
|
||||||
Execute (PlugUpdate still should not care):
|
Execute (PlugUpdate still should not care):
|
||||||
PlugUpdate
|
PlugUpdate
|
||||||
@@ -504,21 +519,46 @@ Execute (Common parent):
|
|||||||
**********************************************************************
|
**********************************************************************
|
||||||
~ Frozen plugins
|
~ Frozen plugins
|
||||||
**********************************************************************
|
**********************************************************************
|
||||||
|
- We've decided to install plugins that are frozen: see #113
|
||||||
|
Execute (Frozen plugin are not ~~installed nor~~ updated):
|
||||||
|
" Remove plugins
|
||||||
|
call plug#begin()
|
||||||
|
call plug#end()
|
||||||
|
PlugClean!
|
||||||
|
q
|
||||||
|
|
||||||
Execute (Frozen plugin are not installed nor updated):
|
" vim-easy-align is not found, so it will be installed even though it's frozen
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
|
Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
|
||||||
call plug#end()
|
call plug#end()
|
||||||
|
PlugInstall
|
||||||
|
AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
|
||||||
|
q
|
||||||
|
|
||||||
redir => output
|
" Remove plugins again
|
||||||
|
call plug#begin()
|
||||||
|
call plug#end()
|
||||||
|
PlugClean!
|
||||||
|
q
|
||||||
|
|
||||||
|
" PlugUpdate will do the same
|
||||||
|
call plug#begin()
|
||||||
|
Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
|
||||||
|
call plug#end()
|
||||||
|
PlugInstall
|
||||||
|
AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
|
||||||
|
q
|
||||||
|
|
||||||
|
" Since vim-easy-align already exists, PlugInstall or PlugUpdate will skip it
|
||||||
|
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
|
||||||
@@ -581,6 +621,7 @@ Execute (Cleanup):
|
|||||||
call plug#begin()
|
call plug#begin()
|
||||||
call plug#end()
|
call plug#end()
|
||||||
PlugClean!
|
PlugClean!
|
||||||
|
q
|
||||||
|
|
||||||
Execute (On install):
|
Execute (On install):
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
@@ -625,6 +666,14 @@ Execute (When already installed):
|
|||||||
Assert !filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
|
Assert !filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
|
||||||
\ 'vim-easy-align/installed2 should not exist'
|
\ 'vim-easy-align/installed2 should not exist'
|
||||||
Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
|
Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
|
||||||
|
\ 'vim-pseudocl/installed2 should not exist'
|
||||||
|
|
||||||
|
Execute (PlugInstall!):
|
||||||
|
PlugInstall!
|
||||||
|
q
|
||||||
|
Assert filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
|
||||||
|
\ 'vim-easy-align/installed2 should exist'
|
||||||
|
Assert filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
|
||||||
\ 'vim-pseudocl/installed2 should exist'
|
\ 'vim-pseudocl/installed2 should exist'
|
||||||
|
|
||||||
Execute (When already updated):
|
Execute (When already updated):
|
||||||
@@ -638,11 +687,19 @@ Execute (When already updated):
|
|||||||
Assert !filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
|
Assert !filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
|
||||||
\ 'vim-easy-align/updated2 should not exist'
|
\ 'vim-easy-align/updated2 should not exist'
|
||||||
Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
|
Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
|
||||||
|
\ 'vim-pseudocl/updated2 should not exist'
|
||||||
|
|
||||||
|
Execute (PlugUpdate!):
|
||||||
|
PlugUpdate!
|
||||||
|
q
|
||||||
|
Assert filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
|
||||||
|
\ 'vim-easy-align/updated2 should exist'
|
||||||
|
Assert filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
|
||||||
\ 'vim-pseudocl/updated2 should exist'
|
\ 'vim-pseudocl/updated2 should exist'
|
||||||
|
|
||||||
Execute (Using Funcref):
|
Execute (Using Funcref):
|
||||||
function! PlugUpdated(info)
|
function! PlugUpdated(info)
|
||||||
call system('touch '. a:info.name . a:info.status . len(a:info))
|
call system('touch '. a:info.name . a:info.status . a:info.force . len(a:info))
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
call plug#begin()
|
call plug#begin()
|
||||||
@@ -656,11 +713,26 @@ Execute (Using Funcref):
|
|||||||
PlugUpdate
|
PlugUpdate
|
||||||
Log getline(1, '$')
|
Log getline(1, '$')
|
||||||
q
|
q
|
||||||
Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated2'),
|
Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated03'),
|
||||||
\ 'vim-easy-align/vim-easy-alignupdated2 should exist'
|
\ 'vim-easy-align/vim-easy-alignupdated03 should exist'
|
||||||
Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled2'),
|
Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled03'),
|
||||||
\ 'vim-pseudocl/vim-pseudoclinstalled2 should exist'
|
\ 'vim-pseudocl/vim-pseudoclinstalled03 should exist'
|
||||||
|
|
||||||
|
call system('rm -rf '.g:plugs['vim-pseudocl'].dir)
|
||||||
|
PlugInstall!
|
||||||
|
q
|
||||||
|
Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignunchanged13'),
|
||||||
|
\ 'vim-easy-align/vim-easy-alignunchanged13 should exist'
|
||||||
|
Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled13'),
|
||||||
|
\ 'vim-pseudocl/vim-pseudoclinstalled13 should exist'
|
||||||
|
|
||||||
|
call system('cd '.g:plugs['vim-easy-align'].dir.' && git reset --hard HEAD^')
|
||||||
|
PlugUpdate!
|
||||||
|
q
|
||||||
|
Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated13'),
|
||||||
|
\ 'vim-easy-align/vim-easy-alignupdated13 should exist'
|
||||||
|
Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclunchanged13'),
|
||||||
|
\ 'vim-pseudocl/vim-pseudoclunchanged13 should exist'
|
||||||
|
|
||||||
**********************************************************************
|
**********************************************************************
|
||||||
~ Overriding `dir`
|
~ Overriding `dir`
|
||||||
@@ -683,19 +755,415 @@ 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-=$PLUG_FIXTURES/xxx/
|
||||||
|
set rtp-=$PLUG_FIXTURES/xxx/after
|
||||||
|
|
||||||
unlet g:plugs
|
Execute (Immediate loading):
|
||||||
unlet g:plug_home
|
call plug#begin()
|
||||||
unlet g:vimrc_reloaded
|
Plug '$PLUG_FIXTURES/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 ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
|
||||||
|
else
|
||||||
|
AssertEqual ['xxx/plugin', 'xxx/after/plugin', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
|
||||||
|
endif
|
||||||
|
|
||||||
|
Execute (Command-based on-demand loading):
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PLUG_FIXTURES/xxx', { 'on': 'XXX' }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
AssertEqual [], g:xxx
|
||||||
|
|
||||||
|
silent! XXX
|
||||||
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin'], g:xxx
|
||||||
|
|
||||||
|
setf 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):
|
||||||
|
call plug#begin()
|
||||||
|
Plug '$PLUG_FIXTURES/xxx', { 'for': 'xxx' }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
|
||||||
|
|
||||||
|
setf 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:
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
~ plug#helptags()
|
||||||
|
**********************************************************************
|
||||||
|
|
||||||
|
Execute (plug#helptags):
|
||||||
|
silent! call delete(expand('$PLUG_FIXTURES/xxx/doc/tags'))
|
||||||
|
Assert !filereadable(expand('$PLUG_FIXTURES/xxx/doc/tags'))
|
||||||
|
AssertEqual 1, plug#helptags()
|
||||||
|
Assert filereadable(expand('$PLUG_FIXTURES/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 '$PLUG_FIXTURES/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 '$PLUG_FIXTURES/z1', { 'on': [] }
|
||||||
|
Plug '$PLUG_FIXTURES/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 '$PLUG_FIXTURES/xxx'
|
||||||
|
Plug '$PLUG_FIXTURES/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 '$PLUG_FIXTURES/xxx', { 'for': ['xxx'] }
|
||||||
|
Plug '$PLUG_FIXTURES/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 '$PLUG_FIXTURES/xxx', { 'for': ['xxx'] }
|
||||||
|
Plug '$PLUG_FIXTURES/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('$PLUG_FIXTURES')
|
||||||
|
Plug '$PLUG_FIXTURES/ftplugin-msg', { 'for': [] }
|
||||||
|
Plug '$PLUG_FIXTURES/fzf'
|
||||||
|
Plug '$PLUG_FIXTURES/xxx'
|
||||||
|
Plug '$PLUG_FIXTURES/yyy'
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
" Remove z1, z2
|
||||||
|
PlugClean!
|
||||||
|
AssertExpect '^- ', 2
|
||||||
|
AssertExpect 'Already clean', 0
|
||||||
|
|
||||||
|
PlugClean!
|
||||||
|
AssertExpect '^- ', 0
|
||||||
|
AssertExpect 'Already clean', 1
|
||||||
|
q
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (#112 On-demand loading should not suppress messages from ftplugin):
|
||||||
|
call plug#begin('$PLUG_FIXTURES')
|
||||||
|
Plug '$PLUG_FIXTURES/ftplugin-msg', { 'for': 'c' }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
redir => out
|
||||||
|
tabnew a.c
|
||||||
|
redir END
|
||||||
|
Assert stridx(out, 'ftplugin') >= 0
|
||||||
|
|
||||||
|
* The same applies to plug#load())
|
||||||
|
redir => out
|
||||||
|
call plug#load('ftplugin-msg')
|
||||||
|
redir END
|
||||||
|
Assert stridx(out, 'ftplugin') >= 0
|
||||||
|
q
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (PlugSnapshot):
|
||||||
|
call plug#begin('$TMPDIR/plugged')
|
||||||
|
Plug 'junegunn/vim-emoji'
|
||||||
|
Plug 'junegunn/seoul256.vim'
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
PlugClean!
|
||||||
|
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 (#114 Should not contain empty path in &rtp):
|
||||||
|
call plug#begin('$TMPDIR/plugged')
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
Log &rtp
|
||||||
|
Assert &rtp !~ ',,', 'Commas'
|
||||||
|
Assert &rtp !~ '^,', 'Comma prefix'
|
||||||
|
Assert &rtp !~ ',$', 'Comma suffix'
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (#130 Proper cleanup of on-demand loading triggers):
|
||||||
|
augroup PlugLOD
|
||||||
|
autocmd!
|
||||||
|
augroup END
|
||||||
|
|
||||||
|
" Cleared on command
|
||||||
|
call plug#begin('$TMPDIR/plugged')
|
||||||
|
Plug 'junegunn/vim-emoji', { 'on': ['EmojiCommand', 'EmojiCommand2', '<Plug>(EmojiMapping)'] }
|
||||||
|
call plug#end()
|
||||||
|
PlugInstall | q
|
||||||
|
|
||||||
|
Assert exists(':EmojiCommand'), 'EmojiCommand not defined'
|
||||||
|
Assert exists(':EmojiCommand2'), 'EmojiCommand2 not defined'
|
||||||
|
Assert !empty(mapcheck('<Plug>(EmojiMapping)')), '<Plug>(EmojiMapping) not defined'
|
||||||
|
|
||||||
|
silent! EmojiCommand
|
||||||
|
|
||||||
|
Assert !exists(':EmojiCommand'), 'EmojiCommand defined'
|
||||||
|
Assert !exists(':EmojiCommand2'), 'EmojiCommand2 defined'
|
||||||
|
Assert empty(mapcheck('<Plug>(EmojiMapping)')), '<Plug>(EmojiMapping) defined'
|
||||||
|
|
||||||
|
" Cleared on FileType
|
||||||
|
call plug#begin('$TMPDIR/plugged')
|
||||||
|
Plug 'junegunn/vim-emoji', { 'on': ['EmojiCommandExtra', '<Plug>(EmojiMappingExtra)'], 'for': ['emoji'] }
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
Assert exists(':EmojiCommandExtra'), 'EmojiCommandExtra not defined'
|
||||||
|
Assert !empty(mapcheck('<Plug>(EmojiMappingExtra)')), '<Plug>(EmojiMappingExtra) not defined'
|
||||||
|
|
||||||
|
setf emoji
|
||||||
|
|
||||||
|
Assert !exists(':EmojiCommandExtra'), 'EmojiCommandExtra defined'
|
||||||
|
Assert empty(mapcheck('<Plug>(EmojiMappingExtra)')), '<Plug>(EmojiMappingExtra) defined'
|
||||||
|
|
||||||
|
**********************************************************************
|
||||||
|
Execute (#131 Syntax error):
|
||||||
|
call plug#begin('/no-permission')
|
||||||
|
Plug 'junegunn/vim-emoji'
|
||||||
|
call plug#end()
|
||||||
|
|
||||||
|
redir => out
|
||||||
|
silent PlugInstall
|
||||||
|
redir END
|
||||||
|
Assert out =~ 'Invalid plug directory: /no-permission'
|
||||||
|
|
||||||
|
Execute (Cleanup):
|
||||||
|
silent! call system('rm -rf '.temp_plugged)
|
||||||
|
silent! call system('rm -rf '.temp_plugged)
|
||||||
|
silent! call rename(fzf, expand('$PLUG_FIXTURES/fzf-staged'))
|
||||||
|
silent! unlet g:plugs
|
||||||
|
silent! unlet g:plug_home
|
||||||
|
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 AssertExpect
|
||||||
|
silent! delf PlugUpdated
|
||||||
|
silent! delf EnsureLoaded
|
||||||
|
silent! delc AssertExpect
|
||||||
|
silent! unmap /
|
||||||
|
silent! unmap ?
|
||||||
|
|
||||||
Restore
|
Restore
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user