Vim Bootstrap provides a simple method for generating .vimrc configuration files for Vim, NeoVim, NeoVim-Qt, MacVim and GVim.
Want to generate your vim/neovim file? Access here!
The distribution is designed to work with Vim >= 8 and neovim.
$ brew install git ctags - Ubuntu\Debian
$ sudo apt-get install git exuberant-ctags ncurses-term curl - Gentoo
$ sudo emerge --ask dev-util/ctags sys-libs/ncurses dev-vcs/git dev-python/pyflakes net-misc/curl - Arch Linux via pacman
$ sudo pacman -S git ctags ncurses curl - Fedora
$ sudo dnf install ncurses-devel git ctags curl - openSUSE
$ sudo zypper in ncurses-devel git ctags curl - FreeBSD via packages collection
# pkg install git p5-Parse-ExuberantCTags ncurses curl - pyflakes
- jedi
- neovim (neovim only)
$ pip install flake8 jedi $ pip2 install --user --upgrade neovim $ pip3 install --user --upgrade neovim - elm-test
- elm-oracle
- elm-format
$ npm install -g elm-test $ npm install -g elm-oracle $ npm install -g elm-format@exp curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh - Download your own vimrc file at https://vim-bootstrap.com
- Put your vimrc file into home folder or
$XDG_CONFIG_HOME/nvim/init.vimif you use NeoVim
vim:mv ~/Downloads/generate.vim ~/.vimrc
neovim:mv ~/Downloads/generate.vim $XDG_CONFIG_HOME/nvim/init.vim
- Execute ViM and it will install plugins automatically
vim Vim-bootstrap generator can accept URL params via request as example below.
curl 'https://vim-bootstrap.com/generate.vim' --data 'editor=vim&frameworks=vuejs&langs=javascript&langs=php&langs=html&langs=ruby' > ~/.vimrc :VimBootstrapUpdate (thanks to @sherzberg) :PlugInstall You can run vim-bootstrap Go package to generate a vimrc file, just download it:
go get github.com/editor-bootstrap/vim-bootstrap cd $GOPATH/src/github.com/editor-bootstrap/vim-bootstrap go build Inside vim-bootstrap folder cd vim-bootstrap use vim-bootstrap module (file) like this example:
./vim-bootstrap -langs=python,lua,ruby,javascript,haskell -frameworks vuejs -editor=vim > ~/.vimrc For more instructions run vim-bootstrap -h
vim-bootstrap is also available on openSUSE on both Leap 42.2/42.3 and Tumbleweed. Leap versions must add devel:tools repository before, while Tumbleweed users should have vim-bootstrap in the default repository without the need to add any extra repository.
- Leap 42.2
$ sudo zypper ar -f http://download.opensuse.org/repositories/devel:/tools/openSUSE_Leap_42.2/ devel:tools $ sudo zypper ref $ sudo zypper in vim-bootstrap - Leap 42.3
$ sudo zypper ar -f http://download.opensuse.org/repositories/devel:/tools/openSUSE_Leap_42.3/ devel:tools $ sudo zypper ref $ sudo zypper in vim-bootstrap - Tumbleweed
$ sudo zypper ref $ sudo zypper in vim-bootstrap Create a folder inside generate/vim_template/themes/ with the name of your theme.
mkdir generate/vim_template/themes/my_theme Inside this folder, add a file called mytheme.vim with colorscheme instruction (optionally other configs).
echo "colorscheme mytheme" > generate/vim_template/themes/my_theme/mytheme.vim Add a .bundle extension file with instructions of how to install theme.
echo "Plug username/mytheme" > generate/vim_template/themes/my_theme/mytheme.vim.bundle Submit a PR and when approved new theme was added.
It's highly recommended to add customizations in a separate file. This way, you can maintain the original vim-bootstrap generated vimrc file and subsequent updates.
For Vim users, the files available for customization are ~/.vimrc.local and ~/.vimrc.local.bundles. The former handles general configuration while the latter handles external Vim plugins through vim-plug.
NeoVim users can also customize their configuration by using $XDG_CONFIG_HOME/nvim/local_init.vim and $XDG_CONFIG_HOME/nvim/local_bundles.vim.
▪️ Basic Commands
| Commands | Descriptions |
|---|---|
:cd <path> | Open path /path |
| Ctrlw+hjkl | Navigate via split panels |
| Ctrlww | Alternative navigate vim split panels |
| ,. | Set path working directory |
| ,w or ,x | Next buffer navigate |
| ,q or ,z | previous buffer navigate |
| shiftt | Create a tab |
| tab | next tab navigate |
| shifttab | previous tab navigate |
| ,e | Find and open files |
| ,b | Find file on buffer (open file) |
| ,c | Close active buffer (close file) |
| F2 | Open tree navigate in actual opened file |
| F3 | Open/Close tree navigate files |
| F4 | List all class and method, support for python, go, lua, ruby and php |
| ,v | Split vertical |
| ,h | Split horizontal |
| ,f | Search in the project |
| ,o | Open github file/line (website), if used git in github |
| ,sh | Open shell.vim terminal inside Vim or NeoVim built-in terminal |
| ,ga | Execute git add on current file |
| ,gc | git commit (splits window to write commit message) |
| ,gsh | git push |
| ,gll | git pull |
| ,gs | git status |
| ,gb | git blame |
| ,gd | git diff |
| ,gr | git remove |
| ,so | Open Session |
| ,ss | Save Session |
| ,sd | Delete Session |
| ,sc | Close Session |
| > | indent to right |
| < | indent to left |
| gc | Comment or uncomment lines that{motion} moves over |
| YY | Copy to clipboard |
| ,p | Paste |
| Ctrly + , | Activate Emmet plugin |
| Ctrlh | Does a fuzzy search in your command mode history |
▪️ Python hotkeys
| Commands | Descriptions |
|---|---|
SHIFT+k | Open documentation |
Control+Space | Autocomplete |
,d | Go to the Class/Method definition |
,r | Rename object definition |
,n | Show where command is usage |
▪️ Ruby hotkeys
| Commands | Descriptions |
|---|---|
,a | Run all specs |
,l | Run last spec |
,t | Run current spec |
,rap | Add Parameter |
,rcpc | Inline Temp |
,rel | Convert Post Conditional |
,rec | Extract Constant (visual selection) |
,rec | Extract to Let (Rspec) |
,relv | Extract Local Variable (visual selection) |
,rrlv | Rename Local Variable (visual selection/variable under the cursor) |
,rriv | Rename Instance Variable (visual selection) |
,rem | Extract Method (visual selection) |
▪️ Php hotkeys
| Commands | Descriptions |
|---|---|
,u | Include use statement |
,mm | Invoke the context menu |
,nn | Invoke the navigation menu |
,oo | Goto definition |
,oh | Goto definition on horizontal split |
,ov | Goto definition on vertical split |
,ot | Goto definition on tab |
,K | Show brief information about the symbol under the cursor |
,tt | Transform the classes in the current file |
,cc | Generate a new class (replacing the current file) |
,ee | Extract expression (normal mode) |
,ee | Extract expression (visual selection) |
,em | Extract method (visual selection) |
,pcd | cs-fixer fix directory |
,pcf | cs-fixer fix file |
Visit the following sites to learn more about Vim: