# VIM This repo contains my vim configuration, hope it will be useful for you. ## Installation You will need `vim` and `git` to be able to use this configuration. Normally if you run the `install.sh` script it will work, but if you have a problem, try to install vim plug and check if your problem is solved. ```bash curl -fLo ~/.vim/autoload/plug.vim --create-dirs \ https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim ``` Oh and remove neovim, it make some problems with vim. ## Plugins This config has just the necessary plugins installed: - [OneDark](https://github.com/joshdick/onedark.vim) onedark theme. - [Vim Airline](https://github.com/vim-airline/vim-airline) Vim statusline. - [Fern](https://github.com/lambdalisue/fern.vim) to have a file tree in vim. - [Fern hijack](https://github.com/lambdaalisue/fern-hijack.vim) to open folder preview with fern. - [Fern renderer devicons](https://github.com/lambdalisue/fern-renderer-devicons.vim) to have devicons in fern. - [Fern git mapping](https://github.com/lambdalisue/fern-mapping-git.vim) to add git stage & unstage in fern. - [Fern copy node](https://github.com/andykog/fern-copynode.vim) to copy filename or foldername or filepath or folderpath. - [Fern git status](https://github.com/lambdalisue/fern-git-status.vim.git) show file git status in fern. - [Vim which key](https://github.com/liuchengxu/vim-which-key) show leader keybinds in a GUI. - [Vim devicons](https://github.com/ryanoasis/vim-devicons) language icons for vim. - [Vim nerdtree syntax highlighting](https://github.com/tiagofumo/vim-nerdtree-syntax-highlight) nerdtree syntax highlighting - [Vim gitgutter](https://github.com/airblade/vim-gitgutter) to see diff between files with git. - [Vim-lsp](https://github.com/prabirshrestha/vim-lsp) linter & formatter for language. - [Vim-lsp settings](https://github.com/mattn/vim-lsp-settings) easily setup lsp servers for languages. - [Asyncomplete](https://github.com/prabirshrestha/asyncomplete.vim) async autocompletion - [Asyncomplete & lsp-vim](https://github.com/prabirshrestha/asyncomplete-lsp.vim) use vim-lsp as source for autocompletion lsp server. ## Command & keybinds ### General - `hl` remove highlighting #### Window - `Ctrl+h` move to the left window, - `Ctrl+j` move to the bottom window, - `Ctrl+k` move to the upper window, - `Ctrl+l` move to the right window, #### Buffer - `bd` close the current buffer, - `ba` close all the buffers, - `bn` go to the next buffer, - `bp` go to the precedent buffer, #### Tabs - `tn` open a new tab, - `to` close all other tabs, - `tc` close current tab page, - `tm` move the tab after another, - `t` go to the next tab, - `tl` toggle between this tab and the last accessed tab, - `te` open a new tab with the current buffer, #### Spell check - `ss` toggle / untoggle spellchecking, - `sn` go to the next word to spellcheck, - `sp` go to the previous word to spellcheck, - `sa` add a word into the dictionary, - `s?` show the list of alternatives for the word, More help at `:help spell` ### Fern For help, use `:help fern`. Keybinds: - `Ctrl+f` open the treeview in the current window - `ga` stage a file or unstage if already stagged (TODO) - `cp` copy node name (file, folder..) - `cP` copy node path ### Vim Gutter For help, use `:help gitgutter`. Keybinds: - `hp` go to the previous hunk, - `hn` go to the next hunk, - `hP` to preview hunk, - `hs` to stage hunk, - `hu` to undo hunk, - `ht` to toggle GitGutter. Hunks are the difference between your file and the git file. ### LSP For help, use `:help vim-lsp`. Keybinds: - `ld` go to the definition, - `lnd` go to the next diagnostic, - `lpd` go to the previous diagnostic, - `lf` go to the reference, - `lr` rename element, - `ls` stop lsp server, - `lp` peek a view to the definition, - `la` code action, - `lh` lsp hover, - `ldf` format document. ## Linters & fixers ### Python For using python linters & fixers, you will need to setup a virtual env & install the linters & fixers. ```bash python -m venv .venv source .venv/bin/activate pip install python-lsp-server[all] ```