initial commit 2
This commit is contained in:
parent
8566de3260
commit
5c1199caf9
12
.gitignore
vendored
Normal file
12
.gitignore
vendored
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
tt.*
|
||||||
|
.tests
|
||||||
|
doc/tags
|
||||||
|
debug
|
||||||
|
.repro
|
||||||
|
foo.*
|
||||||
|
*.log
|
||||||
|
data
|
||||||
|
lazy-lock.json
|
||||||
|
lazyvim.json
|
||||||
|
|
||||||
|
.luarc.json
|
15
.neoconf.json
Normal file
15
.neoconf.json
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"neodev": {
|
||||||
|
"library": {
|
||||||
|
"enabled": true,
|
||||||
|
"plugins": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"neoconf": {
|
||||||
|
"plugins": {
|
||||||
|
"lua_ls": {
|
||||||
|
"enabled": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
2
init.lua
Normal file
2
init.lua
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
-- bootstrap lazy.nvim, LazyVim and your plugins
|
||||||
|
require "config.lazy"
|
40
lua/config/autocmds.lua
Normal file
40
lua/config/autocmds.lua
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
-- Autocmds are automatically loaded on the VeryLazy event
|
||||||
|
-- Default autocmds that are always set: https://github.com/LazyVim/LazyVim/blob/main/lua/lazyvim/config/autocmds.lua
|
||||||
|
-- Add any additional autocmds here
|
||||||
|
|
||||||
|
local opt = vim.opt
|
||||||
|
|
||||||
|
opt.shiftwidth = 4
|
||||||
|
opt.tabstop = 4
|
||||||
|
|
||||||
|
-- vim.api.nvim_create_autocmd("BufReadPost", {
|
||||||
|
-- group = vim.api.nvim_create_augroup("LazyVim_AutoUpdate", {}),
|
||||||
|
-- once = true,
|
||||||
|
-- callback = function()
|
||||||
|
-- require("lazy").update {
|
||||||
|
-- show = false,
|
||||||
|
-- wait = false,
|
||||||
|
-- concurrency = 4,
|
||||||
|
-- }
|
||||||
|
-- end,
|
||||||
|
-- })
|
||||||
|
|
||||||
|
-- Golang templ filetype
|
||||||
|
vim.filetype.add {
|
||||||
|
extension = {
|
||||||
|
templ = "templ",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
require("lspconfig").nil_ls.setup {
|
||||||
|
settings = {
|
||||||
|
["nil"] = {
|
||||||
|
nix = {
|
||||||
|
flake = {
|
||||||
|
autoArchive = true,
|
||||||
|
autoEvalInputs = vim.fn.getenv "NIL_LS_NIX_AUTO_EVAL_INPUTS" ~= vim.NIL,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
11
lua/config/keymaps.lua
Normal file
11
lua/config/keymaps.lua
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
-- Keymaps are automatically loaded on the VeryLazy event
|
||||||
|
-- Default keymaps that are always set: https://github.com/LazyVim/LazyVim/blob/main/lua/lazyvim/config/keymaps.lua
|
||||||
|
-- Add any additional keymaps here
|
||||||
|
|
||||||
|
require "config.neovide"
|
||||||
|
|
||||||
|
vim.keymap.set("t", "<c-d>", "<C-\\><C-n>", { silent = true, desc = "Exit Terminal Mode" })
|
||||||
|
|
||||||
|
-- LazyVim hardcode tabs to jump snippet completions. Very fucking annoying.
|
||||||
|
vim.keymap.del({ "i" }, "<tab>")
|
||||||
|
vim.keymap.del({ "i" }, "<s-tab>")
|
65
lua/config/lazy.lua
Normal file
65
lua/config/lazy.lua
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
local lazypath = vim.fn.stdpath "data" .. "/lazy/lazy.nvim"
|
||||||
|
if not vim.loop.fs_stat(lazypath) then
|
||||||
|
-- bootstrap lazy.nvim
|
||||||
|
-- stylua: ignore
|
||||||
|
vim.fn.system({ "git", "clone", "--filter=blob:none", "https://github.com/folke/lazy.nvim.git", "--branch=stable", lazypath })
|
||||||
|
end
|
||||||
|
vim.opt.rtp:prepend(vim.env.LAZY or lazypath)
|
||||||
|
|
||||||
|
require("lazy").setup {
|
||||||
|
spec = {
|
||||||
|
-- add LazyVim and import its plugins
|
||||||
|
{ "LazyVim/LazyVim", import = "lazyvim.plugins" },
|
||||||
|
-- import any extras modules here
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.typescript" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.json" },
|
||||||
|
{ import = "lazyvim.plugins.extras.coding.copilot" },
|
||||||
|
{ import = "lazyvim.plugins.extras.coding.yanky" },
|
||||||
|
{ import = "lazyvim.plugins.extras.coding.luasnip" },
|
||||||
|
{ import = "lazyvim.plugins.extras.formatting.prettier" },
|
||||||
|
|
||||||
|
{ import = "lazyvim.plugins.extras.dap.core" },
|
||||||
|
{ import = "lazyvim.plugins.extras.dap.nlua" },
|
||||||
|
{ import = "lazyvim.plugins.extras.test.core" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.docker" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.go" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.json" },
|
||||||
|
-- { import = "lazyvim.plugins.extras.lang.markdown" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.tailwind" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.typescript" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.yaml" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lsp.none-ls" },
|
||||||
|
{ import = "lazyvim.plugins.extras.lang.java" },
|
||||||
|
{ import = "lazyvim.plugins.extras.util.project" },
|
||||||
|
{ import = "lazyvim.plugins.extras.editor.mini-files" },
|
||||||
|
-- { import = "lazyvim.plugins.extras.ui.edgy" },
|
||||||
|
-- import/override with your plugins
|
||||||
|
{ import = "plugins" },
|
||||||
|
},
|
||||||
|
defaults = {
|
||||||
|
-- By default, only LazyVim plugins will be lazy-loaded. Your custom plugins will load during startup.
|
||||||
|
-- If you know what you're doing, you can set this to `true` to have all your custom plugins lazy-loaded by default.
|
||||||
|
lazy = false,
|
||||||
|
-- It's recommended to leave version=false for now, since a lot the plugin that support versioning,
|
||||||
|
-- have outdated releases, which may break your Neovim install.
|
||||||
|
version = false, -- always use the latest git commit
|
||||||
|
-- version = "*", -- try installing the latest stable version for plugins that support semver
|
||||||
|
},
|
||||||
|
install = { colorscheme = { "tokyonight", "habamax" } },
|
||||||
|
checker = { enabled = false }, -- automatically check for plugin updates
|
||||||
|
performance = {
|
||||||
|
rtp = {
|
||||||
|
-- disable some rtp plugins
|
||||||
|
disabled_plugins = {
|
||||||
|
"gzip",
|
||||||
|
-- "matchit",
|
||||||
|
-- "matchparen",
|
||||||
|
-- "netrwPlugin",
|
||||||
|
"tarPlugin",
|
||||||
|
"tohtml",
|
||||||
|
"tutor",
|
||||||
|
"zipPlugin",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
21
lua/config/neovide.lua
Normal file
21
lua/config/neovide.lua
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
if not vim.g.neovide then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local font = "JetBrainsMono Nerd Font Mono"
|
||||||
|
|
||||||
|
local font_size = vim.o.lines < 60 and 11 or 12
|
||||||
|
|
||||||
|
vim.o.guifont = font .. ":h" .. font_size
|
||||||
|
|
||||||
|
vim.keymap.set("n", "<c-->", function()
|
||||||
|
font_size = font_size - 1
|
||||||
|
vim.o.guifont = font .. ":h" .. font_size
|
||||||
|
vim.notify("Font Set: " .. font .. ":h" .. font_size)
|
||||||
|
end, { desc = "Decrease font size" })
|
||||||
|
|
||||||
|
vim.keymap.set("n", "<c-=>", function()
|
||||||
|
font_size = font_size + 1
|
||||||
|
vim.o.guifont = font .. ":h" .. font_size
|
||||||
|
vim.notify("Font Set: " .. font .. ":h" .. font_size)
|
||||||
|
end, { desc = "Increase font size" })
|
10
lua/config/options.lua
Normal file
10
lua/config/options.lua
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
-- Options are automatically loaded before lazy.nvim startup
|
||||||
|
-- Default options that are always set: https://github.com/LazyVim/LazyVim/blob/main/lua/lazyvim/config/options.lua
|
||||||
|
-- Add any additional options here
|
||||||
|
|
||||||
|
-- Disable swap files
|
||||||
|
vim.opt.swapfile = false
|
||||||
|
|
||||||
|
vim.defer_fn(function()
|
||||||
|
vim.opt.title = true
|
||||||
|
end, 100)
|
10
lua/plugins/arrow.lua
Normal file
10
lua/plugins/arrow.lua
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
return {
|
||||||
|
"otavioschwanck/arrow.nvim",
|
||||||
|
opts = {
|
||||||
|
show_icons = true,
|
||||||
|
leader_key = [[\]], -- Recommended to be a single key
|
||||||
|
},
|
||||||
|
keys = {
|
||||||
|
{ "<cr>", desc = "Open Arrow bookmarks" },
|
||||||
|
},
|
||||||
|
}
|
70
lua/plugins/base16.lua
Normal file
70
lua/plugins/base16.lua
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"rktjmp/fwatch.nvim",
|
||||||
|
dependencies = {
|
||||||
|
"xiyaowong/transparent.nvim", -- For Transparency support
|
||||||
|
{ "echasnovski/mini.nvim", version = false },
|
||||||
|
},
|
||||||
|
lazy = false,
|
||||||
|
config = function()
|
||||||
|
local fwatch = require "fwatch"
|
||||||
|
|
||||||
|
local color_file = vim.fn.getenv "HOME" .. "/.cache/wallust/base16-nvim.lua"
|
||||||
|
local error_fn = function(err)
|
||||||
|
vim.notify("Watch Error: " .. err, vim.log.levels.ERROR, { title = "fwatch.nvim" })
|
||||||
|
end
|
||||||
|
local command = {}
|
||||||
|
local source_fn = function(_, _, unwatch)
|
||||||
|
vim.schedule(function()
|
||||||
|
if vim.fn.filereadable(color_file) == 1 then
|
||||||
|
vim.cmd(("source %s"):format(color_file))
|
||||||
|
if not vim.g.neovide then
|
||||||
|
require("transparent").setup {
|
||||||
|
groups = {
|
||||||
|
"Normal",
|
||||||
|
"NormalNC",
|
||||||
|
"Comment",
|
||||||
|
"Constant",
|
||||||
|
"Special",
|
||||||
|
"Identifier",
|
||||||
|
"Statement",
|
||||||
|
"PreProc",
|
||||||
|
"Type",
|
||||||
|
"Underlined",
|
||||||
|
"Todo",
|
||||||
|
"String",
|
||||||
|
"Function",
|
||||||
|
"Conditional",
|
||||||
|
"Repeat",
|
||||||
|
"Operator",
|
||||||
|
"Structure",
|
||||||
|
"LineNr",
|
||||||
|
"NonText",
|
||||||
|
"SignColumn",
|
||||||
|
-- "CursorLine",
|
||||||
|
-- "CursorLineNr",
|
||||||
|
"StatusLine",
|
||||||
|
"StatusLineNC",
|
||||||
|
"EndOfBuffer",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end
|
||||||
|
if unwatch then
|
||||||
|
unwatch()
|
||||||
|
end
|
||||||
|
fwatch.watch(color_file, command)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
command.on_event = source_fn
|
||||||
|
command.on_error = error_fn
|
||||||
|
source_fn()
|
||||||
|
fwatch.watch(color_file, command)
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"brenoprata10/nvim-highlight-colors",
|
||||||
|
opts = {},
|
||||||
|
event = "VeryLazy",
|
||||||
|
},
|
||||||
|
}
|
9
lua/plugins/before.lua
Normal file
9
lua/plugins/before.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
return {
|
||||||
|
"bloznelis/before.nvim",
|
||||||
|
opts = {},
|
||||||
|
event = { "InsertEnter" },
|
||||||
|
keys = {
|
||||||
|
{ "<C-h>", "<cmd>lua require'before'.jump_to_last_edit()<CR>", desc = "Jump to last edit" },
|
||||||
|
{ "<C-l>", "<cmd>lua require'before'.jump_to_next_edit()<CR>", desc = "Jump to next edit" },
|
||||||
|
},
|
||||||
|
}
|
4
lua/plugins/caddyfile.lua
Normal file
4
lua/plugins/caddyfile.lua
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
return {
|
||||||
|
"isobit/vim-caddyfile",
|
||||||
|
event = { "BufReadPre", "BufNewFile" },
|
||||||
|
}
|
18
lua/plugins/catppuccin.lua
Normal file
18
lua/plugins/catppuccin.lua
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"catppuccin/nvim",
|
||||||
|
name = "catppuccin",
|
||||||
|
opts = {
|
||||||
|
styles = {
|
||||||
|
functions = { "italic" },
|
||||||
|
keywords = { "italic" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
-- {
|
||||||
|
-- "LazyVim/LazyVim",
|
||||||
|
-- opts = {
|
||||||
|
-- colorscheme = "catppuccin",
|
||||||
|
-- },
|
||||||
|
-- },
|
||||||
|
}
|
62
lua/plugins/cmp.lua
Normal file
62
lua/plugins/cmp.lua
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
return {
|
||||||
|
"hrsh7th/nvim-cmp",
|
||||||
|
dependencies = {
|
||||||
|
"hrsh7th/cmp-cmdline",
|
||||||
|
"hrsh7th/cmp-nvim-lsp-document-symbol",
|
||||||
|
-- "hrsh7th/cmp-nvim-lsp-signature-help",
|
||||||
|
{ "lukas-reineke/cmp-rg", enabled = vim.fn.exepath "rg" ~= "" },
|
||||||
|
},
|
||||||
|
event = { "InsertEnter", "CmdlineEnter" },
|
||||||
|
opts = function(_, opts)
|
||||||
|
local cmp = require "cmp"
|
||||||
|
|
||||||
|
if vim.fn.exepath "rg" ~= "" then
|
||||||
|
table.insert(opts.sources, 3, { name = "rg" })
|
||||||
|
end
|
||||||
|
|
||||||
|
opts.preselect = cmp.PreselectMode.None
|
||||||
|
|
||||||
|
opts.mapping = cmp.mapping.preset.insert {
|
||||||
|
["<cr>"] = function(fallback)
|
||||||
|
cmp.abort()
|
||||||
|
fallback()
|
||||||
|
end,
|
||||||
|
["<c-cr>"] = cmp.mapping.confirm { select = true },
|
||||||
|
["<C-n>"] = cmp.mapping.select_next_item { behavior = cmp.SelectBehavior.Insert },
|
||||||
|
["<C-p>"] = cmp.mapping.select_prev_item { behavior = cmp.SelectBehavior.Insert },
|
||||||
|
["<C-b>"] = cmp.mapping.scroll_docs(-4),
|
||||||
|
["<C-f>"] = cmp.mapping.scroll_docs(4),
|
||||||
|
["<C-Space>"] = cmp.mapping.complete(),
|
||||||
|
["<C-e>"] = cmp.mapping.abort(),
|
||||||
|
["<S-CR>"] = cmp.mapping.confirm {
|
||||||
|
behavior = cmp.ConfirmBehavior.Replace,
|
||||||
|
select = true,
|
||||||
|
}, -- Accept currently selected item. Set `select` to `false` to only confirm explicitly selected items.
|
||||||
|
}
|
||||||
|
|
||||||
|
---@diagnostic disable-next-line: missing-fields
|
||||||
|
cmp.setup.cmdline(":", {
|
||||||
|
mapping = cmp.mapping.preset.cmdline(),
|
||||||
|
sources = cmp.config.sources {
|
||||||
|
{ name = "path" },
|
||||||
|
{
|
||||||
|
name = "cmdline",
|
||||||
|
option = {
|
||||||
|
ignore_cmds = { "Man", "!" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
---@diagnostic disable-next-line: missing-fields
|
||||||
|
cmp.setup.cmdline("/", {
|
||||||
|
mapping = cmp.mapping.preset.cmdline(),
|
||||||
|
sources = cmp.config.sources {
|
||||||
|
{ name = "nvim_lsp_document_symbol" },
|
||||||
|
{ name = "buffer" },
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
return opts
|
||||||
|
end,
|
||||||
|
}
|
9
lua/plugins/conform.lua
Normal file
9
lua/plugins/conform.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
return {
|
||||||
|
"conform.nvim",
|
||||||
|
opts = {
|
||||||
|
formatters_by_ft = {
|
||||||
|
nix = { "nixpkgs_fmt" },
|
||||||
|
templ = { "templ" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
28
lua/plugins/copilot.lua
Normal file
28
lua/plugins/copilot.lua
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"zbirenbaum/copilot.lua",
|
||||||
|
event = { "InsertEnter" },
|
||||||
|
opts = {
|
||||||
|
panel = { enabled = false },
|
||||||
|
suggestion = {
|
||||||
|
enabled = true,
|
||||||
|
auto_trigger = true,
|
||||||
|
keymap = {
|
||||||
|
accept = "<M-l>",
|
||||||
|
accept_word = false,
|
||||||
|
accept_line = false,
|
||||||
|
next = "<M-j>",
|
||||||
|
prev = "<M-k>",
|
||||||
|
dismiss = "<M-h>",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
filetypes = {
|
||||||
|
["*"] = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"zbirenbaum/copilot-cmp",
|
||||||
|
enabled = false,
|
||||||
|
},
|
||||||
|
}
|
21
lua/plugins/corn.lua
Normal file
21
lua/plugins/corn.lua
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
return {
|
||||||
|
"RaafatTurki/corn.nvim",
|
||||||
|
event = { "LspAttach" },
|
||||||
|
opts = {
|
||||||
|
border_style = "rounded",
|
||||||
|
icons = {
|
||||||
|
error = " ",
|
||||||
|
warn = " ",
|
||||||
|
hint = " ",
|
||||||
|
info = " ",
|
||||||
|
},
|
||||||
|
item_preprocess_func = function(item)
|
||||||
|
return item
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
config = function(_, opts)
|
||||||
|
vim.diagnostic.config { virtual_text = false }
|
||||||
|
require("corn").setup(opts)
|
||||||
|
end,
|
||||||
|
enabled = false,
|
||||||
|
}
|
18
lua/plugins/diagflow.lua
Normal file
18
lua/plugins/diagflow.lua
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
return {
|
||||||
|
"dgagn/diagflow.nvim",
|
||||||
|
event = { "LspAttach" },
|
||||||
|
opts = {
|
||||||
|
scope = "line",
|
||||||
|
show_sign = false,
|
||||||
|
show_borders = true,
|
||||||
|
text_align = "right",
|
||||||
|
max_width = 60,
|
||||||
|
format = function(diagnostic)
|
||||||
|
if diagnostic.source and #diagnostic.source > 0 then
|
||||||
|
return string.format("[%s] %s: %s", diagnostic.source, diagnostic.code, diagnostic.message)
|
||||||
|
end
|
||||||
|
return diagnostic.message
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
-- enabled = false,
|
||||||
|
}
|
5
lua/plugins/discord-presence.lua
Normal file
5
lua/plugins/discord-presence.lua
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
return {
|
||||||
|
"andweeb/presence.nvim",
|
||||||
|
event = "BufReadPost",
|
||||||
|
config = true,
|
||||||
|
}
|
6
lua/plugins/gitsigns.lua
Normal file
6
lua/plugins/gitsigns.lua
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
return {
|
||||||
|
"lewis6991/gitsigns.nvim",
|
||||||
|
opts = {
|
||||||
|
current_line_blame = true,
|
||||||
|
},
|
||||||
|
}
|
28
lua/plugins/incline.lua
Normal file
28
lua/plugins/incline.lua
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
return {
|
||||||
|
-- Show filenames in the right top most of buffer
|
||||||
|
"b0o/incline.nvim",
|
||||||
|
config = function()
|
||||||
|
local helpers = require "incline.helpers"
|
||||||
|
local devicons = require "nvim-web-devicons"
|
||||||
|
require("incline").setup {
|
||||||
|
window = {
|
||||||
|
padding = 0,
|
||||||
|
margin = { horizontal = 0 },
|
||||||
|
},
|
||||||
|
render = function(props)
|
||||||
|
local filename = vim.fn.fnamemodify(vim.api.nvim_buf_get_name(props.buf), ":t")
|
||||||
|
local ft_icon, ft_color = devicons.get_icon_color(filename)
|
||||||
|
local modified = vim.bo[props.buf].modified
|
||||||
|
return {
|
||||||
|
ft_icon and { " ", ft_icon, " ", guibg = ft_color, guifg = helpers.contrast_color(ft_color) } or "",
|
||||||
|
" ",
|
||||||
|
{ filename, gui = modified and "bold,italic" or "bold" },
|
||||||
|
" ",
|
||||||
|
guibg = "#44406e",
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
-- Optional: Lazy load Incline
|
||||||
|
event = "VeryLazy",
|
||||||
|
}
|
40
lua/plugins/java.lua
Normal file
40
lua/plugins/java.lua
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"conform.nvim",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.formatters_by_ft = opts.formatters_by_ft or {}
|
||||||
|
opts.formatters_by_ft.xml = { "xmlformat" }
|
||||||
|
|
||||||
|
require("conform").formatters.xmlformat = {
|
||||||
|
prepend_args = { "--indent", "1", "--indent-char", "\t" },
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"williamboman/mason.nvim",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.ensure_installed = opts.ensure_installed or {}
|
||||||
|
vim.list_extend(opts.ensure_installed, { "xmlformatter" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
-- Add lombok support
|
||||||
|
"mfussenegger/nvim-jdtls",
|
||||||
|
opts = function(_, opts)
|
||||||
|
local lombok_jar_path = (vim.fn.expand "$MASON") .. "/packages/jdtls/lombok.jar"
|
||||||
|
opts.cmd = {
|
||||||
|
vim.fn.exepath "jdtls",
|
||||||
|
([[--jvm-arg=-javaagent:%s]]):format(lombok_jar_path),
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{ "rcasia/neotest-java", lazy = true },
|
||||||
|
{
|
||||||
|
"nvim-neotest/neotest",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts = opts or {}
|
||||||
|
opts.adapters = opts.adapters or {}
|
||||||
|
vim.list_extend(opts.adapters, { "neotest-java" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
108
lua/plugins/lang-go.lua
Normal file
108
lua/plugins/lang-go.lua
Normal file
|
@ -0,0 +1,108 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"neovim/nvim-lspconfig",
|
||||||
|
opts = {
|
||||||
|
servers = {
|
||||||
|
gopls = {
|
||||||
|
settings = {
|
||||||
|
gopls = {
|
||||||
|
analyses = {
|
||||||
|
fieldalignment = false,
|
||||||
|
},
|
||||||
|
usePlaceholders = false,
|
||||||
|
hints = {
|
||||||
|
assignVariableTypes = false,
|
||||||
|
compositeLiteralFields = false,
|
||||||
|
compositeLiteralTypes = false,
|
||||||
|
constantValues = false,
|
||||||
|
functionTypeParameters = false,
|
||||||
|
parameterNames = false,
|
||||||
|
rangeVariableTypes = false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
setup = {
|
||||||
|
gopls = function(_, opts)
|
||||||
|
require("lazyvim.util").lsp.on_attach(function(client, bufnr)
|
||||||
|
if client.name == "gopls" then
|
||||||
|
-- workaround for gopls not supporting semanticTokensProvider
|
||||||
|
-- https://github.com/golang/go/issues/54531#issuecomment-1464982242
|
||||||
|
if not client.server_capabilities.semanticTokensProvider then
|
||||||
|
local semantic = client.config.capabilities.textDocument.semanticTokens
|
||||||
|
client.server_capabilities.semanticTokensProvider = {
|
||||||
|
full = true,
|
||||||
|
legend = {
|
||||||
|
tokenTypes = semantic.tokenTypes,
|
||||||
|
tokenModifiers = semantic.tokenModifiers,
|
||||||
|
},
|
||||||
|
range = true,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
-- end workaround
|
||||||
|
|
||||||
|
-- run lsp imports code action on save.
|
||||||
|
vim.api.nvim_create_autocmd("BufWritePre", {
|
||||||
|
desc = "Auto format and organize imports on save (gopls)",
|
||||||
|
group = vim.api.nvim_create_augroup("GoplsAutoFormat", {}),
|
||||||
|
buffer = bufnr,
|
||||||
|
callback = function(event)
|
||||||
|
local context = { source = { organizeImports = true } }
|
||||||
|
local params = vim.lsp.util.make_range_params()
|
||||||
|
params.context = context
|
||||||
|
local result =
|
||||||
|
vim.lsp.buf_request_sync(event.buf, "textDocument/codeAction", params, 3000)
|
||||||
|
if not result then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not result[1] then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
result = result[1].result
|
||||||
|
if not result then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not result[1] then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local edit = result[1].edit
|
||||||
|
if not edit then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
vim.lsp.util.apply_workspace_edit(edit, "utf-8")
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"olexsmir/gopher.nvim",
|
||||||
|
ft = "go",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"edolphin-ydf/goimpl.nvim",
|
||||||
|
ft = "go",
|
||||||
|
config = function()
|
||||||
|
require("telescope").load_extension "goimpl"
|
||||||
|
vim.api.nvim_create_autocmd("LspAttach", {
|
||||||
|
group = vim.api.nvim_create_augroup("GoImpl", {}),
|
||||||
|
callback = function(ctx)
|
||||||
|
local client = vim.lsp.get_client_by_id(ctx.data.client_id) or {}
|
||||||
|
if client.name == "gopls" then
|
||||||
|
vim.api.nvim_create_user_command("Impl", [[Telescope goimpl]], {})
|
||||||
|
vim.keymap.set(
|
||||||
|
"n",
|
||||||
|
"<leader>ci",
|
||||||
|
[[<cmd>Telescope goimpl<cr>]],
|
||||||
|
{ buffer = ctx.buf, desc = "Generate implementation stub" }
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
11
lua/plugins/lazygit.lua
Normal file
11
lua/plugins/lazygit.lua
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
return {
|
||||||
|
"kdheepak/lazygit.nvim",
|
||||||
|
-- optional for floating window border decoration
|
||||||
|
dependencies = {
|
||||||
|
"nvim-lua/plenary.nvim",
|
||||||
|
},
|
||||||
|
enabled = vim.fn.exepath("lazygit") ~= "",
|
||||||
|
keys = {
|
||||||
|
{ "<leader>z", "<cmd>LazyGit<cr>", desc = "Symbols Outline" },
|
||||||
|
},
|
||||||
|
}
|
9
lua/plugins/lsp-html.lua
Normal file
9
lua/plugins/lsp-html.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"williamboman/mason.nvim",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.ensure_installed = opts.ensure_installed or {}
|
||||||
|
vim.list_extend(opts.ensure_installed, { "html-lsp" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
8
lua/plugins/lsp-lazy.lua
Normal file
8
lua/plugins/lsp-lazy.lua
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
return {
|
||||||
|
"dundalek/lazy-lsp.nvim",
|
||||||
|
dependencies = { "neovim/nvim-lspconfig" },
|
||||||
|
opts = {
|
||||||
|
excluded_servers = { "jdtls", "gopls", "tsserver" },
|
||||||
|
},
|
||||||
|
enabled = false,
|
||||||
|
}
|
61
lua/plugins/lspconfig.lua
Normal file
61
lua/plugins/lspconfig.lua
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
return {
|
||||||
|
"nvim-lspconfig",
|
||||||
|
init = function()
|
||||||
|
local keys = require("lazyvim.plugins.lsp.keymaps").get()
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"gD",
|
||||||
|
"<cmd>lua require('telescope.builtin').lsp_definitions({ jump_type = 'vsplit' })<cr>",
|
||||||
|
desc = "Jump to definitions in vsplit",
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"grr",
|
||||||
|
"<cmd>Trouble lsp_references focus=true<cr>",
|
||||||
|
desc = "Jump to references",
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"gri",
|
||||||
|
"<cmd>Trouble lsp_implementations focus=true<cr>",
|
||||||
|
desc = "Jump to references",
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"grt",
|
||||||
|
"<cmd>Trouble lsp_type_definitions focus=true<cr>",
|
||||||
|
desc = "Jump to references",
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"grs",
|
||||||
|
"<cmd>Trouble lsp_document_symbols focus=true<cr>",
|
||||||
|
desc = "Jump to references",
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"<F2>",
|
||||||
|
vim.lsp.buf.rename,
|
||||||
|
desc = "Rename Symbol",
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"<c-k>",
|
||||||
|
false,
|
||||||
|
mode = { "i" },
|
||||||
|
}
|
||||||
|
keys[#keys + 1] = {
|
||||||
|
"gr",
|
||||||
|
false,
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
opts = {
|
||||||
|
servers = {
|
||||||
|
templ = {
|
||||||
|
on_attach = function(client, _)
|
||||||
|
client.server_capabilities.documentFormattingProvider = false
|
||||||
|
client.server_capabilities.documentRangeFormattingProvider = false
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
html = {
|
||||||
|
on_attach = function(client, _)
|
||||||
|
client.server_capabilities.documentFormattingProvider = false
|
||||||
|
client.server_capabilities.documentRangeFormattingProvider = false
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
7
lua/plugins/luasnip.lua
Normal file
7
lua/plugins/luasnip.lua
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
return {
|
||||||
|
"L3MON4D3/LuaSnip",
|
||||||
|
opts = function(_, opts)
|
||||||
|
require "snippets"
|
||||||
|
return opts
|
||||||
|
end,
|
||||||
|
}
|
14
lua/plugins/makefile.lua
Normal file
14
lua/plugins/makefile.lua
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
return {
|
||||||
|
"sopa0/telescope-makefile",
|
||||||
|
dependencies = {
|
||||||
|
"akinsho/toggleterm.nvim",
|
||||||
|
},
|
||||||
|
cmd = { "Make" },
|
||||||
|
keys = {
|
||||||
|
{ "<leader>m", "<cmd>Telescope make<cr>", { desc = "Launch Make Items" } },
|
||||||
|
},
|
||||||
|
config = function()
|
||||||
|
require("telescope").load_extension "make"
|
||||||
|
vim.api.nvim_create_user_command("Make", [[Telescope make]], {})
|
||||||
|
end,
|
||||||
|
}
|
8
lua/plugins/markdown.lua
Normal file
8
lua/plugins/markdown.lua
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
return {
|
||||||
|
"MeanderingProgrammer/markdown.nvim",
|
||||||
|
name = "render-markdown", -- Only needed if you have another plugin named markdown.nvim
|
||||||
|
dependencies = { "nvim-treesitter/nvim-treesitter" },
|
||||||
|
config = function()
|
||||||
|
require("render-markdown").setup {}
|
||||||
|
end,
|
||||||
|
}
|
7
lua/plugins/mason.lua
Normal file
7
lua/plugins/mason.lua
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
return {
|
||||||
|
"mason.nvim",
|
||||||
|
opts = {
|
||||||
|
-- NixOS packages should override Mason packages if exist
|
||||||
|
PATH = vim.loop.os_uname().version:find("NixOS") and "append" or "prepend",
|
||||||
|
},
|
||||||
|
}
|
55
lua/plugins/mini_files.lua
Normal file
55
lua/plugins/mini_files.lua
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
return {
|
||||||
|
"echasnovski/mini.nvim",
|
||||||
|
version = false,
|
||||||
|
opts = {
|
||||||
|
windows = {
|
||||||
|
preview = true,
|
||||||
|
width_preview = 50,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
config = function(_, opts)
|
||||||
|
require("mini.files").setup(opts)
|
||||||
|
local map_split = function(buf_id, lhs, direction)
|
||||||
|
local mf = require "mini.files"
|
||||||
|
local rhs = function()
|
||||||
|
-- Make new window and set it as target
|
||||||
|
local new_target_window
|
||||||
|
vim.api.nvim_win_call(mf.get_target_window(), function()
|
||||||
|
vim.cmd(direction .. " split")
|
||||||
|
new_target_window = vim.api.nvim_get_current_win()
|
||||||
|
end)
|
||||||
|
|
||||||
|
mf.set_target_window(new_target_window)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Adding `desc` will result into `show_help` entries
|
||||||
|
local desc = "Split " .. direction
|
||||||
|
vim.keymap.set("n", lhs, rhs, { buffer = buf_id, desc = desc })
|
||||||
|
end
|
||||||
|
vim.api.nvim_create_autocmd("User", {
|
||||||
|
pattern = "MiniFilesBufferCreate",
|
||||||
|
callback = function(args)
|
||||||
|
local mf = require "mini.files"
|
||||||
|
local buf_id = args.data.buf_id
|
||||||
|
-- Tweak keys to your liking
|
||||||
|
map_split(buf_id, "gs", "belowright horizontal")
|
||||||
|
map_split(buf_id, "gv", "belowright vertical")
|
||||||
|
vim.keymap.set("n", "<cr>", function()
|
||||||
|
mf.go_in { close_on_file = true }
|
||||||
|
end, { buffer = buf_id, desc = "Open file or directory" })
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
keys = {
|
||||||
|
{
|
||||||
|
"-",
|
||||||
|
function()
|
||||||
|
local mf = require "mini.files"
|
||||||
|
if not mf.close() then
|
||||||
|
mf.open(vim.api.nvim_buf_get_name(0), false)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
desc = "Open/Close mini files from current file directory",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
12
lua/plugins/neotree.lua
Normal file
12
lua/plugins/neotree.lua
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
return {
|
||||||
|
"nvim-neo-tree/neo-tree.nvim",
|
||||||
|
opts = {
|
||||||
|
filesystem = {
|
||||||
|
filtered_items = {
|
||||||
|
visible = true,
|
||||||
|
},
|
||||||
|
group_empty_dirs = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
enabled = true,
|
||||||
|
}
|
9
lua/plugins/nix.lua
Normal file
9
lua/plugins/nix.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"williamboman/mason.nvim",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.ensure_installed = opts.ensure_installed or {}
|
||||||
|
vim.list_extend(opts.ensure_installed, { "nixpkgs-fmt", "nil" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
9
lua/plugins/notifier.lua
Normal file
9
lua/plugins/notifier.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
return {
|
||||||
|
{ "rcarriga/nvim-notify", enabled = false },
|
||||||
|
{
|
||||||
|
"folke/noice.nvim",
|
||||||
|
dependencies = {
|
||||||
|
"vigoux/notifier.nvim",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
53
lua/plugins/obsidian.lua
Normal file
53
lua/plugins/obsidian.lua
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
local function workspace(name)
|
||||||
|
return {
|
||||||
|
name = name,
|
||||||
|
path = ("%s/Obsidian/%s"):format(vim.env.HOME, name),
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
local function event(name)
|
||||||
|
return ("%s %s/Obsidian/**.md"):format(name, vim.env.HOME)
|
||||||
|
end
|
||||||
|
|
||||||
|
return {
|
||||||
|
"epwalsh/obsidian.nvim",
|
||||||
|
cmd = {
|
||||||
|
"ObsidianOpen",
|
||||||
|
"ObsidianNew",
|
||||||
|
"ObsidianToday",
|
||||||
|
"ObsidianYesterday",
|
||||||
|
"ObsidianWorkspace",
|
||||||
|
"ObsidianSearch",
|
||||||
|
"ObsidianQuickSwitch",
|
||||||
|
},
|
||||||
|
dependencies = {
|
||||||
|
-- Required.
|
||||||
|
"nvim-lua/plenary.nvim",
|
||||||
|
|
||||||
|
-- see below for full list of optional dependencies 👇
|
||||||
|
},
|
||||||
|
event = {
|
||||||
|
event "BufReadPre",
|
||||||
|
event "BufNewFile",
|
||||||
|
},
|
||||||
|
opts = {
|
||||||
|
workspaces = {
|
||||||
|
workspace "personal",
|
||||||
|
workspace "work",
|
||||||
|
workspace "stories",
|
||||||
|
workspace "tigor",
|
||||||
|
},
|
||||||
|
mappings = {},
|
||||||
|
},
|
||||||
|
config = function(_, opts)
|
||||||
|
require("obsidian").setup(opts)
|
||||||
|
|
||||||
|
vim.keymap.set("n", "gf", function()
|
||||||
|
if require("obsidian").util.cursor_on_markdown_link() then
|
||||||
|
return "<cmd>ObsidianFollowLink<CR>"
|
||||||
|
else
|
||||||
|
return "gf"
|
||||||
|
end
|
||||||
|
end, { noremap = false, expr = true, desc = "Obsidian Follow Link or Fallback" })
|
||||||
|
end,
|
||||||
|
}
|
15
lua/plugins/oil.lua
Normal file
15
lua/plugins/oil.lua
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
return {
|
||||||
|
"stevearc/oil.nvim",
|
||||||
|
opts = {
|
||||||
|
keymaps = {
|
||||||
|
["q"] = "actions.close",
|
||||||
|
["<bs>"] = "actions.parent",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
dependencies = { "nvim-tree/nvim-web-devicons" },
|
||||||
|
cmd = { "Oil" },
|
||||||
|
keys = {
|
||||||
|
{ "-", "<cmd>Oil<cr>", desc = "Open Oil" },
|
||||||
|
},
|
||||||
|
enabled = false,
|
||||||
|
}
|
27
lua/plugins/precognition.lua
Normal file
27
lua/plugins/precognition.lua
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
return {
|
||||||
|
"tris203/precognition.nvim",
|
||||||
|
event = "VeryLazy",
|
||||||
|
opts = {
|
||||||
|
-- startVisible = true,
|
||||||
|
-- showBlankVirtLine = true,
|
||||||
|
-- highlightColor = { link = "Comment" },
|
||||||
|
-- hints = {
|
||||||
|
-- Caret = { text = "^", prio = 2 },
|
||||||
|
-- Dollar = { text = "$", prio = 1 },
|
||||||
|
-- MatchingPair = { text = "%", prio = 5 },
|
||||||
|
-- Zero = { text = "0", prio = 1 },
|
||||||
|
-- w = { text = "w", prio = 10 },
|
||||||
|
-- b = { text = "b", prio = 9 },
|
||||||
|
-- e = { text = "e", prio = 8 },
|
||||||
|
-- W = { text = "W", prio = 7 },
|
||||||
|
-- B = { text = "B", prio = 6 },
|
||||||
|
-- E = { text = "E", prio = 5 },
|
||||||
|
-- },
|
||||||
|
-- gutterHints = {
|
||||||
|
-- G = { text = "G", prio = 10 },
|
||||||
|
-- gg = { text = "gg", prio = 9 },
|
||||||
|
-- PrevParagraph = { text = "{", prio = 8 },
|
||||||
|
-- NextParagraph = { text = "}", prio = 8 },
|
||||||
|
-- },
|
||||||
|
},
|
||||||
|
}
|
19
lua/plugins/protobuf.lua
Normal file
19
lua/plugins/protobuf.lua
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"williamboman/mason.nvim",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.ensure_installed = opts.ensure_installed or {}
|
||||||
|
vim.list_extend(opts.ensure_installed, { "buf", "buf-language-server" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"nvimtools/none-ls.nvim",
|
||||||
|
opts = function(_, opts)
|
||||||
|
local nls = require("null-ls")
|
||||||
|
opts.sources = vim.list_extend(opts.sources or {}, {
|
||||||
|
nls.builtins.diagnostics.buf,
|
||||||
|
nls.builtins.formatting.buf,
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
17
lua/plugins/rest.lua
Normal file
17
lua/plugins/rest.lua
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"nicwest/vim-http",
|
||||||
|
ft = "http",
|
||||||
|
init = function()
|
||||||
|
vim.g.vim_http_tempbuffer = 1
|
||||||
|
vim.g.vim_http_clean_before_do = 0
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"nvim-treesitter/nvim-treesitter",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.ensure_installed = opts.ensure_installed or {}
|
||||||
|
vim.list_extend(opts.ensure_installed, { "http", "json" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
9
lua/plugins/rose-pine.lua
Normal file
9
lua/plugins/rose-pine.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
return {
|
||||||
|
{ "rose-pine/neovim", name = "rose-pine" },
|
||||||
|
-- {
|
||||||
|
-- "LazyVim/LazyVim",
|
||||||
|
-- opts = {
|
||||||
|
-- colorscheme = "rose-pine",
|
||||||
|
-- },
|
||||||
|
-- },
|
||||||
|
}
|
56
lua/plugins/silicon.lua
Normal file
56
lua/plugins/silicon.lua
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
return {
|
||||||
|
"tigorlazuardi/silicon.lua",
|
||||||
|
cmd = { "Silicon" },
|
||||||
|
config = function()
|
||||||
|
require("silicon").setup {
|
||||||
|
output = function()
|
||||||
|
return ([[%s/Pictures/SILICON_%s.png]]):format(vim.env.HOME, os.date "%Y-%m-%d_%H-%M-%S")
|
||||||
|
end,
|
||||||
|
padHoriz = 40,
|
||||||
|
padVert = 50,
|
||||||
|
}
|
||||||
|
vim.api.nvim_create_user_command("Silicon", function(ctx)
|
||||||
|
local args = (ctx.fargs or {})[1]
|
||||||
|
local opts = {}
|
||||||
|
if args == "buffer" then
|
||||||
|
opts.show_buf = true
|
||||||
|
end
|
||||||
|
if args == "visible" then
|
||||||
|
opts.visible = true
|
||||||
|
end
|
||||||
|
if not ctx.bang then
|
||||||
|
opts.to_clip = true
|
||||||
|
end
|
||||||
|
require("silicon").visualise_cmdline(opts)
|
||||||
|
end, {
|
||||||
|
range = 2,
|
||||||
|
desc = "Create screenshot from given range. Add Bang (!) at the end of the command to save to file instead of clipboard",
|
||||||
|
bang = true,
|
||||||
|
nargs = "?",
|
||||||
|
complete = function(arg)
|
||||||
|
if not arg then
|
||||||
|
return { "buffer", "visible" }
|
||||||
|
end
|
||||||
|
if arg:gsub(" ", "") == "" then
|
||||||
|
return { "buffer", "visible" }
|
||||||
|
end
|
||||||
|
if string.find("buffer", arg) then
|
||||||
|
return { "buffer" }
|
||||||
|
end
|
||||||
|
if string.find("visible", arg) then
|
||||||
|
return { "visible" }
|
||||||
|
end
|
||||||
|
return {}
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
vim.api.nvim_create_autocmd({ "ColorScheme" }, {
|
||||||
|
group = vim.api.nvim_create_augroup("SiliconRefresh", {}),
|
||||||
|
callback = function()
|
||||||
|
local silicon_utils = require "silicon.utils"
|
||||||
|
silicon_utils.build_tmTheme()
|
||||||
|
silicon_utils.reload_silicon_cache { async = true }
|
||||||
|
end,
|
||||||
|
desc = "Reload silicon themes cache on colorscheme switch",
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
}
|
13
lua/plugins/ssh.lua
Normal file
13
lua/plugins/ssh.lua
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
return {
|
||||||
|
"ojroques/nvim-osc52",
|
||||||
|
cond = vim.env.SSH_CLIENT ~= nil,
|
||||||
|
config = function()
|
||||||
|
require("osc52").setup({})
|
||||||
|
vim.api.nvim_create_autocmd("TextYankPost", {
|
||||||
|
callback = function()
|
||||||
|
require("osc52").copy(table.concat(vim.v.event.regcontents, "\n"))
|
||||||
|
end,
|
||||||
|
desc = "Copy to Clipboard from SSH Session",
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
}
|
15
lua/plugins/tailwind.lua
Normal file
15
lua/plugins/tailwind.lua
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
return {
|
||||||
|
"neovim/nvim-lspconfig",
|
||||||
|
opts = {
|
||||||
|
servers = {
|
||||||
|
tailwindcss = {
|
||||||
|
-- exclude a filetype from the default_config
|
||||||
|
filetypes_exclude = { "markdown", "javascript", "typescript" },
|
||||||
|
-- add additional filetypes to the default_config
|
||||||
|
filetypes_include = {},
|
||||||
|
-- to fully override the default_config, change the below
|
||||||
|
-- filetypes = {}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
10
lua/plugins/telescope-fzf-native.lua
Normal file
10
lua/plugins/telescope-fzf-native.lua
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
return {
|
||||||
|
"telescope.nvim",
|
||||||
|
dependencies = {
|
||||||
|
"nvim-telescope/telescope-fzf-native.nvim",
|
||||||
|
build = "make",
|
||||||
|
config = function()
|
||||||
|
require("telescope").load_extension("fzf")
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
21
lua/plugins/toggleterm.lua
Normal file
21
lua/plugins/toggleterm.lua
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
return {
|
||||||
|
"akinsho/toggleterm.nvim",
|
||||||
|
keys = {
|
||||||
|
{ "<F5>", "Open Toggleterm" },
|
||||||
|
},
|
||||||
|
cmd = { "ToggleTerm" },
|
||||||
|
version = "*",
|
||||||
|
opts = {
|
||||||
|
size = function(term)
|
||||||
|
if term.direction == "horizontal" then
|
||||||
|
if vim.o.lines < 60 then
|
||||||
|
return 12
|
||||||
|
end
|
||||||
|
return 20
|
||||||
|
elseif term.direction == "vertical" then
|
||||||
|
return vim.o.columns * 0.3
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
open_mapping = [[<F5>]],
|
||||||
|
},
|
||||||
|
}
|
38
lua/plugins/treesitter.lua
Normal file
38
lua/plugins/treesitter.lua
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"nvim-treesitter/nvim-treesitter",
|
||||||
|
dependencies = {
|
||||||
|
"RRethy/nvim-treesitter-endwise",
|
||||||
|
},
|
||||||
|
opts = {
|
||||||
|
endwise = {
|
||||||
|
enable = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"windwp/nvim-ts-autotag",
|
||||||
|
opts = {
|
||||||
|
filetypes = {
|
||||||
|
"astro",
|
||||||
|
"glimmer",
|
||||||
|
"handlebars",
|
||||||
|
"hbs",
|
||||||
|
"html",
|
||||||
|
"javascript",
|
||||||
|
"javascriptreact",
|
||||||
|
"jsx",
|
||||||
|
"markdown",
|
||||||
|
"php",
|
||||||
|
"rescript",
|
||||||
|
"svelte",
|
||||||
|
"templ",
|
||||||
|
"tsx",
|
||||||
|
"typescript",
|
||||||
|
"typescriptreact",
|
||||||
|
"vue",
|
||||||
|
"xml",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
10
lua/plugins/vim-test.lua
Normal file
10
lua/plugins/vim-test.lua
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
return {
|
||||||
|
"vim-test/vim-test",
|
||||||
|
keys = {
|
||||||
|
{ "<leader>Tr", "<cmd>TestNearest<cr>", desc = "Test Run Nearest" },
|
||||||
|
{ "<leader>Tt", "<cmd>TestFile<cr>", desc = "Test File" },
|
||||||
|
{ "<leader>TT", "<cmd>TestSuite<cr>", desc = "Test All Files" },
|
||||||
|
{ "<leader>Tl", "<cmd>TestLast<cr>", desc = "Test Last" },
|
||||||
|
{ "<leader>Tg", "<cmd>TestVisit<cr>", desc = "Test Visit" },
|
||||||
|
},
|
||||||
|
}
|
10
lua/plugins/yanky.lua
Normal file
10
lua/plugins/yanky.lua
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
return {
|
||||||
|
"gbprod/yanky.nvim",
|
||||||
|
dependencies = {
|
||||||
|
{ "kkharji/sqlite.lua" },
|
||||||
|
},
|
||||||
|
opts = {
|
||||||
|
ring = { storage = "sqlite" },
|
||||||
|
highlight = { timer = 150 },
|
||||||
|
},
|
||||||
|
}
|
170
lua/snippets/go/apm_span.lua
Normal file
170
lua/snippets/go/apm_span.lua
Normal file
|
@ -0,0 +1,170 @@
|
||||||
|
local ls = require "luasnip"
|
||||||
|
local sn = ls.sn
|
||||||
|
local s = ls.s
|
||||||
|
local i = ls.insert_node
|
||||||
|
local t = ls.text_node
|
||||||
|
local d = ls.dynamic_node
|
||||||
|
local f = ls.function_node
|
||||||
|
local fmta = require("luasnip.extras.fmt").fmta
|
||||||
|
local c = ls.choice_node
|
||||||
|
|
||||||
|
local get_node_text = vim.treesitter.get_node_text
|
||||||
|
|
||||||
|
local create_package_query = function()
|
||||||
|
return vim.treesitter.query.parse(
|
||||||
|
"go",
|
||||||
|
[[
|
||||||
|
((package_identifier) @package)
|
||||||
|
]]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_method_receiver_type_text(node)
|
||||||
|
local query = vim.treesitter.query.parse(
|
||||||
|
"go",
|
||||||
|
[[
|
||||||
|
(method_declaration receiver: (parameter_list
|
||||||
|
(parameter_declaration type: (_) @method_receiver)))
|
||||||
|
]]
|
||||||
|
)
|
||||||
|
|
||||||
|
for _, capture in query:iter_captures(node, 0) do
|
||||||
|
return get_node_text(capture, 0)
|
||||||
|
end
|
||||||
|
return "Method Receiver Not Found"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_package_node(node)
|
||||||
|
local root = node:tree():root()
|
||||||
|
local query = create_package_query()
|
||||||
|
for _, capture in query:iter_captures(root, 0) do
|
||||||
|
return capture
|
||||||
|
end
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_method_or_function_declaration_node(node)
|
||||||
|
local parent = node:parent()
|
||||||
|
while parent ~= nil do
|
||||||
|
if parent:type() == "function_declaration" or parent:type() == "method_declaration" then
|
||||||
|
return parent
|
||||||
|
end
|
||||||
|
parent = parent:parent()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local root_types = {
|
||||||
|
method_declaration = true,
|
||||||
|
function_declaration = true,
|
||||||
|
func_literal = true,
|
||||||
|
}
|
||||||
|
|
||||||
|
local handlers = {
|
||||||
|
["context.Context"] = function(node)
|
||||||
|
local var_name_node = node:prev_named_sibling()
|
||||||
|
local text = get_node_text(var_name_node, 0)
|
||||||
|
return text
|
||||||
|
end,
|
||||||
|
["*http.Request"] = function(node)
|
||||||
|
local var_name_node = node:prev_named_sibling()
|
||||||
|
local text = get_node_text(var_name_node, 0)
|
||||||
|
return text .. ".Context()"
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
|
||||||
|
local build_context_node = function()
|
||||||
|
local query = assert(vim.treesitter.query.get("go", "search-context"), "No Query")
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
while node ~= nil do
|
||||||
|
if root_types[node:type()] then
|
||||||
|
for _, capture in query:iter_captures(node, 0) do
|
||||||
|
local text = get_node_text(capture, 0)
|
||||||
|
local handle = handlers[text]
|
||||||
|
if handle then
|
||||||
|
return handle(capture)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
node = node:parent()
|
||||||
|
end
|
||||||
|
return "context.Background()"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_method_or_function_name(node)
|
||||||
|
if node:type() == "method_declaration" then
|
||||||
|
return get_node_text(node:named_child(1), 0)
|
||||||
|
end
|
||||||
|
return get_node_text(node:named_child(0), 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
local build_span_type_node = function(ctx)
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
local method_or_function_node = get_method_or_function_declaration_node(node)
|
||||||
|
if method_or_function_node == nil then
|
||||||
|
vim.notify "Not inside method or function"
|
||||||
|
return { t "" }
|
||||||
|
end
|
||||||
|
local package_node = get_package_node(node)
|
||||||
|
if package_node == nil then
|
||||||
|
vim.notify "No package node found"
|
||||||
|
return { t "" }
|
||||||
|
end
|
||||||
|
local package_text = get_node_text(package_node, 0)
|
||||||
|
local final_name = ""
|
||||||
|
if method_or_function_node:type() == "method_declaration" then
|
||||||
|
local method_node = method_or_function_node
|
||||||
|
local receiver_type = get_method_receiver_type_text(method_node)
|
||||||
|
final_name = ([[%s.%s]]):format(package_text, receiver_type)
|
||||||
|
else
|
||||||
|
if method_or_function_node:type() == "function_declaration" then
|
||||||
|
local function_node = method_or_function_node
|
||||||
|
local fn_name = get_method_or_function_name(function_node)
|
||||||
|
final_name = ([[%s.%s]]):format(package_text, fn_name)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
ctx.index = ctx.index + 1
|
||||||
|
return { i(ctx.index, final_name) }
|
||||||
|
end
|
||||||
|
|
||||||
|
local build_span_name_node = function(ctx)
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
local method_or_function_node = get_method_or_function_declaration_node(node)
|
||||||
|
if method_or_function_node == nil then
|
||||||
|
vim.notify "Not inside method or function"
|
||||||
|
return { t "" }
|
||||||
|
end
|
||||||
|
local fn_name = get_method_or_function_name(method_or_function_node)
|
||||||
|
ctx.index = ctx.index + 1
|
||||||
|
return { i(ctx.index, fn_name) }
|
||||||
|
end
|
||||||
|
|
||||||
|
local get_span_name_node = function()
|
||||||
|
return sn(nil, build_span_name_node { index = 0 })
|
||||||
|
end
|
||||||
|
|
||||||
|
local get_span_type_node = function()
|
||||||
|
return sn(nil, build_span_type_node { index = 0 })
|
||||||
|
end
|
||||||
|
|
||||||
|
ls.add_snippets("go", {
|
||||||
|
s(
|
||||||
|
"apm:span",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
span, <ctx_var> := apm.StartSpan(<ctx>, "<span_name>", "<span_type>")
|
||||||
|
defer span.End()
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
ctx_var = c(1, {
|
||||||
|
t "ctx",
|
||||||
|
t "_",
|
||||||
|
}),
|
||||||
|
ctx = f(build_context_node, {}),
|
||||||
|
span_name = d(2, get_span_name_node),
|
||||||
|
span_type = d(3, get_span_type_node),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
})
|
178
lua/snippets/go/efi.lua
Normal file
178
lua/snippets/go/efi.lua
Normal file
|
@ -0,0 +1,178 @@
|
||||||
|
local ls = require "luasnip"
|
||||||
|
|
||||||
|
local sn = ls.sn
|
||||||
|
|
||||||
|
local s = ls.s
|
||||||
|
local i = ls.insert_node
|
||||||
|
local t = ls.text_node
|
||||||
|
local d = ls.dynamic_node
|
||||||
|
local c = ls.choice_node
|
||||||
|
local fmta = require("luasnip.extras.fmt").fmta
|
||||||
|
local rep = require("luasnip.extras").rep
|
||||||
|
|
||||||
|
local get_node_text = vim.treesitter.get_node_text
|
||||||
|
|
||||||
|
local default_values = {
|
||||||
|
int = "0",
|
||||||
|
int8 = "0",
|
||||||
|
int16 = "0",
|
||||||
|
int32 = "0",
|
||||||
|
int64 = "0",
|
||||||
|
uint = "0",
|
||||||
|
uint8 = "0",
|
||||||
|
uint16 = "0",
|
||||||
|
uint32 = "0",
|
||||||
|
uint64 = "0",
|
||||||
|
["time.Time"] = "time.Time{}",
|
||||||
|
["time.Duration"] = "time.Duration(0)",
|
||||||
|
bool = "false",
|
||||||
|
string = [[""]],
|
||||||
|
float32 = "0",
|
||||||
|
float64 = "0",
|
||||||
|
error = function(_, info)
|
||||||
|
if info then
|
||||||
|
info.index = info.index + 1
|
||||||
|
|
||||||
|
return c(info.index, {
|
||||||
|
t(info.err_name),
|
||||||
|
t(string.format('errors.Wrap(%s, "%s")', info.err_name, info.func_name)),
|
||||||
|
})
|
||||||
|
else
|
||||||
|
return t "err"
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
|
-- Types with a "*" mean they are pointers, so return nil
|
||||||
|
[function(text)
|
||||||
|
return string.find(text, "*", 1, true) ~= nil
|
||||||
|
end] = function(_, _)
|
||||||
|
return t "nil"
|
||||||
|
end,
|
||||||
|
|
||||||
|
[function(text)
|
||||||
|
return not string.find(text, "*", 1, true) and string.upper(string.sub(text, 1, 1)) == string.sub(text, 1, 1)
|
||||||
|
end] = function(text, info)
|
||||||
|
info.index = info.index + 1
|
||||||
|
return sn(info.index, {
|
||||||
|
c(1, {
|
||||||
|
t(text .. "{}"),
|
||||||
|
i(2, text),
|
||||||
|
}),
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
|
||||||
|
local transform = function(text, info)
|
||||||
|
local condition_matches = function(condition, ...)
|
||||||
|
if type(condition) == "string" then
|
||||||
|
return condition == text
|
||||||
|
else
|
||||||
|
return condition(...)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for condition, result in pairs(default_values) do
|
||||||
|
if condition_matches(condition, text, info) then
|
||||||
|
if type(result) == "string" then
|
||||||
|
return t(result)
|
||||||
|
end
|
||||||
|
return result(text, info)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
info.index = info.index + 1
|
||||||
|
return sn(info.index, {
|
||||||
|
c(1, {
|
||||||
|
t(text .. "{}"),
|
||||||
|
i(2, text),
|
||||||
|
}),
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
local handlers = {
|
||||||
|
parameter_list = function(node, info)
|
||||||
|
local result = {}
|
||||||
|
|
||||||
|
local count = node:named_child_count()
|
||||||
|
for idx = 0, count - 1 do
|
||||||
|
local matching_node = node:named_child(idx)
|
||||||
|
local type_node = matching_node:field("type")[1]
|
||||||
|
table.insert(result, transform(get_node_text(type_node, 0), info))
|
||||||
|
if idx ~= count - 1 then
|
||||||
|
table.insert(result, t { ", " })
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return result
|
||||||
|
end,
|
||||||
|
|
||||||
|
type_identifier = function(node, info)
|
||||||
|
local text = get_node_text(node, 0)
|
||||||
|
return { transform(text, info) }
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
|
||||||
|
local function_node_types = {
|
||||||
|
function_declaration = true,
|
||||||
|
method_declaration = true,
|
||||||
|
func_literal = true,
|
||||||
|
}
|
||||||
|
|
||||||
|
local function go_result_type(info)
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
while node ~= nil do
|
||||||
|
if function_node_types[node:type()] then
|
||||||
|
break
|
||||||
|
end
|
||||||
|
node = node:parent()
|
||||||
|
end
|
||||||
|
if not node then
|
||||||
|
vim.notify("Not inside a function", vim.log.levels.ERROR, { title = "Snippet" })
|
||||||
|
return t ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local query = assert(vim.treesitter.query.get("go", "return-snippet"), "No Query")
|
||||||
|
|
||||||
|
for _, capture in query:iter_captures(node, 0) do
|
||||||
|
if handlers[capture:type()] then
|
||||||
|
return handlers[capture:type()](capture, info)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
info.index = info.index + 1
|
||||||
|
return { i(info.index, "nil") }
|
||||||
|
end
|
||||||
|
|
||||||
|
local go_return_values = function(args)
|
||||||
|
return sn(
|
||||||
|
nil,
|
||||||
|
go_result_type {
|
||||||
|
index = 0,
|
||||||
|
err_name = args[1][1],
|
||||||
|
func_name = args[2][1],
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
ls.add_snippets("go", {
|
||||||
|
s(
|
||||||
|
"efi",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
<val>, <err> := <f>(<args>)
|
||||||
|
if <err_same> != nil {
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
val = i(1),
|
||||||
|
err = i(2, "err"),
|
||||||
|
f = i(3),
|
||||||
|
args = i(4),
|
||||||
|
err_same = rep(2),
|
||||||
|
result = d(5, go_return_values, { 2, 3 }),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
})
|
452
lua/snippets/go/err_tower.lua
Normal file
452
lua/snippets/go/err_tower.lua
Normal file
|
@ -0,0 +1,452 @@
|
||||||
|
local ls = require "luasnip"
|
||||||
|
|
||||||
|
local sn = ls.snippet_node
|
||||||
|
local isn = ls.indent_snippet_node
|
||||||
|
|
||||||
|
local s = ls.s
|
||||||
|
local i = ls.insert_node
|
||||||
|
local t = ls.text_node
|
||||||
|
local d = ls.dynamic_node
|
||||||
|
local c = ls.choice_node
|
||||||
|
local f = ls.function_node
|
||||||
|
local fmta = require("luasnip.extras.fmt").fmta
|
||||||
|
local rep = require("luasnip.extras").rep
|
||||||
|
|
||||||
|
local get_node_text = vim.treesitter.get_node_text
|
||||||
|
|
||||||
|
local default_values = {
|
||||||
|
int = "0",
|
||||||
|
int8 = "0",
|
||||||
|
int16 = "0",
|
||||||
|
int32 = "0",
|
||||||
|
int64 = "0",
|
||||||
|
uint = "0",
|
||||||
|
uint8 = "0",
|
||||||
|
uint16 = "0",
|
||||||
|
uint32 = "0",
|
||||||
|
uint64 = "0",
|
||||||
|
["time.Time"] = "time.Time{}",
|
||||||
|
["time.Duration"] = "time.Duration(0)",
|
||||||
|
bool = "false",
|
||||||
|
string = [[""]],
|
||||||
|
float32 = "0",
|
||||||
|
float64 = "0",
|
||||||
|
error = "errt",
|
||||||
|
|
||||||
|
-- Types with a "*" mean they are pointers, so return nil
|
||||||
|
[function(text)
|
||||||
|
return string.find(text, "*", 1, true) ~= nil
|
||||||
|
end] = function(_, _)
|
||||||
|
return t "nil"
|
||||||
|
end,
|
||||||
|
|
||||||
|
[function(text)
|
||||||
|
return not string.find(text, "*", 1, true) and string.upper(string.sub(text, 1, 1)) == string.sub(text, 1, 1)
|
||||||
|
end] = function(text, info)
|
||||||
|
info.index = info.index + 1
|
||||||
|
return sn(info.index, {
|
||||||
|
c(1, {
|
||||||
|
t(text .. "{}"),
|
||||||
|
i(2, text),
|
||||||
|
}),
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
|
||||||
|
local transform = function(text, info)
|
||||||
|
local condition_matches = function(condition, ...)
|
||||||
|
if type(condition) == "string" then
|
||||||
|
return condition == text
|
||||||
|
else
|
||||||
|
return condition(...)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for condition, result in pairs(default_values) do
|
||||||
|
if condition_matches(condition, text, info) then
|
||||||
|
if type(result) == "string" then
|
||||||
|
return t(result)
|
||||||
|
end
|
||||||
|
return result(text, info)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
info.index = info.index + 1
|
||||||
|
return sn(info.index, {
|
||||||
|
c(1, {
|
||||||
|
t(text .. "{}"),
|
||||||
|
i(2, text),
|
||||||
|
}),
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
local handlers = {
|
||||||
|
parameter_list = function(node, info)
|
||||||
|
local result = {}
|
||||||
|
|
||||||
|
local count = node:named_child_count()
|
||||||
|
for idx = 0, count - 1 do
|
||||||
|
local matching_node = node:named_child(idx)
|
||||||
|
local type_node = matching_node:field("type")[1]
|
||||||
|
table.insert(result, transform(get_node_text(type_node, 0), info))
|
||||||
|
if idx ~= count - 1 then
|
||||||
|
table.insert(result, t { ", " })
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return result
|
||||||
|
end,
|
||||||
|
|
||||||
|
type_identifier = function(node, info)
|
||||||
|
local text = get_node_text(node, 0)
|
||||||
|
return { transform(text, info) }
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
|
||||||
|
local function_node_types = {
|
||||||
|
function_declaration = true,
|
||||||
|
method_declaration = true,
|
||||||
|
func_literal = true,
|
||||||
|
}
|
||||||
|
|
||||||
|
local function go_result_type(info)
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
while node ~= nil do
|
||||||
|
if function_node_types[node:type()] then
|
||||||
|
break
|
||||||
|
end
|
||||||
|
node = node:parent()
|
||||||
|
end
|
||||||
|
if not node then
|
||||||
|
vim.notify("Not inside a function", vim.log.levels.ERROR, { title = "Snippet" })
|
||||||
|
return t ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local query = assert(vim.treesitter.query.get("go", "return-snippet"), "No Query")
|
||||||
|
|
||||||
|
for _, capture in query:iter_captures(node, 0) do
|
||||||
|
if handlers[capture:type()] then
|
||||||
|
return handlers[capture:type()](capture, info)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return {}
|
||||||
|
end
|
||||||
|
|
||||||
|
local go_return_values = function()
|
||||||
|
return sn(
|
||||||
|
nil,
|
||||||
|
go_result_type {
|
||||||
|
index = 0,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_method_or_function_declaration_node(node)
|
||||||
|
local parent = node:parent()
|
||||||
|
while parent ~= nil do
|
||||||
|
if parent:type() == "function_declaration" or parent:type() == "method_declaration" then
|
||||||
|
return parent
|
||||||
|
end
|
||||||
|
parent = parent:parent()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_method_or_function_name(node)
|
||||||
|
if node:type() == "method_declaration" then
|
||||||
|
return get_node_text(node:named_child(1), 0)
|
||||||
|
end
|
||||||
|
return get_node_text(node:named_child(0), 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_method_receiver_type_text(node)
|
||||||
|
local query = vim.treesitter.query.parse(
|
||||||
|
"go",
|
||||||
|
[[
|
||||||
|
(method_declaration receiver: (parameter_list
|
||||||
|
(parameter_declaration type: (_) @method_receiver)))
|
||||||
|
]]
|
||||||
|
)
|
||||||
|
|
||||||
|
for _, capture in query:iter_captures(node, 0) do
|
||||||
|
local text = get_node_text(capture, 0)
|
||||||
|
if text:sub(1, 1) == "*" then
|
||||||
|
return "(" .. text .. ")"
|
||||||
|
end
|
||||||
|
return text
|
||||||
|
end
|
||||||
|
return "Method Receiver Not Found"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_package_node(node)
|
||||||
|
local root = node:tree():root()
|
||||||
|
local query = assert(vim.treesitter.query.get("go", "package-node"), "No Query")
|
||||||
|
for _, capture in query:iter_captures(root, 0) do
|
||||||
|
return capture
|
||||||
|
end
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_package_text(node)
|
||||||
|
local package_node = get_package_node(node)
|
||||||
|
if package_node then
|
||||||
|
return get_node_text(package_node, 0) .. "."
|
||||||
|
end
|
||||||
|
vim.notify("Package name not found", vim.log.levels.ERROR, { title = "Snippet" })
|
||||||
|
return ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_function_name()
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
local method_or_function_node = get_method_or_function_declaration_node(node)
|
||||||
|
if not method_or_function_node then
|
||||||
|
vim.notify("Not inside a function", vim.log.levels.ERROR, { title = "Snippet" })
|
||||||
|
return ""
|
||||||
|
end
|
||||||
|
local fn_name = get_method_or_function_name(method_or_function_node)
|
||||||
|
if method_or_function_node:type() == "method_declaration" then
|
||||||
|
return ([[(%s.%s.%s)]]):format(get_package_text(node), get_method_receiver_type_text(node), fn_name)
|
||||||
|
end
|
||||||
|
return ([[(%s.%s)]]):format(get_package_text(node), fn_name)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_context_var_name()
|
||||||
|
local node = vim.treesitter.get_node()
|
||||||
|
while node ~= nil do
|
||||||
|
if function_node_types[node:type()] then
|
||||||
|
local query = assert(vim.treesitter.query.get("go", "get-function-params"), "No Query")
|
||||||
|
for _, capture in query:iter_captures(node, 0) do
|
||||||
|
local var_name = capture:named_child(0)
|
||||||
|
if var_name:type() == "identifier" then
|
||||||
|
local type_name = capture:named_child(1)
|
||||||
|
local type_text = get_node_text(type_name, 0)
|
||||||
|
if type_text == "context.Context" then
|
||||||
|
return get_node_text(var_name, 0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
node = node:parent()
|
||||||
|
end
|
||||||
|
return "context.Background()"
|
||||||
|
end
|
||||||
|
|
||||||
|
local create_tower_build_choice = function(index)
|
||||||
|
return c(index, {
|
||||||
|
t "Freeze()",
|
||||||
|
sn(nil, { i(1), t "Log(", f(get_context_var_name), t ")" }),
|
||||||
|
-- stylua: ignore start
|
||||||
|
isn(nil, {
|
||||||
|
i(1), t "Log(", f(get_context_var_name), t ").",
|
||||||
|
t {"", "Notify("}, f(get_context_var_name), t ")",
|
||||||
|
}, "$PARENT_INDENT\t\t"),
|
||||||
|
-- stylua: ignore end
|
||||||
|
}, {
|
||||||
|
node_ext_opts = {
|
||||||
|
active = {
|
||||||
|
virt_text = { { "<-- Choose build choice" } },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
local function register_snippet()
|
||||||
|
ls.add_snippets("go", {
|
||||||
|
s(
|
||||||
|
"errt",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <err> != nil {
|
||||||
|
errt := tower.
|
||||||
|
Wrap(<err_same>, "<caller> <message>").
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
err = i(1, "err"),
|
||||||
|
err_same = rep(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
build = create_tower_build_choice(3),
|
||||||
|
result = d(4, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errtc",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <err> != nil {
|
||||||
|
errt := tower.
|
||||||
|
Wrap(<err_same>, "<caller> <message>").
|
||||||
|
Context(<fields>).
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
err = i(1, "err"),
|
||||||
|
err_same = rep(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
fields = i(3),
|
||||||
|
build = create_tower_build_choice(4),
|
||||||
|
result = d(5, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errtp",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <err> != nil {
|
||||||
|
errt := tower.
|
||||||
|
Wrap(<err_same>, "<caller> <message>").
|
||||||
|
PublicMessage("<public_message>").
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
err = i(1, "err"),
|
||||||
|
err_same = rep(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
public_message = i(3, "public_message"),
|
||||||
|
build = create_tower_build_choice(4),
|
||||||
|
result = d(5, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errtpc",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <err> != nil {
|
||||||
|
errt := tower.
|
||||||
|
Wrap(<err_same>, "<caller> <message>").
|
||||||
|
PublicMessage("<public_message>").
|
||||||
|
Context(<fields>).
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
err = i(1, "err"),
|
||||||
|
err_same = rep(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
public_message = i(3, "public_message"),
|
||||||
|
fields = i(4),
|
||||||
|
build = create_tower_build_choice(5),
|
||||||
|
result = d(6, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errb",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <condition> {
|
||||||
|
errt := tower.
|
||||||
|
Bail("<caller> <message>").
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
condition = i(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
build = create_tower_build_choice(3),
|
||||||
|
result = d(4, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errbc",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <condition> {
|
||||||
|
errt := tower.
|
||||||
|
Bail("<caller> <message>").
|
||||||
|
Context(<fields>).
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
condition = i(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
fields = i(3),
|
||||||
|
build = create_tower_build_choice(4),
|
||||||
|
result = d(5, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errbp",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <condition> {
|
||||||
|
errt := tower.
|
||||||
|
Bail("<caller> <message>").
|
||||||
|
PublicMessage("<public_message>").
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
condition = i(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
public_message = i(3, "public_message"),
|
||||||
|
build = create_tower_build_choice(4),
|
||||||
|
result = d(5, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
s(
|
||||||
|
"errbpc",
|
||||||
|
fmta(
|
||||||
|
[[
|
||||||
|
if <condition> {
|
||||||
|
errt := tower.
|
||||||
|
Bail("<caller> <message>").
|
||||||
|
PublicMessage("<public_message>").
|
||||||
|
Context(<fields>).
|
||||||
|
<build>
|
||||||
|
return <result>
|
||||||
|
}
|
||||||
|
<finish>
|
||||||
|
]],
|
||||||
|
{
|
||||||
|
condition = i(1),
|
||||||
|
caller = f(get_function_name),
|
||||||
|
message = i(2, "message"),
|
||||||
|
public_message = i(3, "public_message"),
|
||||||
|
fields = i(4),
|
||||||
|
build = create_tower_build_choice(5),
|
||||||
|
result = d(6, go_return_values),
|
||||||
|
finish = i(0),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
),
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
register_snippet()
|
9
lua/snippets/go/init.lua
Normal file
9
lua/snippets/go/init.lua
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
-- Use to clear snippets when sourced.
|
||||||
|
--
|
||||||
|
-- Useful when building a new snippet.
|
||||||
|
--
|
||||||
|
-- require("luasnip.session.snippet_collection").clear_snippets("go")
|
||||||
|
|
||||||
|
require "snippets.go.efi"
|
||||||
|
require "snippets.go.apm_span"
|
||||||
|
require "snippets.go.err_tower"
|
1
lua/snippets/init.lua
Normal file
1
lua/snippets/init.lua
Normal file
|
@ -0,0 +1 @@
|
||||||
|
require "snippets.go"
|
10
queries/go/get-function-params.scm
Normal file
10
queries/go/get-function-params.scm
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
[
|
||||||
|
(method_declaration
|
||||||
|
parameters: (parameter_list
|
||||||
|
(parameter_declaration) @params))
|
||||||
|
(function_declaration
|
||||||
|
parameters: (parameter_list
|
||||||
|
(parameter_declaration) @params))
|
||||||
|
(func_literal parameters:
|
||||||
|
(parameter_list (parameter_declaration) @params))
|
||||||
|
]
|
1
queries/go/package-node.scm
Normal file
1
queries/go/package-node.scm
Normal file
|
@ -0,0 +1 @@
|
||||||
|
(source_file (package_clause (package_identifier) @package_name) )
|
5
queries/go/return-snippet.scm
Normal file
5
queries/go/return-snippet.scm
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
[
|
||||||
|
(method_declaration result: (_) @type)
|
||||||
|
(function_declaration result: (_) @type)
|
||||||
|
(func_literal result: (_) @type)
|
||||||
|
]
|
11
queries/go/search-context.scm
Normal file
11
queries/go/search-context.scm
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
[
|
||||||
|
(method_declaration
|
||||||
|
parameters: (parameter_list
|
||||||
|
(parameter_declaration type: (_) @type)))
|
||||||
|
(function_declaration
|
||||||
|
parameters: (parameter_list
|
||||||
|
(parameter_declaration type: (_) @type)))
|
||||||
|
(func_literal
|
||||||
|
parameters: (parameter_list
|
||||||
|
(parameter_declaration type: (_) @type)))
|
||||||
|
]
|
4
stylua.toml
Normal file
4
stylua.toml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
indent_type = "Spaces"
|
||||||
|
indent_width = 4
|
||||||
|
column_width = 120
|
||||||
|
call_parentheses = "None"
|
Loading…
Reference in a new issue