feat: update luasnip configuration
This commit is contained in:
parent
89400c9167
commit
06664fda41
|
@ -7,6 +7,12 @@ if vim.g.snippets ~= "luasnip" then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
ls.config.set_config {
|
||||||
|
enable_autosnippets = true,
|
||||||
|
history = true,
|
||||||
|
updateevents = "TextChanged,TextChangedI",
|
||||||
|
}
|
||||||
|
|
||||||
local snippet = ls.snippet
|
local snippet = ls.snippet
|
||||||
local i = ls.insert_node
|
local i = ls.insert_node
|
||||||
local t = ls.text_node
|
local t = ls.text_node
|
||||||
|
@ -27,7 +33,7 @@ local shortcut = function(val)
|
||||||
return val
|
return val
|
||||||
end
|
end
|
||||||
|
|
||||||
local function make(tbl)
|
local make = function(tbl)
|
||||||
local result = {}
|
local result = {}
|
||||||
for k, v in pairs(tbl) do
|
for k, v in pairs(tbl) do
|
||||||
table.insert(result, (snippet({ trig = k, desc = v.desc }, shortcut(v))))
|
table.insert(result, (snippet({ trig = k, desc = v.desc }, shortcut(v))))
|
||||||
|
@ -37,12 +43,14 @@ local function make(tbl)
|
||||||
end
|
end
|
||||||
|
|
||||||
local javascript = make(R "opdavies.snippets.ft.javascript")
|
local javascript = make(R "opdavies.snippets.ft.javascript")
|
||||||
|
local lua = make(R "opdavies.snippets.ft.lua")
|
||||||
local markdown = make(R "opdavies.snippets.ft.markdown")
|
local markdown = make(R "opdavies.snippets.ft.markdown")
|
||||||
local php = make(R "opdavies.snippets.ft.php")
|
local php = make(R "opdavies.snippets.ft.php")
|
||||||
local rst = make(R "opdavies.snippets.ft.rst")
|
local rst = make(R "opdavies.snippets.ft.rst")
|
||||||
|
|
||||||
local snippets = {
|
ls.snippets = {
|
||||||
js = javascript,
|
js = javascript,
|
||||||
|
lua = lua,
|
||||||
markdown = markdown,
|
markdown = markdown,
|
||||||
php = php,
|
php = php,
|
||||||
rst = rst,
|
rst = rst,
|
||||||
|
@ -50,12 +58,42 @@ local snippets = {
|
||||||
vue = javascript,
|
vue = javascript,
|
||||||
}
|
}
|
||||||
|
|
||||||
ls.snippets = snippets
|
local imap = require("opdavies.keymap").imap
|
||||||
|
local map = require("opdavies.keymap").map
|
||||||
|
local nmap = require("opdavies.keymap").nmap
|
||||||
|
|
||||||
vim.cmd [[
|
local map_opts = { silent = true }
|
||||||
imap <silent><expr> <c-k> luasnip#expand_or_jumpable() ? '<Plug>luasnip-expand-or-jump' : ''
|
|
||||||
inoremap <silent> <c-j> <cmd>lua require('luasnip').jump(-1)<CR>
|
map {
|
||||||
imap <silent><expr> <C-l> luasnip#choice_active() ? '<Plug>luasnip-next-choice' : '<C-l>'
|
{ "i", "s" },
|
||||||
snoremap <silent> <c-k> <cmd>lua require('luasnip').jump(1)<CR>
|
"<c-j>",
|
||||||
snoremap <silent> <c-j> <cmd>lua require('luasnip').jump(-1)<CR>
|
function()
|
||||||
]]
|
if ls.jumpable(-1) then
|
||||||
|
ls.jump(-1)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
map_opts,
|
||||||
|
}
|
||||||
|
|
||||||
|
map {
|
||||||
|
{ "i", "s" },
|
||||||
|
"<c-k>",
|
||||||
|
function()
|
||||||
|
if ls.expand_or_jumpable() then
|
||||||
|
ls.expand_or_jump()
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
map_opts,
|
||||||
|
}
|
||||||
|
|
||||||
|
imap {
|
||||||
|
"<c-l>",
|
||||||
|
function()
|
||||||
|
if ls.choice_active() then
|
||||||
|
ls.change_choice(1)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
map_opts,
|
||||||
|
}
|
||||||
|
|
||||||
|
nmap { "<leader><leader>s", "<cmd>source ~/.config/nvim/after/plugin/luasnip.lua<CR>", map_opts }
|
||||||
|
|
|
@ -4,6 +4,10 @@ M.imap = function(tbl)
|
||||||
vim.keymap.set("i", tbl[1], tbl[2], tbl[3])
|
vim.keymap.set("i", tbl[1], tbl[2], tbl[3])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
M.map = function(tbl)
|
||||||
|
vim.keymap.set(tbl[1], tbl[2], tbl[3], tbl[4] or {})
|
||||||
|
end
|
||||||
|
|
||||||
M.nmap = function(tbl)
|
M.nmap = function(tbl)
|
||||||
vim.keymap.set("n", tbl[1], tbl[2], tbl[3])
|
vim.keymap.set("n", tbl[1], tbl[2], tbl[3])
|
||||||
end
|
end
|
||||||
|
|
9
roles/neovim/files/lua/opdavies/snippets/ft/lua.lua
Normal file
9
roles/neovim/files/lua/opdavies/snippets/ft/lua.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
local fmt = require("luasnip.extras.fmt").fmt
|
||||||
|
local ls = require "luasnip"
|
||||||
|
local rep = require("luasnip.extras").rep
|
||||||
|
|
||||||
|
local i = ls.insert_node
|
||||||
|
|
||||||
|
return {
|
||||||
|
req = fmt("local {} = require('{}')", { i(1), rep(1) })
|
||||||
|
}
|
|
@ -6,45 +6,26 @@ local i = ls.insert_node
|
||||||
local t = ls.text_node
|
local t = ls.text_node
|
||||||
|
|
||||||
local M = {
|
local M = {
|
||||||
-- TODO: only load if within a Drupal project?
|
func = fmta("function <>(<>)<> {\n <>\n}<>", { i(1), i(2), i(3), i(4), i(0) }),
|
||||||
drupalclass = {
|
|
||||||
fmta(
|
met = fmta(
|
||||||
[[
|
[[
|
||||||
<<?php
|
<> function <>(<>)<> {
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace Drupal\<>;
|
|
||||||
|
|
||||||
<>class <> {
|
|
||||||
|
|
||||||
<>
|
<>
|
||||||
|
}<>
|
||||||
}
|
|
||||||
]],
|
]],
|
||||||
{ i(1), c(2, { t "", t "final " }), i(3), i(0) }
|
{ c(1, { t "public", t "protected", t "private" }), i(2), i(3), i(4), i(5), i(0) }
|
||||||
),
|
),
|
||||||
},
|
|
||||||
|
|
||||||
test = {
|
test = fmta(
|
||||||
fmta(
|
|
||||||
[[
|
[[
|
||||||
/** @test */
|
/** @test */
|
||||||
public function <><>(): void {
|
public function <><>(): void {
|
||||||
<>
|
<>
|
||||||
}
|
}<>
|
||||||
]],
|
]],
|
||||||
{
|
{ c(1, { t "test", t "it", t "should" }), i(2), i(3), i(0) }
|
||||||
c(1, {
|
|
||||||
t "test",
|
|
||||||
t "it",
|
|
||||||
t "should",
|
|
||||||
}),
|
|
||||||
i(2),
|
|
||||||
i(0),
|
|
||||||
}
|
|
||||||
),
|
),
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
|
Loading…
Reference in a new issue