Change the default plugin directory for Neovim
And suggest users to call plug#begin() without an argument to avoid confusion.
This commit is contained in:
parent
f085751ca1
commit
e300178a0e
3 changed files with 51 additions and 43 deletions
14
README.md
14
README.md
|
@ -87,7 +87,7 @@ iwr -useb https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim |`
|
||||||
|
|
||||||
Add a vim-plug section to your `~/.vimrc` (or `stdpath('config') . '/init.vim'` for Neovim)
|
Add a vim-plug section to your `~/.vimrc` (or `stdpath('config') . '/init.vim'` for Neovim)
|
||||||
|
|
||||||
1. Begin the section with `call plug#begin()`
|
1. Begin the section with `call plug#begin([PLUGIN_DIR])`
|
||||||
1. List the plugins with `Plug` commands
|
1. List the plugins with `Plug` commands
|
||||||
1. `call plug#end()` to update `&runtimepath` and initialize plugin system
|
1. `call plug#end()` to update `&runtimepath` and initialize plugin system
|
||||||
- Automatically executes `filetype plugin indent on` and `syntax enable`.
|
- Automatically executes `filetype plugin indent on` and `syntax enable`.
|
||||||
|
@ -96,12 +96,14 @@ Add a vim-plug section to your `~/.vimrc` (or `stdpath('config') . '/init.vim'`
|
||||||
#### Example
|
#### Example
|
||||||
|
|
||||||
```vim
|
```vim
|
||||||
" Specify a directory for plugins
|
call plug#begin()
|
||||||
" - For Vim (Linux/macOS): '~/.vim/plugged'
|
" The default plugin directory will be as follows:
|
||||||
" - For Vim (Windows): '~/vimfiles/plugged'
|
" - Vim (Linux/macOS): '~/.vim/plugged'
|
||||||
" - For Neovim (Linux/macOS/Windows): stdpath('data') . '/plugged'
|
" - Vim (Windows): '~/vimfiles/plugged'
|
||||||
|
" - Neovim (Linux/macOS/Windows): stdpath('data') . '/plugged'
|
||||||
|
" You can specify a custom plugin directory by passing it as the argument
|
||||||
|
" - e.g. `call plug#begin('~/.vim/plugged')`
|
||||||
" - Avoid using standard Vim directory names like 'plugin'
|
" - Avoid using standard Vim directory names like 'plugin'
|
||||||
call plug#begin('~/.vim/plugged')
|
|
||||||
|
|
||||||
" Make sure you use single quotes
|
" Make sure you use single quotes
|
||||||
|
|
||||||
|
|
74
doc/plug.txt
74
doc/plug.txt
|
@ -1,4 +1,4 @@
|
||||||
plug.txt plug Last change: November 27 2017
|
plug.txt plug Last change: January 3 2022
|
||||||
PLUG - TABLE OF CONTENTS *plug* *plug-toc*
|
PLUG - TABLE OF CONTENTS *plug* *plug-toc*
|
||||||
==============================================================================
|
==============================================================================
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@ PLUG - TABLE OF CONTENTS *plug* *plug-to
|
||||||
Post-update hooks
|
Post-update hooks
|
||||||
PlugInstall! and PlugUpdate!
|
PlugInstall! and PlugUpdate!
|
||||||
Articles
|
Articles
|
||||||
|
Collaborators
|
||||||
License
|
License
|
||||||
|
|
||||||
VIM-PLUG *vim-plug*
|
VIM-PLUG *vim-plug*
|
||||||
|
@ -36,8 +37,8 @@ https://raw.githubusercontent.com/junegunn/i/master/vim-plug/installer.gif
|
||||||
< Pros. >_____________________________________________________________________~
|
< Pros. >_____________________________________________________________________~
|
||||||
*plug-pros*
|
*plug-pros*
|
||||||
|
|
||||||
- Easier to setup: Single file. No boilerplate code required.
|
- Easy to set up: Single file. No boilerplate code required.
|
||||||
- Easier to use: Concise, intuitive syntax
|
- Easy to use: Concise, intuitive syntax
|
||||||
- {Super-fast}{1} parallel installation/update (with any of `+job`, `+python`,
|
- {Super-fast}{1} parallel installation/update (with any of `+job`, `+python`,
|
||||||
`+python3`, `+ruby`, or {Neovim}{2})
|
`+python3`, `+ruby`, or {Neovim}{2})
|
||||||
- Creates shallow clones to minimize disk space usage and download time
|
- Creates shallow clones to minimize disk space usage and download time
|
||||||
|
@ -77,14 +78,8 @@ file as suggested {here}{5}.
|
||||||
|
|
||||||
>> Windows (PowerShell)~
|
>> Windows (PowerShell)~
|
||||||
>
|
>
|
||||||
md ~\vimfiles\autoload
|
iwr -useb https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim |`
|
||||||
$uri = 'https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim'
|
ni $HOME/vimfiles/autoload/plug.vim -Force
|
||||||
(New-Object Net.WebClient).DownloadFile(
|
|
||||||
$uri,
|
|
||||||
$ExecutionContext.SessionState.Path.GetUnresolvedProviderPathFromPSPath(
|
|
||||||
"~\vimfiles\autoload\plug.vim"
|
|
||||||
)
|
|
||||||
)
|
|
||||||
<
|
<
|
||||||
|
|
||||||
Neovim~
|
Neovim~
|
||||||
|
@ -93,20 +88,14 @@ Neovim~
|
||||||
|
|
||||||
>> Unix~
|
>> Unix~
|
||||||
>
|
>
|
||||||
curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \
|
sh -c 'curl -fLo "${XDG_DATA_HOME:-$HOME/.local/share}"/nvim/site/autoload/plug.vim --create-dirs \
|
||||||
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
|
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim'
|
||||||
<
|
<
|
||||||
|
|
||||||
>> Windows (PowerShell)~
|
>> Windows (PowerShell)~
|
||||||
>
|
>
|
||||||
md ~\AppData\Local\nvim\autoload
|
iwr -useb https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim |`
|
||||||
$uri = 'https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim'
|
ni "$(@($env:XDG_DATA_HOME, $env:LOCALAPPDATA)[$null -eq $env:XDG_DATA_HOME])/nvim-data/site/autoload/plug.vim" -Force
|
||||||
(New-Object Net.WebClient).DownloadFile(
|
|
||||||
$uri,
|
|
||||||
$ExecutionContext.SessionState.Path.GetUnresolvedProviderPathFromPSPath(
|
|
||||||
"~\AppData\Local\nvim\autoload\plug.vim"
|
|
||||||
)
|
|
||||||
)
|
|
||||||
<
|
<
|
||||||
|
|
||||||
< Getting Help >______________________________________________________________~
|
< Getting Help >______________________________________________________________~
|
||||||
|
@ -127,12 +116,12 @@ Neovim~
|
||||||
< Usage >_____________________________________________________________________~
|
< Usage >_____________________________________________________________________~
|
||||||
*plug-usage*
|
*plug-usage*
|
||||||
|
|
||||||
Add a vim-plug section to your `~/.vimrc` (or `~/.config/nvim/init.vim` for
|
Add a vim-plug section to your `~/.vimrc` (or `stdpath('config') . '/init.vim'` for
|
||||||
Neovim):
|
Neovim)
|
||||||
|
|
||||||
*plug#begin* *plug#end*
|
*plug#begin* *plug#end*
|
||||||
|
|
||||||
1. Begin the section with `call plug#begin()`
|
1. Begin the section with `call plug#begin([PLUGIN_DIR])`
|
||||||
2. List the plugins with `Plug` commands
|
2. List the plugins with `Plug` commands
|
||||||
3. `call plug#end()` to update 'runtimepath' and initialize plugin system
|
3. `call plug#end()` to update 'runtimepath' and initialize plugin system
|
||||||
- Automatically executes `filetype plugin indent on` and `syntax enable`.
|
- Automatically executes `filetype plugin indent on` and `syntax enable`.
|
||||||
|
@ -143,10 +132,14 @@ Neovim):
|
||||||
Example~
|
Example~
|
||||||
*plug-example*
|
*plug-example*
|
||||||
>
|
>
|
||||||
" Specify a directory for plugins
|
call plug#begin()
|
||||||
" - For Neovim: ~/.local/share/nvim/plugged
|
" The default plugin directory will be as follows:
|
||||||
|
" - Vim (Linux/macOS): '~/.vim/plugged'
|
||||||
|
" - Vim (Windows): '~/vimfiles/plugged'
|
||||||
|
" - Neovim (Linux/macOS/Windows): stdpath('data') . '/plugged'
|
||||||
|
" You can specify a custom plugin directory by passing it as the argument
|
||||||
|
" - e.g. `call plug#begin('~/.vim/plugged')`
|
||||||
" - Avoid using standard Vim directory names like 'plugin'
|
" - Avoid using standard Vim directory names like 'plugin'
|
||||||
call plug#begin('~/.vim/plugged')
|
|
||||||
|
|
||||||
" Make sure you use single quotes
|
" Make sure you use single quotes
|
||||||
|
|
||||||
|
@ -285,16 +278,16 @@ Reload .vimrc and `:PlugInstall` to install plugins.
|
||||||
Plug 'junegunn/goyo.vim', { 'for': 'markdown' }
|
Plug 'junegunn/goyo.vim', { 'for': 'markdown' }
|
||||||
autocmd! User goyo.vim echom 'Goyo is now loaded!'
|
autocmd! User goyo.vim echom 'Goyo is now loaded!'
|
||||||
<
|
<
|
||||||
`for` option is generally not needed as most plugins for specific file types
|
The `for` option is generally not needed as most plugins for specific file
|
||||||
usually don't have too much code in `plugin` directory. You might want to
|
types usually don't have too much code in the `plugin` directory. You might
|
||||||
examine the output of `vim --startuptime` before applying the option.
|
want to examine the output of `vim --startuptime` before applying the option.
|
||||||
|
|
||||||
|
|
||||||
< Post-update hooks >_________________________________________________________~
|
< Post-update hooks >_________________________________________________________~
|
||||||
*plug-post-update-hooks*
|
*plug-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 the `do` option to describe the task to be performed.
|
||||||
>
|
>
|
||||||
Plug 'Shougo/vimproc.vim', { 'do': 'make' }
|
Plug 'Shougo/vimproc.vim', { 'do': 'make' }
|
||||||
Plug 'ycm-core/YouCompleteMe', { 'do': './install.py' }
|
Plug 'ycm-core/YouCompleteMe', { 'do': './install.py' }
|
||||||
|
@ -325,9 +318,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 and double-quotes when you write `do` option inline
|
Make sure to escape BARs and double-quotes when you write the `do` option
|
||||||
as they are mistakenly recognized as command separator or the start of the
|
inline as they are mistakenly recognized as command separator or the start of
|
||||||
trailing comment.
|
the trailing comment.
|
||||||
>
|
>
|
||||||
Plug 'junegunn/fzf', { 'do': 'yes \| ./install' }
|
Plug 'junegunn/fzf', { 'do': 'yes \| ./install' }
|
||||||
<
|
<
|
||||||
|
@ -351,7 +344,8 @@ The installer takes the following steps when installing/updating a plugin:
|
||||||
1. Update submodules
|
1. Update submodules
|
||||||
2. Execute post-update hooks
|
2. Execute post-update hooks
|
||||||
|
|
||||||
The commands with `!` suffix ensure that all steps are run unconditionally.
|
The commands with the `!` suffix ensure that all steps are run
|
||||||
|
unconditionally.
|
||||||
|
|
||||||
|
|
||||||
< Articles >__________________________________________________________________~
|
< Articles >__________________________________________________________________~
|
||||||
|
@ -367,6 +361,16 @@ The commands with `!` suffix ensure that all steps are run unconditionally.
|
||||||
{13} http://junegunn.kr/2013/09/thoughts-on-vim-plugin-dependency
|
{13} http://junegunn.kr/2013/09/thoughts-on-vim-plugin-dependency
|
||||||
|
|
||||||
|
|
||||||
|
< Collaborators >_____________________________________________________________~
|
||||||
|
*plug-collaborators*
|
||||||
|
|
||||||
|
- {Jan Edmund Lazo}{14} - Windows support
|
||||||
|
- {Jeremy Pallats}{15} - Python installer
|
||||||
|
|
||||||
|
{14} https://github.com/janlazo
|
||||||
|
{15} https://github.com/starcraftman
|
||||||
|
|
||||||
|
|
||||||
< License >___________________________________________________________________~
|
< License >___________________________________________________________________~
|
||||||
*plug-license*
|
*plug-license*
|
||||||
|
|
||||||
|
|
2
plug.vim
2
plug.vim
|
@ -242,6 +242,8 @@ function! plug#begin(...)
|
||||||
let home = s:path(s:plug_fnamemodify(s:plug_expand(a:1), ':p'))
|
let home = s:path(s:plug_fnamemodify(s:plug_expand(a:1), ':p'))
|
||||||
elseif exists('g:plug_home')
|
elseif exists('g:plug_home')
|
||||||
let home = s:path(g:plug_home)
|
let home = s:path(g:plug_home)
|
||||||
|
elseif has('nvim')
|
||||||
|
let home = stdpath('data') . '/plugged'
|
||||||
elseif !empty(&rtp)
|
elseif !empty(&rtp)
|
||||||
let home = s:path(split(&rtp, ',')[0]) . '/plugged'
|
let home = s:path(split(&rtp, ',')[0]) . '/plugged'
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in a new issue