mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-01-24 06:40:05 +08:00
1499 lines
44 KiB
Plaintext
Vendored
1499 lines
44 KiB
Plaintext
Vendored
*dein.txt* Dark powered Vim/Neovim plugin manager
|
|
|
|
Version: 3.0
|
|
Author: Shougo <Shougo.Matsu at gmail.com>
|
|
License: MIT license
|
|
|
|
==============================================================================
|
|
CONTENTS *dein-contents*
|
|
|
|
Introduction |dein-introduction|
|
|
Usage |dein-usage|
|
|
Install |dein-install|
|
|
Interface |dein-interface|
|
|
Functions |dein-functions|
|
|
Variables |dein-variables|
|
|
Options |dein-options|
|
|
Toml |dein-toml|
|
|
Unite Sources |dein-unite-sources|
|
|
Denite Sources |dein-denite-sources|
|
|
Configuration Examples |dein-examples|
|
|
Plugins merged feature |dein-merge|
|
|
FAQ |dein-faq|
|
|
Compatibility |dein-compatibility|
|
|
|
|
|
|
==============================================================================
|
|
INTRODUCTION *dein-introduction*
|
|
|
|
*dein* is the dark powered Vim package manager. It is created from full
|
|
scratch.
|
|
|
|
Concepts are:
|
|
|
|
* Faster than NeoBundle
|
|
|
|
* Simple
|
|
|
|
* No commands, Functions only to simplify the implementation
|
|
|
|
* Easy to test and maintain
|
|
|
|
* No Vundle/NeoBundle compatibility
|
|
|
|
* neovim/Vim8 asynchronous API installation support
|
|
|
|
* Local plugin support
|
|
|
|
* Non github plugins support
|
|
|
|
* Go like clone directory name ex:"github.com/{user}/{repository}"
|
|
|
|
* Merge the plugins directories automatically to avoid long 'runtimepath'
|
|
|
|
|
|
==============================================================================
|
|
USAGE *dein-usage*
|
|
|
|
Refer to the example:
|
|
|dein-examples|
|
|
|
|
Run this command to update your plugins:
|
|
>
|
|
:call dein#update()
|
|
<
|
|
Note: The plugins are not updated automatically.
|
|
|
|
==============================================================================
|
|
INSTALL *dein-install*
|
|
|
|
Requirements:
|
|
* Vim 8.2+ or NeoVim 0.5+.
|
|
* "git" command in $PATH (if you want to install github or vim.org plugins)
|
|
|
|
Note: If you use below Vim 8.2 or neovim 0.5, please use dein.vim ver.2.2
|
|
instead.
|
|
|
|
First of all, git clone the repository.
|
|
|
|
Note: You must define the installation directory before to use dein. It
|
|
depends on your usage.
|
|
For example, "~/.vim/bundles" or "~/.cache/dein" or "~/.local/share/dein".
|
|
dein.vim does not define the default installation directory.
|
|
You must not set the installation directory under "~/.vim/plugin" or
|
|
"~/.config/nvim/plugin".
|
|
|
|
Note: You need to have git installed.
|
|
>
|
|
$ mkdir -p ~/.vim/bundle/repos/github.com/Shougo/dein.vim
|
|
$ git clone https://github.com/Shougo/dein.vim \
|
|
~/.vim/bundle/repos/github.com/Shougo/dein.vim
|
|
<
|
|
And set up a path to the repository directory.
|
|
>
|
|
set runtimepath+={path to dein directory}
|
|
<
|
|
Example:
|
|
>
|
|
set runtimepath+=~/.vim/bundle/repos/github.com/Shougo/dein.vim
|
|
<
|
|
Now configure your bundles. (Refer to |dein-examples|)
|
|
|
|
Call |dein#update()| function to install your plugins.
|
|
>
|
|
If you need vim-plug like install UI, you can use ddu-source-dein_update.
|
|
https://github.com/matsui54/ddu-source-dein_update
|
|
|
|
|
|
==============================================================================
|
|
INTERFACE *dein-interface*
|
|
|
|
|
|
------------------------------------------------------------------------------
|
|
FUNCTIONS *dein-functions*
|
|
|
|
*dein#add()*
|
|
dein#add({repo}[, {options}])
|
|
Initialize a plugin.
|
|
{repo} is the repository URI or local repository directory
|
|
path. If {repo} starts with github user name (ex:
|
|
"Shougo/dein.vim"), dein will install github plugins.
|
|
See |dein-options| for what to set in {options}.
|
|
Note: If plugin is already defined, duplicated calls will be
|
|
ignored. If you want to overwrite plugin config, you need to
|
|
use |dein-options-overwrite| or |dein#config()| instead.
|
|
Note: You must call it in |dein#begin()| block.
|
|
Note: If you install plugins, you need to call
|
|
|dein#install()| manually.
|
|
|
|
*dein#begin()*
|
|
dein#begin({base-path}, [{vimrcs}])
|
|
Initialize dein.vim and start plugins configuration
|
|
block.
|
|
{base-path} is where your downloaded plugins will be placed.
|
|
For example, "Shougo/dein.vim" will be downloaded in
|
|
"{base-path}/repos/github.com/Shougo/dein.vim" directory.
|
|
{vimrcs} is a list of compared .vimrc and/or other
|
|
configuration(TOML) files. The default is |$MYVIMRC|.
|
|
The typical {base-path} is "~/.cache/dein" or
|
|
"~/.local/share/dein".
|
|
|
|
Note: You must not call the function inside a
|
|
"has('vim_starting')" block.
|
|
|
|
Note: It executes ":filetype off" automatically.
|
|
|
|
*dein#build()*
|
|
dein#build([{plugins}])
|
|
Build for {plugins}.
|
|
{plugins} is the plugins name list.
|
|
|
|
*dein#call_hook()*
|
|
dein#call_hook({hook-name})
|
|
Calls the hook {hook-name}.
|
|
Note: If {hook-name} is "source", dein will call "source"
|
|
hooks in sourced plugins.
|
|
|
|
*dein#check_install()*
|
|
dein#check_install({plugins})
|
|
Check {plugins} installation.
|
|
If {plugins} are not installed, it will return non-zero.
|
|
If {plugins} are invalid, it will return -1.
|
|
{plugins} are the plugins name list or the plugin name to
|
|
check.
|
|
If you omit it, dein will check all plugins installation.
|
|
Note: You can disable the message by |:silent|.
|
|
|
|
*dein#check_lazy_plugins()*
|
|
dein#check_lazy_plugins()
|
|
Check the no meaning lazy plugins. These plugins don't have
|
|
"plugin/" directory.
|
|
|
|
*dein#check_update()*
|
|
dein#check_update([{force}[, {plugins}]])
|
|
Check updated {plugins} by github GraphQL API.
|
|
https://docs.github.com/en/graphql
|
|
If {force} is |v:true|, it call |dein#update()| after updated
|
|
check.
|
|
{plugins} are the plugins name list or the plugin name to
|
|
check.
|
|
Note: You can use it for github plugins.
|
|
Note: It does not return value instead of
|
|
|dein#check_install()|.
|
|
Note: You need to set |g:dein#install_github_api_token| to use
|
|
the feature.
|
|
Note: The update check is quick but it is not perfect
|
|
solution. If "git" command change ".git" directory status(for
|
|
example: "git reset"), it cannot detect the update properly.
|
|
And github API cannot detect upstream changes immediately.
|
|
If you set |g:dein#install_check_remote_threshold|, the check
|
|
is more strict but slower.
|
|
|
|
*dein#check_clean()*
|
|
dein#check_clean()
|
|
Returns the non-used plugins directories. You can write the
|
|
wrap command to remove them.
|
|
|
|
*dein#clear_state()*
|
|
dein#clear_state()
|
|
Clear the state file manually.
|
|
|
|
*dein#config()*
|
|
dein#config({plugin-name}, {options})
|
|
dein#config({options})
|
|
Change plugin options for {plugin-name}.
|
|
It you omit {plugin-name}, it uses |g:dein#name| variable.
|
|
If {plugin-name} is list, you can change the options in the
|
|
multiple plugins.
|
|
If {plugin-name} is already loaded or invalid, it will be
|
|
ignored.
|
|
|
|
Note: You must call it within |dein#begin()| / |dein#end()|
|
|
block.
|
|
>
|
|
call dein#add('Shougo/deoplete.nvim')
|
|
call dein#config('deoplete.nvim', {
|
|
\ 'lazy' : 1, 'on_event' : 'InsertEnter',
|
|
\ })
|
|
<
|
|
*dein#deno_cache()*
|
|
dein#deno_cache({plugins})
|
|
Update {plugins} deno cache.
|
|
If you omit {plugins}, all plugins cache is updated.
|
|
It is executed automatically when plugins are updated.
|
|
Note: "deno" must be executable in your "$PATH".
|
|
|
|
*dein#direct_install()*
|
|
dein#direct_install({repo}[, {options}])
|
|
Direct install a plugin without editing the configuration.
|
|
The arguments are same with |dein#add()|.
|
|
It installs and sources the plugin.
|
|
Note: The direct installed plugins configuration is saved in
|
|
|dein#get_direct_plugins_path()|. You can load or edit it. >
|
|
|
|
" Try deoplete without the configuration.
|
|
call dein#direct_install('Shougo/deoplete.nvim')
|
|
<
|
|
*dein#disable()*
|
|
dein#disable({plugins})
|
|
Disables plugins specified by {plugins}.
|
|
{plugins} is the plugins name list.
|
|
Note: This command must be executed before dein loads
|
|
the plugins.
|
|
Note: The plugins must be disabled |dein-options-merged|.
|
|
Because merged plugins are moved to plugins directory and
|
|
loaded automatically.
|
|
Note: Disabled plugins are removed from dein's plugin list.
|
|
You cannot get disabled plugins from dein.
|
|
|
|
*dein#each()*
|
|
dein#each({command}[, {plugins}])
|
|
Execute {command} for {plugins}.
|
|
{plugins} is the plugins name list.
|
|
You can execute "git gc" command for the plugins.
|
|
|
|
*dein#end()*
|
|
dein#end()
|
|
End dein configuration block.
|
|
You must not use the plugins in |dein#begin()| block.
|
|
If you enable |g:dein#auto_recache|, it executes
|
|
|dein#recache_runtimepath()| automatically.
|
|
Note: 'runtimepath' is changed after |dein#end()|.
|
|
|
|
*dein#get()*
|
|
dein#get([{plugin-name}])
|
|
Get the plugin options dictionary for {plugin-name}.
|
|
If you omit {plugin-name}, dein will return the plugins
|
|
dictionary. The key is the plugin name. The value is the
|
|
plugin dictionary.
|
|
|
|
*dein#get_direct_plugins_path()*
|
|
dein#get_direct_plugins_path()
|
|
Get the direct installed plugins script path.
|
|
|
|
*dein#get_failed_plugins()*
|
|
dein#get_failed_plugins()
|
|
Get the previous installation failed plugins.
|
|
|
|
*dein#get_updated_plugins()*
|
|
dein#get_updated_plugins([, {plugins}])
|
|
Get updated {plugins} by github GraphQL API.
|
|
https://docs.github.com/en/graphql
|
|
{plugins} are the plugins name list or the plugin name to
|
|
check.
|
|
Note: You can use it for github plugins.
|
|
Note: You need to set |g:dein#install_github_api_token| to use
|
|
the feature.
|
|
|
|
*dein#get_log()*
|
|
dein#get_log()
|
|
Get all previous install logs.
|
|
|
|
*dein#get_progress()*
|
|
dein#get_progress()
|
|
Get current update progress message.
|
|
|
|
*dein#get_updates_log()*
|
|
dein#get_updates_log()
|
|
Print previous update logs.
|
|
|
|
*dein#install()*
|
|
dein#install([{plugins}])
|
|
Install the plugins asynchronously.
|
|
{plugins} is the plugins name list.
|
|
If you omit it, dein will install all plugins.
|
|
|
|
*dein#is_available()*
|
|
dein#is_available([{plugin-name}])
|
|
Return non-zero if {plugin-name} exists and is enabled.
|
|
|
|
*dein#is_sourced()*
|
|
dein#is_sourced({plugin-name})
|
|
Return non-zero if {plugin-name} exists and is sourced.
|
|
See |dein#source()| and |dein#tap()| as well.
|
|
|
|
*dein#load_dict()*
|
|
dein#load_dict({dict}, [{options}])
|
|
Load the plugin configuration from {dict}. {dict} is the
|
|
|Dictionary|. The key is the repository URI and the value is
|
|
the |dein-options| dictionary. See |dein-options| for keys to
|
|
set in {options}. >
|
|
|
|
call dein#load_dict({
|
|
\ 'Shougo/denite.nvim': {},
|
|
\ 'Shougo/deoplete.nvim': {'name': 'deoplete'}
|
|
\ })
|
|
<
|
|
*dein#load_rollback()*
|
|
dein#load_rollback({rollbackfile}[, {plugins}])
|
|
Rollback {plugins} from {rollbackfile}.
|
|
Note: It is the dangerous command.
|
|
|
|
*dein#load_state()*
|
|
*dein#min#load_state()*
|
|
dein#load_state({base-path})
|
|
dein#min#load_state({base-path})
|
|
Load dein's state from the cache script, {base-path} is where
|
|
your downloaded plugins will be placed.
|
|
Note: You must call it before |dein#begin()|. It clears dein
|
|
all configuration.
|
|
Note: It overwrites your 'runtimepath' completely, you must
|
|
not call it after change 'runtimepath' dynamically.
|
|
Note: The block is skipped if dein's state is loaded.
|
|
Note: |dein#min#load_state()| is faster a bit.
|
|
|
|
It returns 1, if the cache script is old or invalid or not
|
|
found.
|
|
>
|
|
if dein#min#load_state(path)
|
|
call dein#begin(path)
|
|
" My plugins here:
|
|
" ...
|
|
call dein#end()
|
|
call dein#save_state()
|
|
endif
|
|
<
|
|
*dein#load_toml()*
|
|
dein#load_toml({filename}, [{options}])
|
|
Load TOML plugin configuration from {filename}. See
|
|
|dein-options| for keys to set in {options}.
|
|
Note: TOML parser is slow. You should use it with
|
|
|dein#load_state()| and |dein#save_state()|.
|
|
Note: You need to specify toml files in |dein#begin()|
|
|
argument.
|
|
|
|
For toml file formats: |dein-toml|
|
|
>
|
|
let s:toml = '~/test_vim/lazy.toml'
|
|
if dein#load_state('~/test_vim/.cache/dein')
|
|
call dein#begin('~/test_vim/.cache/dein')
|
|
|
|
call dein#load_toml(s:toml, {'lazy': 1})
|
|
|
|
call dein#end()
|
|
call dein#save_state()
|
|
endif
|
|
<
|
|
*dein#local()*
|
|
dein#local({directory}, [{options}, [{names}]])
|
|
Add the subdirectories in {directory} to 'runtimepath', like
|
|
"pathogen" does. See |dein-options| for keys to set in
|
|
{options}.
|
|
If {names} is given, {names} directories are only loaded.
|
|
{names} is |wildcards| list.
|
|
>
|
|
" Load plugin from "~/.vim/bundle".
|
|
call dein#local("~/.vim/bundle")
|
|
" Load plugin1 and plugin2 from "~/.vim/bundle".
|
|
call dein#local("~/.vim/bundle", {},
|
|
\ ['plugin1', 'plugin2', 'vim-*', '*.vim'])
|
|
<
|
|
*dein#toml#syntax()*
|
|
dein#toml#syntax()
|
|
Enable dein specific toml syntax.
|
|
Note: It is experimental feature.
|
|
|
|
*dein#update()*
|
|
dein#update([{plugins}])
|
|
Install/Update the plugins.
|
|
{plugins} is the plugins name list.
|
|
If you omit it, dein will update all plugins.
|
|
Note: If you are using neovim or Vim 8.0+, it runs
|
|
asynchronously.
|
|
|
|
*dein#plugins2toml()*
|
|
dein#plugins2toml({plugins})
|
|
Returns the toml configurations for {plugins}
|
|
{plugins} is the plugins dictionary from |dein#get()|.
|
|
|
|
*dein#post_sync()*
|
|
dein#post_sync({plugins})
|
|
Execute an process needed after the plugins are updated.
|
|
It can be used to create third-party dein upgrader.
|
|
{plugins} is the plugins name list that was updated.
|
|
|
|
*dein#reinstall()*
|
|
dein#reinstall({plugins})
|
|
Reinstall the plugins.
|
|
{plugins} is the plugins name list.
|
|
|
|
*dein#remote_plugins()*
|
|
dein#remote_plugins()
|
|
Load not loaded neovim |remote-plugin| and execute
|
|
":UpdateRemotePlugins" command.
|
|
It is better than ":UpdateRemotePlugins" for dein.
|
|
Note: It is valid only in neovim.
|
|
|
|
*dein#rollback()*
|
|
dein#rollback({date}[, {plugins}])
|
|
Rollback to the latest matched {date} revisions for {plugins}.
|
|
If {date} is "", it rollbacks to the latest revisions.
|
|
{plugins} is the plugins name list.
|
|
Note: It is the dangerous command.
|
|
|
|
*dein#recache_runtimepath()*
|
|
dein#recache_runtimepath()
|
|
Re-make the dein runtimepath cache and execute |:helptags|.
|
|
It is called automatically after the installation.
|
|
|
|
*dein#save_rollback()*
|
|
dein#save_rollback({rollbackfile}[, {plugins}])
|
|
Save {plugins} rollback information to {rollbackfile}.
|
|
|
|
*dein#save_state()*
|
|
dein#save_state()
|
|
Save dein's state in the cache script.
|
|
It must be after |dein#end()|.
|
|
Note: It is available when loading .vimrc.
|
|
Note: It saves your 'runtimepath' completely, you must not
|
|
call it after change 'runtimepath' dynamically.
|
|
|
|
*dein#set_hook()*
|
|
dein#set_hook({plugins}, {hook-name}, {hook})
|
|
{plugins} is the plugins name list.
|
|
If it is empty list, it means all plugins.
|
|
Set hook {hook} as {hook-name} in {plugins}.
|
|
It can be called after |dein#begin()| / |dein#end()| block.
|
|
Note: If it is |Funcref|, it does not work in
|
|
|dein#load_state()| / |dein#save_state()| block.
|
|
>
|
|
call dein#add('Shougo/neosnippet.vim', {'lazy': 1})
|
|
function! Foo() abort
|
|
endfunction
|
|
" Does not work for dein#load_state()/dein#save_state() block
|
|
call dein#set_hook('neosnippet.vim', 'hook_source', function('Foo'))
|
|
" Does work for dein#load_state()/dein#save_state() block
|
|
call dein#set_hook('neosnippet.vim', 'hook_source', 'echomsg "foo"')
|
|
<
|
|
*dein#source()*
|
|
dein#source([{plugins}])
|
|
|:source| the plugins specified by {plugins}.
|
|
{plugins} is the plugins name list.
|
|
If you omit it, dein will source all plugins.
|
|
It returns sourced plugins list.
|
|
|
|
*dein#tap()*
|
|
dein#tap({plugin-name})
|
|
Return non-zero if {plugin-name} exists and isn't
|
|
disabled.
|
|
It initializes |g:dein#name| and |g:dein#plugin| variables.
|
|
|
|
------------------------------------------------------------------------------
|
|
VARIABLES *dein-variables*
|
|
|
|
*g:dein#auto_recache*
|
|
g:dein#auto_recache
|
|
If you set it to |v:true|, call |dein#recache_runtimepath()|
|
|
automatically in |dein#save_state()|.
|
|
Note: It is slow especially Windows.
|
|
|
|
Default: v:false
|
|
|
|
*g:dein#auto_remote_plugins*
|
|
g:dein#auto_remote_plugins
|
|
If you set it to |v:true|, call |dein#remote_plugins()|
|
|
automatically in |dein#recache_runtimepath()|.
|
|
|
|
Default: v:true
|
|
|
|
*g:dein#cache_directory*
|
|
g:dein#cache_directory
|
|
The cache directory to use.
|
|
|
|
Default: Under the base directory you have already specified
|
|
by |dein#begin()|.
|
|
|
|
*g:dein#default_options*
|
|
g:dein#default_options
|
|
The default options for plugins.
|
|
|
|
Default: {}
|
|
|
|
*g:dein#download_command*
|
|
g:dein#download_command
|
|
The default download command.
|
|
|
|
Default: "curl --silent --location --output" or "wget -q -O"
|
|
or use PowerShell.
|
|
|
|
*g:dein#enable_name_conversion*
|
|
g:dein#enable_name_conversion
|
|
If you set it to 1 and omit plugin name,
|
|
|dein-options-normalized_name| is used as plugin name.
|
|
It is useful for absorbing difference of repository name.
|
|
|
|
Defaults: v:false
|
|
|
|
*g:dein#enable_notification*
|
|
g:dein#enable_notification
|
|
If you set it to 1, dein uses the notification feature.
|
|
|
|
In neovim: Use "nvim-notify" or |nvim_notify()| API
|
|
https://github.com/rcarriga/nvim-notify
|
|
|
|
In Vim: Use "vim-notification" or |popup_notification()| API
|
|
https://github.com/mattn/vim-notification
|
|
|
|
Defaults: v:false
|
|
|
|
*g:dein#inline_vimrcs*
|
|
g:dein#inline_vimrcs
|
|
The vimrcs are sourced in |dein#end()| or
|
|
|dein#load_state()|.
|
|
Note: It must be set before |dein#begin()|.
|
|
Note: The files must not be included "<<" pattern(here
|
|
document). It breaks the parser.
|
|
|
|
Defaults: []
|
|
|
|
*g:dein#install_check_diff*
|
|
g:dein#install_check_diff
|
|
It checks plugins documentation diff when updated plugins.
|
|
Note: Dein outputs the diff to new buffer in the background.
|
|
|
|
Defaults: v:false
|
|
|
|
*g:dein#install_check_remote_threshold*
|
|
g:dein#install_check_remote_threshold
|
|
If the repository is updated newer than the threshold, use
|
|
strict "git ls-remote" check when |dein#check_update()|.
|
|
The unit is second.
|
|
|
|
Defaults: 0
|
|
>
|
|
" Strict check updated plugins yesterday
|
|
let g:dein#install_check_remote_threshold = 24 * 60 * 60
|
|
<
|
|
*g:dein#install_copy_vim*
|
|
g:dein#install_copy_vim
|
|
It use Vim script copy routine when
|
|
|dein#recache_runtimepath()|.
|
|
|
|
Defaults: v:true if neovim and not Windows
|
|
|
|
*g:dein#install_github_api_token*
|
|
g:dein#install_github_api_token
|
|
github API key to use |dein#check_update()|.
|
|
https://github.com/settings/tokens
|
|
|
|
Defaults: ""
|
|
|
|
*g:dein#install_max_processes*
|
|
g:dein#install_max_processes
|
|
The max number of processes used for dein/install source
|
|
asynchronous update.
|
|
If it is less than equal 1, this feature is disabled.
|
|
|
|
Defaults: "16"(Windows) or "8"(Others)
|
|
|
|
*g:dein#install_process_timeout*
|
|
g:dein#install_process_timeout
|
|
The time of timeout seconds when updating/installing plugins.
|
|
|
|
Defaults: "120"
|
|
|
|
*g:dein#install_progress_type*
|
|
g:dein#install_progress_type
|
|
The output type of the progress bar in the installer.
|
|
Note: If you want to display the progress in the 'statusline',
|
|
you should use |dein#get_progress()|.
|
|
|
|
"none":
|
|
Disabled.
|
|
"echo":
|
|
Displayed in the echo area.
|
|
"tabline":
|
|
Displayed in the 'tabline'.
|
|
"title":
|
|
Displayed in the 'titlestring'.
|
|
Note: It is neovim only support
|
|
"floating":
|
|
Displayed in the floating/popup window.
|
|
|
|
Defaults: "echo"
|
|
|
|
*g:dein#install_message_type*
|
|
g:dein#install_message_type
|
|
The output type of the messages in the installer.
|
|
|
|
"none":
|
|
Disabled.
|
|
"echo":
|
|
Displayed in the echo area.
|
|
|
|
*g:dein#install_log_filename*
|
|
g:dein#install_log_filename
|
|
The log filename. Set it to "" to disable logging.
|
|
Note: This option slows your installation process.
|
|
|
|
Default: ""
|
|
|
|
*g:dein#lazy_rplugins*
|
|
g:dein#lazy_rplugins
|
|
If you set it to 1, neovim remote plugins are lazy loaded.
|
|
It is useful to save startup time.
|
|
Note: It disables all remote plugins at startup. You must
|
|
define all remote plugins as lazy loaded if it is enabled.
|
|
|
|
Defaults: v:false
|
|
|
|
*g:dein#name*
|
|
g:dein#name
|
|
Current plugin name.
|
|
You can only use it in |dein#tap()| block.
|
|
Note: The variable is deprecated.
|
|
|
|
*g:dein#notification_icon*
|
|
g:dein#notification_icon
|
|
The notification icon path or stocked icon to display.
|
|
|
|
Default: ""
|
|
|
|
*g:dein#notification_time*
|
|
g:dein#notification_time
|
|
This is the time the notification should be displayed in
|
|
milli seconds.
|
|
|
|
Default: 2000
|
|
|
|
*g:dein#plugin*
|
|
g:dein#plugin
|
|
Current plugin.
|
|
You can use it in |dein#tap()| block or |dein-hooks|.
|
|
|
|
*g:dein#types#git#clone_depth*
|
|
g:dein#types#git#clone_depth
|
|
The default history depth for "git clone".
|
|
If it is 1, dein will use shallow clone feature.
|
|
See |dein-options-type__depth|.
|
|
|
|
Default: 0
|
|
|
|
*g:dein#types#git#command_path*
|
|
g:dein#types#git#command_path
|
|
The "git" command path used for git type.
|
|
|
|
Default: "git"
|
|
|
|
*g:dein#types#git#default_hub_site*
|
|
g:dein#types#git#default_hub_site
|
|
The default hub site used for git type.
|
|
|
|
Default: "github.com"
|
|
|
|
*g:dein#types#git#default_protocol*
|
|
g:dein#types#git#default_protocol
|
|
The default protocol used for git (github).
|
|
Note: It only accepts "https" or "ssh".
|
|
|
|
Default: "https"
|
|
|
|
*g:dein#types#git#pull_command*
|
|
g:dein#types#git#pull_command
|
|
The git command used to pull updates.
|
|
|
|
Default: "pull --ff --ff-only"
|
|
|
|
------------------------------------------------------------------------------
|
|
OPTIONS *dein-options*
|
|
The {options} accepts the following keys:
|
|
|
|
*dein-options-augroup*
|
|
augroup (String)
|
|
An augroup name that the plugin uses for |VimEnter| or
|
|
|GUIEnter| autocmd events.
|
|
|
|
*dein-options-build*
|
|
build (String)
|
|
Specify the build script.
|
|
This command is executed by |system()| in the plugin
|
|
runtimepath.
|
|
Note: In previous versions of dein, build could also be of
|
|
type dictionary, but that is now deprecated.
|
|
Please use |dein-options-hook_post_update| instead.
|
|
|
|
Example:
|
|
>
|
|
call dein#add('Shougo/vimproc.vim', {'build': 'make'})
|
|
<
|
|
Note: The command is executed in plugin top directory.
|
|
If you need cd command, you must use "sh -c". >
|
|
call dein#add('wincent/command-t', {
|
|
\ 'build':
|
|
\ 'sh -c "cd ruby/command-t && ruby extconf.rb && make"'
|
|
\ })
|
|
<
|
|
*dein-options-depends*
|
|
depends (List or String)
|
|
Specify a list of plugins a plugin depends on.
|
|
List items are '{plugin-name}'.
|
|
Those specified in the list are NOT installed automatically.
|
|
Note: The loading order is not guaranteed in non lazy plugins.
|
|
|
|
*dein-options-frozen*
|
|
frozen (Bool)
|
|
If set to v:true, dein doesn't update it automatically. It is
|
|
useful for outdated plugins that can no longer be updated.
|
|
|
|
*dein-options-ftplugin*
|
|
ftplugin (Dictionary)
|
|
"_" key is executed after all ftplugin.
|
|
"{filetype}" key is executed {filetype} ftplugin.
|
|
Note: You need to call |dein#recache_runtimepath()| or enable
|
|
|g:dein#auto_recache| after vimrc is changed.
|
|
|
|
*dein-options-if*
|
|
if (Bool) or (String)
|
|
If set to |v:false|, dein doesn't load the plugin.
|
|
If it is |String|, dein will eval it.
|
|
If you don't set it, dein will register (enable) the plugin.
|
|
Note: You cannot disable plugins register in dein if you use
|
|
the option.
|
|
|
|
*dein-options-lazy*
|
|
lazy (Bool)
|
|
If set to v:true, dein doesn't add the path to 'runtimepath'
|
|
automatically.
|
|
If you don't set it, dein will set it automatically when the
|
|
conditions are met.
|
|
Note: You should not specify the plugins which have no
|
|
"plugin/" directory as lazy load plugins. It is meaningless
|
|
and just increases the overhead. You can get the no meaning
|
|
lazy plugins by |dein#check_lazy_plugins()|.
|
|
|
|
*dein-options-merged*
|
|
merged (Bool)
|
|
If set to v:false, dein doesn't merge the plugin directory.
|
|
It is useful for the plugin files conflicts.
|
|
|
|
Default: See |dein-merge|.
|
|
|
|
*dein-options-merge_ftdetect*
|
|
merge_ftdetect (Bool)
|
|
If set to v:true, dein merge the plugin "ftdetect" directory.
|
|
It is useful to enable file detection when lazy loaded plugin.
|
|
Note: It does not work if ftdetect script depends on lazy
|
|
plugin functions.
|
|
|
|
*dein-options-name*
|
|
name (String)
|
|
Specify the name of the plugin. This is used for dein
|
|
management and other functions. If it is omitted, the tail of
|
|
the repository name will be used.
|
|
Note: Must be unique across the all plugin. If the plugin
|
|
name conflicts with another plugin, dein will overwrite the
|
|
previous settings with the new one. If the repo tail is bound
|
|
to conflict, you can set the "name" option manually to prevent
|
|
overwriting an existing plugin setting.
|
|
|
|
*dein-options-normalized_name*
|
|
normalized_name (String)
|
|
Specify the normalized name of the plugin. If omitted, dein
|
|
will normalize the tail of the repository name.
|
|
Note: Must be unique across all plugins.
|
|
Normalized name example:
|
|
name : normalized name
|
|
>
|
|
denite.nvim denite
|
|
dein.vim dein
|
|
vim-quickrun quickrun
|
|
dps-dial dial
|
|
denops-foo foo
|
|
<
|
|
*dein-options-on_cmd*
|
|
on_cmd (List) or (String)
|
|
If it is matched to the executed command, dein will call
|
|
|dein#source()|.
|
|
|
|
*dein-options-on_event*
|
|
on_event (String) or (List)
|
|
dein will call |dein#source()| on the events.
|
|
|
|
*dein-options-on_func*
|
|
on_func (List) or (String)
|
|
If it is matched to the called function, dein will call
|
|
|dein#source()|.
|
|
Note: It does not work when Vim initialised.
|
|
|
|
*dein-options-on_ft*
|
|
on_ft (List) or (String)
|
|
If it is matched to 'filetype', dein will call
|
|
|dein#source()|.
|
|
|
|
*dein-options-on_if*
|
|
on_if (String)
|
|
If it is evaluated and it is non-zero, dein will call
|
|
|dein#source()|.
|
|
The default evaluate timings are "BufRead", "BufNewFile",
|
|
"VimEnter" and "FileType".
|
|
If |dein-options-on_event| exists, it is evaluated when
|
|
|dein-options-on_event|.
|
|
|
|
For example: >
|
|
call dein#add('blueyed/vim-diminactive',
|
|
\ {'on_event': 'WinEnter', 'on_if': 'winnr("$") > 1'})
|
|
<
|
|
*dein-options-on_lua*
|
|
on_lua (List) or (String)
|
|
If it is matched to the required lua module root, dein will
|
|
call |dein#source()|.
|
|
Note: It is for neovim only.
|
|
Note: It does not work for neovim standard modules and require
|
|
in |vim.loop| modules.
|
|
Note: You cannot require on_lua plugins in
|
|
|dein-options-hook_add|. Because the plugins are not
|
|
initialized.
|
|
|
|
*dein-options-on_map*
|
|
on_map (Dictionary) or (List) or (String)
|
|
If it is the Dictionary, the key is {mode} and the items are
|
|
{mapping} or [{mapping1}, {mapping2}, ...].
|
|
If it is the List, the items are {mapping} or [{mode},
|
|
{mapping1}, [{mapping2}, ...]].
|
|
If {mode} is omitted, "nx" is used.
|
|
Note: You can use plugin prefix mappings.
|
|
For example, you can use "<Plug>(ref-" instead of
|
|
"<Plug>(ref-back)" and so on.
|
|
For example: >
|
|
call dein#add('Shougo/deol.nvim',
|
|
\ { 'on_map': {'n': '<Plug>'} })
|
|
<
|
|
Note: You can use "<Plug>" keyword as {mapping}. If
|
|
{mapping} is "<Plug>", "<Plug>({normalized_name}" is
|
|
used.
|
|
For example: >
|
|
" It is same as "'on_map': '<Plug>(anzu'"
|
|
call dein#add('osyo-manga/vim-anzu', {'on_map': '<Plug>'})
|
|
|
|
" It is same as "'on_map': '<Plug>(easy-align'"
|
|
" But it does not work as expected. Because the plugin
|
|
" defines '<Plug>(EasyAlign)' mapping instead.
|
|
call dein#add('junegunn/vim-easy-align', {'on_map': '<Plug>'})
|
|
|
|
" This works as expected
|
|
call dein#add('junegunn/vim-easy-align',
|
|
\ {'on_map': '<Plug>(EasyAlign)'})
|
|
<
|
|
Note: You cannot use lazy <Plug> mappings twice.
|
|
For example: >
|
|
call dein#add('osyo-manga/vim-anzu',
|
|
\ {'on_map': '<Plug>(anzu-'}
|
|
" Not working!!
|
|
nmap n <Plug>(anzu-jump-n)<Plug>(anzu-echo-search-status)zv
|
|
nmap N <Plug>(anzu-jump-N)<Plug>(anzu-echo-search-status)zv
|
|
<
|
|
*dein-options-on_path*
|
|
on_path (List) or (String)
|
|
If set to ".*", dein will call |dein#source()| on editing all
|
|
files. Otherwise, dein will call |dein#source()| if the
|
|
buffer name is matched to the string pattern.
|
|
Note: It is useful for explorer behavior plugins.
|
|
|
|
*dein-options-on_source*
|
|
on_source (List) or (String)
|
|
Load the plugin before the listed plugins are loaded.
|
|
Note: The plugins must be lazy loaded plugins.
|
|
|
|
*dein-options-overwrite*
|
|
overwrite (Bool)
|
|
If set to v:true, dein overwrite existing plugin config when
|
|
|dein#add()|.
|
|
|
|
*dein-options-path*
|
|
path (String)
|
|
Specify the plugin downloaded path.
|
|
|
|
*dein-options-rev*
|
|
rev (String)
|
|
Specify a revision number or branch/tag name.
|
|
If it is "*" in "git" type, dein will use latest released tag.
|
|
You can specify the wildcards like "0.*".
|
|
Note: If the type is "raw", rev must be hash number.
|
|
|
|
Example:
|
|
>
|
|
call dein#add('Shougo/deol.nvim', { 'rev': 'a1b5108fd5' })
|
|
<
|
|
*dein-options-rtp*
|
|
rtp (String)
|
|
Specify the runtime path.
|
|
You can use it when the repository has the Vim plugin in a
|
|
subdirectory.
|
|
For example: https://github.com/rstacruz/sparkup
|
|
If it is empty string, dein will not add the path to
|
|
'runtimepath'
|
|
|
|
Example:
|
|
>
|
|
call dein#add('rstacruz/sparkup', {'rtp': 'vim'})
|
|
<
|
|
*dein-options-script_type*
|
|
script_type (String)
|
|
Specify the script type. It is useful for non-official
|
|
categorized plugins.
|
|
For example: "indent", "plugin", "ftplugin", ...
|
|
Note: You must not specify it for categorized plugins.
|
|
Example:
|
|
>
|
|
call dein#add(
|
|
\ 'https://raw.githubusercontent.com/Shougo/'
|
|
\ . 'shougo-s-github/master/vim/colors/candy.vim',
|
|
\ {'script_type' : 'colors'})
|
|
call dein#add(
|
|
\ 'https://github.com/bronzehedwick/impactjs-colorscheme',
|
|
\ {'script_type' : 'colors'})
|
|
<
|
|
*dein-options-timeout*
|
|
timeout (Number)
|
|
The time of timeout seconds when updating/installing plugins.
|
|
If omit it, |g:dein#install_process_timeout| will be used.
|
|
|
|
*dein-options-trusted*
|
|
trusted (Bool)
|
|
If set to v:true, dein will load the plugin in "sudo" mode.
|
|
If you don't set it, dein won't load it.
|
|
|
|
*dein-options-type*
|
|
type (String)
|
|
Specify the repository type. If it is omitted, a guess is made
|
|
based on {repository}.
|
|
|
|
The available types:
|
|
"none" : None repository
|
|
"raw" : Raw plugin file ("script_type" attribute is
|
|
needed)
|
|
"git" : Git
|
|
|
|
*dein-options-type__depth*
|
|
type__depth (Number)
|
|
The history depth for "git clone".
|
|
If omitted, |g:dein#types#git#clone_depth| is used.
|
|
If it is than 0, dein clones the repository by shallow
|
|
clone. Shallow clone feature saves your repository clone time.
|
|
But it has problems in some repository.
|
|
|
|
See below issues:
|
|
https://github.com/Shougo/neobundle.vim/issues/81
|
|
https://github.com/Homebrew/homebrew/issues/12024
|
|
|
|
Note: This attribute is available in git type only.
|
|
|
|
------------------------------------------------------------------------------
|
|
HOOKS *dein-hooks*
|
|
|
|
The string will be split by the lines.
|
|
It is useful for the plugins initialization.
|
|
|
|
Note: You cannot use function hooks in |dein#save_state()|.
|
|
Note: You can use |g:dein#plugin| in the hooks.
|
|
Note: The loading order is not guaranteed in non lazy plugins.
|
|
Note: The string is executed as Ex commands.
|
|
|
|
*dein-options-hook_add*
|
|
hook_add (String) or (Function)
|
|
It is executed after the line is parsed.
|
|
Note: You cannot call plugin function in "hook_add".
|
|
Because the plugin is not sourced when "hook_add".
|
|
>
|
|
call dein#add('Shougo/defx.nvim', {
|
|
\ 'hook_add': 'nnoremap <silent> <Space>v
|
|
\ :<C-u>Defx<CR>'
|
|
\ })
|
|
call dein#add('kana/vim-niceblock', {
|
|
\ 'hook_add': join(['xmap I <Plug>(niceblock-I)',
|
|
'xmap A <Plug>(niceblock-A)'], "\n")
|
|
\ })
|
|
call dein#add('godlygeek/csapprox', {
|
|
\ 'hook_add': "
|
|
\ let g:CSApprox_konsole = 1\n
|
|
\ let g:CSApprox_attr_map =
|
|
\ { 'bold' : 'bold', 'italic' : '', 'sp' : '' }\n
|
|
\ "})
|
|
<
|
|
*dein-options-hook_done_update*
|
|
hook_done_update (String) or (Function)
|
|
It is executed after plugins are sourced and updated.
|
|
|
|
*dein-options-hook_post_source*
|
|
hook_post_source (String) or (Function)
|
|
It is executed after plugins are sourced.
|
|
|
|
Note: In Vim initializing, you must call the
|
|
"hook_post_source" hooks manually in |VimEnter| if needed.
|
|
>
|
|
autocmd VimEnter * call dein#call_hook('post_source')
|
|
<
|
|
*dein-options-hook_post_update*
|
|
hook_post_update (String) or (Function)
|
|
It is executed after are updated and before
|
|
|dein-options-build|.
|
|
Note: The plugin may not be sourced.
|
|
|
|
*dein-options-hook_source*
|
|
hook_source (String) or (Function)
|
|
It is executed before plugins are sourced.
|
|
Note: The "sourced" means after |dein#end()| or when
|
|
|VimEnter| or autoloaded.
|
|
>
|
|
call dein#add('artur-shaik/vim-javacomplete2')
|
|
call dein#config('artur-shaik/vim-javacomplete2', {
|
|
\ 'hook_source': 'autocmd FileType java
|
|
\ setlocal omnifunc=javacomplete#Complete'
|
|
\ })
|
|
function! Func() abort
|
|
autocmd FileType qf nnoremap <buffer> r :<C-u>Qfreplace<CR>
|
|
endfunction
|
|
call dein#source('thinca/vim-qfreplace',
|
|
\ 'hook_source': function('Func'))
|
|
<
|
|
Note: non lazy plugins' |dein-options-hook_source| cannot be
|
|
called. You must call it by |dein#call_hook()| if needed.
|
|
>
|
|
call dein#begin()
|
|
...
|
|
call dein#end()
|
|
call dein#call_hook('source')
|
|
<
|
|
------------------------------------------------------------------------------
|
|
TOML *dein-toml*
|
|
|
|
TOML file format specification:
|
|
https://github.com/toml-lang/toml
|
|
Note: Original TOML parser is created by kamichidu.
|
|
https://github.com/kamichidu
|
|
|
|
*dein-toml-ftplugin*
|
|
ftplugin (Dictionary)
|
|
"_" key is executed after all ftplugin.
|
|
"{filetype}" key is executed {filetype} ftplugin.
|
|
You can define multiple filetypes by "{filetype1}_{filetype2}"
|
|
key. "b:undo_ftplugin" is defined automatically.
|
|
Note: You need to call |dein#recache_runtimepath()| or enable
|
|
|g:dein#auto_recache| after vimrc is changed.
|
|
|
|
*dein-toml-hook_add*
|
|
hook_add (String)
|
|
It is the global |dein-options-hook_add|.
|
|
It is executed in |dein#end()|.
|
|
|
|
*dein-toml-plugins*
|
|
plugins (Dictionary)
|
|
It is converted to |dein#add()|.
|
|
"repo" key is needed.
|
|
|
|
*dein-toml-multple_plugins*
|
|
multiple_plugins (Dictionary)
|
|
It is converted to |dein-toml-hook_add|.
|
|
"plugins" key is needed.
|
|
|
|
*dein-toml-example*
|
|
|
|
TOML file sample is here:
|
|
>
|
|
# TOML sample
|
|
hook_add = 'let g:foo = 0'
|
|
|
|
[ftplugin]
|
|
# Execute after ftplugin.
|
|
_ = '''
|
|
setl formatoptions-=ro | setl formatoptions+=mMBl
|
|
'''
|
|
html = '''
|
|
setlocal includeexpr=substitute(v:fname,'^\\/','','')
|
|
setlocal path+=./;/
|
|
'''
|
|
|
|
[[plugins]]
|
|
repo = 'Shougo/neosnippet.vim'
|
|
on_event = 'InsertEnter'
|
|
on_ft = 'snippet'
|
|
|
|
[[plugins]]
|
|
repo = 'rhysd/accelerated-jk'
|
|
on_map = '<Plug>'
|
|
hook_add = '''
|
|
nmap <silent>j <Plug>(accelerated_jk_gj)
|
|
nmap <silent>k <Plug>(accelerated_jk_gk)
|
|
'''
|
|
[plugins.ftplugin]
|
|
python = '''
|
|
let b:undo_ftplugin .= 'setlocal foldmethod<'
|
|
setlocal foldmethod=indent
|
|
|
|
# "hook_add" is only executed when both "foo" and "bar" are
|
|
# available.
|
|
[[multiple_plugins]]
|
|
plugins = ['foo', 'bar']
|
|
hook_add = ''
|
|
'''
|
|
|
|
==============================================================================
|
|
DDU SOURCES *dein-ddu-sources*
|
|
|
|
*dein-ddu-source-dein*
|
|
dein
|
|
Nominates dein plugins as candidates.
|
|
|
|
==============================================================================
|
|
UNITE SOURCES *dein-unite-sources*
|
|
|
|
Here let me explain about a source for unite plugin provided in dein.
|
|
|
|
*dein-unite-source-dein*
|
|
dein
|
|
Nominates dein plugins as candidates.
|
|
|
|
Note:
|
|
If argument is bang(!), print plugins status.
|
|
|
|
*dein-unite-source-dein_log*
|
|
dein_log
|
|
Print previous dein install logs.
|
|
And you can jump the diff URI in github.
|
|
|
|
If argument 1 is "!", the updated logs are displayed.
|
|
|
|
Source arguments:
|
|
1. "!"
|
|
|
|
==============================================================================
|
|
DENITE SOURCES *dein-denite-sources*
|
|
|
|
Here let me explain about a source for denite plugin provided in dein.
|
|
|
|
*dein-denite-source-dein*
|
|
dein
|
|
Nominates dein plugins as candidates.
|
|
|
|
*dein-denite-source-dein-log*
|
|
dein/log
|
|
Print previous dein install logs.
|
|
And you can jump the diff URI in github.
|
|
|
|
If argument 1 is "!", the updated logs are displayed.
|
|
|
|
Source arguments:
|
|
1. "!"
|
|
|
|
==============================================================================
|
|
EXAMPLES *dein-examples*
|
|
>
|
|
if &compatible
|
|
set nocompatible " Be iMproved
|
|
endif
|
|
|
|
" Required:
|
|
set runtimepath+={path to dein.vim directory}
|
|
|
|
" Required:
|
|
call dein#begin({path to plugin base path directory})
|
|
|
|
" Let dein manage dein
|
|
call dein#add({path to dein.vim directory})
|
|
if !has('nvim')
|
|
call dein#add('roxma/nvim-yarp')
|
|
call dein#add('roxma/vim-hug-neovim-rpc')
|
|
endif
|
|
|
|
" Add or remove your plugins here like this:
|
|
"call dein#add('Shougo/neosnippet.vim')
|
|
"call dein#add('Shougo/neosnippet-snippets')
|
|
|
|
" Required:
|
|
call dein#end()
|
|
|
|
" Required:
|
|
filetype plugin indent on
|
|
syntax enable
|
|
|
|
" If you want to install not installed plugins on startup.
|
|
"if dein#check_install()
|
|
" call dein#install()
|
|
"endif
|
|
<
|
|
==============================================================================
|
|
PLUGINS MERGED FEATURE *dein-merge*
|
|
|
|
dein.vim copies the files of multiple plugins into a single directory and
|
|
loads them as plugins by default. It expects to improve performance.
|
|
|
|
That path is usually `DEIN_INSTALLED_DIR/.cache/init.vim/.dein`.
|
|
For DEIN_INSTALLED_DIR, see |dein-install|.
|
|
|
|
Other plugin managers add a plugin path into 'runtimepath' to load external
|
|
plugins. However, if the 'runtimepath' is very large then it will load
|
|
slowly. This is because Vim needs to find and load all 'runtimepath' to load
|
|
plugins. In dein.vim, this problem does not exist.
|
|
|
|
The following plugins will not be merged to prevent merge problems
|
|
- |dein-options-merged| is v:false
|
|
- local plugin (|dein#local()|)
|
|
- lazy loaded plugin (|dein-options-lazy|)
|
|
- uses |dein-options-build|
|
|
- uses |dein-options-hook_post_update|
|
|
- uses |dein-options-if|
|
|
|
|
==============================================================================
|
|
FAQ *dein-faq*
|
|
|
|
Q: How to donate money to you?
|
|
|
|
A: I have started github sponsorship to spend more time for Vim/neovim
|
|
plugins. You can donate money to help me!
|
|
|
|
https://github.com/sponsors/Shougo
|
|
|
|
Q: Where is ":NeoBundleFetch" in dein features?
|
|
|
|
A: You can use |dein-options-rtp|.
|
|
>
|
|
call dein#add('Shougo/dein.vim', {'rtp': ''})
|
|
<
|
|
Note: It does not generate |:helptags| file.
|
|
|
|
Q: vimproc does not work when manually build it.
|
|
https://github.com/Shougo/dein.vim/issues/11
|
|
|
|
A: You should not build it manually. Please use |dein-options-build| feature.
|
|
>
|
|
call dein#add('Shougo/vimproc.vim', {'build': 'make'})
|
|
<
|
|
Q: Where is ":NeoBundleCheck" in dein features?
|
|
|
|
A: You can use |dein#check_install()|.
|
|
>
|
|
if dein#check_install()
|
|
call dein#install()
|
|
endif
|
|
<
|
|
Q: I want to disable plugins loading dynamically.
|
|
|
|
A: Please use |dein-options-if|.
|
|
|
|
Q: Cannot load colorscheme when reloading .vimrc.
|
|
|
|
A: You must write |:colorscheme| lines after |dein#end()|.
|
|
>
|
|
call dein#add('tomasr/molokai', {'merged': 0})
|
|
...
|
|
|
|
call dein#end()
|
|
colorscheme molokai
|
|
<
|
|
Or you can use |dein#source()| for it.
|
|
>
|
|
call dein#add('tomasr/molokai', {'merged': 0})
|
|
call dein#source('molokai')
|
|
colorscheme molokai
|
|
<
|
|
Q: There is the conflict between "jedi-vim" and "vim-pyenv" "initialize.py"
|
|
file.
|
|
|
|
A: All plugins should avoid file name collisions. dein.vim can load them
|
|
by setting |dein-options-merged|. See |dein-merge| for details.
|
|
|
|
Q: How to remove the disabled plugins?
|
|
|
|
A: You can remove them like below.
|
|
Note: You must call |dein#recache_runtimepath()| after the remove.
|
|
>
|
|
call map(dein#check_clean(), { _, val -> delete(val, 'rf') })
|
|
call dein#recache_runtimepath()
|
|
<
|
|
Q: How to use the script functions for hooks feature?
|
|
|
|
A: You can use them like this.
|
|
Note: You cannot use the script functions for cached plugins.
|
|
The SID will be changed in the next run.
|
|
>
|
|
function s:SID()
|
|
return matchstr(expand('<sfile>'), '\zs<SNR>\d\+_\zeSID$')
|
|
endfun
|
|
function! s:test()
|
|
endfunction
|
|
call dein#add('Shougo/deoplete.nvim',
|
|
\ {'hook_source': 'call ' . s:SID() . 'test()'})
|
|
<
|
|
Or you can execute the autocmd manually.
|
|
>
|
|
autocmd User dein#source#deoplete.nvim call s:test()
|
|
call dein#add('Shougo/deoplete.nvim', {
|
|
\ 'hook_source':
|
|
\ 'execute "doautocmd <nomodeline> User" "dein#source#".
|
|
\ g:dein#plugin.name'
|
|
\ })
|
|
<
|
|
But you must define the autocmd.
|
|
|
|
Q: I don't want to call |dein#recache_runtimepath()| manually.
|
|
A: Please specify your vimrc path to |dein#begin()| 2nd argument.
|
|
It detects the vimrc changes.
|
|
>
|
|
call dein#begin(path, [expand('<sfile>')])
|
|
<
|
|
Q: I need the wrapper commands for dein.vim.
|
|
|
|
A: You can use it.
|
|
https://github.com/haya14busa/dein-command.vim
|
|
|
|
Q: Why the install script does not use "curl | bash" ?
|
|
https://github.com/Shougo/neobundle.vim/pull/515
|
|
|
|
A:
|
|
https://www.idontplaydarts.com/2016/04/detecting-curl-pipe-bash-server-side/
|
|
|
|
Q: I want to use "git" or "http" protocol instead of "https".
|
|
|
|
A: No, you cannot.
|
|
|
|
Q: Why dein.vim only accepts "https" or "ssh"?
|
|
|
|
A: https://glyph.twistedmatrix.com/2015/11/editor-malware.html
|
|
|
|
Q: YouCompleteMe installation is failed.
|
|
https://github.com/Shougo/dein.vim/issues/144
|
|
|
|
A: Please check |:messages| result.
|
|
If you have found "Process timeout" error, you should increase
|
|
|g:dein#install_process_timeout| value.
|
|
|
|
Q: YouCompleteMe does not work. I have built YouCompleteMe manually.
|
|
|
|
A: dein.vim has |dein-merge| feature. It copies the plugin files into the
|
|
merge directory. If you build it manually, it will not be copied
|
|
from time to time.
|
|
You can disable the |dein-options-merged|. >
|
|
call dein#add('Valloric/YouCompleteMe', {'merged': 0})
|
|
|
|
or >
|
|
call dein#add('Valloric/YouCompleteMe', {'build': './install.py'})
|
|
|
|
Q: I have got "Invalid range error" when plugin updating.
|
|
|
|
A: It is Vim/neovim |delete()| implementation bug.
|
|
It uses |glob()| internally.
|
|
If the directory has contains "[]" files, it will be errored.
|
|
For example, vimtex has the file.
|
|
https://github.com/lervag/vimtex/issues/237
|
|
|
|
You can disable the |dein-merge| feature to prevent the error. >
|
|
call dein#add('lervag/vimtex', {'merged': 0})
|
|
|
|
|
|
Q: I have got prompted for my github username and I have to kill the editor...
|
|
|
|
A: You have specified wrong/removed repository name. You should check the
|
|
repository.
|
|
|
|
Q: Why dein.vim merges the plugins directories automatically?
|
|
|
|
A: |dein-merge| merge improves performance by avoiding long 'runtimepath'.
|
|
See also the |dein-merge|.
|
|
|
|
Q: I want to update from shell.
|
|
|
|
A: >
|
|
$ vim -c "try | call dein#update() | finally | qall! | endtry" \
|
|
-N -u $VIMRC -U NONE -i NONE -V1 -e -s
|
|
|
|
Q: I want to change the environment variable when build.
|
|
A: >
|
|
call dein#add('nixprime/cpsm',
|
|
\ {'build': 'sh -c "PY3=ON ./install.sh"'})
|
|
|
|
|
|
Q: dein.vim does not load plugin in sudo session.
|
|
https://github.com/SpaceVim/SpaceVim/issues/1660
|
|
https://github.com/Shougo/dein.vim/issues/274
|
|
|
|
A:
|
|
It is intended behavior for security reason.
|
|
In sudo session, installed plugin can do anything in root permission.
|
|
It is very dangerous.
|
|
But you can load trusted plugins using |dein-options-trusted|.
|
|
|
|
Q: I want to uninstall dein.vim.
|
|
|
|
A: Please remove |dein#begin()|'s argument directory.
|
|
For example, if you use below configuration: >
|
|
call dein#begin('~/.cache/dein')
|
|
Please remove "~/.cache/dein" directory.
|
|
|
|
Q: I want to update dein.vim from shell command line.
|
|
|
|
A: Please execute the command line like this. >
|
|
vim -N -u ~/.vim/init.vim -c \
|
|
"try | call dein#update() | finally | qall! | endtry" -V1 -es
|
|
|
|
Q: I want to set build conditions.
|
|
|
|
A: Please use |dein-options-hook_post_update|. >
|
|
|
|
[[plugins]]
|
|
repo = 'autozimu/LanguageClient-neovim'
|
|
hook_post_update = '''
|
|
if has('win32') || has('win64')
|
|
call system(
|
|
\ 'powershell -executionpolicy bypass -File install.ps1')
|
|
else
|
|
call system('bash install.sh')
|
|
endif
|
|
'''
|
|
|
|
Q: Why I need to call |dein#recache_runtimepath()| manually after removing
|
|
plugins?
|
|
https://github.com/Shougo/dein.vim/issues/357
|
|
|
|
A: You can use |g:dein#auto_recache| option instead.
|
|
Dein.vim has |dein-merge| feature. It copies the plugins into the
|
|
merge directory. You can disable the feature by setting
|
|
|dein-options-merged|. See also the |dein-merge|.
|
|
|
|
Q: I want to load plugins lazily on requiring lua modules
|
|
A: >
|
|
call dein#add('neovim/nvim-lsp', {'on_lua': 'nvim_lsp'})
|
|
|
|
Q: deoplete does not work when I use |dein#load_state()|.
|
|
|
|
A: Please read |dein#load_state()| documentation. "The block is skipped if
|
|
dein's state is loaded." >
|
|
|
|
if dein#load_state(path)
|
|
call dein#begin(path)
|
|
call dein#add('Shougo/deoplete.nvim')
|
|
let g:deoplete#enable_at_startup = v:true " It will be skipped!
|
|
call dein#end()
|
|
call dein#save_state()
|
|
endif
|
|
|
|
" You must set variables or execute functions outside the block
|
|
let g:deoplete#enable_at_startup = v:true
|
|
|
|
Q: I want to enable default merged config in Windows.
|
|
|
|
A: >
|
|
let g:dein#default_options = { 'merged': v:true }
|
|
|
|
==============================================================================
|
|
COMPATIBILITY *dein-compatibility*
|
|
|
|
2022.04.20
|
|
* Use Vim/neovim standard API for notification instead of commands.
|
|
|
|
2021.09.20
|
|
* Remove "dein-options-on_i".
|
|
* Remove "dein-options-on_idle".
|
|
|
|
2021.09.18
|
|
* hook_post_update is executed before "build".
|
|
* hook_done_update is executed after "build" and sourced.
|
|
|
|
2021.08.28
|
|
* Change dein#source() return value
|
|
|
|
2021.08.26
|
|
* Vim 8.2 or nvim 0.5 is required
|
|
|
|
==============================================================================
|
|
vim:tw=78:ts=8:ft=help:norl:noet:fen:
|