perf: better letter and index snippet matching

This commit is contained in:
arne314
2024-12-13 16:20:47 +01:00
parent e32609f9cd
commit 5d29ba3f3e
2 changed files with 76 additions and 47 deletions

View File

@@ -1,60 +1,92 @@
local ls = require('luasnip')
local d = ls.dynamic_node
local s = ls.snippet_node
local t = ls.text_node
local helper = require('typstar.autosnippets') local helper = require('typstar.autosnippets')
local snip = helper.snip local snip = helper.snip
local cap = helper.cap local cap = helper.cap
local math = helper.in_math local math = helper.in_math
local markup = helper.in_markup local markup = helper.in_markup
local letter_snippets = {} local letter_snippets = {}
local greek_letters = { local greek_letters_map = {
{ 'a', 'alpha' }, { 'A', 'Alpha' }, ['a'] = 'alpha',
{ 'b', 'beta' }, { 'B', 'Beta' }, ['b'] = 'beta',
{ 'c', 'chi' }, { 'C', 'Chi' }, ['c'] = 'chi',
{ 'd', 'delta' }, { 'D', 'Delta' }, ['d'] = 'delta',
{ 'e', 'epsilon' }, { 'E', 'Epsilon' }, ['e'] = 'epsilon',
{ 'g', 'gamma' }, { 'G', 'Gamma' }, ['g'] = 'gamma',
{ 'h', 'phi' }, { 'H', 'Phi' }, ['h'] = 'phi',
{ 'i', 'iotta' }, { 'I', 'Iotta' }, ['i'] = 'iotta',
{ 'j', 'theta' }, { 'J', 'Theta' }, ['j'] = 'theta',
{ 'k', 'kappa' }, { 'K', 'Kappa' }, ['k'] = 'kappa',
{ 'l', 'lambda' }, { 'L', 'Lambda' }, ['l'] = 'lambda',
{ 'm', 'mu' }, { 'M', 'Mu' }, ['m'] = 'mu',
{ 'n', 'nu' }, { 'N', 'Nu' }, ['n'] = 'nu',
{ 'o', 'omega' }, { 'O', 'Omega' }, ['o'] = 'omega',
{ 'p', 'pi' }, { 'P', 'Pi' }, ['p'] = 'pi',
{ 'q', 'eta' }, { 'Q', 'Eta' }, ['q'] = 'eta',
{ 'r', 'rho' }, { 'R', 'Rho' }, ['r'] = 'rho',
{ 's', 'sigma' }, { 'S', 'Sigma' }, ['s'] = 'sigma',
{ 't', 'tau' }, { 'T', 'Tau' }, ['t'] = 'tau',
{ 'x', 'xi' }, { 'X', 'xi' }, ['x'] = 'xi',
{ 'z', 'zeta' }, { 'Z', 'Zeta' }, ['z'] = 'zeta',
} }
local latin_letters = { 'f', 'u', 'v', 'w', 'y' } -- remaining ones are added dynamically local greek_letters = {}
local common_indices = { '\\d+', 'i', 'j', 'k', 'n' } local greek_keys = {}
local common_indices = { '\\d+', '[i-n]' }
local index_conflicts = { 'in', 'pi', 'xi' }
local index_conflicts_set = {}
local trigger_latin = '[A-Za-z0-9]'
local trigger_greek = ''
local trigger_index_pre = ''
local trigger_index_post = ''
for _, letter in ipairs({ unpack(latin_letters) }) do local upper_first = function(str)
table.insert(latin_letters, letter:upper()) return str:sub(1, 1):upper() .. str:sub(2, -1)
end end
local generate_index_snippets = function(letter) local greek_full = {}
for _, index in pairs(common_indices) do for latin, greek in pairs(greek_letters_map) do
table.insert(letter_snippets, greek_full[latin] = greek
snip(letter .. '(' .. index .. ') ', letter .. '_<> ', { cap(1) }, math, 200)) greek_full[latin:upper()] = upper_first(greek)
table.insert(letter_snippets, table.insert(greek_letters, greek)
snip('\\$' .. letter .. '\\$(' .. index .. ') ', '$' .. letter .. '_<>$ ', { cap(1) }, markup, 200)) table.insert(greek_letters, upper_first(greek))
table.insert(greek_keys, latin)
table.insert(greek_keys, latin:upper())
end
for _, conflict in ipairs(index_conflicts) do
index_conflicts_set[conflict] = true
end
greek_letters_map = greek_full
trigger_greek = table.concat(greek_keys, '|')
trigger_index_pre = trigger_latin .. '|' .. table.concat(greek_letters, '|')
trigger_index_post = table.concat(common_indices, '|')
local get_greek = function(_, snippet)
return s(nil, t(greek_letters_map[snippet.captures[1]]))
end
local get_index = function(_, snippet)
local letter, index = snippet.captures[1], snippet.captures[2]
local trigger = letter .. index
if index_conflicts_set[trigger] then
return s(nil, t(trigger))
end end
return s(nil, t(letter .. '_' .. index))
end end
for _, val in pairs(greek_letters) do table.insert(letter_snippets, snip(':(' .. trigger_latin .. ')', '$<>$ ', { cap(1) }, markup))
table.insert(letter_snippets, snip(';' .. val[1], val[2], {}, math)) table.insert(letter_snippets, snip(';(' .. trigger_greek .. ')', '$<>$ ', { d(1, get_greek) }, markup))
table.insert(letter_snippets, snip(';' .. val[1], '$' .. val[2] .. '$ ', {}, markup)) table.insert(letter_snippets, snip(';(' .. trigger_greek .. ')', '<> ', { d(1, get_greek) }, math))
generate_index_snippets(val[2]) table.insert(letter_snippets,
table.insert(latin_letters, val[1]) snip('\\$(' .. trigger_index_pre .. ')\\$' .. '(' .. trigger_index_post .. ') ',
end '$<>$ ', { d(1, get_index) }, markup, 500))
table.insert(letter_snippets,
for _, letter in pairs(latin_letters) do snip('(' .. trigger_index_pre .. ')' .. '(' .. trigger_index_post .. ') ', '<> ', { d(1, get_index) }, math, 200))
generate_index_snippets(letter)
table.insert(letter_snippets, snip(':' .. letter, '$' .. letter .. '$ ', {}, markup))
end
return { return {
unpack(letter_snippets) unpack(letter_snippets)

View File

@@ -19,7 +19,6 @@ return {
snip('een', 'exists epsilon>>0 ', {}, math), snip('een', 'exists epsilon>>0 ', {}, math),
-- boolean logic -- boolean logic
snip('an', 'and ', {}, math),
snip('no', 'not ', {}, math), snip('no', 'not ', {}, math),
-- relations -- relations
@@ -52,7 +51,7 @@ return {
snip('nn', 'sect ', {}, math), snip('nn', 'sect ', {}, math),
snip('uu', 'union ', {}, math), snip('uu', 'union ', {}, math),
snip('bnn', 'sect.big ', {}, math, 1100), snip('bnn', 'sect.big ', {}, math, 1100),
snip('buu', 'untion.big ', {}, math, 1100), snip('buu', 'union.big ', {}, math, 1100),
snip('swo', 'without ', {}, math), snip('swo', 'without ', {}, math),
-- misc -- misc
@@ -62,8 +61,6 @@ return {
snip('iso', 'tilde.equiv ', {}, math), snip('iso', 'tilde.equiv ', {}, math),
snip('rrn', 'RR^n ', {}, math), snip('rrn', 'RR^n ', {}, math),
snip('cc', 'cases(\n\t<>\n)\\', { i(1, '1') }, math), snip('cc', 'cases(\n\t<>\n)\\', { i(1, '1') }, math),
snip('pi', 'pi ', {}, math),
snip('in', 'in ', {}, math),
snip('(.*)iv', '<>^(-1)', { cap(1) }, math), snip('(.*)iv', '<>^(-1)', { cap(1) }, math),
snip('(.*)sr', '<>^2', { cap(1) }, math), snip('(.*)sr', '<>^2', { cap(1) }, math),
snip('(.*)jj', '<>_(<>)', { cap(1), i(1, 'n') }, math), snip('(.*)jj', '<>_(<>)', { cap(1), i(1, 'n') }, math),