A Vim plugin to help users organize and navigate their .vimrc
/ init.vim
configs.
- Rationale
- Video Demonstration
- Installation
- File Structure Conventions
- Jumping Between Files
- Telescope Finder
- Sourcing & Tracking
- Auto-Sourcing
- Path Helpers
Most Vim users start out with a single .vimrc
/ init.vim
file. As that file becomes large and unruly, it becomes desirable to split into multiple vim config files. However, each approach has pros and cons...
Pros & Cons | |
---|---|
π | Simple setup |
π | Everything in one place |
π | Harder to manage as the file grows |
Pros & Cons | |
---|---|
π | More organized |
π | Smaller files |
π | More work to setup and source every new file |
π | Jumping between files can become tedious |
Pros & Cons | |
---|---|
π | Simple installation |
π | More organized |
π | Smaller files |
π | Every new file is automatically sourced |
π | Conventional structure makes it easy to manage as your config grows |
π | Easily jump between related plugin definitions, mappings, and configs |
Less boring video incoming π΄
But until then...
-
Install using vim-plug or similar:
Plug 'jesseleite/vim-sourcery'
-
If you want Sourcery to help scaffold a sensible file structure, run the
:SourceryScaffold
command. -
If you are using vim-plug or similar, you might consider moving your plugin definitions into
plugins.vim
. -
Initialize Sourcery after you source your plugins.
call plug#begin() source ~/.dotfiles/vim/plugins.vim call plug#end() call sourcery#init()
-
Add the Sourcery mappings:
function! SourceryMappings() nmap <buffer> gp <Plug>SourceryGoToRelatedPluginDefinition nmap <buffer> gm <Plug>SourceryGoToRelatedMappings nmap <buffer> gc <Plug>SourceryGoToRelatedConfig endfunction
-
Order pizza! π π€ π
Two file structure conventions are automatically detected, sourced, and tracked for jump mappings and auto-sourcing on save.
The first is based on your standard system vimfiles path. Depending on your OS and Vim distribution, this should be in $HOME/.vim
, $HOME/.config/nvim
, or $HOME/vimfiles
. Sourcery will source and/or track the following by default:
~/.vim
βββ $MYVIMRC // Your .vimrc / init.vim, wherever it is located
βββ plugins.vim // A plugin manager definitions file will be sourced & tracked
βββ mappings.vim // A mappings file will be sourced & tracked
βββ plugin // All files within the following folders will be tracked as well
βββ autoload
βββ after
βββ lua
Tip: This is what is sourced and tracked by default. Feel free to delete
plugins.vim
and/ormappings.vim
if you prefer to organize that stuff in a different location. You may also source & track as many extra paths as you see fit. The world is your oyster!
If you prefer a more custom config structure in an external location, a common practice is to symlink your ~/.vimrc
/ ~/.config/nvim/init.vim
to your custom dotfiles location. Sourcery will source and/or track the following by default, relative to the .vimrc
/ init.vim
within your dotfiles:
~/.dotfiles
βββ vim
βββ $MYVIMRC // Symlink your .vimrc / init.vim to this file
βββ plugins.vim // A plugin manager definitions file will be sourced & tracked
βββ mappings.vim // A mappings file will be sourced & tracked
βββ config // All files within this folder will be sourced & tracked as well
Β Β βββ sanity.vim
Β Β βββ theme.vim
Β Β βββ telescope.lua
Sourcery should be able to follow the .vimrc
/ init.vim
symlink to find your vim dotfiles, but you can explicitly define the path by setting the following before your call to sourcery#init()
:
let g:sourcery#vim_dotfiles_path = '~/.dotfiles/vim'
Tip: Again, you may customize the above structure however you see fit! Just be sure to source & track any custom paths you wish to configure.
If you want Sourcery to help scaffold example files for either of the above conventions, run the :SourceryScaffold
command!
The best part about Sourcery is the jump mappings. These let you jump between related plugin definition, mappings, and configs, no matter where they are in your vim dotfiles. To do this, Sourcery uses a set of annotation conventions to setup your jump points. Imagine you have the following pieces of code somewhere in your config:
Plugins sourced via packadd
, vim-plug, and vundle.vim are supported and indexed out-of-the-box:
Plug 'nvim-telescope/telescope.nvim'
By default, Sourcery will take the last segment of the plugin repository or path and use that as the handle. It will also ignore common prefixes and suffixes (vim-
, nvim-
, -vim
, -nvim
, .vim
, .nvim
) to create a cleaner handle.
In the above example, telescope
will be the handle we'll need to use for our jump point annotations. If you want to customize a handle, you can explicitly set a plugin annotation binding:
let g:sourcery#explicit_plugin_bindings = {
\ 'nvim-telescope/telescope.nvim': 'telescopic-johnson',
\ }
Let's say you have a set of related mappings for a plugin like telescope.nvim. To setup a jump point to a related set of mappings, add the " Mappings: <handle>
annotation above those mappings:
" Mappings: telescope
nmap <Leader>f :Telescope find_files<CR>
nmap <Leader>/ :Telescope live_grep<CR>
nmap <Leader>b :Telescope buffers<CR>
nmap <Leader>h :Telescope help_tags<CR>
Note: If within a .lua file, you can use a lua comment like
-- Mappings: telescope
to annotate mappings.
The same applies for a related set of config and/or settings. To setup a jump point to a related set of config, add the " Config: <handle>
annotation above that config:
" Config: sourcery
let g:sourcery#disable_sourcing_on_boot = 0
let g:sourcery#disable_autosourcing_on_save = 0
Note: If within a .lua file, you can use a lua comment like
-- Config: sourcery
to annotate config.
If you have a lot of config for a specific thing, you can create a separate <handle>.vim
or <handle>.lua
config file in any of your sourced or tracked directories.
Once you have the above annotations setup, you can use the provided jump mappings to jump between related plugin definitions, mappings, and configs π₯
function! SourceryMappings()
nmap <buffer> gp <Plug>SourceryGoToRelatedPluginDefinition
nmap <buffer> gm <Plug>SourceryGoToRelatedMappings
nmap <buffer> gc <Plug>SourceryGoToRelatedConfig
endfunction
Maybe you want to setup a custom annotation and jump mapping for something other than config and mappings. For example, maybe you have a set of related highlight customizations. Here is how you would go about adding custom annotation types:
-
Define an explicit annotation types list before calling
sourcery#init()
, so that Sourcery knows which annotations to index:let g:sourcery#annotation_types = [ \ 'Mappings', \ 'Config', \ 'Highlights', \ ]
-
Add a mapping for jumping to your new annotation to your
SourceryMappings()
function:nmap <silent><buffer> gh :SourceryGoToRelatedAnnotation Highlights<CR>
Note: If you call this command with a
!
bang modifier, Sourcery will attempt to find a related file before looking for a related annotation, similar to how Sourcery handles going to related config files and annotations. You may also pass a second path regex argument to scope where Sourcery will look for your file and/or annotation. -
You should now be able to jump to your custom annotation!
" Highlights: telescope highlight TelescopeBorder ctermfg=darkgrey highlight TelescopePromptBorder ctermfg=darkgrey highlight TelescopeResultsBorder ctermfg=darkgrey highlight TelescopePreviewBorder ctermfg=darkgrey
The best part about Sourcery is the Telescope finder. This lets you magically fuzzy find any of your vim config files or annotations from any project. Assuming you have Telescope installed:
-
Load the sourcery extension:
require('telescope').load_extension('sourcery')
-
Open the sourcery finder
:Telescope sourcery
!
The best part about Sourcery is the sourcing & tracking. Sourcery really isn't sorcery, it's just good old fashioned Sourcery. Let's take a look at what sourcery#init()
does out-of-the-box:
By default, Vim will automatically source your .vimrc
/ init.vim
(wherever it is located, see :help vimrc
), as well as files within autoload
, plugin
, after
, etc. within your system vimfiles directory (see :help vimfiles
).
On top of the files Vim sources for you, Sourcery will also source plugins.vim
and mappings.vim
files, and if you've chosen an external dotfiles repo (see file structure conventions), any files added to a config
folder will also be sourced.
Note: The
plugins.vim
,mappings.vim
, andconfig
paths are totally optional. Feel free to delete them if they don't suit your fancy!
If you have extra *.vim
/ *.lua
files or folders you wish to source, you can source them before you initialize Sourcery:
call sourcery#source_path('custom-file.vim')
call sourcery#source_path('custom-file.lua')
call sourcery#source_path('custom-config-folder')
call sourcery#init()
Note: You can pass both absolute and relative paths to
sourcery#source_path()
.
You may find yourself in a situation where a whole folder is being sourced (ie. the config
folder, which is sourced by default), but you need to defer the sourcing of a specific file until the end to ensure everything is loaded in the correct order. In these situations, you can defer the sourcing of a specific file:
call sourcery#source_defer('config/highlights.vim')
call sourcery#init()
When files are sourced, they are also tracked for Sourcery's jump mappings and auto-sourcing. If you don't want Sourcery to handle the sourcing of a file or folder, it is recommended you still track it before initializing Sourcery:
call sourcery#track_path('custom-file.vim')
call sourcery#track_path('custom-file.lua')
call sourcery#track_path('custom-config-folder')
call sourcery#init()
Note: You can pass both absolute and relative paths to
sourcery#track_path()
.
The best part about Sourcery is the auto-sourcing. Sourcery attempts to re-source your whole vim config when saving any of your sourced or tracked files. This kind of thing is easy when you have a single .vimrc
/ init.vim
file, but it can get more complicated to setup when you split everything out into multiple files. Sourcery does all of this for you, so that it's easier to test out changes in your vimscript without having to restart Vim.
Note: That said, sometimes you need to restart Vim anyway, like when removing variables, etc. For example, if Vim has sourced a variable and you remove it, the value may remain in memory until you restart Vim.
The best part about Sourcery is the path helpers. After Sourcery has been loaded, you can use these helper functions anywhere in your vim configs to easily get absolute paths to the things you love most:
Get path relative to your dotfiles (see file structure conventions):
sourcery#vim_dotfiles_path('config/sushi.vim')
Get path relative to your system vimfiles (see :help vimfiles
):
sourcery#system_vimfiles_path('plugin/sushi.vim')
The best part about Sourcery is what is not yet finished:
- Record less boring video
- If there are multiple matching files or annotations, cycle between them
- Support packer.nvim
- Write proper vim help file
- Order pizza