diff --git a/nvim/README.md b/nvim/README.md new file mode 100644 index 0000000..dc7634e --- /dev/null +++ b/nvim/README.md @@ -0,0 +1,8 @@ +nodejs + +clang + + +:CocInstall coc-clangd + +:CocCommand clangd.install diff --git a/nvim/init.lua b/nvim/init.lua new file mode 100755 index 0000000..4f8afd2 --- /dev/null +++ b/nvim/init.lua @@ -0,0 +1,830 @@ +vim.g.mapleader = ' ' +vim.g.maplocalleader = ' ' +vim.o.relativenumber = true +vim.o.colorcolumn = "80" +vim.o.number = true +vim.o.tabstop = 4 +vim.o.softtabstop = 4 +vim.o.shiftwidth = 4 +vim.o.expandtab = true +vim.o.smartindent = true +-- [[ Setting options ]] +-- See `:help vim.o` +-- NOTE: You can change these options as you wish! + +-- Make line numbers default +vim.wo.number = true + +-- Enable mouse mode +vim.o.mouse = 'a' + +-- Sync clipboard between OS and Neovim. +-- Schedule the setting after `UiEnter` because it can increase startup-time. +-- Remove this option if you want your OS clipboard to remain independent. +-- See `:help 'clipboard'` +vim.schedule(function() + vim.opt.clipboard = 'unnamedplus' +end) +vim.o.clipboard = 'unnamedplus' +vim.opt.clipboard = 'unnamedplus' + +-- Enable break indent +vim.o.breakindent = true + +-- Save undo history +vim.o.undofile = true + +-- Keep signcolumn on by default +vim.wo.signcolumn = 'yes' + +-- Decrease update time +vim.o.updatetime = 250 +vim.o.timeoutlen = 300 + +-- Set completeopt to have a better completion experience +vim.o.completeopt = 'menuone,noselect' + +-- NOTE: You should make sure your terminal supports this +vim.o.termguicolors = true + +-- [[ Basic Keymaps ]] + +--vim.o.listchars="eol:$" + +--vim.keymap.set({"n", "v", "i"}, "", "", {noremap = true}) + +--ignore case if pattern doesn't contain upper case +vim.o.ignorecase = true +vim.o.smartcase = true + +--number of line to show around the cursor +vim.o.scrolloff = 8 +vim.g.rustfmt_autosave = 1 + +-- +vim.keymap.set("n", "pv", vim.cmd.Ex) +vim.keymap.set("n", "h", ":noh") + +--move line shortcut +vim.keymap.set("n", "", ":m +1==", {noremap = true}) +vim.keymap.set("n", "", ":m -2==", {noremap = true}) + +vim.keymap.set("v", "", ":m '>+1gv=gv", {noremap = true}) +vim.keymap.set("v", "", ":m '<-2gv=gv", {noremap = true}) + +vim.keymap.set("n", "", "zz", {noremap = true}) +vim.keymap.set("n", "", "zz", {noremap = true}) + +vim.keymap.set("x", "p", "\"_dP") + +vim.keymap.set("n", "y", "\"+y") +vim.keymap.set("v", "y", "\"+y") + +--surrounding +vim.keymap.set("v", 's(', "xi()P", {noremap = true}) +vim.keymap.set("v", 's)', "xi()P", {noremap = true}) +vim.keymap.set("v", 's{', "xi{}P", {noremap = true}) +vim.keymap.set("v", 's}', "xi{}P", {noremap = true}) +vim.keymap.set("v", 's[', "xi[]P", {noremap = true}) +vim.keymap.set("v", 's]', "xi[]P", {noremap = true}) +vim.keymap.set("v", 's"', 'xi""P', {noremap = true}) +vim.keymap.set("v", "s'", "xi''P", {noremap = true}) + +--tab buffer +vim.keymap.set("n", "fn", ":bnext", {noremap = true}) +vim.keymap.set("n", "fp", ":bprev", {noremap = true}) + +-- wrap toggle +vim.keymap.set("n", "w", function() vim.o.wrap = not vim.o.wrap end, {noremap = true}) + + +--[[ + + - https://learnxinyminutes.com/docs/lua/ + + And then you can explore or search through `:help lua-guide` + - https://neovim.io/doc/user/lua-guide.html +--]] + +-- [[ Install `lazy.nvim` plugin manager ]] +-- https://github.com/folke/lazy.nvim +-- `:help lazy.nvim.txt` for more info +local lazypath = vim.fn.stdpath 'data' .. '/lazy/lazy.nvim' +if not vim.loop.fs_stat(lazypath) then + vim.fn.system { + 'git', + 'clone', + '--filter=blob:none', + 'https://github.com/folke/lazy.nvim.git', + '--branch=stable', -- latest stable release + lazypath, + } +end +vim.opt.rtp:prepend(lazypath) + +-- [[ Configure plugins ]] +-- NOTE: Here is where you install your plugins. +-- You can configure plugins using the `config` key. +-- +-- You can also configure plugins after the setup call, +-- as they will be available in your neovim runtime. +require('lazy').setup({ + -- NOTE: First, some plugins that don't require any configuration + + -- Git related plugins + 'tpope/vim-fugitive', + 'tpope/vim-rhubarb', + + -- harpoon + -- { + -- 'ThePrimeagen/harpoon', + -- branch = "harpoon2", + -- dependencies = { "nvim-lua/plenary.nvim" } + -- }, + { + 'ThePrimeagen/harpoon', + branch = 'harpoon2', + opts = { + menu = { + width = vim.api.nvim_win_get_width(0) - 4, + }, + }, + keys = { + { + 'q', + function() + require('harpoon'):list():add() + end, + desc = 'Harpoon File', + }, + { + '', + function() + local harpoon = require('harpoon') + harpoon.ui:toggle_quick_menu(harpoon:list()) + end, + desc = 'Harpoon Quick Menu', + }, + { + '', + function() + require('harpoon'):list():select(1) + end, + desc = 'Harpoon to File 1', + }, + { + '', + function() + require('harpoon'):list():select(2) + end, + desc = 'Harpoon to File 2', + }, + { + '', + function() + require('harpoon'):list():select(3) + end, + desc = 'Harpoon to File 3', + }, + { + '', + function() + require('harpoon'):list():select(4) + end, + desc = 'Harpoon to File 4', + }, + { + '', + function() + require('harpoon'):list():select(5) + end, + desc = 'Harpoon to File 5', + }, + }, + }, + + -- Mini + { 'echasnovski/mini.files', version = false }, + + -- Detect tabstop and shiftwidth automatically + -- 'tpope/vim-sleuth', + + -- NOTE: This is where your plugins related to LSP can be installed. + -- The configuration is done below. Search for lspconfig to find it below. + { + -- LSP Configuration & Plugins + 'neovim/nvim-lspconfig', + dependencies = { + -- Automatically install LSPs to stdpath for neovim + { 'williamboman/mason.nvim', config = true }, + 'williamboman/mason-lspconfig.nvim', + + -- Useful status updates for LSP + -- NOTE: `opts = {}` is the same as calling `require('fidget').setup({})` + { 'j-hui/fidget.nvim', opts = {} }, + + -- Additional lua configuration, makes nvim stuff amazing! + 'folke/neodev.nvim', + }, + }, + + { + -- Autocompletion + 'hrsh7th/nvim-cmp', + dependencies = { + -- Snippet Engine & its associated nvim-cmp source + { + 'L3MON4D3/LuaSnip', + build = (function() + -- Build Step is needed for regex support in snippets + -- This step is not supported in many windows environments + -- Remove the below condition to re-enable on windows + if vim.fn.has 'win32' == 1 then + return + end + return 'make install_jsregexp' + end)(), + }, + 'saadparwaiz1/cmp_luasnip', + + -- Adds LSP completion capabilities + 'hrsh7th/cmp-nvim-lsp', + 'hrsh7th/cmp-path', + + -- Adds a number of user-friendly snippets + 'rafamadriz/friendly-snippets', + }, + }, + + -- auto pair + { + "windwp/nvim-autopairs", + config = function() require("nvim-autopairs").setup {} end + }, + + -- Rust + "simrat39/rust-tools.nvim", + + -- Useful plugin to show you pending keybinds. + -- { 'folke/which-key.nvim', opts = {} }, + --{ + -- -- Adds git related signs to the gutter, as well as utilities for managing changes + -- 'lewis6991/gitsigns.nvim', + -- opts = { + -- -- See `:help gitsigns.txt` + -- signs = { + -- add = { text = '+' }, + -- change = { text = '~' }, + -- delete = { text = '_' }, + -- topdelete = { text = '‾' }, + -- changedelete = { text = '~' }, + -- }, + -- on_attach = function(bufnr) + -- local gs = package.loaded.gitsigns + + -- local function map(mode, l, r, opts) + -- opts = opts or {} + -- opts.buffer = bufnr + -- vim.keymap.set(mode, l, r, opts) + -- end + + -- -- Navigation + -- map({ 'n', 'v' }, ']c', function() + -- if vim.wo.diff then + -- return ']c' + -- end + -- vim.schedule(function() + -- gs.next_hunk() + -- end) + -- return '' + -- end, { expr = true, desc = 'Jump to next hunk' }) + + -- map({ 'n', 'v' }, '[c', function() + -- if vim.wo.diff then + -- return '[c' + -- end + -- vim.schedule(function() + -- gs.prev_hunk() + -- end) + -- return '' + -- end, { expr = true, desc = 'Jump to previous hunk' }) + + -- -- Actions + -- -- visual mode + -- map('v', 'hs', function() + -- gs.stage_hunk { vim.fn.line '.', vim.fn.line 'v' } + -- end, { desc = 'stage git hunk' }) + -- map('v', 'hr', function() + -- gs.reset_hunk { vim.fn.line '.', vim.fn.line 'v' } + -- end, { desc = 'reset git hunk' }) + -- -- normal mode + -- map('n', 'hs', gs.stage_hunk, { desc = 'git stage hunk' }) + -- map('n', 'hr', gs.reset_hunk, { desc = 'git reset hunk' }) + -- map('n', 'hS', gs.stage_buffer, { desc = 'git Stage buffer' }) + -- map('n', 'hu', gs.undo_stage_hunk, { desc = 'undo stage hunk' }) + -- map('n', 'hR', gs.reset_buffer, { desc = 'git Reset buffer' }) + -- map('n', 'hp', gs.preview_hunk, { desc = 'preview git hunk' }) + -- map('n', 'hb', function() + -- gs.blame_line { full = false } + -- end, { desc = 'git blame line' }) + -- map('n', 'hd', gs.diffthis, { desc = 'git diff against index' }) + -- map('n', 'hD', function() + -- gs.diffthis '~' + -- end, { desc = 'git diff against last commit' }) + + -- -- Toggles + -- map('n', 'tb', gs.toggle_current_line_blame, { desc = 'toggle git blame line' }) + -- map('n', 'td', gs.toggle_deleted, { desc = 'toggle git show deleted' }) + + -- -- Text object + -- map({ 'o', 'x' }, 'ih', ':Gitsigns select_hunk', { desc = 'select git hunk' }) + -- end, + -- }, + --}, + + { + -- Theme inspired by Atom + 'navarasu/onedark.nvim', + priority = 1000, + lazy = false, + config = function() + require('onedark').setup { + -- Set a style preset. 'dark' is default. + style = 'dark', -- dark, darker, cool, deep, warm, warmer, light + } + require('onedark').load() + end, + }, + + -- bar + --{ + -- -- Set lualine as statusline + -- 'nvim-lualine/lualine.nvim', + -- -- See `:help lualine.txt` + -- opts = { + -- options = { + -- icons_enabled = false, + -- theme = 'auto', + -- component_separators = '|', + -- section_separators = '', + -- }, + -- }, + --}, + + -- coloration and indentation + --{ + -- -- Add indentation guides even on blank lines + -- 'lukas-reineke/indent-blankline.nvim', + -- -- Enable `lukas-reineke/indent-blankline.nvim` + -- -- See `:help ibl` + -- main = 'ibl', + -- opts = {}, + --}, + + -- `gcc` - Toggles the current line using linewise comment + -- `gbc` - Toggles the current line using blockwise comment + -- `[count]gcc` - Toggles the number of line given as a prefix-count using linewise + -- `[count]gbc` - Toggles the number of line given as a prefix-count using blockwise + -- `gc[count]{motion}` - (Op-pending) Toggles the region using linewise comment + -- `gb[count]{motion}` - (Op-pending) Toggles the region using blockwise comment + { 'numToStr/Comment.nvim', opts = {} }, + + -- Fuzzy Finder (files, lsp, etc) + { + 'nvim-telescope/telescope.nvim', + branch = '0.1.x', + dependencies = { + 'nvim-lua/plenary.nvim', + -- Fuzzy Finder Algorithm which requires local dependencies to be built. + -- Only load if `make` is available. Make sure you have the system + -- requirements installed. + { + 'nvim-telescope/telescope-fzf-native.nvim', + -- NOTE: If you are having trouble with this installation, + -- refer to the README for telescope-fzf-native for more instructions. + build = 'make', + cond = function() + return vim.fn.executable 'make' == 1 + end, + }, + }, + }, + + { + -- Highlight, edit, and navigate code + 'nvim-treesitter/nvim-treesitter', + dependencies = { + 'nvim-treesitter/nvim-treesitter-textobjects', + }, + build = ':TSUpdate', + }, + + -- NOTE: Next Step on Your Neovim Journey: Add/Configure additional "plugins" for kickstart + -- These are some example plugins that I've included in the kickstart repository. + -- Uncomment any of the lines below to enable them. + -- require 'kickstart.plugins.autoformat', + -- require 'kickstart.plugins.debug', + + -- NOTE: The import below can automatically add your own plugins, configuration, etc from `lua/custom/plugins/*.lua` + -- You can use this folder to prevent any conflicts with this init.lua if you're interested in keeping + -- up-to-date with whatever is in the kickstart repo. + -- Uncomment the following line and add your plugins to `lua/custom/plugins/*.lua` to get going. + -- + -- For additional information see: https://github.com/folke/lazy.nvim#-structuring-your-plugins + -- { import = 'custom.plugins' }, +}, {}) + +-- Keymaps for better default experience +-- See `:help vim.keymap.set()` +vim.keymap.set({ 'n', 'v' }, '', '', { silent = true }) + +-- Remap for dealing with word wrap +vim.keymap.set('n', 'k', "v:count == 0 ? 'gk' : 'k'", { expr = true, silent = true }) +vim.keymap.set('n', 'j', "v:count == 0 ? 'gj' : 'j'", { expr = true, silent = true }) + +-- Diagnostic keymaps +vim.keymap.set('n', '[d', vim.diagnostic.goto_prev, { desc = 'Go to previous diagnostic message' }) +vim.keymap.set('n', ']d', vim.diagnostic.goto_next, { desc = 'Go to next diagnostic message' }) +vim.keymap.set('n', 'e', vim.diagnostic.open_float, { desc = 'Open floating diagnostic message' }) +vim.keymap.set('n', 'd', vim.diagnostic.setloclist, { desc = 'Open diagnostics list' }) + +-- [[ Highlight on yank ]] +-- See `:help vim.highlight.on_yank()` +--local highlight_group = vim.api.nvim_create_augroup('YankHighlight', { clear = true }) +--vim.api.nvim_create_autocmd('TextYankPost', { +-- callback = function() +-- vim.highlight.on_yank() +-- end, +-- group = highlight_group, +-- pattern = '*', +--}) + +-- Enable telescope fzf native, if installed +pcall(require('telescope').load_extension, 'fzf') + +-- Telescope live_grep in git root +-- Function to find the git root directory based on the current buffer's path +local function find_git_root() + -- Use the current buffer's path as the starting point for the git search + local current_file = vim.api.nvim_buf_get_name(0) + local current_dir + local cwd = vim.fn.getcwd() + -- If the buffer is not associated with a file, return nil + if current_file == '' then + current_dir = cwd + else + -- Extract the directory from the current file's path + current_dir = vim.fn.fnamemodify(current_file, ':h') + end + + -- Find the Git root directory from the current file's path + local git_root = vim.fn.systemlist('git -C ' .. vim.fn.escape(current_dir, ' ') .. ' rev-parse --show-toplevel')[1] + if vim.v.shell_error ~= 0 then + print 'Not a git repository. Searching on current working directory' + return cwd + end + return git_root +end + +-- Custom live_grep function to search in git root +local function live_grep_git_root() + local git_root = find_git_root() + if git_root then + require('telescope.builtin').live_grep { + search_dirs = { git_root }, + } + end +end + +vim.api.nvim_create_user_command('LiveGrepGitRoot', live_grep_git_root, {}) + +-- See `:help telescope.builtin` +vim.keymap.set('n', '?', require('telescope.builtin').oldfiles, { desc = '[?] Find recently opened files' }) +vim.keymap.set('n', '', require('telescope.builtin').buffers, { desc = '[ ] Find existing buffers' }) +vim.keymap.set('n', '/', function() + -- You can pass additional configuration to telescope to change theme, layout, etc. + require('telescope.builtin').current_buffer_fuzzy_find(require('telescope.themes').get_dropdown { + winblend = 10, + previewer = false, + }) +end, { desc = '[/] Fuzzily search in current buffer' }) + +local function telescope_live_grep_open_files() + require('telescope.builtin').live_grep { + grep_open_files = true, + prompt_title = 'Live Grep in Open Files', + } +end +vim.keymap.set('n', 's/', telescope_live_grep_open_files, { desc = '[S]earch [/] in Open Files' }) +vim.keymap.set('n', 'ss', require('telescope.builtin').builtin, { desc = '[S]earch [S]elect Telescope' }) +vim.keymap.set('n', 'gf', require('telescope.builtin').git_files, { desc = 'Search [G]it [F]iles' }) +vim.keymap.set('n', 'sf', require('telescope.builtin').find_files, { desc = '[S]earch [F]iles' }) +vim.keymap.set('n', 'sh', require('telescope.builtin').help_tags, { desc = '[S]earch [H]elp' }) +vim.keymap.set('n', 'sw', require('telescope.builtin').grep_string, { desc = '[S]earch current [W]ord' }) +vim.keymap.set('n', 'sg', require('telescope.builtin').live_grep, { desc = '[S]earch by [G]rep' }) +vim.keymap.set('n', 'sG', ':LiveGrepGitRoot', { desc = '[S]earch by [G]rep on Git Root' }) +vim.keymap.set('n', 'sd', require('telescope.builtin').diagnostics, { desc = '[S]earch [D]iagnostics' }) +vim.keymap.set('n', 'sr', require('telescope.builtin').resume, { desc = '[S]earch [R]esume' }) + +-- [[ Configure Treesitter ]] +-- See `:help nvim-treesitter` +-- Defer Treesitter setup after first render to improve startup time of 'nvim {filename}' +vim.defer_fn(function() + require('nvim-treesitter.configs').setup { + -- Add languages to be installed here that you want installed for treesitter + ensure_installed = { 'rust', 'vimdoc', 'vim', 'bash' }, + + -- Autoinstall languages that are not installed. Defaults to false (but you can change for yourself!) + auto_install = false, + -- Install languages synchronously (only applied to `ensure_installed`) + sync_install = false, + -- List of parsers to ignore installing + ignore_install = {}, + -- You can specify additional Treesitter modules here: -- For example: -- playground = {--enable = true,-- }, + modules = {}, + highlight = { enable = true }, + indent = { enable = true }, + incremental_selection = { + enable = true, + keymaps = { + init_selection = '', + node_incremental = '', + scope_incremental = '', + node_decremental = '', + }, + }, + textobjects = { + select = { + enable = true, + lookahead = true, -- Automatically jump forward to textobj, similar to targets.vim + keymaps = { + -- You can use the capture groups defined in textobjects.scm + ['aa'] = '@parameter.outer', + ['ia'] = '@parameter.inner', + ['af'] = '@function.outer', + ['if'] = '@function.inner', + ['ac'] = '@class.outer', + ['ic'] = '@class.inner', + }, + }, + move = { + enable = true, + set_jumps = true, -- whether to set jumps in the jumplist + goto_next_start = { + [']m'] = '@function.outer', + [']]'] = '@class.outer', + }, + goto_next_end = { + [']M'] = '@function.outer', + [']['] = '@class.outer', + }, + goto_previous_start = { + ['[m'] = '@function.outer', + ['[['] = '@class.outer', + }, + goto_previous_end = { + ['[M'] = '@function.outer', + ['[]'] = '@class.outer', + }, + }, + swap = { + enable = true, + swap_next = { + ['a'] = '@parameter.inner', + }, + swap_previous = { + ['A'] = '@parameter.inner', + }, + }, + }, + } +end, 0) + +-- [[ Configure LSP ]] +-- This function gets run when an LSP connects to a particular buffer. +local on_attach = function(_, bufnr) + -- NOTE: Remember that lua is a real programming language, and as such it is possible + -- to define small helper and utility functions so you don't have to repeat yourself + -- many times. + -- + -- In this case, we create a function that lets us more easily define mappings specific + -- for LSP related items. It sets the mode, buffer and description for us each time. + local nmap = function(keys, func, desc) + if desc then + desc = 'LSP: ' .. desc + end + + vim.keymap.set('n', keys, func, { buffer = bufnr, desc = desc }) + end + + nmap('rn', vim.lsp.buf.rename, '[R]e[n]ame') + nmap('ca', function() + vim.lsp.buf.code_action { context = { only = { 'quickfix', 'refactor', 'source' } } } + end, '[C]ode [A]ction') + + nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition') + nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences') + nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation') + nmap('D', require('telescope.builtin').lsp_type_definitions, 'Type [D]efinition') + nmap('ds', require('telescope.builtin').lsp_document_symbols, '[D]ocument [S]ymbols') + nmap('ws', require('telescope.builtin').lsp_dynamic_workspace_symbols, '[W]orkspace [S]ymbols') + + -- See `:help K` for why this keymap + nmap('K', vim.lsp.buf.hover, 'Hover Documentation') + nmap('', vim.lsp.buf.signature_help, 'Signature Documentation') + + -- Lesser used LSP functionality + nmap('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration') + nmap('wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder') + nmap('wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder') + nmap('wl', function() + print(vim.inspect(vim.lsp.buf.list_workspace_folders())) + end, '[W]orkspace [L]ist Folders') + + -- Create a command `:Format` local to the LSP buffer + vim.api.nvim_buf_create_user_command(bufnr, 'Format', function(_) + vim.lsp.buf.format() + end, { desc = 'Format current buffer with LSP' }) +end + +-- document existing key chains +-- require('which-key').register { +-- ['c'] = { name = '[C]ode', _ = 'which_key_ignore' }, +-- ['d'] = { name = '[D]ocument', _ = 'which_key_ignore' }, +-- ['g'] = { name = '[G]it', _ = 'which_key_ignore' }, +-- ['h'] = { name = 'Git [H]unk', _ = 'which_key_ignore' }, +-- ['r'] = { name = '[R]ename', _ = 'which_key_ignore' }, +-- ['s'] = { name = '[S]earch', _ = 'which_key_ignore' }, +-- ['t'] = { name = '[T]oggle', _ = 'which_key_ignore' }, +-- ['w'] = { name = '[W]orkspace', _ = 'which_key_ignore' }, +-- } +-- -- register which-key VISUAL mode +-- -- required for visual hs (hunk stage) to work +-- require('which-key').register({ +-- [''] = { name = 'VISUAL ' }, +-- ['h'] = { 'Git [H]unk' }, +-- }, { mode = 'v' }) + +-- mason-lspconfig requires that these setup functions are called in this order +-- before setting up the servers. +require('mason').setup() +require('mason-lspconfig').setup() + +-- vim.api.nvim_create_augroup("LspAttach_inlayhints", {}) +-- vim.api.nvim_create_autocmd("LspAttach", { +-- group = "LspAttach_inlayhints", +-- callback = function(args) +-- if not (args.data and args.data.client_id) then +-- return +-- end +-- +-- local bufnr = args.buf +-- local client = vim.lsp.get_client_by_id(args.data.client_id) +-- require("lsp-inlayhints").on_attach(client, bufnr) +-- end, +-- }) + +-- rust +require("rust-tools").setup({ + tools = { + inlay_hints = { + auto = true + } + } +}) +vim.api.nvim_create_autocmd("LspAttach", { + group = vim.api.nvim_create_augroup("UserLspConfig", {}), + callback = function(args) + local client = vim.lsp.get_client_by_id(args.data.client_id) + if client.server_capabilities.inlayHintProvider then + vim.lsp.inlay_hint.enable(true, { 0 }) + end + -- whatever other lsp config you want + end +}) +-- toggle inlay hint +vim.keymap.set("n", "ri", function() vim.lsp.inlay_hint.enable(not vim.lsp.inlay_hint.is_enabled({0}), {0}) end) + +-- Enable the following language servers +-- Feel free to add/remove any LSPs that you want here. They will automatically be installed. +-- +-- Add any additional override configuration in the following tables. They will be passed to +-- the `settings` field of the server config. You must look up that documentation yourself. +-- +-- If you want to override the default filetypes that your language server will attach to you can +-- define the property 'filetypes' to the map in question. +local servers = { + -- clangd = {}, + -- gopls = {}, + -- pyright = {}, + rust_analyzer = { + imports = { + granularity = { + group = "module", + }, + prefix = "self", + }, + cargo = { + buildScripts = { + enable = true, + }, + }, + procMacro = { + enable = true, + }, + diagnostics = { + experimental = { + enable = false + } + } + }, + -- tsserver = {}, + -- html = { filetypes = { 'html', 'twig', 'hbs'} }, + + lua_ls = { + Lua = { + workspace = { checkThirdParty = false }, + telemetry = { enable = false }, + -- NOTE: toggle below to ignore Lua_LS's noisy `missing-fields` warnings + -- diagnostics = { disable = { 'missing-fields' } }, + }, + }, +} + +-- Setup neovim lua configuration +require('neodev').setup() + +-- nvim-cmp supports additional completion capabilities, so broadcast that to servers +local capabilities = vim.lsp.protocol.make_client_capabilities() +capabilities = require('cmp_nvim_lsp').default_capabilities(capabilities) + +-- Ensure the servers above are installed +local mason_lspconfig = require 'mason-lspconfig' + +mason_lspconfig.setup { + ensure_installed = vim.tbl_keys(servers), + -- ensure_installed = { "rust-analyzer" } +} + +mason_lspconfig.setup_handlers { + function(server_name) + require('lspconfig')[server_name].setup { + capabilities = capabilities, + on_attach = on_attach, + settings = servers[server_name], + filetypes = (servers[server_name] or {}).filetypes, + } + end, +} + +-- [[ Configure nvim-cmp ]] +-- See `:help cmp` +local cmp = require 'cmp' +local luasnip = require 'luasnip' +require('luasnip.loaders.from_vscode').lazy_load() +luasnip.config.setup {} + +cmp.setup { + snippet = { + expand = function(args) + luasnip.lsp_expand(args.body) + end, + }, + completion = { + completeopt = 'menu,menuone,noinsert', + }, + mapping = cmp.mapping.preset.insert { + [''] = cmp.mapping.select_next_item(), + [''] = cmp.mapping.select_prev_item(), + [''] = cmp.mapping.scroll_docs(-4), + [''] = cmp.mapping.scroll_docs(4), + [''] = cmp.mapping.complete {}, + [''] = cmp.mapping.confirm { + behavior = cmp.ConfirmBehavior.Replace, + select = true, + }, + [''] = cmp.mapping(function(fallback) + if cmp.visible() then + cmp.select_next_item() + elseif luasnip.expand_or_locally_jumpable() then + luasnip.expand_or_jump() + else + fallback() + end + end, { 'i', 's' }), + [''] = cmp.mapping(function(fallback) + if cmp.visible() then + cmp.select_prev_item() + elseif luasnip.locally_jumpable(-1) then + luasnip.jump(-1) + else + fallback() + end + end, { 'i', 's' }), + }, + sources = { + { name = 'nvim_lsp' }, + { name = 'luasnip' }, + { name = 'path' }, + }, +} diff --git a/nvim/lazy-lock.json b/nvim/lazy-lock.json new file mode 100644 index 0000000..77b9b3a --- /dev/null +++ b/nvim/lazy-lock.json @@ -0,0 +1,28 @@ +{ + "Comment.nvim": { "branch": "master", "commit": "e30b7f2008e52442154b66f7c519bfd2f1e32acb" }, + "LuaSnip": { "branch": "master", "commit": "45db5addf8d0a201e1cf247cae4cdce605ad3768" }, + "cmp-nvim-lsp": { "branch": "main", "commit": "39e2eda76828d88b773cc27a3f61d2ad782c922d" }, + "cmp-path": { "branch": "main", "commit": "91ff86cd9c29299a64f968ebb45846c485725f23" }, + "cmp_luasnip": { "branch": "master", "commit": "05a9ab28b53f71d1aece421ef32fee2cb857a843" }, + "fidget.nvim": { "branch": "main", "commit": "d855eed8a06531a7e8fd0684889b2943f373c469" }, + "friendly-snippets": { "branch": "main", "commit": "00ebcaa159e817150bd83bfe2d51fa3b3377d5c4" }, + "harpoon": { "branch": "harpoon2", "commit": "0378a6c428a0bed6a2781d459d7943843f374bce" }, + "lazy.nvim": { "branch": "main", "commit": "077102c5bfc578693f12377846d427f49bc50076" }, + "mason-lspconfig.nvim": { "branch": "main", "commit": "482350b050bd413931c2cdd4857443c3da7d57cb" }, + "mason.nvim": { "branch": "main", "commit": "e2f7f9044ec30067bc11800a9e266664b88cda22" }, + "mini.files": { "branch": "main", "commit": "2e262838a773c0bc3ccbc9c4bcf4a1a012497ea2" }, + "neodev.nvim": { "branch": "main", "commit": "46aa467dca16cf3dfe27098042402066d2ae242d" }, + "nvim-autopairs": { "branch": "master", "commit": "19606af7c039271d5aa96bceff101e7523af3136" }, + "nvim-cmp": { "branch": "main", "commit": "ae644feb7b67bf1ce4260c231d1d4300b19c6f30" }, + "nvim-lspconfig": { "branch": "master", "commit": "6bfd9210e312af6cfedba05d272e85618c93ab0d" }, + "nvim-treesitter": { "branch": "master", "commit": "585860a1865853d2c287c8ef534297da8115818e" }, + "nvim-treesitter-textobjects": { "branch": "master", "commit": "41e3abf6bfd9a9a681eb1f788bdeba91c9004b2b" }, + "onedark.nvim": { "branch": "master", "commit": "fae34f7c635797f4bf62fb00e7d0516efa8abe37" }, + "plenary.nvim": { "branch": "master", "commit": "ec289423a1693aeae6cd0d503bac2856af74edaa" }, + "rust-tools.nvim": { "branch": "master", "commit": "676187908a1ce35ffcd727c654ed68d851299d3e" }, + "telescope-fzf-native.nvim": { "branch": "main", "commit": "cf48d4dfce44e0b9a2e19a008d6ec6ea6f01a83b" }, + "telescope.nvim": { "branch": "0.1.x", "commit": "a0bbec21143c7bc5f8bb02e0005fa0b982edc026" }, + "vim-fugitive": { "branch": "master", "commit": "0444df68cd1cdabc7453d6bd84099458327e5513" }, + "vim-rhubarb": { "branch": "master", "commit": "ee69335de176d9325267b0fd2597a22901d927b1" }, + "which-key.nvim": { "branch": "main", "commit": "6c1584eb76b55629702716995cca4ae2798a9cca" } +} diff --git a/nvim/lua/packer-plugins.lua b/nvim/lua/packer-plugins.lua new file mode 100644 index 0000000..2e87b53 --- /dev/null +++ b/nvim/lua/packer-plugins.lua @@ -0,0 +1,93 @@ +return require('packer').startup(function() + use 'wbthomason/packer.nvim' + use 'sonph/onehalf' + use 'navarasu/onedark.nvim' + use { + 'nvim-telescope/telescope.nvim', tag = '0.1.4', + -- or , branch = '0.1.x', + requires = { {'nvim-lua/plenary.nvim'} } + } + + require('onedark').setup { + style = 'darker' + } + require('onedark').load() + -- use({ + -- 'rose-pine/neovim', + -- as = 'rose-pine', + -- config = function() + -- vim.cmd('colorscheme rose-pine') + -- end + -- }) + + use { + "williamboman/mason.nvim", + "williamboman/mason-lspconfig.nvim", + 'neovim/nvim-lspconfig' + } + use 'hrsh7th/nvim-cmp' -- Autocompletion plugin + use 'hrsh7th/cmp-nvim-lsp' -- Autocompletion with LSPs + use 'hrsh7th/cmp-buffer' + use 'hrsh7th/cmp-path' + + use {'neoclide/coc.nvim', branch = 'release'} + + use('nvim-treesitter/nvim-treesitter', {run = ':TSUpdate'}) + + --use { + -- 'VonHeikemen/lsp-zero.nvim', + -- branch = 'v2.x', + -- requires = { + -- -- LSP Support + -- {'neovim/nvim-lspconfig'}, + -- {'williamboman/mason.nvim', run = function() + -- pcall(vim.cmd, 'MasonUpdate') + -- end,}, + -- {'williamboman/mason-lspconfig.nvim'}, -- Optional + + -- -- Autocompletion + -- {'hrsh7th/nvim-cmp'}, -- Required + -- {'hrsh7th/cmp-nvim-lsp'}, -- Required + -- {'L3MON4D3/LuaSnip'}, -- Required + -- } + --} + + -- Auto pairs + use { + "windwp/nvim-autopairs", + config = function() require("nvim-autopairs").setup {} end + } + + --harpoon + use("theprimeagen/harpoon") + + ---- neogen + --local i = require("neogen.types.template").item + --local annotation = { + -- { nil, "/**", { no_results = true, type = { "func", "file", "class" } } }, + -- { nil, "** \\file", { no_results = true, type = { "file" } } }, + -- { nil, "** \\brief $1", { no_results = true, type = { "func", "file", "class" } } }, + -- { nil, "*/", { no_results = true, type = { "func", "file", "class" } } }, + -- { nil, "", { no_results = true, type = { "file" } } }, + + -- { nil, "/**", { type = { "func", "class", "type" } } }, + -- { i.ClassName, "** @class %s", { type = { "class" } } }, + -- { i.Type, "** @typedef %s", { type = { "type" } } }, + -- { nil, "** \\brief $1", { type = { "func", "class", "type" } } }, + -- { nil, "**", { type = { "func", "class", "type" } } }, + -- { i.Tparam, "** \\tparam %s $1" }, + -- { i.Parameter, "** \\param %s $1" }, + -- { i.Return, "** \\return $1" }, + -- { nil, "*/", { type = { "func", "class", "type" } } }, + --} + --require("neogen").setup({ + -- languages = { + -- c = { + -- template = { + -- annotation_convention = "my_annotation", + -- my_annotation = annotation + -- } + -- } + -- } + --}) +end) diff --git a/nvim/plugin/harpoon.lua b/nvim/plugin/harpoon.lua new file mode 100644 index 0000000..930ec8a --- /dev/null +++ b/nvim/plugin/harpoon.lua @@ -0,0 +1,11 @@ +local harpoon = require("harpoon") +harpoon:setup() +-- +-- vim.keymap.set("n", "q", function() harpoon:list().append() end) +-- vim.keymap.set("n", "", function() harpoon.ui:toggle_quick_menu(harpoon:list()) end) +-- +-- vim.keymap.set("n", "", function() harpoon:list():select(1) end) +-- vim.keymap.set("n", "", function() harpoon:list():select(2) end) +-- vim.keymap.set("n", "", function() harpoon:list():select(3) end) +-- vim.keymap.set("n", "", function() harpoon:list():select(4) end) +-- vim.keymap.set("n", "", function() harpoon:list():select(5) end) diff --git a/nvim/plugin/minifiles.lua b/nvim/plugin/minifiles.lua new file mode 100644 index 0000000..76ec814 --- /dev/null +++ b/nvim/plugin/minifiles.lua @@ -0,0 +1,52 @@ +require('mini.files').setup({ + -- Customization of shown content + content = { + -- Predicate for which file system entries to show + filter = nil, + -- What prefix to show to the left of file system entry + prefix = nil, + -- In which order to show file system entries + sort = nil, + }, + + -- Module mappings created only inside explorer. + -- Use `''` (empty string) to not create one. + mappings = { + close = 'q', + go_in = 'l', + go_in_plus = 'L', + go_out = 'h', + go_out_plus = 'H', + reset = '', + reveal_cwd = '@', + show_help = 'g?', + synchronize = '=', + trim_left = '<', + trim_right = '>', + }, + + -- General options + options = { + -- Whether to delete permanently or move into module-specific trash + permanent_delete = true, + -- Whether to use for editing directories + use_as_default_explorer = true, + }, + + -- Customization of explorer windows + windows = { + -- Maximum number of windows to show side by side + max_number = math.huge, + -- Whether to show preview of file/directory under cursor + preview = false, + -- Width of focused window + width_focus = 50, + -- Width of non-focused window + width_nofocus = 15, + -- Width of preview window + width_preview = 25, + }, +}) + +vim.keymap.set("n", "-", 'lua MiniFiles.open(vim.api.nvim_buf_get_name(0)); MiniFiles.reveal_cwd()', { desc = 'Open MiniFiles' }) +vim.keymap.set("n", "", 'lua MiniFiles.close()', { desc = 'Close MiniFiles' }) diff --git a/nvim/plugin/rustaceanvim.lua b/nvim/plugin/rustaceanvim.lua new file mode 100644 index 0000000..c61053d --- /dev/null +++ b/nvim/plugin/rustaceanvim.lua @@ -0,0 +1,50 @@ +-- vim.g.auto_ra_attach = true +-- +-- vim.g.rustaceanvim = { +-- -- Plugin configuration +-- tools = {}, +-- -- LSP configuration +-- ---@type RustaceanLspClientOpts +-- server = { +-- load_vscode_settings = true, +-- auto_attach = function(bufnr) +-- return vim.g.auto_ra_attach +-- end, +-- on_attach = function(client, _) +-- client.server_capabilities.workspace.didChangeWatchedFiles = { +-- dynamicRegistration = false, +-- relativePatternSupport = false, +-- } +-- +-- vim.api.nvim_create_autocmd({ 'BufEnter' }, { +-- desc = 'Resize splits when resizing the window', +-- pattern = { '*.rs' }, +-- callback = function() +-- vim.cmd('RustAnalyzer reloadSettings') +-- end, +-- }) +-- end, +-- default_settings = { +-- ['rust-analyzer'] = { +-- cachePriming = false, +-- rustfmt = { +-- extraArgs = { +-- '--config', +-- 'comment_width=120,condense_wildcard_suffixes=false,format_code_in_doc_comments=true,format_macro_bodies=true,hex_literal_case=Upper,imports_granularity=One,normalize_doc_attributes=true,wrap_comments=true', +-- }, +-- }, +-- }, +-- }, +-- }, +-- -- DAP configuration +-- dap = {}, +-- } +-- +-- return { +-- { +-- 'mrcjkb/rustaceanvim', +-- version = '^4', -- Recommended +-- ft = { 'rust' }, +-- dev = true, +-- }, +-- } diff --git a/nvim/plugin/telescope.lua b/nvim/plugin/telescope.lua new file mode 100644 index 0000000..3edc053 --- /dev/null +++ b/nvim/plugin/telescope.lua @@ -0,0 +1,18 @@ +-- [[ Configure Telescope ]] +-- See `:help telescope` and `:help telescope.setup()` +require('telescope').setup { + defaults = { + mappings = { + i = { + [''] = false, + [''] = false, + }, + }, + }, +} + +local builtin = require('telescope.builtin') + +vim.keymap.set('n', 'pf', builtin.find_files, {noremap = true}) +vim.keymap.set('n', 'pg', builtin.live_grep, {noremap = true}) +vim.keymap.set('n', '', builtin.git_files, {noremap = true}) diff --git a/nvim/plugin_back/coc.lua b/nvim/plugin_back/coc.lua new file mode 100644 index 0000000..f34bd2f --- /dev/null +++ b/nvim/plugin_back/coc.lua @@ -0,0 +1,184 @@ +-- Some servers have issues with backup files, see #649 +vim.opt.backup = false +vim.opt.writebackup = false + +-- Having longer updatetime (default is 4000 ms = 4s) leads to noticeable +-- delays and poor user experience +vim.opt.updatetime = 300 + +-- Always show the signcolumn, otherwise it would shift the text each time +-- diagnostics appeared/became resolved +vim.opt.signcolumn = "yes" + +local keyset = vim.keymap.set +-- Autocomplete +function _G.check_back_space() + local col = vim.fn.col('.') - 1 + return col == 0 or vim.fn.getline('.'):sub(col, col):match('%s') ~= nil +end + +-- Use Tab for trigger completion with characters ahead and navigate +-- NOTE: There's always a completion item selected by default, you may want to enable +-- no select by setting `"suggest.noselect": true` in your configuration file +-- NOTE: Use command ':verbose imap ' to make sure Tab is not mapped by +-- other plugins before putting this into your config +local opts = {silent = true, noremap = true, expr = true, replace_keycodes = false} +keyset("i", "", 'coc#pum#visible() ? coc#pum#next(1) : v:lua.check_back_space() ? "" : coc#refresh()', opts) +keyset("i", "", [[coc#pum#visible() ? coc#pum#prev(1) : "\"]], opts) + +-- Make to accept selected completion item or notify coc.nvim to format +-- u breaks current undo, please make your own choice +keyset("i", "", [[coc#pum#visible() ? coc#pum#confirm() : "\u\\=coc#on_enter()\"]], opts) + +-- Use to trigger snippets +keyset("i", "", "(coc-snippets-expand-jump)") +-- Use to trigger completion +keyset("i", "", "coc#refresh()", {silent = true, expr = true}) + +-- Use `[g` and `]g` to navigate diagnostics +-- Use `:CocDiagnostics` to get all diagnostics of current buffer in location list +keyset("n", "[g", "(coc-diagnostic-prev)", {silent = true}) +keyset("n", "]g", "(coc-diagnostic-next)", {silent = true}) + +-- GoTo code navigation +keyset("n", "gd", "(coc-definition)", {silent = true}) +keyset("n", "gy", "(coc-type-definition)", {silent = true}) +keyset("n", "gi", "(coc-implementation)", {silent = true}) +keyset("n", "gr", "(coc-references)", {silent = true}) + + +-- Use K to show documentation in preview window +function _G.show_docs() + local cw = vim.fn.expand('') + if vim.fn.index({'vim', 'help'}, vim.bo.filetype) >= 0 then + vim.api.nvim_command('h ' .. cw) + elseif vim.api.nvim_eval('coc#rpc#ready()') then + vim.fn.CocActionAsync('doHover') + else + vim.api.nvim_command('!' .. vim.o.keywordprg .. ' ' .. cw) + end +end +keyset("n", "K", 'lua _G.show_docs()', {silent = true}) + + +-- Highlight the symbol and its references on a CursorHold event(cursor is idle) +vim.api.nvim_create_augroup("CocGroup", {}) +vim.api.nvim_create_autocmd("CursorHold", { + group = "CocGroup", + command = "silent call CocActionAsync('highlight')", + desc = "Highlight symbol under cursor on CursorHold" +}) + + +-- Symbol renaming +keyset("n", "rn", "(coc-rename)", {silent = true}) + + +-- Formatting selected code +keyset("x", "f", "(coc-format-selected)", {silent = true}) +keyset("n", "f", "(coc-format-selected)", {silent = true}) + + +-- Setup formatexpr specified filetype(s) +vim.api.nvim_create_autocmd("FileType", { + group = "CocGroup", + pattern = "typescript,json", + command = "setl formatexpr=CocAction('formatSelected')", + desc = "Setup formatexpr specified filetype(s)." +}) + +-- Update signature help on jump placeholder +vim.api.nvim_create_autocmd("User", { + group = "CocGroup", + pattern = "CocJumpPlaceholder", + command = "call CocActionAsync('showSignatureHelp')", + desc = "Update signature help on jump placeholder" +}) + +-- Apply codeAction to the selected region +-- Example: `aap` for current paragraph +local opts = {silent = true, nowait = true} +keyset("x", "a", "(coc-codeaction-selected)", opts) +keyset("n", "a", "(coc-codeaction-selected)", opts) + +-- Remap keys for apply code actions at the cursor position. +keyset("n", "ac", "(coc-codeaction-cursor)", opts) +-- Remap keys for apply source code actions for current file. +keyset("n", "as", "(coc-codeaction-source)", opts) +-- Apply the most preferred quickfix action on the current line. +keyset("n", "qf", "(coc-fix-current)", opts) + +-- Remap keys for apply refactor code actions. +keyset("n", "re", "(coc-codeaction-refactor)", { silent = true }) +keyset("x", "r", "(coc-codeaction-refactor-selected)", { silent = true }) +keyset("n", "r", "(coc-codeaction-refactor-selected)", { silent = true }) + +-- Run the Code Lens actions on the current line +keyset("n", "cl", "(coc-codelens-action)", opts) + + +-- Map function and class text objects +-- NOTE: Requires 'textDocument.documentSymbol' support from the language server +keyset("x", "if", "(coc-funcobj-i)", opts) +keyset("o", "if", "(coc-funcobj-i)", opts) +keyset("x", "af", "(coc-funcobj-a)", opts) +keyset("o", "af", "(coc-funcobj-a)", opts) +keyset("x", "ic", "(coc-classobj-i)", opts) +keyset("o", "ic", "(coc-classobj-i)", opts) +keyset("x", "ac", "(coc-classobj-a)", opts) +keyset("o", "ac", "(coc-classobj-a)", opts) + + +-- Remap and to scroll float windows/popups +---@diagnostic disable-next-line: redefined-local +local opts = {silent = true, nowait = true, expr = true} +keyset("n", "", 'coc#float#has_scroll() ? coc#float#scroll(1) : ""', opts) +keyset("n", "", 'coc#float#has_scroll() ? coc#float#scroll(0) : ""', opts) +keyset("i", "", + 'coc#float#has_scroll() ? "=coc#float#scroll(1)" : ""', opts) +keyset("i", "", + 'coc#float#has_scroll() ? "=coc#float#scroll(0)" : ""', opts) +keyset("v", "", 'coc#float#has_scroll() ? coc#float#scroll(1) : ""', opts) +keyset("v", "", 'coc#float#has_scroll() ? coc#float#scroll(0) : ""', opts) + + +-- Use CTRL-S for selections ranges +-- Requires 'textDocument/selectionRange' support of language server +keyset("n", "", "(coc-range-select)", {silent = true}) +keyset("x", "", "(coc-range-select)", {silent = true}) + + +-- Add `:Format` command to format current buffer +vim.api.nvim_create_user_command("Format", "call CocAction('format')", {}) + +-- " Add `:Fold` command to fold current buffer +vim.api.nvim_create_user_command("Fold", "call CocAction('fold', )", {nargs = '?'}) + +-- Add `:OR` command for organize imports of the current buffer +vim.api.nvim_create_user_command("OR", "call CocActionAsync('runCommand', 'editor.action.organizeImport')", {}) + +-- Add (Neo)Vim's native statusline support +-- NOTE: Please see `:h coc-status` for integrations with external plugins that +-- provide custom statusline: lightline.vim, vim-airline +vim.opt.statusline:prepend("%{coc#status()}%{get(b:,'coc_current_function','')}") + +-- Mappings for CoCList +-- code actions and coc stuff +---@diagnostic disable-next-line: redefined-local +local opts = {silent = true, nowait = true} +-- Show all diagnostics +keyset("n", "a", ":CocList diagnostics", opts) +-- Manage extensions +keyset("n", "e", ":CocList extensions", opts) +-- Show commands +keyset("n", "c", ":CocList commands", opts) +-- Find symbol of current document +keyset("n", "o", ":CocList outline", opts) +-- Search workspace symbols +keyset("n", "s", ":CocList -I symbols", opts) +-- Do default action for next item +keyset("n", "j", ":CocNext", opts) +-- Do default action for previous item +keyset("n", "k", ":CocPrev", opts) +-- Resume latest coc list +keyset("n", "p", ":CocListResume", opts) diff --git a/nvim/plugin_back/harpoon.lua b/nvim/plugin_back/harpoon.lua new file mode 100644 index 0000000..fcb2fdc --- /dev/null +++ b/nvim/plugin_back/harpoon.lua @@ -0,0 +1,11 @@ +local mark = require("harpoon.mark") +local ui = require("harpoon.ui") + +vim.keymap.set("n", "q", mark.add_file) +vim.keymap.set("n", "", ui.toggle_quick_menu) + +vim.keymap.set("n", "", function() ui.nav_file(1) end) +vim.keymap.set("n", "", function() ui.nav_file(2) end) +vim.keymap.set("n", "", function() ui.nav_file(3) end) +vim.keymap.set("n", "", function() ui.nav_file(4) end) +vim.keymap.set("n", "", function() ui.nav_file(5) end) diff --git a/nvim/plugin_back/lsp.lua b/nvim/plugin_back/lsp.lua new file mode 100644 index 0000000..1099264 --- /dev/null +++ b/nvim/plugin_back/lsp.lua @@ -0,0 +1,117 @@ +-- Initialize Mason and specify which language servers to install +--require("mason").setup() +--require("mason-lspconfig").setup({ +-- ensured_installed = { "rust_analyzer" } +--}) +-- +---- Define lspconfig settings for rust_analyzer +--local on_attach = function(_, _) +-- local opts = { buffer = bufnr, remap = false } +-- vim.keymap.set("n", "gd", function() vim.lsp.buf.definition() end, opts) +--end +-- +--local capabilities = require('cmp_nvim_lsp').default_capabilities() +-- +---- Configure autocomplete using nvim-cmp +--local cmp = require("cmp") +--cmp.setup({ +-- mapping = { +-- [""] = cmp.mapping.select_prev_item(), +-- [""] = cmp.mapping.select_next_item(), +-- [""] = cmp.mapping.scroll_docs(-4), +-- [""] = cmp.mapping.scroll_docs(4), +-- [""] = cmp.mapping.complete(), +-- [""] = cmp.mapping.confirm({ select = true }), +-- [""] = cmp.mapping.confirm({ select = true }), +-- }, +-- sources = { +-- { name = 'nvim_lsp' }, +-- { name = 'buffer' }, +-- { name = 'path' }, +-- }, +-- experimental = { ghost_text = false }, +-- formatting = { fields = { 'menu', 'abbr', 'kind' } }, +-- confirm_opts = { behavior = cmp.ConfirmBehavior.Replace, select = false }, +-- window = { +-- --completion = cmp.config.window.bordered(), +-- --documentation = cmp.config.window.bordered(), +-- }, +-- capabilities = capabilities, +--}) +-- +---- Set up Rust Analyzer +--local lspconfig = require('lspconfig') +--lspconfig.rust_analyzer.setup { +-- capabilities = capabilities, +-- on_attach = on_attach +--} +--vim.keymap.set('n', 'e', vim.diagnostic.open_float) +--vim.keymap.set('n', '[d', vim.diagnostic.goto_prev) +--vim.keymap.set('n', ']d', vim.diagnostic.goto_next) +---- vim.keymap.set('n', 'q', vim.diagnostic.setloclist) + + +-- old +--require("mason").setup() +--require("mason-lspconfig").setup({ +-- ensure_installed = { "rust_analyzer" } +--}) +-- +--local on_attach = function(_, _) +-- local opts = {buffer = bufnr, remap = false} +-- vim.keymap.set("n", "gd", function() vim.lsp.buf.definition() end, opts) +--end +-- +--local capabilities = require('cmp_nvim_lsp').default_capabilities() +--require("configs.nvim-cmp") +--require('nvim-cmp').setup{} +--require('cmp').setup({ +-- mapping = { +-- [''] = cmp.mapping.select_prev_item(), +-- [''] = cmp.mapping.select_next_item(), +-- [''] = cmp.mapping.scroll_docs(-4), +-- [''] = cmp.mapping.scroll_docs(4), +-- [''] = cmp.mapping.complete(), +-- [''] = cmp.mapping.confirm({ select = true }), +-- }, +-- sources = { +-- { name = 'nvim_lsp' }, +-- { name = 'buffer' }, +-- { name = 'path' }, +-- }, +-- experimental = { ghost_text = false }, +-- formatting = { fields = { 'menu', 'abbr', 'kind' } }, +-- confirm_opts = { behavior = cmp.ConfirmBehavior.Replace, select = false }, +-- window = { +-- completion = cmp.config.window.bordered(), +-- documentation = cmp.config.window.bordered(), +-- }, +-- capabilities = capabilities, +--}) +-- +-- +--require("lspconfig").rust_analyzer.setup { +-- capabilities = capabilities +-- on_attach = on_attach +--} + +--local lsp = require('lsp-zero').preset({}) +-- +-- lsp.on_attach(function(client, bufnr) +-- local opts = {buffer = bufnr, remap = false} +-- +-- vim.keymap.set("n", "gd", function() vim.lsp.buf.definition() end, opts) +-- end) +-- +----lsp['rust_analyzer'].setup({ +---- capabilities = capabilities, +---- on_attach = on_attach +----}) +-- +--lsp.ensure_installed({ +-- 'tsserver', +-- 'eslint', +-- 'rust_analyzer' +--}) +--lsp.setup() +----lsp.rust_analyzer.setup() diff --git a/nvim/plugin_back/neogen.lua b/nvim/plugin_back/neogen.lua new file mode 100755 index 0000000..fe113a9 --- /dev/null +++ b/nvim/plugin_back/neogen.lua @@ -0,0 +1,5 @@ +--require('neogen').generate() +--local opts = { noremap = true, silent = true } +-- +--vim.api.nvim_set_keymap("n", "nf", ":lua require('neogen').generate()", opts) + diff --git a/nvim/plugin_back/packer_compiled.lua b/nvim/plugin_back/packer_compiled.lua new file mode 100644 index 0000000..f86cd30 --- /dev/null +++ b/nvim/plugin_back/packer_compiled.lua @@ -0,0 +1,179 @@ +-- Automatically generated packer.nvim plugin loader code + +if vim.api.nvim_call_function('has', {'nvim-0.5'}) ~= 1 then + vim.api.nvim_command('echohl WarningMsg | echom "Invalid Neovim version for packer.nvim! | echohl None"') + return +end + +vim.api.nvim_command('packadd packer.nvim') + +local no_errors, error_msg = pcall(function() + +_G._packer = _G._packer or {} +_G._packer.inside_compile = true + +local time +local profile_info +local should_profile = false +if should_profile then + local hrtime = vim.loop.hrtime + profile_info = {} + time = function(chunk, start) + if start then + profile_info[chunk] = hrtime() + else + profile_info[chunk] = (hrtime() - profile_info[chunk]) / 1e6 + end + end +else + time = function(chunk, start) end +end + +local function save_profiles(threshold) + local sorted_times = {} + for chunk_name, time_taken in pairs(profile_info) do + sorted_times[#sorted_times + 1] = {chunk_name, time_taken} + end + table.sort(sorted_times, function(a, b) return a[2] > b[2] end) + local results = {} + for i, elem in ipairs(sorted_times) do + if not threshold or threshold and elem[2] > threshold then + results[i] = elem[1] .. ' took ' .. elem[2] .. 'ms' + end + end + if threshold then + table.insert(results, '(Only showing plugins that took longer than ' .. threshold .. ' ms ' .. 'to load)') + end + + _G._packer.profile_output = results +end + +time([[Luarocks path setup]], true) +local package_path_str = "/home/grimhilt/.cache/nvim/packer_hererocks/2.1.1693350652/share/lua/5.1/?.lua;/home/grimhilt/.cache/nvim/packer_hererocks/2.1.1693350652/share/lua/5.1/?/init.lua;/home/grimhilt/.cache/nvim/packer_hererocks/2.1.1693350652/lib/luarocks/rocks-5.1/?.lua;/home/grimhilt/.cache/nvim/packer_hererocks/2.1.1693350652/lib/luarocks/rocks-5.1/?/init.lua" +local install_cpath_pattern = "/home/grimhilt/.cache/nvim/packer_hererocks/2.1.1693350652/lib/lua/5.1/?.so" +if not string.find(package.path, package_path_str, 1, true) then + package.path = package.path .. ';' .. package_path_str +end + +if not string.find(package.cpath, install_cpath_pattern, 1, true) then + package.cpath = package.cpath .. ';' .. install_cpath_pattern +end + +time([[Luarocks path setup]], false) +time([[try_loadstring definition]], true) +local function try_loadstring(s, component, name) + local success, result = pcall(loadstring(s), name, _G.packer_plugins[name]) + if not success then + vim.schedule(function() + vim.api.nvim_notify('packer.nvim: Error running ' .. component .. ' for ' .. name .. ': ' .. result, vim.log.levels.ERROR, {}) + end) + end + return result +end + +time([[try_loadstring definition]], false) +time([[Defining packer_plugins]], true) +_G.packer_plugins = { + ["cmp-buffer"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/cmp-buffer", + url = "https://github.com/hrsh7th/cmp-buffer" + }, + ["cmp-nvim-lsp"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/cmp-nvim-lsp", + url = "https://github.com/hrsh7th/cmp-nvim-lsp" + }, + ["cmp-path"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/cmp-path", + url = "https://github.com/hrsh7th/cmp-path" + }, + ["coc.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/coc.nvim", + url = "https://github.com/neoclide/coc.nvim" + }, + harpoon = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/harpoon", + url = "https://github.com/theprimeagen/harpoon" + }, + ["mason-lspconfig.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/mason-lspconfig.nvim", + url = "https://github.com/williamboman/mason-lspconfig.nvim" + }, + ["mason.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/mason.nvim", + url = "https://github.com/williamboman/mason.nvim" + }, + ["nvim-autopairs"] = { + config = { "\27LJ\2\n@\0\0\3\0\3\0\a6\0\0\0'\2\1\0B\0\2\0029\0\2\0004\2\0\0B\0\2\1K\0\1\0\nsetup\19nvim-autopairs\frequire\0" }, + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/nvim-autopairs", + url = "https://github.com/windwp/nvim-autopairs" + }, + ["nvim-cmp"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/nvim-cmp", + url = "https://github.com/hrsh7th/nvim-cmp" + }, + ["nvim-lspconfig"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/nvim-lspconfig", + url = "https://github.com/neovim/nvim-lspconfig" + }, + ["nvim-treesitter"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/nvim-treesitter", + url = "https://github.com/nvim-treesitter/nvim-treesitter" + }, + ["onedark.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/onedark.nvim", + url = "https://github.com/navarasu/onedark.nvim" + }, + onehalf = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/onehalf", + url = "https://github.com/sonph/onehalf" + }, + ["packer.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/packer.nvim", + url = "https://github.com/wbthomason/packer.nvim" + }, + ["plenary.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/plenary.nvim", + url = "https://github.com/nvim-lua/plenary.nvim" + }, + ["telescope.nvim"] = { + loaded = true, + path = "/home/grimhilt/.local/share/nvim/site/pack/packer/start/telescope.nvim", + url = "https://github.com/nvim-telescope/telescope.nvim" + } +} + +time([[Defining packer_plugins]], false) +-- Config for: nvim-autopairs +time([[Config for nvim-autopairs]], true) +try_loadstring("\27LJ\2\n@\0\0\3\0\3\0\a6\0\0\0'\2\1\0B\0\2\0029\0\2\0004\2\0\0B\0\2\1K\0\1\0\nsetup\19nvim-autopairs\frequire\0", "config", "nvim-autopairs") +time([[Config for nvim-autopairs]], false) + +_G._packer.inside_compile = false +if _G._packer.needs_bufread == true then + vim.cmd("doautocmd BufRead") +end +_G._packer.needs_bufread = false + +if should_profile then save_profiles() end + +end) + +if not no_errors then + error_msg = error_msg:gsub('"', '\\"') + vim.api.nvim_command('echohl ErrorMsg | echom "Error in packer_compiled: '..error_msg..'" | echom "Please check your config for correctness" | echohl None') +end diff --git a/nvim/plugin_back/telescope.lua b/nvim/plugin_back/telescope.lua new file mode 100644 index 0000000..93a4dfb --- /dev/null +++ b/nvim/plugin_back/telescope.lua @@ -0,0 +1,4 @@ +local builtin = require('telescope.builtin') + +vim.keymap.set('n', 'pf', builtin.find_files, {noremap = true}) +vim.keymap.set('n', '', builtin.git_files, {noremap = true}) diff --git a/nvim/plugin_back/treesitter.lua b/nvim/plugin_back/treesitter.lua new file mode 100644 index 0000000..a8322c0 --- /dev/null +++ b/nvim/plugin_back/treesitter.lua @@ -0,0 +1,35 @@ +require'nvim-treesitter.configs'.setup { + -- A list of parser names, or "all" (the five listed parsers should always be installed) + ensure_installed = { "javascript", "typescript", "rust", "c", "lua", "vim", "vimdoc", "query" }, + + -- Install parsers synchronously (only applied to `ensure_installed`) + sync_install = false, + + -- Automatically install missing parsers when entering buffer + -- Recommendation: set to false if you don't have `tree-sitter` CLI installed locally + auto_install = true, + + highlight = { + enable = true, + + -- NOTE: these are the names of the parsers and not the filetype. (for example if you want to + -- disable highlighting for the `tex` filetype, you need to include `latex` in this list as this is + -- the name of the parser) + -- list of language that will be disabled + disable = { }, + -- Or use a function for more flexibility, e.g. to disable slow treesitter highlight for large files + disable = function(lang, buf) + local max_filesize = 100 * 1024 -- 100 KB + local ok, stats = pcall(vim.loop.fs_stat, vim.api.nvim_buf_get_name(buf)) + if ok and stats and stats.size > max_filesize then + return true + end + end, + + -- Setting this to true will run `:h syntax` and tree-sitter at the same time. + -- Set this to `true` if you depend on 'syntax' being enabled (like for indentation). + -- Using this option may slow down your editor, and you may see some duplicate highlights. + -- Instead of true it can also be a list of languages + additional_vim_regex_highlighting = false, + }, +}