rust-tools

master
spike 2 years ago
parent 4a013e2b7e
commit fba0ef8038

@ -8,10 +8,18 @@ local theme = require("base46").get_theme_tb "base_16"
local ts_context_hl = c.change_hex_saturation(colors["yellow"], -20)
local ts_context_hl = c.change_hex_lightness(ts_context_hl, -55)
local highlights = {
TreesitterContext = {
bg = ts_context_hl,
},
InlayHint = {
fg = "#a9a19a",
},
Comment = {
fg = c.change_hex_lightness(colors["one_bg"], 20),
},
}
function set_hl()

@ -0,0 +1,3 @@
snippet lnd
println!("{:?}", $1);

@ -591,7 +591,8 @@ M.general = { --{{{
-- ["<C-p>"] = { "<cmd> Telescope find_files <CR>", "find files" },
--
["<leader>fa"] = { "<cmd> Telescope find_files follow=true no_ignore=true hidden=true <CR>", "find all" },
["<C-p>"] = { function ()
["<C-p>"] = {
function ()
local ignored_bufs = {
"qf",
}

@ -2,6 +2,7 @@ local M = {}
M.options = {
auto_clean = true,
-- log = { level = 'debug'},
compile_on_sync = true,
git = { clone_timeout = 6000 },
display = {

@ -37,58 +37,58 @@ M.ui = {
},
},
hl_add = {
Visual = {
bg = "blue",
fg = "black",
},
BookmarkSign = {
fg = "blue",
},
BookmarkAnnotationSign = {
fg = "yellow",
},
BookmarkAnnotationLine = {
fg = "black",
bg = "yellow"
},
DiagnosticInfo = { -- nvchad uses DiagnosticInformation wrong hi group for lsp
Visual = {
bg = "blue",
fg = "black",
},
BookmarkSign = {
fg = "blue",
},
BookmarkAnnotationSign = {
fg = "yellow",
},
BookmarkAnnotationLine = {
fg = "black",
bg = "yellow"
},
DiagnosticInfo = { -- nvchad uses DiagnosticInformation wrong hi group for lsp
fg = "white",
italic = true,
},
DiagnosticFloatingInfo = {
},
DiagnosticFloatingInfo = {
fg="white",
italic=true,
},
DiagnosticUnderlineError = {
},
DiagnosticUnderlineError = {
fg="black",
bg="pink",
},
-- Code Lens related colors
LspCodeLens = {
},
-- Code Lens related colors
LspCodeLens = {
fg = "vibrant_green",
underline = true,
},
LspDiagnosticsSignHint = { -- LspDiagnostics Code Action
fg = "vibrant_green",
italic = true,
},
LspDiagnosticsSignHint = { -- LspDiagnostics Code Action
fg = "vibrant_green",
italic = true,
},
-- end of code lens colors
DiffText = {
bg = "vigrant_green"
bg = "vigrant_green"
},
St_DapMode = {
fg = "black2",
bg = "baby_pink",
fg = "black2",
bg = "baby_pink",
},
St_DapModeSep = {
fg = "baby_pink",
bg = "one_bg3",
fg = "baby_pink",
bg = "one_bg3",
},
St_DapModeSep2 = {
fg = "grey",
bg = "baby_pink",
fg = "grey",
bg = "baby_pink",
},
},
},
-- hl_override = {
-- CursorLine = {
-- underline = 1

@ -143,7 +143,7 @@ local config = {
diagnostic_scrollbar_sign = false,
disable_lsp = {"clangd"},
disable_lsp = {"clangd", "rust_analyzer"},
-- disable auto start of lsp per language
-- set global default on lspconfig (see lspconfig doc)

@ -0,0 +1,182 @@
local M = {}
local opts = {
tools = { -- rust-tools options
-- how to execute terminal commands
-- options right now: termopen / quickfix
executor = require("rust-tools/executors").termopen,
-- callback to execute once rust-analyzer is done initializing the workspace
-- The callback receives one parameter indicating the `health` of the server: "ok" | "warning" | "error"
on_initialized = nil,
-- automatically call RustReloadWorkspace when writing to a Cargo.toml file.
reload_workspace_from_cargo_toml = true,
-- These apply to the default RustSetInlayHints command
inlay_hints = {
-- automatically set inlay hints (type hints)
-- default: true
auto = true,
-- Only show inlay hints for the current line
only_current_line = false,
-- whether to show parameter hints with the inlay hints or not
-- default: true
show_parameter_hints = true,
-- prefix for parameter hints
-- default: "<-"
parameter_hints_prefix = "",
-- prefix for all the other hints (type, chaining)
-- default: "=>"
other_hints_prefix = "",
-- whether to align to the length of the longest line in the file
max_len_align = false,
-- padding from the left if max_len_align is true
max_len_align_padding = 1,
-- whether to align to the extreme right or not
right_align = false,
-- padding from the right if right_align is true
right_align_padding = 7,
-- The color of the hints
highlight = "InlayHint",
},
-- options same as lsp hover / vim.lsp.util.open_floating_preview()
hover_actions = {
-- the border that is used for the hover window
-- see vim.api.nvim_open_win()
border = {
{ "", "FloatBorder" },
{ "", "FloatBorder" },
{ "", "FloatBorder" },
{ "", "FloatBorder" },
{ "", "FloatBorder" },
{ "", "FloatBorder" },
{ "", "FloatBorder" },
{ "", "FloatBorder" },
},
-- whether the hover action window gets automatically focused
-- default: false
auto_focus = false,
},
-- settings for showing the crate graph based on graphviz and the dot
-- command
crate_graph = {
-- Backend used for displaying the graph
-- see: https://graphviz.org/docs/outputs/
-- default: x11
backend = "x11",
-- where to store the output, nil for no output stored (relative
-- path from pwd)
-- default: nil
output = nil,
-- true for all crates.io and external crates, false only the local
-- crates
-- default: true
full = true,
-- List of backends found on: https://graphviz.org/docs/outputs/
-- Is used for input validation and autocompletion
-- Last updated: 2021-08-26
enabled_graphviz_backends = {
"bmp",
"cgimage",
"canon",
"dot",
"gv",
"xdot",
"xdot1.2",
"xdot1.4",
"eps",
"exr",
"fig",
"gd",
"gd2",
"gif",
"gtk",
"ico",
"cmap",
"ismap",
"imap",
"cmapx",
"imap_np",
"cmapx_np",
"jpg",
"jpeg",
"jpe",
"jp2",
"json",
"json0",
"dot_json",
"xdot_json",
"pdf",
"pic",
"pct",
"pict",
"plain",
"plain-ext",
"png",
"pov",
"ps",
"ps2",
"psd",
"sgi",
"svg",
"svgz",
"tga",
"tiff",
"tif",
"tk",
"vml",
"vmlz",
"wbmp",
"webp",
"xlib",
"x11",
},
},
},
-- all the opts to send to nvim-lspconfig
-- these override the defaults set by rust-tools.nvim
-- see https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md#rust_analyzer
server = {
-- standalone file support
-- setting it to false may improve startup time
standalone = true,
cmd = {"run-rust-analyzer"}, -- use my wrapper script to see separate input/output log
on_attach = function(client, bufnr)
require('navigator.lspclient.mapping').setup({client=client, bufnr=bufnr}) -- setup navigator keymaps here,
require("navigator.dochighlight").documentHighlight(bufnr)
require('navigator.codeAction').code_action_prompt(bufnr)
-- otherwise, you can define your own commands to call navigator functions
end
}, -- rust-analyzer options
-- debugging stuff
dap = {
adapter = {
type = "executable",
command = "lldb-vscode",
name = "rt_lldb",
},
},
}
function M.setup()
require("rust-tools").setup(opts)
end
return M

@ -1,4 +1,4 @@
-- vim: foldlevel=1
-- vim: foldlevel=1 foldmethod=marker
--
-- TODO: interesting plugins to install
-- - neovim minisurround to replace vim-surround
@ -188,7 +188,6 @@ return {
-- lock = true,
after = "vim-hardtime",
tag = "*",
disable = false,
},
["tom-anders/telescope-vim-bookmarks.nvim"] = {
@ -325,7 +324,6 @@ return {
"fugitive",
"guihua*",
}
vim.g.hardtime_maxcount = 2
end,
},
@ -493,6 +491,16 @@ return {
config = function()
require("custom.plugins.configs.gonvim").setup()
end
},-- }}}
-- Rust dev
["simrat39/rust-tools.nvim"] = {-- {{{
lock = true,
ft = {"rust"},
opt = true,
config = function()
require("custom.plugins.configs.rust-tools").setup()
end
}-- }}}
}

@ -26,7 +26,7 @@ local plugins = {
},
["NvChad/ui"] = {
lock = false,
lock = true,
after = "base46",
config = function()
require("plugins.configs.others").nvchad_ui()

@ -1 +1,3 @@
(field) @field.outer
(function_declaration) @function.outer

Loading…
Cancel
Save