83 lines
2.2 KiB
Markdown
83 lines
2.2 KiB
Markdown
A code minimap for Vim
|
|
======================
|
|
|
|
The Sublime text-editor can display an useful overview of the code as a
|
|
*minimap* sidebar.
|
|
|
|
We can implement the same thing in Vim, relying on the [Drawille
|
|
library](https://github.com/asciimoo/drawille) to 'draw' in text mode.
|
|
|
|
data:image/s3,"s3://crabby-images/d485c/d485ce90561b1a0dd584446ae99a3767f9e8883f" alt="minimap in action"
|
|
|
|
This code is made available under a MIT license. See [LICENSE](LICENSE) for
|
|
details.
|
|
|
|
Features
|
|
--------
|
|
|
|
- displays the minimap of the currently active buffer (and updates when
|
|
switching to a different buffer)
|
|
- synchronized scrolling
|
|
- live update while typing
|
|
|
|
Installation
|
|
------------
|
|
|
|
Note that this extension requires Vim with Python support.
|
|
|
|
### Vundle
|
|
|
|
With [vundle](https://github.com/gmarik/Vundle.vim), simply add: `Plugin
|
|
'severin-lemaignan/vim-minimap'` to your `.vimrc` and run `:PluginInstall` from
|
|
vim.
|
|
|
|
### Janus
|
|
|
|
With Janus just clone inside ```.janus```.
|
|
|
|
```
|
|
cd ~/.janus
|
|
git clone https://github.com/severin-lemaignan/vim-minimap.git vim-minimap
|
|
```
|
|
|
|
Usage
|
|
-----
|
|
|
|
`:Minimap` to show the minimap, `:MinimapClose` to hide it.
|
|
|
|
Default mappings: `<Leader>mm` to display the minimap, `<Leader>mc` to close it.
|
|
|
|
To overwrite the default keybindings, using following settings in ``.vimrc'':
|
|
|
|
```
|
|
let g:minimap_show='<leader>ms'
|
|
let g:minimap_update='<leader>mu'
|
|
let g:minimap_close='<leader>gc'
|
|
let g:minimap_toggle='<leader>gt'
|
|
```
|
|
|
|
Settings
|
|
--------
|
|
|
|
You can customize the color of the highlighting by setting `g:minimap_highlight` in your vimrc:
|
|
|
|
`let g:minimap_highlight='Visual'`
|
|
|
|
Note: To find out which highlights are available on your vim installation use :hi to get the list.
|
|
|
|
Troubleshooting
|
|
---------------
|
|
|
|
- Weird display
|
|
|
|
Certain fonts do not display plain dots and empty spaces, but
|
|
plain dots and circles for braille characters. As a result, you may want to use
|
|
any other font that display braille characters in a way that suit the minimap
|
|
plugin, like `Ubuntu Mono`, or `Droid Sans Mono`.
|
|
|
|
For example, with `Inconsolata`:
|
|
data:image/s3,"s3://crabby-images/d23a2/d23a23a534bdd607b9f0a21567f791e721322e19" alt="image"
|
|
|
|
With `Ubuntu Mono`
|
|
data:image/s3,"s3://crabby-images/84b9b/84b9b11651279065406e43d067afff799ebee41e" alt="image"
|
|
|