2015-02-14 15:20:55 +01:00
|
|
|
[![Build Status](https://travis-ci.org/SirVer/ultisnips.svg?branch=master)](https://travis-ci.org/SirVer/ultisnips)
|
2015-02-07 12:33:08 -07:00
|
|
|
[![Stories in Ready](https://badge.waffle.io/SirVer/ultisnips.png?label=ready&title=Ready)](https://waffle.io/SirVer/ultisnips)
|
2015-07-18 22:57:19 +02:00
|
|
|
[![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/SirVer/ultisnips?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
|
2015-02-14 15:20:55 +01:00
|
|
|
|
2014-03-04 17:56:48 +01:00
|
|
|
UltiSnips
|
|
|
|
=========
|
|
|
|
|
|
|
|
UltiSnips is the ultimate solution for snippets in Vim. It has tons of features
|
|
|
|
and is very fast.
|
|
|
|
|
2014-03-12 08:23:22 +01:00
|
|
|
![GIF Demo](https://raw.github.com/SirVer/ultisnips/master/doc/demo.gif)
|
2014-03-12 08:21:00 +01:00
|
|
|
|
|
|
|
In this demo I am editing a python file. I first expand the `#!` snippet, then
|
|
|
|
the `class` snippet. The completion menu comes from
|
2014-03-12 08:22:58 +01:00
|
|
|
[YouCompleteMe](https://github.com/Valloric/YouCompleteMe), UltiSnips also
|
2018-04-08 21:47:13 +02:00
|
|
|
integrates with [deoplete](https://github.com/Shougo/deoplete.nvim). I can
|
2014-03-12 08:22:58 +01:00
|
|
|
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.
|
2014-03-12 08:21:00 +01:00
|
|
|
|
|
|
|
The official home of UltiSnips is at <https://github.com/sirver/ultisnips>.
|
|
|
|
Please add pull requests and issues there.
|
|
|
|
|
2015-11-28 11:44:53 +01:00
|
|
|
UltiSnips was started in Jun 2009 by @SirVer. In Dec 2015, maintenance was
|
2016-05-06 11:15:34 +06:00
|
|
|
handed over to [@seletskiy](https://github.com/seletskiy).
|
2015-11-28 11:44:53 +01:00
|
|
|
|
2016-04-28 10:53:48 +06:00
|
|
|
What can you do with UltiSnips?
|
|
|
|
-------------------------------
|
|
|
|
|
|
|
|
1. Advanced snippets:
|
|
|
|
|
|
|
|
* [Snippets Aliases](doc/examples/snippets-aliasing/README.md)
|
2016-05-06 11:15:34 +06:00
|
|
|
* [Dynamic Tabstops/Tabstop Generation](doc/examples/tabstop-generation/README.md)
|
2016-04-28 10:53:48 +06:00
|
|
|
|
2014-03-04 17:56:48 +01:00
|
|
|
Quick Start
|
|
|
|
-----------
|
|
|
|
|
|
|
|
This assumes you are using [Vundle](https://github.com/gmarik/Vundle.vim). Adapt
|
|
|
|
for your plugin manager of choice. Put this into your `.vimrc`.
|
|
|
|
|
|
|
|
" Track the engine.
|
2014-04-15 08:47:51 -07:00
|
|
|
Plugin 'SirVer/ultisnips'
|
2014-03-04 17:56:48 +01:00
|
|
|
|
|
|
|
" Snippets are separated from the engine. Add this if you want them:
|
2014-04-15 08:47:51 -07:00
|
|
|
Plugin 'honza/vim-snippets'
|
2014-03-04 17:56:48 +01:00
|
|
|
|
|
|
|
" 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](https://github.com/SirVer/ultisnips/blob/master/doc/UltiSnips.txt).
|
|
|
|
As there are more options and tons of features I suggest you at least skim it.
|
|
|
|
|
|
|
|
Screencasts
|
|
|
|
-----------
|
|
|
|
|
2015-11-28 11:44:53 +01:00
|
|
|
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.
|
2014-03-04 17:56:48 +01:00
|
|
|
|
|
|
|
- [Episode 1: What are snippets and do I need them?](http://www.sirver.net/blog/2011/12/30/first-episode-of-ultisnips-screencast/)
|
|
|
|
- [Episode 2: Creating Basic Snippets](http://www.sirver.net/blog/2012/01/08/second-episode-of-ultisnips-screencast/)
|
|
|
|
- [Episode 3: What's new in version 2.0](http://www.sirver.net/blog/2012/02/05/third-episode-of-ultisnips-screencast/)
|
|
|
|
- [Episode 4: Python Interpolation](http://www.sirver.net/blog/2012/03/31/fourth-episode-of-ultisnips-screencast/)
|
2015-07-18 18:05:36 +02:00
|
|
|
|
2015-09-19 07:37:56 +10:00
|
|
|
Also the excellent [Vimcasts](http://vimcasts.org) dedicated three episodes to
|
2015-07-18 18:05:36 +02:00
|
|
|
UltiSnips:
|
|
|
|
|
|
|
|
- [Meet UltiSnips](http://vimcasts.org/episodes/meet-ultisnips/)
|
|
|
|
- [Using Python interpolation in UltiSnips snippets](http://vimcasts.org/episodes/ultisnips-python-interpolation/)
|
|
|
|
- [Using selected text in UltiSnips snippets](http://vimcasts.org/episodes/ultisnips-visual-placeholder/)
|