README ΒΆ
β‘ Volt
$ volt
.----------------. .----------------. .----------------. .----------------.
| .--------------. || .--------------. || .--------------. || .--------------. |
| | ____ ____ | || | ____ | || | _____ | || | _________ | |
| ||_ _| |_ _| | || | .' `. | || | |_ _| | || | | _ _ | | |
| | \ \ / / | || | / .--. \ | || | | | | || | |_/ | | \_| | |
| | \ \ / / | || | | | | | | || | | | _ | || | | | | |
| | \ ' / | || | \ `--' / | || | _| |__/ | | || | _| |_ | |
| | \_/ | || | `.____.' | || | |________| | || | |_____| | |
| | | || | | || | | || | | |
| '--------------' || '--------------' || '--------------' || '--------------' |
'----------------' '----------------' '----------------' '----------------'
Usage
volt COMMAND ARGS
Command
get [-l] [-u] [{repository} ...]
Install or upgrade given {repository} list, or add local {repository} list as plugins
rm [-r] [-p] {repository} [{repository2} ...]
Remove vim plugin from ~/.vim/pack/volt/opt/ directory
list [-f {text/template string}]
Vim plugin information extractor.
Unless -f flag was given, this command shows vim plugins of **current profile** (not all installed plugins) by default.
enable {repository} [{repository2} ...]
This is shortcut of:
volt profile add -current {repository} [{repository2} ...]
disable {repository} [{repository2} ...]
This is shortcut of:
volt profile rm -current {repository} [{repository2} ...]
profile set {name}
Set profile name
profile show {name}
Show profile info
profile list
List all profiles
profile new {name}
Create new profile
profile destroy {name}
Delete profile
profile rename {old} {new}
Rename profile {old} to {new}
profile add {name} {repository} [{repository2} ...]
Add one or more repositories to profile
profile rm {name} {repository} [{repository2} ...]
Remove one or more repositories to profile
build [-full]
Build ~/.vim/pack/volt/ directory
migrate
Convert old version $VOLTPATH/lock.json structure into the latest version
self-upgrade [-check]
Upgrade to the latest volt command, or if -check was given, it only checks the newer version is available
version
Show volt command version
See the command reference for more details.
- What is Volt
- Install
- Build Environment
- Config
- Self upgrade
- Introduction
- How it works
- Features
- Contribution
What is Volt
- Multi-platform CLI tool managing Vim plugin life
- Based on Vim 8 packages feature
- All plugins are installed under
~/.vim/pack/volt
directory
- All plugins are installed under
- Zero overhead & optimizations
- Volt does not slow down your startup
- We plan to support transpilation of Vim script (Uglification, Transpiler to LuaJIT, ...)
- Provides version locking & easy setup
- Managing plugin configuration by plugconf files
- This separates plugin configuration from vimrc, so you can easily disable/remove plugins in a second
- Profile feature saves set of plugins, vimrc, and gvimrc
- You can switch those combinations with one command
Install
$ go get github.com/vim-volt/volt
Or download binaries from GitHub releases.
Build environment
- Go 1.9 or higher
- If you are on WSL (Windows Subsystem Linux), note that you need the patch for os.RemoveAll() (#1)
- But it's a hassle, you can just download linux-386/amd64 binaries from GitHub releases :)
Config
Config file: $VOLTPATH/config.toml
[build]
# * "symlink" (default): "volt build" creates symlinks "~/.vim/pack/volt/opt/<repos>" referring to "$VOLTPATH/repos/<repos>"
# * "copy": "volt build" copies "$VOLTPATH/repos/<repos>" files to "~/.vim/pack/volt/opt/<repos>"
strategy = "symlink"
[get]
# * true (default): "volt get" creates skeleton plugconf file at "$VOLTPATH/plugconf/<repos>.vim"
# * false: It does not creates skeleton plugconf file
create_skeleton_plugconf = true
# * true (default): When "volt get" or "volt get -u" fail and "git" command is
# installed, it tries to execute "git clone" or "git pull" as a fallback
# * false: "volt get" or "volt get -u" won't try to execute fallback commands
fallback_git_cmd = true
Self upgrade
$ volt self-upgrade
will upgrade current running volt binary to the latest version if the newer releases published.
$ volt self-upgrade -check
just checks if the newer releases published. It also shows the release note of the latest version.
Introduction
VOLTPATH
You can change base directory of volt by VOLTPATH
environment variable.
This is $HOME/volt
by default.
Install plugin(s)
For example, installing tyru/caw.vim plugin:
$ volt get https://github.com/tyru/caw.vim # most verbose way (but handy when you copy & paste from browser address bar :)
$ volt get github.com/tyru/caw.vim # you can omit https:// of repository URL
$ volt get tyru/caw.vim # you can omit github.com/ if the repository is on GitHub
And you can install multiple plugins (parallel download):
$ volt get tyru/open-browser.vim tyru/open-browser-github.vim
For example, what volt get tyru/caw.vim
command does internally is:
- Clone and install the repository to
$VOLTPATH/repos/github.com/tyru/caw.vim
- Volt does not require
git
command because it's powered by go-git
- Volt does not require
- Update
$VOLTPATH/lock.json
- Run
volt build
- Copy repository files to
~/.vim/pack/volt/opt/github.com_tyru_caw.vim
- Install
~/.vim/pack/volt/start/system/plugin/bundled_plugconf.vim
- It loads plugins like
packadd github.com_tyru_caw.vim
- It loads plugins like
- Copy repository files to
Update plugins
You can update all plugins as follows:
$ volt get -l -u
-l
works like all installed plugins are specified (the repositories list is read from $VOLTPATH/lock.json
).
-u
updates specified plugins.
Or, update only specified plugin(s) as follows:
$ volt get -u tyru/caw.vim
Uninstall plugins
You can uninstall tyru/caw.vim
as follows:
$ volt rm tyru/caw.vim # (sob)
How it works
Syncing ~/.vim/pack/volt directory with $VOLTPATH
volt build
synchronizes ~/.vim/pack/volt/...
with $VOLTPATH/rc
(vimrc/gvimrc), $VOLTPATH/repos
(repositories), $VOLTPATH/plugconf
(plugconf):
- Install
$VOLTPATH/rc/<profile>/{vimrc.vim,gvimrc.vim}
to~/.vim/vimrc
and~/.vim/gvimrc
- Copy
$VOLTPATH/repos/<repos>
to~/.vim/pack/volt/opt/<repos>
- if
$VOLTPATH/repos/<repos>
has modified/new file(s), copy them to~/.vim/pack/volt/opt/<repos>
- if
$VOLTPATH/repos/<repos>
does not exist, remove~/.vim/pack/volt/opt/<repos>
- Install bootstrap script to
~/.vim/pack/volt/start/system/plugin/bundled_plugconf.vim
(load plugins & plugconfs)
Users don't have to run volt build
when running volt get
, volt rm
, volt add
, volt profile
, ... commands, because those commands invoke volt build
command internally if the commands modify repositories, plugconf, lock.json.
But if you edit $VOLTPATH/rc/<profile>/vimrc.vim
or $VOLTPATH/rc/<profile>/gvimrc.vim
, you have to run volt build
to copy them to ~/.vim/vimrc
or ~/.vim/gvimrc
.
volt build
uses cache for the next running.
Normally volt build
synchronizes correctly, but if you met the bug, try volt build -full
(or please file an issue as possible :) to ignore the previous cache.
Features
Easy setup
If you want to install set of plugins which you have installed by volt get
, you can use volt get -l
.
$ volt get -l # install plugins listed in $VOLTPATH/lock.json
First, you have to manage the following files under $VOLTPATH
.
$VOLTPATH/
β β β lock.json
β β β plugconf (optional)
β β β rc (optional)
NOTE: DO NOT RECOMMEND SHARING VOLT DIRECTORY ITSELF ON DROPBOX (see related issues).
For example, my actual setup is:
$ tree -L 1 ~/volt/
/home/tyru/volt/
β β β lock.json -> /home/tyru/git/dotfiles/dotfiles/volt/lock.json
β β β plugconf -> /home/tyru/git/dotfiles/dotfiles/volt/plugconf
β β β rc -> /home/tyru/git/dotfiles/dotfiles/volt/rc
β β β repos
See volt directory in tyru/dotfiles repository for example.
Configuration per plugin ("Plugconf" feature)
You can write plugin configuration in "plugconf" file. The files are placed at:
$VOLTPATH/plugconf/<repository>.vim
For example, tyru/open-browser-github.vim configuration is $VOLTPATH/plugconf/user/github.com/tyru/open-browser.vim.vim
because "github.com/tyru/open-browser-github.vim" is the repository URL.
Some special functions can be defined in plugconf file:
s:config()
- Plugin configuration
s:loaded_on()
(optional)- Return value: String (when to load a plugin by
:packadd
) - This function specifies when to load a plugin by
:packadd
- e.g.:
return "start"
(default, load onVimEnter
autocommand) - e.g.:
return "filetype=<filetype>"
(load onFileType
autocommand) - e.g.:
return "excmd=<excmd>"
(load onCmdUndefined
autocommand)
- Return value: String (when to load a plugin by
s:depends()
(optional)- Return value: List (repository name)
- The specified plugins by this function are loaded before the plugin of plugconf
- e.g.:
["github.com/tyru/open-browser.vim"]
However, you can also define global functions in plugconf (see tyru/nextfile.vim example).
An example config of tyru/open-browser-github.vim:
" Plugin configuration like the code written in vimrc.
function! s:config()
let g:openbrowser_github_always_use_commit_hash = 1
endfunction
" This function determines when a plugin is loaded.
"
" Possible values are:
" * 'start' (a plugin will be loaded at VimEnter event)
" * 'filetype=<filetypes>' (a plugin will be loaded at FileType event)
" * 'excmd=<excmds>' (a plugin will be loaded at CmdUndefined event)
" <filetypes> and <excmds> can be multiple values separated by comma.
"
" This function must contain 'return "<str>"' code.
" (the argument of :return must be string literal)
function! s:depends()
" this is the default value, you don't have to write this
return 'start'
endfunction
" Dependencies of this plugin.
" The specified dependencies are loaded after this plugin is loaded.
"
" This function must contain 'return [<repos>, ...]' code.
" (the argument of :return must be list literal, and the elements are string)
function! s:depends()
return ['github.com/tyru/open-browser.vim']
endfunction
NOTE:
- Plugconf file is parsed by go-vimlparser
- The rhs of
:return
must be literal - Breaking newline by backslash (
\
) ins:loaded_on()
ands:depends()
is safe, but the following code can not be recognized (currently not supported at least)
" Wrong
function! s:loaded_on()
let when = 'filetype=vim'
return when
endfunction
" Wrong
function! s:depends()
let list = ['github.com/tyru/open-browser.vim']
return list
endfunction
" OK
function! s:depends()
return [
\ 'github.com/tyru/open-browser.vim'
\]
endfunction
See plugconf directory in tyru/dotfiles repository for example.
Switch set of plugins ("Profile" feature)
You can think this is similar feature of branch of git
.
The default profile name is "default".
You can see profile list by volt profile list
.
$ volt profile list
* default
You can create a new profile by volt profile new
.
$ volt profile new foo # will create profile "foo"
$ volt profile list
* default
foo
You can switch current profile by volt profile set
.
$ volt profile set foo # will switch profile to "foo"
$ volt profile list
default
* foo
You can delete profile by volt profile destroy
(but you cannot delete current profile which you are switching on).
$ volt profile destroy foo # will delete profile "foo"
You can enable/disable plugin by volt enable
(volt profile add
), volt disable
(volt profile rm
).
$ volt enable tyru/caw.vim # enable loading tyru/caw.vim on current profile
$ volt profile add foo tyru/caw.vim # enable loading tyru/caw.vim on "foo" profile
$ volt disable tyru/caw.vim # disable loading tyru/caw.vim on current profile
$ volt profile rm foo tyru/caw.vim # disable loading tyru/caw.vim on "foo" profile
You can create a vimrc & gvimrc file for each profile:
- vimrc:
$VOLTPATH/rc/<profile name>/vimrc.vim
- gvimrc:
$VOLTPATH/rc/<profile name>/gvimrc.vim
This file is copied to ~/.vim/vimrc
and ~/.vim/gvimrc
with magic comment (shows error if existing vimrc/gvimrc files exist with no magic comment).
And you can enable/disable vimrc by volt profile use
(or you can simply remove $VOLTPATH/rc/<profile name>/vimrc.vim
file if you don't want vimrc for the profile).
$ volt profile use -current vimrc false # Disable installing vimrc on current profile
$ volt profile use default gvimrc true # Enable installing gvimrc on profile default
See volt help profile
for more detailed information.
Manage a local directory as a vim plugin
You can manage also a local directory as a vim plugin (it's called static repository
).
Quick try:
$ mkdir -p ~/volt/repos/localhost/local/hello/plugin
$ echo 'command! Hello echom "hello"' >~/volt/repos/localhost/local/hello/plugin/hello.vim
$ volt get localhost/local/hello # will add the local repository as a plugin
$ vim -c Hello # will output "hello"
volt get
does not make a request when the specified repository directory already exists,
but it adds to $VOLTPATH/lock.json
if it does not have.
You can use a arbitrary name as a repository name, but localhost/{user}/{name}
is recommended.
Because if you run volt get localhost/{user}/{name}
accidentally you only get connection refused
.
So it is guaranteed that you won't install a unwanted plugin :)
In other words, this means you can also manage your ~/.vim/*
files as a vim plugin.
Off cource you can disable/enable it by volt disable <repos>
and volt enable <repos>
.
Move files/directories to vimdir
$ mkdir -p ~/volt/repos/localhost/my/vimdir
$ mv ~/.vim/* ~/volt/repos/localhost/my/vimdir/
Remove unnecessary files/directories
$ rm -rf ~/volt/repos/localhost/my/vimdir/pack/volt # generated by volt
$ rm -rf ~/volt/repos/localhost/my/vimdir/.netrwhist # netrw plugin history file
$ ...
Move to profile directory if you have vimrc/gvimrc
$ mv ~/volt/repos/localhost/my/vimdir/vimrc ~/volt/repos/default/vimrc.vim
$ mv ~/volt/repos/localhost/my/vimdir/gvimrc ~/volt/repos/default/gvimrc.vim
Install vimdir as a vim plugin
$ volt get localhost/my/vimdir
π Contribution
If you want to contribute to volt, you can setup like:
$ make precompile # this speeds up 'go build'
$ vim ... # edit sources
$ make
$ bin/volt ... # run volt command
Documentation ΒΆ
There is no documentation for this package.