Credit to OrangeX4 for the great fork of the original plugin by draivin.
GitHub: https://github.com/Oskar-Idland/hsnips
Press Ctrl + Shift + P
, and choose Open Snippets Directory
, then create a markdown.hsnips
file, for your markdown snippets. Substitute "markdown" for whatever language you want. You can also create a all.hsnips
file for snippets that should be available in all languages.
Here is an example of a snippet that will expand to \mathbb{R}
when you type RR
in a math environment:
snippet RR "R" iAm
\mathbb{R}
endsnippet
There are three flags in this snippet: i
, A
, and m
. i
allows the snippet to be triggered in the middle of a word, A
allows the snippet to be triggered automatically, and m
specifies that the snippet should only be triggered in a math environment.
Tabstops are used to define where the cursor should go after the snippet is expanded. Pressing Tab
will move the cursor to the next tabstop. Here is an example of a snippet that will expand to a table environment with a caption and a label:
snippet tabular "tabular" wA
\begin{table}[${1:h!}]
\centering
$0
\caption{$2}
\label{tab: $3}
\end{table}
endsnippet
The cursor begins at the first tabstop, ${1:h!}
. Here h!
is the default value, but will be overwritten by typing. By pressing Tab
, the cursor will move to the next tabstop, ${2}
. The cursor will then move to ${3}
. The final tabstop is $0
, which is inside the table environment.
Nested tabstops are supported, meaning you can use snippets inside snippets!
Here is another example of a snippet that will postfix any word, putting it in the bold font:
priority 100
snippet `(\\?[a-zA-Z]\w*({?\w*})?)(bf|BF)` "mathbf" iAm
\mathbf{``rv = m[1]``}
endsnippet
Priority is set to 100, so that if two snippets match sometimes, this will be prioritized. You can have many different priorities.
We can manipulate our snippets further with return values: rv = m[1]
. In this case, m[1]
is the first match group of the regex trigger. We can use JavaScript to manipulate this string before it is inserted. Here we use it to uppercase the letter to be put in the math font.
priority 100
snippet `(\\?[a-zA-Z]\w*({?\w*})?)cal` "mathcal" iAm
\mathcal{``rv = m[1].toUpperCase()``}$0
endsnippet
With the VISUAL keyword, we can insert what was selected, before typing the trigger. Here is an example of a snippet that will expand to a fraction with the selected text as the numerator:
snippet fr "frac" iAm
\\frac{${1:${VISUAL}}}{$2}
endsnippet
My own snippet file, latex.hsnips
, is made for math/physics and can be found here.
HyperSnips is a snippet engine for vscode heavily inspired by vim's UltiSnips.
To use HyperSnips you create .hsnips
files on a directory which depends on your platform:
- Windows:
%APPDATA%\Code\User\hsnips\(language).hsnips
- Mac:
$HOME/Library/Application Support/Code/User/hsnips/(language).hsnips
- Linux:
$HOME/.config/Code/User/hsnips/(language).hsnips
Or alternatively, you can open this directory by running the command HyperSnips: Open snippets directory
.
Additionally, you can create an all.hsnips
file for snippets that should be available on all languages.
A snippets file is a file with the .hsnips
extension, the file is composed of two types of blocks:
global blocks and snippet blocks.
Global blocks are JavaScript code blocks with code that is shared between all the snippets defined
in the current file. They are defined with the global
keyword, as follows:
global
// JavaScript code
endglobal
Snippet blocks are snippet definitions. They are defined with the snippet
keyword, as follows:
snippet trigger "description" flags
body
endsnippet
where the trigger
field is required and the fields description
and flags
are optional.
A trigger can be any sequence of characters which does not contain a space, or a regular expression
surrounded by backticks (`
).
The flags field is a sequence of characters which modify the behavior of the snippet, the available flags are the following:
-
A
: Automatic snippet expansion - Usually snippets are activated when thetab
key is pressed, with theA
flag snippets will activate as soon as their trigger matches, it is specially useful for regex snippets. -
i
: In-word expansion* - By default, a snippet trigger will only match when the trigger is preceded by whitespace characters. A snippet with this option is triggered regardless of the preceding character, for example, a snippet can be triggered in the middle of a word. -
w
: Word boundary* - With this option the snippet trigger will match when the trigger is a word boundary character. Use this option, for example, to permit expansion where the trigger follows punctuation without expanding suffixes of larger words. -
b
: Beginning of line expansion* - A snippet with this option is expanded only if the tab trigger is the first word on the line. In other words, if only whitespace precedes the tab trigger, expand. -
M
: Multi-line mode - By default, regex matches will only match content on the current line, when this option is enabled the lasthsnips.multiLineContext
lines will be available for matching. -
m
: Math mode -
h
: Hidden snippet - RequiresA
flag. By default, all non-regex snippets will be listed by the inline suggestions. Thish
flag hides the snippet from the inline suggestions.
*: This flag will only affect snippets which have non-regex triggers.
The body is the text that will replace the trigger when the snippet is expanded, as in usual
snippets, the tab stops $1
, $2
, etc. are available.
The full power of HyperSnips comes when using JavaScript interpolation: you can have code blocks
inside your snippet delimited by two backticks (``
) that will run when the snippet is expanded,
and every time the text in one of the tab stops is changed.
Inside the code interpolation, you have access to a few special variables:
rv
: The return value of your code block, the value of this variable will replace the code block when the snippet is expanded.t
: An array containing the text within the tab stops, in the same order as the tab stops are defined in the snippet block. You can use it to dynamically change the snippet content.m
: An array containing the match groups of your regular expression trigger, or an empty array if the trigger is not a regular expression.w
: A URI string of the currently opened workspace, or an empty string if no workspace is open.path
: A URI string of the current document. (untitled documents have the schemeuntitled
)
Additionally, every variable defined in one code block will be available in all the subsequent code blocks in the snippet.
The require
function can also be used to import NodeJS modules.
- Simple snippet which greets you with the current date and time
snippet dategreeting "Gives you the current date!"
Hello from your hsnip at ``rv = new Date().toDateString()``!
endsnippet
- Box snippet as shown in the gif above
snippet box "Box" A
``rv = '┌' + '─'.repeat(t[0].length + 2) + '┐'``
│ $1 │
``rv = '└' + '─'.repeat(t[0].length + 2) + '┘'``
endsnippet
- Snippet to insert the current filename
snippet filename "Current Filename"
``rv = require('path').basename(path)``
endsnippet