tesoura.nvim is a snippet management plugin using the new native snippet
api (:h vim.snippet
).
[!CAUTION] This plugin is not stable, and the API could change significantly.
nvim-cmp
completion source.nvim-cmp
(Optional, but recommended).Using lazy.nvim
:
{
'guilherme-puida/tesoura.nvim',
opts = {} -- see the configuration section below.
}
tesoura.nvim comes with the following defaults:
{
-- highlight snippet content on the documentation window.
highlight = true,
-- filetypes where snippets won't be setup.
ignored_filetypes = {},
-- set up autocmd to automatically initialize snippets when a new filetype is opened.
setup_autocmd = false,
-- your snippets!
snippets = {},
-- the nvim_cmp source name.
source_name = 'tesoura',
}
Snippets should be provided in the snippets
key when calling the setup
method.
A snippet is a Lua table containing at least a prefix
and a body
. The
prefix is what you type, and the body is what it expands to.
local snippet = {
prefix = 'hello',
body = 'world',
}
The body
can be:
string
. The body will be inserted as-is.string
s. Every element of the list will be inserted on a new
line.string
. The function will be evaluated when the
snippet hits the nvim-cmp
completion dialog.The vim.snippet
api supports a subset of the LSP snippet syntax, so you can
use tab stops inside the body.
The fact that snippets are just Lua code makes the system very flexible.
local snippet = {
prefix = 'date',
body = function() return tostring(os.date '%F') end,
}
The snippets
configuration parameter is a table that maps filetypes to
snippet definitions. The *
key applies to all filetypes (except those that
are explicitly ignored).
local snippets = {
['*'] = {
{ prefix = 'copyright', body = 'Copyright (c) 2024 Guilherme Puida Moreira' },
},
c = {
{ prefix = '#i', body = '#include "$1"$0' },
}
}
nvim-cmp
.tesoura.nvim is licensed under the MIT License.