Go to file
Stanislav Seletskiy 7536ac9002 tabstops can be overwritten from interpolation
It adds new type of flexibility, where just entered text can be
dynamically modified if some conditions are satisfied (e.g. dynamically
add line wraps).
2016-03-28 12:21:09 +06:00
after/plugin Remove bootstrap.vim. Simplify startup. 2015-07-11 16:17:50 +02:00
autoload change g:current_ulti_dict_all to g:current_ulti_dict_info 2016-01-11 23:58:42 +08:00
ctags Support TagBar for snippets files 2014-07-05 19:36:38 -07:00
doc More detailed documentation on multiline option 2016-01-21 03:28:19 -08:00
ftdetect Do not run autocommands when using --noplugin. 2015-08-04 07:57:38 +02:00
ftplugin Tweak the ftplugin 2014-08-26 01:03:15 -07:00
plugin autotrigger: make snippets expand without <tab> 2015-10-09 16:00:24 +06:00
pythonx/UltiSnips tabstops can be overwritten from interpolation 2016-03-28 12:21:09 +06:00
rplugin/python3/deoplete/sources Allow Deoplete entries to show up with existing matches 2016-01-22 16:32:59 -05:00
syntax Fix highlighting for nested visual tabstob 2015-12-30 20:57:35 +01:00
test tabstops can be overwritten from interpolation 2016-03-28 12:21:09 +06:00
utils Applied pyformat on entire codebase. 2015-01-20 21:26:03 +01:00
.bzrignore Ignore .bzr-repo 2010-03-05 14:31:40 +01:00
.gitignore ignore .ropeproject 2016-03-28 12:21:07 +06:00
.travis.yml Disable Neovim tests, since they do not pass. 2015-10-11 22:28:10 +02:00
ChangeLog Updated ChangeLog for 3.1. 2015-11-28 11:30:21 +01:00
COPYING.txt Added a license file. 2013-10-29 07:22:06 +01:00
pylintrc Less verbose pylint errors. 2015-01-22 08:00:43 +01:00
README.md Reworked README for change of maintenance. 2015-11-28 11:44:53 +01:00
test_all.py Pass the expected python version to the tests. 2015-07-18 12:49:23 +02:00
travis_install.sh Add a testing interface that works for Neovim. 2015-07-14 21:58:30 +02:00
travis_test.sh Fix a unicode bug in python3. 2015-11-21 07:54:35 -08:00

Build Status Stories in Ready Gitter

UltiSnips

UltiSnips is the ultimate solution for snippets in Vim. It has tons of features and is very fast.

GIF Demo

In this demo I am editing a python file. I first expand the #! snippet, then the class snippet. The completion menu comes from YouCompleteMe, UltiSnips also integrates with neocomplete. I can jump through placeholders and add text while the snippet inserts text in other places automatically: when I add Animal as a base class, __init__ gets updated to call the base class constructor. When I add arguments to the constructor, they automatically get assigned to instance variables. I then insert my personal snippet for print debugging. Note that I left insert mode, inserted another snippet and went back to add an additional argument to __init__ and the class snippet was still active and added another instance variable.

The official home of UltiSnips is at https://github.com/sirver/ultisnips. Please add pull requests and issues there.

UltiSnips was started in Jun 2009 by @SirVer. In Dec 2015, maintenance was handed over to @seletskiy.

Quick Start

This assumes you are using Vundle. Adapt for your plugin manager of choice. Put this into your .vimrc.

" Track the engine.
Plugin 'SirVer/ultisnips'

" Snippets are separated from the engine. Add this if you want them:
Plugin 'honza/vim-snippets'

" Trigger configuration. Do not use <tab> if you use https://github.com/Valloric/YouCompleteMe.
let g:UltiSnipsExpandTrigger="<tab>"
let g:UltiSnipsJumpForwardTrigger="<c-b>"
let g:UltiSnipsJumpBackwardTrigger="<c-z>"

" If you want :UltiSnipsEdit to split your window.
let g:UltiSnipsEditSplit="vertical"

UltiSnips comes with comprehensive documentation. As there are more options and tons of features I suggest you at least skim it.

Screencasts

From a gentle introduction to really advanced in a few minutes: The blog posts of the screencasts contain more advanced examples of the things discussed in the videos.

Also the excellent Vimcasts dedicated three episodes to UltiSnips: