diff --git a/doc/UltiSnips.txt b/doc/UltiSnips.txt index d23d1ac..2070d5c 100644 --- a/doc/UltiSnips.txt +++ b/doc/UltiSnips.txt @@ -1,4 +1,4 @@ -*UltiSnips.txt* For Vim version 7.0 or later. +*UltiSnips.txt* For Vim version 7.4 or later. The Ultimate Plugin for Snippets in Vim~ @@ -7,24 +7,28 @@ UltiSnips *snippet* *snippets* *UltiSnips* 1. Description |UltiSnips-description| 1.1 Requirements |UltiSnips-requirements| 1.2 Acknowledgments |UltiSnips-acknowledgments| -2. Installation and Updating |UltiSnips-installnupdate| +2. Installation and Updating |UltiSnips-install-and-update| 3. Settings & Commands |UltiSnips-settings| 3.1 Commands |UltiSnips-commands| + 3.1.1 UltiSnipsEdit |UltiSnipsEdit| + 3.1.2 UltiSnipsAddFiletypes |UltiSnipsAddFiletypes| 3.2 Triggers |UltiSnips-triggers| - 3.2.1 Using your own trigger functions |UltiSnips-trigger-functions| - 3.2.2 Custom autocommands |UltiSnips-custom-autocommands| - 3.2.3 Path to Python Module |UltiSnips-python-module-path| - 3.3 Snippet Search Path |UltiSnips-snippet-search-path| - 3.4 Warning About Select Mode Mappings |UltiSnips-warning-smappings| - 3.5 Functions |UltiSnips-functions| - 3.5.1 UltiSnips#AddSnippetWithPriority |UltiSnips#AddSnippetWithPriority| - 3.5.2 UltiSnips#Anon |UltiSnips#Anon| - 3.5.3 UltiSnips#SnippetsInCurrentScope |UltiSnips#SnippetsInCurrentScope| - 3.6 Missing python support |UltiSnips-python-warning| -4. Syntax |UltiSnips-syntax| - 4.1 Adding Snippets |UltiSnips-adding-snippets| - 4.1.1 Snippet Options |UltiSnips-snippet-options| - 4.1.2 Character Escaping |UltiSnips-character-escaping| + 3.2.1 Trigger key mappings |UltiSnips-trigger-key-mappings| + 3.2.2 Using your own trigger functions |UltiSnips-trigger-functions| + 3.2.3 Custom autocommands |UltiSnips-custom-autocommands| + 3.2.4 Direct use of Python API |UltiSnips-use-python-api| + 3.3 Warning About Select Mode Mappings |UltiSnips-warning-smappings| + 3.4 Functions |UltiSnips-functions| + 3.4.1 UltiSnips#AddSnippetWithPriority |UltiSnips#AddSnippetWithPriority| + 3.4.2 UltiSnips#Anon |UltiSnips#Anon| + 3.4.3 UltiSnips#SnippetsInCurrentScope |UltiSnips#SnippetsInCurrentScope| + 3.5 Missing python support |UltiSnips-python-warning| +4. Authoring snippets |UltiSnips-authoring-snippets| + 4.1 Basics |UltiSnips-basics| + 4.1.1 How snippets are loaded |UltiSnips-how-snippets-are-loaded| + 4.1.2 Basic syntax |UltiSnips-basic-syntax| + 4.1.3 Snippet Options |UltiSnips-snippet-options| + 4.1.4 Character Escaping |UltiSnips-character-escaping| 4.2 Plaintext Snippets |UltiSnips-plaintext-snippets| 4.3 Visual Placeholder |UltiSnips-visual-placeholder| 4.4 Interpolation |UltiSnips-interpolation| @@ -38,7 +42,7 @@ UltiSnips *snippet* *snippets* *UltiSnips* 4.7.1 Replacement String |UltiSnips-replacement-string| 4.7.2 Demos |UltiSnips-demos| 4.8 Clearing snippets |UltiSnips-clearing-snippets| - 4.9 Context snippets |UltiSnips-context-snippets| + 4.9 Custom context snippets |UltiSnips-custom-context-snippets| 4.10 Snippet actions |UltiSnips-snippet-actions| 4.10.1 Pre-expand actions |UltiSnips-pre-expand-actions| 4.10.2 Post-expand actions |UltiSnips-post-expand-actions| @@ -63,8 +67,8 @@ UltiSnips provides snippet management for the Vim editor. A snippet is a short piece of text that is either re-used often or contains a lot of redundant text. UltiSnips allows you to insert a snippet with only a few key strokes. Snippets are common in structured text like source code but can also be used -for general editing like, for example, inserting a signature in an email or -inserting the current date in a text file. +for general editing like inserting a signature in an email or inserting the +current date in a text file. @SirVer posted several short screencasts which make a great introduction to UltiSnips, illustrating its features and usage. @@ -87,8 +91,8 @@ http://vimcasts.org/episodes/ultisnips-visual-placeholder/ This plugin works with Vim version 7.4 or later. It only works if the 'compatible' setting is not set. -This plugin is tested against Python 2.7, 3.3 or 3.4. All other versions are -unsupported, but might work. +This plugin is tested against Python 2.7 and 3.6 in Vim 7.4 and 8. All other +combinations are unsupported, but might work. The Python 2.x or Python 3.x interface must be available. In other words, Vim must be compiled with either the |+python| feature or the |+python3| feature. @@ -131,7 +135,7 @@ permission to use his snippets. ============================================================================= -2. Installation and Updating *UltiSnips-installnupdate* +2. Installation and Updating *UltiSnips-install-and-update* The recommended way of getting UltiSnips is to track SirVer/ultisnips on github. The master branch is always stable. @@ -156,9 +160,9 @@ Download the packet and unpack into a directory of your choice. Then add this directory to your Vim runtime path by adding this line to your vimrc file. > set runtimepath+=~/.vim/ultisnips_rep -UltiSnips also needs that Vim sources files from the ftdetect/ directory. -Unfortunately, Vim only allows this directory in the .vim directory. You -therefore have to symlink/copy the files: > +UltiSnips also needs Vim files from the ftdetect/ directory. Unfortunately, +Vim only allows this directory in the .vim directory. You therefore have to +symlink/copy the files: > mkdir -p ~/.vim/ftdetect/ ln -s ~/.vim/ultisnips_rep/ftdetect/* ~/.vim/ftdetect/ @@ -166,15 +170,17 @@ Restart Vim and UltiSnips should work. To access the help, use > :helptags ~/.vim/ultisnips_rep/doc :help UltiSnips -UltiSnips comes without snippets. The default snippets can be found here: -https://github.com/honza/vim-snippets +UltiSnips comes without snippets. An excellent selection of snippets can be +found here: https://github.com/honza/vim-snippets ============================================================================= 3. Settings & Commands *UltiSnips-settings* 3.1 Commands *UltiSnips-commands* ------------ - *:UltiSnipsEdit* + + 3.1.1 UltiSnipsEdit *:UltiSnipsEdit* + The UltiSnipsEdit command opens a private snippet definition file for the current filetype. If no snippet file exists, a new file is created. If used as UltiSnipsEdit! all public snippet files are taken into account too. If @@ -194,25 +200,32 @@ g:UltiSnipsEditSplit Defines how the edit window is opened. Possible *g:UltiSnipsSnippetsDir* g:UltiSnipsSnippetsDir - Defines the directory private snippet definition - files are stored in. For example, if the variable - is set to "~/.vim/mydir/UltiSnips" and the current - 'filetype' is "cpp", then :UltiSnipsEdit will open - "~/.vim/mydir/UltiSnips/cpp.snippets" if file is - not empty, if it's empty :UltiSnipsEdit will see - for non-empty files in directories - g:UltiSnipsSnippetDirectories, if nothing found, - :UltiSnipsEdit will open new file in - g:UltiSnipsSnippetsDir. + Defines the directory where private snippet + definition files are placed in in. + + As example, if the current 'filetype' is "cpp" the + :UltiSnipsEdit command looks for a file to edit in + this order: + 1. An existing + g:UltiSnipsSnippetsDir."/cpp.snippets" file + 2. Find a matching "cpp" snippets file in + g:UltiSnipsSnippetDirectories + 3. Create a new + g:UltiSnipsSnippetsDir."/cpp.snippets" file + Note that directories named "snippets" are reserved for snipMate snippets and cannot be used. + Also, this setting does not affect where snippets + are searched for, so it is possible to change this + to opening files that are then not found by + UltiSnips. See |UltiSnips-snippet-search-path| for + details. *g:UltiSnipsSnippetDirectories* g:UltiSnipsSnippetDirectories - Defines the directories for looking for snippets. - Do not mix up this variable with previous one. - More information about that variable can - be found at section |UltiSnips-snippet-search-path|. + Configures the directories that are searched for + snippets. Do not mix up this variable with the + previous one. See |UltiSnips-how-snippets-are-loaded|. *g:UltiSnipsEnableSnipMate* g:UltiSnipsEnableSnipMate @@ -223,7 +236,8 @@ g:UltiSnipsEnableSnipMate will look for SnipMate snippets. - *:UltiSnipsAddFiletypes* + 3.1.2 UltiSnipsAddFiletypes *:UltiSnipsAddFiletypes* + The UltiSnipsAddFiletypes command allows for explicit merging of other snippet filetypes for the current buffer. For example, if you edit a .rst file but also want the Lua snippets to be available you can issue the command > @@ -232,7 +246,7 @@ also want the Lua snippets to be available you can issue the command > using the dotted filetype syntax. Order is important, the first filetype in this list will be the one used for UltiSnipsEdit and the list is -ordered by evaluation priority. Consequently, you might add this to your +ordered by evaluation priority. For example you might add this to your ftplugin/rails.vim > :UltiSnipsAddFiletypes rails.ruby @@ -250,13 +264,17 @@ The priority will then be rails -> ruby -> programming -> all. 3.2 Triggers *UltiSnips-triggers* ------------ + 3.2.1 Trigger key mappings *UltiSnips-trigger-key-mappings* + *g:UltiSnipsExpandTrigger* *g:UltiSnipsListSnippets* *g:UltiSnipsJumpForwardTrigger* *g:UltiSnipsJumpBackwardTrigger* + You can define the keys used to trigger UltiSnips actions by setting global variables. Variables define the keys used to expand a snippet, jump forward and jump backwards within a snippet, and list all available snippets in the current expand context. Be advised, that some terminal emulators don't send - to the running program. The variables with their default values are: > + (and others, like ) to the running program. The variables with +their default values are: > g:UltiSnipsExpandTrigger g:UltiSnipsListSnippets g:UltiSnipsJumpForwardTrigger @@ -271,8 +289,7 @@ following to your vimrc file or switching to a plugin like Supertab or YouCompleteMe. > inoremap -3.2.1 Using your own trigger functions *UltiSnips-trigger-functions* --------------------------------------- +3.2.2 Using your own trigger functions *UltiSnips-trigger-functions* For advanced users there are four functions that you can map directly to a key and that correspond to some of the triggers previously defined: @@ -316,12 +333,11 @@ then you define your mapping as > and if the you can't expand or jump from the current location then the alternative function IMAP_Jumpfunc('', 0) is called. -3.2.2 Custom autocommands *UltiSnips-custom-autocommands* -------------------------- + 3.2.3 Custom autocommands *UltiSnips-custom-autocommands* Note Autocommands must not change the buffer in any way. If lines are added, deleted, or modified it will confuse UltiSnips which might scramble your -snippets contents. +snippet contents. *UltiSnipsEnterFirstSnippet* *UltiSnipsExitLastSnippet* For maximum compatibility with other plug-ins, UltiSnips sets up some special @@ -347,12 +363,11 @@ is entered, and |UltiSnipsExitLastSnippet| will only fire once the last (outermost) snippet have been exited. - -3.2.3 Path to Python module *UltiSnips-python-module-path* ---------------------------- + 3.2.4 Direct use of Python API *UltiSnips-use-python-api* For even more advanced usage, you can directly write python functions using -UltiSnip's python modules. +UltiSnip's python modules. This is an internal and therefore unstable API and +not recommended though. Here is a small example funtion that expands a snippet: > @@ -365,48 +380,8 @@ Here is a small example funtion that expands a snippet: > return "" endfunction -3.3 Snippet Search Path *UltiSnips-snippet-search-path* ------------------------ -UltiSnips snippet definition files are stored in one or more directories. -There are several variables used to indicate those directories and to define -how UltiSnips loads snippets. - -Snippet definition files are stored in snippet directories. A snippet -directory must be a subdirectory of a directory defined in the 'runtimepath' -option. The variable g:UltiSnipsSnippetDirectories defines a list of names -used for snippet directories. Note that "snippets" is reserved for snipMate -snippets and cannot be used. The default is shown below. > - - let g:UltiSnipsSnippetDirectories=["UltiSnips"] - -UltiSnips will search each 'runtimepath' directory for the subdirectory names -defined in g:UltiSnipsSnippetDirectories in the order they are defined. For -example, if you keep your snippets in a .vim subdirectory called -"mycoolsnippets" and you want to make use of the default snippets that come -with UltiSnips, add the following to your vimrc file. > - let g:UltiSnipsSnippetDirectories=["UltiSnips", "mycoolsnippets"] -If you do not want to use the third party snippets that come with plugins, -define the variable accordingly: > - let g:UltiSnipsSnippetDirectories=["mycoolsnippets"] - -You can also redefine the search path on a buffer by buffer basis by setting -the variable b:UltiSnipsSnippetDirectories. This variable takes precedence -over the global variable. - -|UltiSnips-adding-snippets| explains which files are parsed for a given filetype. - -If only one directory is specified in this variable and this directory is -specified by absolute path, UltiSnips will not look for snippets in -&runtimepath, which can lead to significant speedup. So, the common case is: - - let g:UltiSnipsSnippetDirectories=[$HOME.'/.vim/UltiSnips'] - -However, you will not able to use snippets that are shipped with third party -plugins out of the box. You'll need to copy them into your chosen directory. - - -3.4 Warning About Select Mode Mappings *UltiSnips-warning-smappings* +3.3 Warning About Select Mode Mappings *UltiSnips-warning-smappings* -------------------------------------- Vim's help document for |mapmode-s| states: > @@ -435,23 +410,22 @@ complete definition as listed by the |:smap| command. > let g:UltiSnipsMappingsToIgnore = [ "somePlugin", "otherPlugin" ] -3.5 Functions *UltiSnips-functions* +3.4 Functions *UltiSnips-functions* ------------- UltiSnips provides some functions for extending core functionality. - 3.5.1 UltiSnips#AddSnippetWithPriority *UltiSnips#AddSnippetWithPriority* + 3.4.1 UltiSnips#AddSnippetWithPriority *UltiSnips#AddSnippetWithPriority* The first function is UltiSnips#AddSnippetWithPriority(trigger, value, description, -options, filetyp, priority). It adds a new snippet with the provided trigger, value, -description, and options to the current list of snippets. See -|UltiSnips-syntax| for details on the meaning of the function arguments. The -Priority is a number that defines which snippet should be preferred over -others. See the priority keyword in|UltiSnips-add-snippets|. +options, filetyp, priority). It adds a new snippet to the current list of +snippets. See |UltiSnips-authoring-snippets| for details most of the function +arguments. The priority is a number that defines which snippet should be +preferred over others. See the priority keyword in |UltiSnips-add-snippets|. - 3.5.2 UltiSnips#Anon *UltiSnips#Anon* + 3.4.2 UltiSnips#Anon *UltiSnips#Anon* The second function is UltiSnips#Anon(value, ...). It expands an anonymous snippet. Anonymous snippets are defined on the spot, expanded and immediately @@ -472,41 +446,24 @@ This expands the snippet whenever two $ signs are typed. Note: The right-hand side of the mapping starts with an immediate retype of the '$$' trigger and passes '$$' to the function as the trigger argument. This is required in order for UltiSnips to have access to the characters -typed so it can determine if the trigger matches or not. +typed so it can determine if the trigger matches or not. A more elegant way of +creating such a snippet could be to use |UltiSnips-autotrigger|. - 3.5.3 UltiSnips#SnippetsInCurrentScope *UltiSnips#SnippetsInCurrentScope* + 3.4.3 UltiSnips#SnippetsInCurrentScope *UltiSnips#SnippetsInCurrentScope* -A third function is UltiSnips#SnippetsInCurrentScope which is the equivalent -of snipmate GetSnipsInCurrentScope function. - -This function simply returns a vim dictionary with the snippets whose trigger -matches the current word. If you need all snippets information of current -buffer, you can simply pass 1 (which means all) as first argument of this -function, and use a global variable g:current_ulti_dict_info to get the -result (see example below). +UltiSnips#SnippetsInCurrentScope returns a vim dictionary with the snippets +whose trigger matches the current word. If you need all snippets information +for the current buffer, you can simply pass 1 (which means all) as first +argument of this function, and use a global variable g:current_ulti_dict_info +to get the result (see example below). This function does not add any new functionality to ultisnips directly but allows to use third party plugins to integrate the current available snippets. +For example, all completion plugins that integrate with UltiSnips use this +function. -An example of such third party plugin is SnippetCompleteSnipMate which uses -the function GetSnipsInCurrentScope to integrate the current available -snippets with user defined abbreviations and provides these and a completion -menu. -This script is located in -http://www.vim.org/scripts/script.php?script_id=4276. -Note: If you check the above website it lists two dependencies: the -SnippetComplete plugin and snipmate. -You do need the SnippetComplete plugin but you obviously don't need snipmate, -you just have to define the function GetSnipsInCurrentScope. Put the following -in your vimrc: - -function! GetSnipsInCurrentScope() - return UltiSnips#SnippetsInCurrentScope() -endfunction - - -As a second example on how to use this function consider the following -function and mapping definition: +Another example on how to use this function consider the following function +and mapping definition: function! ExpandPossibleShorterSnippet() if len(UltiSnips#SnippetsInCurrentScope()) == 1 "only one candidate... @@ -524,8 +481,8 @@ If the trigger for your snippet is lorem, you type lor, and you have no other snippets whose trigger matches lor then hitting will expand to whatever lorem expands to. -A third example on how to use this function to extract all snippets of -current buffer: > +One more example on how to use this function to extract all snippets available +in the current buffer: > function! GetAllSnippets() call UltiSnips#SnippetsInCurrentScope(1) @@ -542,11 +499,7 @@ function! GetAllSnippets() return list endfunction -The new variable g:current_ulti_dict_info is made to avoid confilct with -exists third party plugins. The definition location contains file path and -line number is also included in this variable. - -3.6 Warning about missing python support *UltiSnips-python-warning* +3.5 Warning about missing python support *UltiSnips-python-warning* ---------------------------------------- When UltiSnips is loaded, it will check that the running Vim was compiled with @@ -562,17 +515,48 @@ This may be useful if your Vim configuration files are shared across several systems where some of them may not have Vim compiled with python support. ============================================================================= -4. Syntax *UltiSnips-syntax* +4. Authoring snippets *UltiSnips-authoring-snippets* -This chapter describes how to write your own snippets and snippet definition -syntax. Examples are used to help illustrate. +4.1 Basics *UltiSnips-basics* +---------- + 4.1.1 How snippets are loaded *UltiSnips-how-snippets-are-loaded* -4.1 Adding Snippets *UltiSnips-adding-snippets* -------------------- +Snippet definition files are stored in snippet directories. The main +controlling variable for where these directories are searched for is the +list variable, set by default to > -See |UltiSnips-snippet-search-path| for an explanation of where directories -with snippet definitions should be located. + let g:UltiSnipsSnippetDirectories=["UltiSnips"] + +Note that "snippets" is reserved for snipMate snippets and cannot be used in +this list. + +UltiSnips will search each 'runtimepath' directory for the subdirectory names +defined in g:UltiSnipsSnippetDirectories in the order they are defined. For +example, if you keep your snippets in `~/.vim/mycoolsnippets`and you want to +make use of the UltiSnips snippets that come with other plugins, add the +following to your vimrc file. > + + let g:UltiSnipsSnippetDirectories=["UltiSnips", "mycoolsnippets"] + +If you do not want to use the third party snippets that come with plugins, +define the variable accordingly: > + + let g:UltiSnipsSnippetDirectories=["mycoolsnippets"] + +If the list has only one entry that is an absolute path, UltiSnips will not +iterate through &runtimepath but only look in this one directory for snippets. +This can lead to significant speedup. This means you will miss out on snippets +that are shipped with third party plugins. You'll need to copy them into this +directory manually. + +An example configuration could be: > + + let g:UltiSnipsSnippetDirectories=[$HOME.'/.vim/UltiSnips'] + +You can also redefine the search path on a buffer by buffer basis by setting +the variable b:UltiSnipsSnippetDirectories. This variable takes precedence +over the global variable. Using a strategy similar to how Vim detects |ftplugins|, UltiSnips iterates over the snippet definition directories looking for files with names of the @@ -588,10 +572,10 @@ snippet filenames and their associated filetype. c_my.snippets c c/a c c/b.snippets c - all.snippets *all - all/a.snippets *all + all.snippets all + all/a.snippets all -* The 'all' filetype is unique. It represents snippets available for use when +The 'all' filetype is unique. It represents snippets available for use when editing any document regardless of the filetype. A date insertion snippet, for example, would fit well in the all.snippets file. @@ -600,6 +584,8 @@ a dotted filetype for the CUDA C++ framework, e.g. ":set ft=cuda.cpp", then UltiSnips will search for and activate snippets for both the cuda and cpp filetypes. + 4.1.2 Basic syntax *UltiSnips-basic-syntax* + The snippets file syntax is simple. All lines starting with a # character are considered comments. Comments are ignored by UltiSnips. Use them to document snippets. @@ -627,10 +613,10 @@ the ones with the highest priority. For example, all shipped snippets have a priority < 0, so that user defined snippets always overwrite shipped snippets. -A line beginning with the keyword 'snippet' marks the beginning of snippet +A line beginning with the keyword 'snippet' marks the beginning of a snippet definition and a line starting with the keyword 'endsnippet' marks the end. The snippet definition is placed between the lines. Here is a snippet of an -'if' statement for the Unix shell (sh) filetype. +'if' statement for the Unix shell (sh) filetype. > snippet if "if ... then (if)" if ${2:[[ ${1:condition} ]]}; then @@ -640,12 +626,12 @@ The snippet definition is placed between the lines. Here is a snippet of an The start line takes the following form: > - snippet tab_trigger [ "description" [ options ] ] + snippet trigger_word [ "description" [ options ] ] -The tab_trigger is required, but the description and options are optional. +The trigger_word is required, but the description and options are optional. -The 'tab_trigger' is the word or string sequence used to trigger the snippet. -Generally a single word is used but the tab_trigger can include spaces. If you +The 'trigger_word' is the word or string sequence used to trigger the snippet. +Generally a single word is used but the trigger_word can include spaces. If you wish to include spaces, you must wrap the tab trigger in quotes. > snippet "tab trigger" [ "description" [ options ] ] @@ -670,7 +656,10 @@ same tab trigger. When a snippet is activated and more than one tab trigger match, UltiSnips displays a list of the matching snippets with their descriptions. The user then selects the snippet they want. - 4.1.1 Snippet Options: *UltiSnips-snippet-options* + + + + 4.1.3 Snippet Options: *UltiSnips-snippet-options* The 'options' control the behavior of the snippet. Options are indicated by single characters. The 'options' characters for a snippet are combined into @@ -711,7 +700,7 @@ The options currently supported are: > indentation settings. (For example, if 'expandtab' is set, the tab is replaced with spaces.) If this option is set, UltiSnips will ignore the Vim settings and insert the tab characters as is. This option is useful - for snippets involved with tab delimited formats, for example. + for snippets involved with tab delimited formats. s Remove whitespace immediately before the cursor at the end of a line before jumping to the next tabstop. This is useful if there is a @@ -722,10 +711,10 @@ The options currently supported are: > Without this option empty lines in snippets definition will have indentation too. - e Context snippets - With this option expansion of snippet can be + e Custom context snippet - With this option expansion of snippet can be controlled not only by previous characters in line, but by any given python expression. This option can be specified along with other - options, like 'b'. See |UltiSnips-context-snippets| for more info. + options, like 'b'. See |UltiSnips-custom-context-snippets| for more info. A Snippet will be triggered automatically, when condition matches. See |UltiSnips-autotrigger| for more info. @@ -738,7 +727,7 @@ When parsing snippet files, UltiSnips chops the trailing newline character from the 'endsnippet' end line. - 4.1.2 Character Escaping: *UltiSnips-character-escaping* + 4.1.4 Character Escaping: *UltiSnips-character-escaping* In snippet definitions, the characters '`', '{', '$' and '\' have special meaning. If you want to insert one of these characters literally, escape them @@ -800,7 +789,7 @@ The ${VISUAL} placeholder can also define a transformation (see Here is a simple example illustrating a visual transformation. The snippet will take selected text, replace every instance of "should" within it with -"is" , and wrap the result in tags. +"is", and wrap the result in tags. ------------------- SNIP ------------------- snippet t @@ -884,10 +873,9 @@ scripts except code is started with '!p'. Python scripts can be run using the python shebang '#!/usr/bin/python', but using the '!p' format comes with some predefined objects and variables, which can simplify and shorten code. For example, a 'snip' object instance is implied in python code. Python code using -the '!p' indicator differs in another way. Generally when a snippet is +the '!p' indicator differs also in another way. Generally when a snippet is expanded the standard output of code replaces the code. With python code the -value of the 'rv' property of the 'snip' instance replaces the code. Standard -output is ignored. +value of the 'snip.rv' property replaces the code. Standard output is ignored. The variables automatically defined in python code are: > @@ -895,8 +883,12 @@ The variables automatically defined in python code are: > path - The complete path to the current file t - The values of the placeholders, t[1] is the text of ${1}, etc. snip - UltiSnips.TextObjects.SnippetUtil object instance. Has methods - that simplify indentation handling. - context - Result of context condition. See |UltiSnips-context-snippets|. + that simplify indentation handling and owns the string that + should be inserted for the snippet. + context - Result of context condition. See |UltiSnips-custom-context-snippets|. + match - Only in regular expression triggered snippets. This is the return + value of the match of the regular expression. See + http://docs.python.org/library/re.html#match-objects The 'snip' object provides the following methods: > @@ -934,8 +926,7 @@ The 'snip' object provides some properties as well: > is only done once. This deprecates the "cur" variable. snip.v: - Data related to the ${VISUAL} placeholder. The property has two - attributes: + Data related to the ${VISUAL} placeholder. This has two attributes: snip.v.mode ('v', 'V', '^V', see |visual-mode| ) snip.v.text The text that was selected. @@ -1083,7 +1074,7 @@ The syntax for a tabstop is the dollar sign followed by a number, for example, '$1'. Tabstops start at number 1 and are followed in sequential order. The '$0' tabstop is a special tabstop. It is always the last tabstop in the snippet no matter how many tabstops are defined. If there is no '$0' defined, -'$0' tabstop will be defined at the end of snippet. +'$0' tabstop will be defined at the end of the snippet. Here is a simple example. @@ -1102,9 +1093,9 @@ Yours sincerely, Paul You can use to jump to the next tabstop, and to jump to the -previous. The key was not used for jumping forward because many people -(myself included) use for completion. See |UltiSnips-triggers| for -help on defining different keys for tabstops. +previous. The key was not used for jumping forward because it is +commonly used for completion. See |UltiSnips-triggers| for help on defining +different keys for motions. It is often useful to have some default text for a tabstop. The default text may be a value commonly used for the variable component, or it may be a word @@ -1373,7 +1364,7 @@ printf("A is: %s\n", A); // End of line There are many more examples of what can be done with transformations in the -bundled snippets. +vim-snippets repo. 4.8 Clearing snippets *UltiSnips-clearing-snippets* @@ -1408,22 +1399,23 @@ clearsnippets trigger1 trigger2 ------------------- SNAP ------------------- -4.9 Context snippets *UltiSnips-context-snippets* +4.9 Custom context snippets *UltiSnips-custom-context-snippets* -Context snippets can be enabled by using 'e' option in snippet definition. +Custom context snippets can be enabled by using the 'e' option in the snippet +definition. In that case snippet should be defined using this syntax: > - snippet tab_trigger "description" "expression" options + snippet trigger_word "description" "expression" options -Context can be defined using special header using this syntax: > +The context can be defined using a special header: > - context "expression" - snippet tab_trigger "description" options + context "python_expression" + snippet trigger_word "description" options The 'expression' can be any python expression. If 'expression' evaluates to -'True', then this snippet will be chosen for expansion. The 'expression' must -be wrapped with double-quotes. +'True', then this snippet will be eligible for expansion. The 'expression' +must be wrapped with double-quotes. The following python modules are automatically imported into the scope before 'expression' is evaluated: 're', 'os', 'vim', 'string', 'random'. @@ -1459,8 +1451,8 @@ endsnippet That snippet will expand to 'return err' only if the previous line is starting from 'if err' prefix. -Note: context snippets prioritized over non-context ones. It makes possible to -use non-context snippets as fallback, if no context matched: +Note: custom context snippets are prioritized over other snippets. It makes possible +to use other snippets as a fallback if no context can be matched: ------------------- SNIP ------------------- snippet i "if ..." b @@ -1476,8 +1468,8 @@ if err != nil { endsnippet ------------------- SNAP ------------------- -That snippet will expand into 'if err != nil' if previous line will -match 'err :=' prefix, otherwise the default 'if' snippet will be expanded. +That snippet will expand into 'if err != nil' if the previous line will match +'err :=' prefix, otherwise the default 'if' snippet will be expanded. It's a good idea to move context conditions to a separate module, so it can be used by other UltiSnips users. In that case, module should be imported @@ -1516,8 +1508,8 @@ That snippet will expand to 'var1 +=' after line, which begins from 'var1 :='. *UltiSnips-capture-placeholder* -You can capture placeholder text from previous snippet by using following -trick: +You can capture placeholder text from the previous snippet by using the +following trick: ------------------- SNIP ------------------- snippet = "desc" "snip.last_placeholder" Ae `!p snip.rv = snip.context.current_text` == nil @@ -1532,27 +1524,27 @@ tabstop value following by ' == nil'. 4.10 Snippets actions *UltiSnips-snippet-actions* --------------------- -Snippet actions is an arbitrary python code which can be executed at specific -points in lifetime of the snippet. +A snippet action is an arbitrary python code which can be executed at specific +points in the lifetime of a snippet expansion. There are three types of actions: * Pre-expand - invoked just after trigger condition was matched, but before snippet actually expanded; * Post-expand - invoked after snippet was expanded and interpolations - was applied for the first time, but before jump on the first placeholder. -* Jump - invoked just after jump to the next/prev placeholder. + were applied for the first time, but before jump on the first placeholder. +* Jump - invoked just after a jump to the next/prev placeholder. Specified code will be evaluated at stages defined above and same global variables and modules will be available that are stated in -the |UltiSnips-context-snippets| section. +the |UltiSnips-custom-context-snippets| section. *UltiSnips-buffer-proxy* Note: special variable called 'snip.buffer' should be used for all buffer modifications. Not 'vim.current.buffer' and not 'vim.command("...")', because -of in that case UltiSnips will not be able to track changes in buffer from -actions. +in that case UltiSnips will not be able to track changes to the buffer +correctly. 'snip.buffer' has the same interface as 'vim.current.window.buffer'. @@ -1607,7 +1599,7 @@ endsnippet Post-expand actions can be used to perform some actions based on the expanded snippet text. Some cases are: code style formatting (e.g. inserting newlines -before and after method declaration), apply actions depending on python +before and after method declaration), and apply actions depending on python interpolation result. Post-expand action declared as follows: > @@ -1706,7 +1698,7 @@ endsnippet 4.11 Autotrigger *UltiSnips-autotrigger* ---------------- -Note: vim should be newer than 7.4.214 to support this feature. +Note: vim must be newer than 7.4.214 to support this feature. Many language constructs can occur only at specific places, so it's possible to use snippets without manually triggering them. @@ -1715,13 +1707,13 @@ Snippet can be marked as autotriggered by specifying 'A' option in the snippet definition. After snippet is defined as being autotriggered, snippet condition will be -checked on every typed character and if condition matches, then snippet will -be triggered. +checked on every typed character and if condition matches, then the snippet +will be triggered. -*Warning:* using of this feature can lead to significant vim slowdown. If you -discovered that, report an issue to the github.com/SirVer/UltiSnips. +*Warning:* using of this feature might lead to significant vim slowdown. If +you discovered that, please report an issue. -Consider following snippets, that can be usefull in Go programming: +Consider following useful Go snippets: ------------------- SNIP ------------------- snippet "^p" "package" rbA package ${1:main} @@ -1753,7 +1745,7 @@ pull request. snipMate - UltiSnips is a drop-in replacement for snipMate. It has many more features, so porting snippets is still a good idea, but switching has low -friction now. UltiSnips is trying hard to truly emulate snipMate, for example +friction. UltiSnips is trying hard to truly emulate snipMate, for example recursive tabstops are not supported in snipMate snippets (but of course in UltiSnips snippets). @@ -1790,15 +1782,15 @@ to Supertab for expansion. UltiSnips allows other plugins to add new snippets on the fly. Since UltiSnips is written in python, the integration is also on a python basis. A small -example can be found in `test.py`, search for AddNewSnippetSource. Please -contact us on github if you integrate UltiSnips with your plugin so it can be -listed in the docs. +example can be found in `test/test_UltiSnipsFunc.py`, search for +AddNewSnippetSource. Please contact us on github if you integrate UltiSnips +with your plugin so it can be listed in the docs. ============================================================================= 6. FAQ *UltiSnips-FAQ* Q: Do I have to call UltiSnips#ExpandSnippet() to check if a snippet is - expandable ? Is there instead an analog of neosnippet#expandable ? + expandable ? Is there instead an analog of neosnippet#expandable ? A: Yes there is, try function UltiSnips#IsExpandable() @@ -1823,8 +1815,9 @@ https://github.com/sirver/ultisnips/issues 8. Contributors *UltiSnips-contributors* UltiSnips has been started and maintained from Jun 2009 - Dec 2015 by Holger -Rapp (@SirVer, SirVer@gmx.de). It is now maintained by Stanislav Seletskiy -(@seletskiy). +Rapp (@SirVer, SirVer@gmx.de). Up to April 2018 it was maintained by Stanislav +Seletskiy (@seletskiy). Now, it is maintained by a growing set of +contributors. This is the list of contributors pre-git in chronological order. For a full list of contributors take the union of this set and the authors according to