diff --git a/.gitignore b/.gitignore
index 8cb205e..e033bc6 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1 +1 @@
-plugin
+lazy-lock.json
diff --git a/README.md b/README.md
index d904a21..e05e476 100644
--- a/README.md
+++ b/README.md
@@ -1,23 +1,15 @@
-## Screenshots
-
-
-
## Try out this config
This config requires >= [Neovim v0.9.0](https://github.com/neovim/neovim/releases).
Clone the repository into the correct location (make a backup your current `nvim` directory if you want to keep it).
+The following command makes it all automatically:
```
-git clone https://github.com/cuqmbr/nvim-config.git ~/.config/nvim
+cp -r ~/.config/nvim ~/.config/nvim_old && rm -rf ~/.cache/nvim ~/.local/share/nvim ~/.local/state/nvim ~/.config/nvim && git clone git@gitea.cuqmbr.xyz:cuqmbr/nvim-config.git ~/.config/nvim && echo 'cuqmbr's NeoVIM config installation completed successfuly' || echo 'Failed to install cuqmbr's NeoVIM config'
```
-Run `nvim` in your terminal and wait for the plugins to be installed. Reopen nvim
+Run `nvim` in your terminal and wait for the plugins to be installed. It should take less than a minute. Reopen nvim
**NOTE**: [Mason](https://github.com/williamboman/mason.nvim) is used to install and manage [LSP](https://microsoft.github.io/language-server-protocol/) servers, [DAP](https://microsoft.github.io/debug-adapter-protocol/) servers, [linters](https://en.wikipedia.org/wiki/Lint_(software)), and [formatters](https://en.wikipedia.org/wiki/Prettyprint) via the `:Mason` command.
@@ -33,23 +25,13 @@ Open `nvim` and enter the following:
:checkhealth
```
-If you noticed that you don't have support for copy/paste also that python and node haven't been setup follow advice:
-
-Copy/paste fix:
+If you noticed that you don't have support for copy/paste:
- On mac `pbcopy` should be builtin
-
- On GNU/Linux install [xsel](https://vergenet.net/~conrad/software/xsel/) or [wl-clipboard](https://github.com/bugaevc/wl-clipboard) for X11 or Wayland accordingly
-Python and node Neovim support:
+## Credits
- ```
- pip install pynvim
- ```
-
- ```
- npm i -g neovim
- ```
----
-
-**NOTE**: Make sure you have [node](https://nodejs.org/) and [python](https://www.python.org/) installed
+- [FixVim](https://github.com/Krator3/FixVim) - base configuration
+- [NeoVim From Scratch by LunarVim](https://github.com/LunarVim/Neovim-from-scratch) - Additional configuration pieces and a good learning experience
+- Documentation of all installed plugins - a lot of configs are default ones with minor tweaks
diff --git a/ftplugin/dart.lua b/ftplugin/dart.lua
deleted file mode 100644
index 10c1efc..0000000
--- a/ftplugin/dart.lua
+++ /dev/null
@@ -1,4 +0,0 @@
-vim.bo.tabstop = 2 -- size of a hard tabstop (ts).
-vim.bo.shiftwidth = 2 -- size of an indentation (sw).
-vim.bo.expandtab = true -- always uses spaces instead of tab characters (et).
-vim.bo.softtabstop = 2 -- number of spaces a counts for. When 0, feature is off (sts).
diff --git a/init.lua b/init.lua
index ccceb95..6f19c99 100644
--- a/init.lua
+++ b/init.lua
@@ -1,22 +1,25 @@
-require("user.options")
-require("user.keymaps")
-require("user.plugins")
-require("user.colorscheme")
-require("user.cmp")
-require("user.lsp")
-require("user.telescope")
-require("user.gitsigns")
-require("user.treesitter")
-require("user.autopairs")
-require("user.comment")
-require("user.nvim-tree")
-require("user.bufferline")
-require("user.lualine")
-require("user.toggleterm")
-require("user.project")
-require("user.impatient")
-require("user.indentline")
-require("user.alpha")
-require("user.whichkey")
-require("user.autocommands")
-require("user.dap")
+-- Базовая настройка
+require("core.plugins")
+require("core.color")
+require("core.config")
+require("core.autocmds")
+require("core.utils")
+require("core.ru_mappings")
+require("core.mappings")
+
+require("plugins.dashboard")
+require("plugins.neotree")
+require("plugins.gitsigns")
+require("plugins.mason")
+require("plugins.lsp")
+require("plugins.cmp")
+require("plugins.dap")
+require("plugins.treesitter")
+require("plugins.bufferline")
+require("plugins.lualine")
+require("plugins.autopairs")
+require("plugins.toggleterm")
+require("plugins.colortils")
+require("plugins.colorizer")
+require("plugins.comment")
+require("plugins.whichkey")
diff --git a/lua/.luarc.json b/lua/.luarc.json
deleted file mode 100644
index 23b9ee2..0000000
--- a/lua/.luarc.json
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- "workspace.checkThirdParty": false
-}
\ No newline at end of file
diff --git a/lua/core/autocmds.lua b/lua/core/autocmds.lua
new file mode 100644
index 0000000..e5ad469
--- /dev/null
+++ b/lua/core/autocmds.lua
@@ -0,0 +1,11 @@
+-- Удалять пустой буфер, который появляется после создания файла в Neotree и открытия любого файла
+vim.api.nvim_create_autocmd('BufHidden', {
+ desc = 'Delete [No Name] buffers',
+ callback = function(data)
+ if data.file == '' and vim.bo[data.buf].buftype == '' and not vim.bo[data.buf].modified then
+ vim.schedule(function()
+ pcall(vim.api.nvim_buf_delete, data.buf, {})
+ end)
+ end
+ end,
+})
diff --git a/lua/core/color.lua b/lua/core/color.lua
new file mode 100644
index 0000000..8c4c1ce
--- /dev/null
+++ b/lua/core/color.lua
@@ -0,0 +1,2 @@
+vim.opt.termguicolors = true -- Enable 24-bit RGB color in the TUI
+require("kanagawa").load("wave") -- Activate theme previously installed in lua/core/plugins
diff --git a/lua/core/config.lua b/lua/core/config.lua
new file mode 100644
index 0000000..c8178d6
--- /dev/null
+++ b/lua/core/config.lua
@@ -0,0 +1,50 @@
+local options = {
+ backup = false, -- creates a backup file
+ clipboard = "unnamedplus", -- allows neovim to access the system clipboard
+ cmdheight = 1, -- more space in the neovim command line for displaying messages
+ completeopt = { "menuone", "noselect" }, -- mostly just for cmp
+ conceallevel = 0, -- so that `` is visible in markdown files
+ fileencoding = "utf-8", -- the encoding written to a file
+ hlsearch = true, -- highlight all matches on previous search pattern
+ ignorecase = true, -- ignore case in search patterns
+ -- mouse = "a", -- allow the mouse to be used in neovim
+ pumheight = 10, -- pop up menu height
+ showmode = false, -- we don't need to see things like -- INSERT -- anymore
+ showtabline = 2, -- always show tabs
+ smartcase = true, -- smart case
+ smartindent = true, -- make indenting smarter again
+ splitbelow = true, -- force all horizontal splits to go below current window
+ splitright = true, -- force all vertical splits to go to the right of current window
+ swapfile = false, -- creates a swapfile
+ termguicolors = true, -- set term gui colors (most terminals support this)
+ timeoutlen = 300, -- time to wait for a mapped sequence to complete (in milliseconds)
+ undofile = true, -- enable ability to undo after closing and opening the same file
+ updatetime = 300, -- faster completion (4000ms default)
+ writebackup = false, -- if a file is being edited by another program (or was written to file while editing with another program), it is not allowed to be edited
+ expandtab = true, -- convert tabs to spaces
+ shiftwidth = 4, -- the number of spaces inserted for each indentation
+ tabstop = 4, -- insert 4 spaces for a tab
+ softtabstop = 4, -- number of spaces a counts for. When 0, feature is off (sts).
+ cursorline = true, -- highlight the current line
+ number = true, -- set numbered lines
+ relativenumber = true, -- set relative numbered lines
+ numberwidth = 4, -- set number column width to 2 {default 4}
+
+ signcolumn = "yes", -- always show the sign column, otherwise it would shift the text each time
+ wrap = true, -- display lines as one long line
+ linebreak = true, -- companion to wrap, don't split words
+ scrolloff = 8, -- minimal number of screen lines to keep above and below the cursor
+ sidescrolloff = 8, -- minimal number of screen columns either side of cursor if wrap is `false`
+ guifont = "monospace:h17", -- the font used in graphical neovim applications
+ whichwrap = "bs<>[]hl", -- which "horizontal" keys are allowed to travel to prev/next line
+}
+
+for k, v in pairs(options) do
+ vim.opt[k] = v
+end
+
+-- vim.opt.shortmess = "ilmnrx" -- flags to shorten vim messages, see :help 'shortmess'
+vim.opt.shortmess:append "c" -- don't give |ins-completion-menu| messages
+vim.opt.iskeyword:append "-" -- hyphenated words recognized by searches
+vim.opt.formatoptions:remove({ "c", "r", "o" }) -- don't insert the current comment leader automatically for auto-wrapping comments using 'textwidth', hitting in insert mode, or hitting 'o' or 'O' in normal mode.
+vim.opt.runtimepath:remove("/usr/share/vim/vimfiles") -- separate vim plugins from neovim in case vim still in use
diff --git a/lua/user/keymaps.lua b/lua/core/mappings.lua
similarity index 96%
rename from lua/user/keymaps.lua
rename to lua/core/mappings.lua
index bf36018..35b97b2 100644
--- a/lua/user/keymaps.lua
+++ b/lua/core/mappings.lua
@@ -1,7 +1,5 @@
local opts = { noremap = true, silent = true }
-local term_opts = { silent = true }
-
-- Shorten function name
local keymap = vim.keymap.set
@@ -40,7 +38,7 @@ keymap("n", "", ":m .+1==", opts)
keymap("n", "", ":m .-2==", opts)
-- Insert --
--- Press jk fast to exit insert mode
+-- Press jk fast to exit insert mode
keymap("i", "jk", "", opts)
keymap("i", "kj", "", opts)
diff --git a/lua/core/plugins.lua b/lua/core/plugins.lua
new file mode 100644
index 0000000..163dc90
--- /dev/null
+++ b/lua/core/plugins.lua
@@ -0,0 +1,125 @@
+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",
+ lazypath,
+ })
+end
+vim.opt.rtp:prepend(lazypath)
+
+require("lazy").setup {
+
+ -- Colorschemes
+ { "rebelot/kanagawa.nvim" },
+ { "Mofiqul/vscode.nvim" },
+
+ -- Create and explore menus of keybindings
+ {
+ "folke/which-key.nvim",
+ tag = "v1.6.0"
+ },
+
+ -- Fuzzy find everything and everywhere
+ {
+ "nvim-telescope/telescope.nvim",
+ tag = "v0.1.5",
+ dependencies = { "nvim-lua/plenary.nvim", "BurntSushi/ripgrep" }
+ },
+
+ -- Git integration for buffers
+ {
+ "lewis6991/gitsigns.nvim",
+ tag = "v0.7"
+ },
+
+ -- Better commenting
+ {
+ "numToStr/Comment.nvim",
+ tag = "v0.8.0"
+ },
+
+ -- LSP and DAP plugin manager. DO NOT change installation order of the following three plugins!
+ { "williamboman/mason.nvim" },
+ -- Integration with lspconfig
+ { "williamboman/mason-lspconfig.nvim" },
+ { "neovim/nvim-lspconfig" },
+ -- Integration wiht dap
+ { "mfussenegger/nvim-dap" },
+ { "rcarriga/nvim-dap-ui" },
+
+ -- Completion
+ { "hrsh7th/cmp-nvim-lsp" },
+ { "hrsh7th/cmp-buffer" },
+ { "hrsh7th/cmp-path" },
+ { "hrsh7th/cmp-cmdline" },
+ { "hrsh7th/cmp-nvim-lsp-signature-help" },
+ { "hrsh7th/nvim-cmp" },
+ -- vsnip and other snippet engines support
+ { "hrsh7th/cmp-vsnip" },
+ { "hrsh7th/vim-vsnip" },
+ { "hrsh7th/vim-vsnip-integ" },
+ { "rafamadriz/friendly-snippets" },
+
+ -- Manage terminal windows inside neovim
+ {
+ "akinsho/toggleterm.nvim",
+ version = "*",
+ config = true
+ },
+
+ -- Manage the file system and other tree like structures
+ {
+ "nvim-neo-tree/neo-tree.nvim",
+ branch = "v3.x",
+ dependencies = { "nvim-lua/plenary.nvim", "nvim-tree/nvim-web-devicons", "MunifTanjim/nui.nvim", }
+ },
+
+ -- Line at the top of the screen with all opened buffers
+ {
+ "akinsho/bufferline.nvim",
+ tag = "v4.5.0",
+ dependencies = "nvim-tree/nvim-web-devicons"
+ },
+
+ -- Line at the bottom of the screen with useful information about opened buffer
+ { "nvim-lualine/lualine.nvim",
+ dependencies = "nvim-tree/nvim-web-devicons"
+ },
+
+ { "nvimdev/dashboard-nvim",
+ event = "VimEnter",
+ dependencies = "nvim-tree/nvim-web-devicons"
+ },
+
+ -- Text highlighting
+ {
+ "nvim-treesitter/nvim-treesitter",
+ tag = "v0.9.2",
+ dependencies = "JoosepAlviste/nvim-ts-context-commentstring", build = ":TSUpdate"
+ },
+
+ -- Autopairs for different kind of brackets and other symbols
+ { "windwp/nvim-autopairs" },
+
+ -- Manipulations with colors
+ { "max397574/colortils.nvim",
+ cmd = "Colortils"
+ },
+
+ -- Highlight colorcodes
+ { "NvChad/nvim-colorizer.lua" },
+
+ -- Preview markdown
+ {
+ "iamcco/markdown-preview.nvim",
+ cmd = { "MarkdownPreviewToggle", "MarkdownPreview", "MarkdownPreviewStop" },
+ ft = { "markdown" },
+ build = function() vim.fn["mkdp#util#install"]() end
+ },
+
+ { "folke/neodev.nvim" },
+}
diff --git a/lua/core/ru_mappings.lua b/lua/core/ru_mappings.lua
new file mode 100644
index 0000000..cd13e3b
--- /dev/null
+++ b/lua/core/ru_mappings.lua
@@ -0,0 +1,131 @@
+--[[
+буква(ы) = Space (пробел)
+ = = Meta (Alt) (также можно исп. вместо )
+ = Ctrl
+ или = Shift (русские буквы писать заглавной и без <>)
+ = Meta eсли ≠ Alt
+ = Super (Win)
+--]]
+
+-- Для исп. нескольких символов в комбинации клавиш можно исп. только (остальные не сработают)
+-- Для того, чтобы исп. shift и ещё какой-то модификатор, букву нужно писать заглавной
+-- Учтите, что клавишы, назначенные системой, будут главнее => сработает системная комбинация вместо установленной здесь
+-- Русские сочетания клавиш добавляются здесь (для сохранения удобной структуры), хотя никто не запрещает создавать их в lua/core/mappings.lua
+
+vim.keymap.set("n", "", ":w") -- Сохранить файл
+vim.keymap.set("n", "", ":q") -- Закрыть Neovim
+
+-- Normal mode
+vim.keymap.set("i", "оо", "")
+
+-- Command mode
+vim.keymap.set("n", "Ж", ":")
+
+-- Insert mode
+vim.keymap.set("n", "ф", "a")
+vim.keymap.set("n", "Ф", "A")
+vim.keymap.set("n", "щ", "o")
+vim.keymap.set("n", "Щ", "O")
+vim.keymap.set("n", "ш", "i")
+vim.keymap.set("n", "Ш", "I")
+vim.keymap.set("v", "с", "c")
+
+-- Перемещение влево
+vim.keymap.set("n", "р", "h")
+vim.keymap.set("v", "р", "h")
+
+-- Перемещение вниз
+vim.keymap.set("n", "о", "j")
+vim.keymap.set("v", "о", "j")
+
+-- Перемещение вверх
+vim.keymap.set("n", "л", "k")
+vim.keymap.set("v", "л", "k")
+
+-- Перемещение вправо
+vim.keymap.set("n", "д", "l")
+vim.keymap.set("v", "д", "l")
+
+-- Удаление
+vim.keymap.set("n", "в", "d")
+vim.keymap.set("v", "в", "d")
+vim.keymap.set("n", "вв", "dd")
+vim.keymap.set("n", "ч", "x")
+
+-- Вставка
+vim.keymap.set("n", "з", "p")
+vim.keymap.set("n", "З", "P")
+vim.keymap.set("v", "з", "p")
+vim.keymap.set("v", "З", "P")
+
+-- Отмена действия
+vim.keymap.set("n", "г", "u")
+
+-- Копирование
+vim.keymap.set("n", "нн", "yy")
+vim.keymap.set("n", "н", "y")
+vim.keymap.set("v", "н", "yy")
+
+-- Замена replace
+vim.keymap.set("n", "к", "r")
+
+-- Работа с вкладками (буферами)
+vim.keymap.set("n", "ч", ":BufferLineSortByTabs:BufferLineCloseRight") -- Закрытие всех буферов
+vim.keymap.set("n", "Ч", ":BufferLinePickClose") -- Закрытие одного буфера
+vim.api.nvim_set_keymap("n", "", ":lua _G.close_and_go_right()", { noremap = true, silent = true }) -- подробнее в lua/core/utils.lua
+vim.keymap.set("n", "", ":BufferLineMoveNext") -- переместить вкладку вперед
+vim.keymap.set("n", "", ":BufferLineMovePrev") -- переместить вкладку назад
+
+-- Выделение
+vim.keymap.set("n", "м", "v")
+vim.keymap.set("v", "м", "v")
+vim.keymap.set("n", "М", "V")
+vim.keymap.set("v", "М", "V")
+
+-- Файловый менеджер
+vim.keymap.set("n", "", ":Neotree toggle float") -- Открыть/Закрыть файловое дерево в плавающем режиме
+vim.keymap.set("n", "", ":Neotree toggle left") -- -- Открыть/Закрыть файловое дерево слева сбоку
+-- vim.keymap.set("n", "", ":Neotree toggle") -- Открыть/Закрыть файловое дерево (используется последний активный режим)
+vim.keymap.set("n", "ы", ":Neotree show reveal") -- Показать файл в дереве (не работает в плавающем режиме)
+
+-- Навигация
+vim.keymap.set("n", "", ":wincmd k") -- Переключиться на верхнее окно
+vim.keymap.set("n", "", ":wincmd j") -- Переключиться на нижнее окно
+vim.keymap.set("n", "", ":wincmd h") -- Переключиться на левое окно
+vim.keymap.set("n", "", ":wincmd l") -- Переключиться на правое окно
+
+-- В начало и конец файла
+vim.keymap.set("n", "пп", "gg")
+vim.keymap.set("v", "пп", "gg")
+vim.keymap.set("n", "П", "G")
+vim.keymap.set("v", "П", "G")
+
+--[[ Если строка визуально разбита на несколько строк, то курсор перепрыгнет через них, так как считает, что это одна строка
+При помощи настройки ниже курсор будет перемещаться по ним будто это разные строки --]]
+vim.keymap.set('n', 'о', "v:count == 0 ? 'gj' : 'j'", {
+ expr = true,
+})
+vim.keymap.set('n', 'л', "v:count == 0 ? 'gk' : 'k'", {
+ expr = true,
+})
+
+
+-- Терминал
+vim.keymap.set("n", "", ":ToggleTerm direction=float") -- Открыть терминал в плавающем режиме
+
+vim.keymap.set("n", "Е", function() require("trouble").toggle() end) -- Открыть/Закрыть список проблем (расширение )
+
+--[[
+Включить/Выключить подсветку Treesitter, то есть исп. подсветку от Treesitter или встроенную от LSP
+Подсветка от Treesitter выдаёт более качественную подсветку по сравнению с LSP, но может замедлять работу Neovim в больших файлах
+Благодаря этому хоткею можно переключаться между ними в зависимости от потребностей и личных приоритетов
+--]]
+vim.keymap.set("n", "",
+ function() if vim.b.ts_highlight then vim.treesitter.stop() else vim.treesitter.start() end end,
+ { desc = "Toggle Treesitter Highlight" })
+
+
+vim.keymap.set("n", "се", ":ColorizerToggle") -- Включить/Отключить подсветку цветовых кодов
+
+vim.keymap.set("n", "", ":m+1") -- Переместить строку под курсором на одну строку вниз
+vim.keymap.set("n", "", ":m-2") -- Переместить строку под курсором на одну строку вверх
diff --git a/lua/core/utils.lua b/lua/core/utils.lua
new file mode 100644
index 0000000..1584ef3
--- /dev/null
+++ b/lua/core/utils.lua
@@ -0,0 +1,29 @@
+-- Функция для правильного и более удобного (функционального) закрытия буфера
+_G.close_and_go_right = function()
+ local current_buf = vim.api.nvim_get_current_buf()
+ local buf_list = vim.fn.getbufinfo({ buflisted = 1 })
+
+ -- Если только один буфер, ничего не делаем
+ if #buf_list == 1 then
+ return
+ end
+
+ -- Находим следующий или предыдущий буфер
+ local next_bufnr
+ for i, buf in ipairs(buf_list) do
+ if buf.bufnr == current_buf then
+ if i == #buf_list then
+ -- Если текущий буфер последний, идем к предыдущему
+ next_bufnr = buf_list[i - 1].bufnr
+ else
+ -- Иначе идем к следующему
+ next_bufnr = buf_list[i % #buf_list + 1].bufnr
+ end
+ break
+ end
+ end
+
+ -- Переходим к выбранному буферу и закрываем текущий
+ vim.cmd("buffer " .. next_bufnr)
+ vim.cmd("bdelete! " .. current_buf)
+end
diff --git a/lua/plugins/autopairs.lua b/lua/plugins/autopairs.lua
new file mode 100644
index 0000000..ba62d44
--- /dev/null
+++ b/lua/plugins/autopairs.lua
@@ -0,0 +1 @@
+require("nvim-autopairs").setup {}
diff --git a/lua/plugins/bufferline.lua b/lua/plugins/bufferline.lua
new file mode 100644
index 0000000..90b1367
--- /dev/null
+++ b/lua/plugins/bufferline.lua
@@ -0,0 +1,103 @@
+-- The following option is required for bufferline to work correctly (already activated in lua/core/color.lua)
+-- vim.opt.termguicolors = true
+local bufferline = require('bufferline')
+bufferline.setup {
+ options = {
+ mode = "buffers", -- set to "tabs" to only show tabpages instead
+ style_preset = bufferline.style_preset.default, -- or bufferline.style_preset.minimal,
+ themable = true, -- allows highlight groups to be overriden i.e. sets highlights as default
+ numbers = "ordinal",
+ close_command = "bdelete! %d", -- can be a string | function, | false see "Mouse actions"
+ right_mouse_command = "bdelete! %d", -- can be a string | function | false, see "Mouse actions"
+ left_mouse_command = "buffer %d", -- can be a string | function, | false see "Mouse actions"
+ middle_mouse_command = nil, -- can be a string | function, | false see "Mouse actions"
+ indicator = {
+ icon = '▎', -- this should be omitted if indicator style is not 'icon'
+ style = 'icon',
+ },
+ buffer_close_icon = '',
+ modified_icon = '●',
+ close_icon = '',
+ left_trunc_marker = '',
+ right_trunc_marker = '',
+ --- name_formatter can be used to change the buffer's label in the bufferline.
+ --- Please note some names can/will break the
+ --- bufferline so use this at your discretion knowing that it has
+ --- some limitations that will *NOT* be fixed.
+ name_formatter = function(buf) -- buf contains:
+ -- name | str | the basename of the active file
+ -- path | str | the full path of the active file
+ -- bufnr (buffer only) | int | the number of the active buffer
+ -- buffers (tabs only) | table(int) | the numbers of the buffers in the tab
+ -- tabnr (tabs only) | int | the "handle" of the tab, can be converted to its ordinal number using: `vim.api.nvim_tabpage_get_number(buf.tabnr)`
+ end,
+ max_name_length = 15,
+ max_prefix_length = 6, -- prefix used when a buffer is de-duplicated
+ truncate_names = true, -- whether or not tab names should be truncated
+ tab_size = 15,
+ diagnostics = false,
+ diagnostics_update_in_insert = false,
+ -- The diagnostics indicator can be set to nil to keep the buffer name highlight but delete the highlighting
+ diagnostics_indicator = function(count, level, diagnostics_dict, context)
+ return "(" .. count .. ")"
+ end,
+ -- NOTE: this will be called a lot so don't do any heavy processing here
+ custom_filter = function(buf_number, buf_numbers)
+ -- filter out filetypes you don't want to see
+ if vim.bo[buf_number].filetype ~= "" then
+ return true
+ end
+ -- filter out by buffer name
+ if vim.fn.bufname(buf_number) ~= "" then
+ return true
+ end
+ -- filter out based on arbitrary rules
+ -- e.g. filter out vim wiki buffer from tabline in your work repo
+ if vim.fn.getcwd() == "" and vim.bo[buf_number].filetype ~= "wiki" then
+ return true
+ end
+ -- filter out by it's index number in list (don't show first buffer)
+ if buf_numbers[1] ~= buf_number then
+ return true
+ end
+ end,
+ offsets = {
+ {
+ filetype = "neo-tree",
+ text = "File Tree",
+ text_align = "center",
+ separator = false
+ }
+ },
+ color_icons = true, -- whether or not to add the filetype icon highlights
+ get_element_icon = function(element)
+ -- element consists of {filetype: string, path: string, extension: string, directory: string}
+ -- This can be used to change how bufferline fetches the icon
+ -- for an element e.g. a buffer or a tab.
+ -- e.g.
+ local icon, hl = require('nvim-web-devicons').get_icon_by_filetype(element.filetype, { default = false })
+ return icon, hl
+ -- or
+ -- local custom_map = {my_thing_ft: {icon = "my_thing_icon", hl}}
+ -- return custom_map[element.filetype]
+ end,
+ show_buffer_icons = true, -- disable filetype icons for buffers
+ show_buffer_close_icons = false,
+ show_close_icon = false,
+ show_tab_indicators = true,
+ show_duplicate_prefix = true, -- whether to show duplicate buffer prefix
+ persist_buffer_sort = true, -- whether or not custom sorted buffers should persist
+ move_wraps_at_ends = false, -- whether or not the move command "wraps" at the first or last position
+ -- can also be a table containing 2 custom separators
+ -- [focused and unfocused]. eg: { '|', '|' }
+ separator_style = "thin",
+ enforce_regular_tabs = false,
+ always_show_bufferline = true,
+ hover = {
+ enabled = true,
+ delay = 200,
+ reveal = { 'close' }
+ },
+ sort_by = 'insert_after_current'
+ }
+}
diff --git a/lua/plugins/cmp.lua b/lua/plugins/cmp.lua
new file mode 100644
index 0000000..c662e95
--- /dev/null
+++ b/lua/plugins/cmp.lua
@@ -0,0 +1,105 @@
+local cmp = require("cmp")
+
+cmp.setup {
+ snippet = {
+ expand = function(args)
+ vim.fn["vsnip#anonymous"](args.body)
+ end,
+ },
+
+ window = {
+ completion = {
+ border = { "╭", "─", "╮", "│", "╯", "─", "╰", "│" },
+ },
+ documentation = {
+ border = { "╭", "─", "╮", "│", "╯", "─", "╰", "│" },
+ },
+ },
+
+ -- window = {
+ -- completion = cmp.config.window.bordered(),
+ -- documentation = cmp.config.window.bordered(),
+ -- },
+
+ mapping = cmp.mapping.preset.insert({
+ [""] = cmp.mapping.select_prev_item(),
+ [""] = cmp.mapping.select_next_item(),
+ [""] = cmp.mapping(cmp.mapping.scroll_docs(-1), { "i", "c" }),
+ [""] = cmp.mapping(cmp.mapping.scroll_docs(1), { "i", "c" }),
+ [""] = cmp.mapping(cmp.mapping.complete(), { "i", "c" }),
+ [""] = cmp.config.disable, -- Specify `cmp.config.disable` if you want to remove the default `` mapping.
+ [""] = cmp.mapping {
+ i = cmp.mapping.abort(),
+ c = cmp.mapping.close(),
+ },
+ -- Accept currently selected item. If none selected, `select` first item.
+ -- Set `select` to `false` to only confirm explicitly selected items.
+ [""] = cmp.mapping.confirm { select = false },
+ [""] = cmp.mapping(function(fallback)
+ if cmp.visible() then
+ cmp.select_next_item()
+ else
+ fallback()
+ end
+ end, { "i", "s" }),
+ [""] = cmp.mapping(function(fallback)
+ if cmp.visible() then
+ cmp.select_prev_item()
+ else
+ fallback()
+ end
+ end, { "i", "s" })
+ }),
+
+ sources = cmp.config.sources(
+ {
+ { name = 'nvim_lsp' },
+ { name = 'nvim_lsp_signature_help' },
+ { name = 'vsnip' },
+ { name = 'nvim_lua' },
+ { name = 'path' },
+ { name = 'buffer' },
+ }
+ ),
+
+ experimental = {
+ ghost_text = false,
+ native_menu = false,
+ },
+}
+
+-- Setup configuration for a specific type of file
+cmp.setup.filetype('gitcommit', {
+ sources = cmp.config.sources({
+ { name = 'git' },
+ }, {
+ { name = 'buffer' },
+ })
+})
+
+-- Использовать источник буфера для `/` и `?` (если вы включили `native_menu`, это больше не будет работать)
+cmp.setup.cmdline({ '/', '?' }, {
+ mapping = cmp.mapping.preset.cmdline(),
+ sources = { { name = 'buffer' } }
+})
+
+-- Используйте cmdline и источник пути для ':' (если вы включили `native_menu`, это больше не будет работать)
+cmp.setup.cmdline(':', {
+ mapping = cmp.mapping.preset.cmdline(),
+ sources = cmp.config.sources({ { name = 'path' } }, { { name = 'cmdline' } })
+})
+
+-- Настройка конфига LSP
+local capabilities = require('cmp_nvim_lsp').default_capabilities()
+-- Замените на нужный lsp-сервер (для каждого нужно создавать отдельный параметр)
+-- require('lspconfig')[''].setup {capabilities = capabilities}
+require('lspconfig')['pyright'].setup { capabilities = capabilities }
+
+
+
+-- Подстановка скобок к подсказкам, которым это нужно (дополнение для nvim-autopairs)
+local cmp_autopairs = require('nvim-autopairs.completion.cmp')
+cmp.event:on(
+ 'confirm_done',
+ cmp_autopairs.on_confirm_done()
+)
diff --git a/lua/plugins/colorizer.lua b/lua/plugins/colorizer.lua
new file mode 100644
index 0000000..4b8f34c
--- /dev/null
+++ b/lua/plugins/colorizer.lua
@@ -0,0 +1,17 @@
+require("colorizer").setup {
+ filetypes = { "*" },
+ user_default_options = {
+ RGB = true, -- #RGB hex codes
+ RRGGBB = true, -- #RRGGBB hex codes
+ names = true, -- "Name" codes like Blue
+ RRGGBBAA = false, -- #RRGGBBAA hex codes
+ rgb_fn = false, -- CSS rgb() and rgba() functions
+ hsl_fn = false, -- CSS hsl() and hsla() functions
+ css = false, -- Enable all CSS features: rgb_fn, hsl_fn, names, RGB, RRGGBB
+ css_fn = false, -- Enable all CSS *functions*: rgb_fn, hsl_fn
+ -- Available modes: foreground, background
+ mode = 'background', -- Set the display mode.
+ },
+ -- Все дополнительные параметры типов файлов применяются к типам буферов
+ buftypes = {},
+}
diff --git a/lua/plugins/colortils.lua b/lua/plugins/colortils.lua
new file mode 100644
index 0000000..e9bae65
--- /dev/null
+++ b/lua/plugins/colortils.lua
@@ -0,0 +1,57 @@
+require("colortils").setup {
+ -- Register in which color codes will be copied
+ register = "+",
+ -- Preview for colors, if it contains `%s` this will be replaced with a hex color code of the color
+ color_preview = "█ %s",
+ -- The default in which colors should be saved
+ -- This can be hex, hsl or rgb
+ default_format = "hex",
+ -- Border for the float
+ border = "rounded",
+ -- Some mappings which are used inside the tools
+ mappings = {
+ -- increment values
+ increment = "l",
+ -- decrement values
+ decrement = "h",
+ -- increment values with bigger steps
+ increment_big = "L",
+ -- decrement values with bigger steps
+ decrement_big = "H",
+ -- set values to the minimum
+ min_value = "0",
+ -- set values to the maximum
+ max_value = "$",
+ -- save the current color in the register specified above with the format specified above
+ set_register_default_format = "",
+ -- save the current color in the register specified above with a format you can choose
+ set_register_cjoose_format = "g",
+ -- replace the color under the cursor with the current color in the format specified above
+ replace_default_format = "",
+ -- replace the color under the cursor with the current color in a format you can choose
+ replace_choose_format = "g",
+ -- export the current color to a different tool
+ export = "E",
+ -- set the value to a certain number (done by just entering numbers)
+ set_value = "c",
+ -- toggle transparency
+ transparency = "T",
+ -- choose the background (for transparent colors)
+ choose_background = "B",
+ }
+}
+
+--[[
+
+You can use the different tools with commands. Those take the format Colortils . The color can be any of the supported formats. Notice that symbols like #, % and space need to be escaped like e.g. this \#FF00AB.
+
+If no valid color is provided as argument the color under the cursor (if available) will be used. If there isn't any found the user will be asked for input (notice that you don't need to escape characters there).
+
+:Colortils picker
+:Colortils lighten
+:Colortils darken
+:Colortils greyscale
+:Colortils gradient
+:Colortils css list
+
+--]]
diff --git a/lua/plugins/comment.lua b/lua/plugins/comment.lua
new file mode 100644
index 0000000..282482d
--- /dev/null
+++ b/lua/plugins/comment.lua
@@ -0,0 +1,45 @@
+local comment = require("Comment")
+
+comment.setup {
+ ---Add a space b/w comment and the line
+ padding = true,
+ ---Whether the cursor should stay at its position
+ sticky = true,
+ ---Lines to be ignored while (un)comment
+ ignore = nil,
+ ---LHS of toggle mappings in NORMAL mode
+ toggler = {
+ ---Line-comment toggle keymap
+ line = 'gcc',
+ ---Block-comment toggle keymap
+ block = 'gbc',
+ },
+ ---LHS of operator-pending mappings in NORMAL and VISUAL mode
+ opleader = {
+ ---Line-comment keymap
+ line = 'gc',
+ ---Block-comment keymap
+ block = 'gb',
+ },
+ ---LHS of extra mappings
+ extra = {
+ ---Add comment on the line above
+ above = 'gcO',
+ ---Add comment on the line below
+ below = 'gco',
+ ---Add comment at the end of line
+ eol = 'gcA',
+ },
+ ---Enable keybindings
+ ---NOTE: If given `false` then the plugin won't create any mappings
+ mappings = {
+ ---Operator-pending mapping; `gcc` `gbc` `gc[count]{motion}` `gb[count]{motion}`
+ basic = true,
+ ---Extra mapping; `gco`, `gcO`, `gcA`
+ extra = true,
+ },
+ ---Function to call before (un)comment
+ pre_hook = require('ts_context_commentstring.integrations.comment_nvim').create_pre_hook(),
+ ---Function to call after (un)comment
+ post_hook = nil,
+}
diff --git a/lua/plugins/dap.lua b/lua/plugins/dap.lua
new file mode 100644
index 0000000..e4a13d2
--- /dev/null
+++ b/lua/plugins/dap.lua
@@ -0,0 +1,51 @@
+local dap = require("dap")
+
+-- dotnet
+
+dap.adapters.coreclr = {
+ type = "executable",
+ command = "netcoredbg",
+ args = { "--interpreter=vscode" }
+}
+
+dap.configurations.cs = {
+ {
+ type = "coreclr",
+ name = "launch - netcoredbg",
+ request = "launch",
+ program = function()
+ return vim.fn.input("Path to dll: ", vim.fn.getcwd(), "file")
+ end,
+ },
+}
+
+-- DapUI
+
+local dapui = require("dapui")
+
+dapui.setup()
+
+-- Open and close windows automatically on certain events from DAP
+dap.listeners.before.attach.dapui_config = function()
+ dapui.open()
+end
+dap.listeners.before.launch.dapui_config = function()
+ dapui.open()
+end
+dap.listeners.before.event_terminated.dapui_config = function()
+ dapui.close()
+end
+dap.listeners.before.event_exited.dapui_config = function()
+ dapui.close()
+end
+
+-- Keymaps
+vim.keymap.set("n", "", ":lua require('dap').continue()")
+vim.keymap.set("n", "", ":lua require('dap').step_over()")
+vim.keymap.set("n", "", ":lua require('dap').step_into()")
+vim.keymap.set("n", "", ":lua require('dap').step_out()")
+vim.keymap.set("n", "db", ":lua require('dap').toggle_breakpoint()")
+vim.keymap.set("n", "dB", ":lua require('dap').set_breakpoint(vim.fn.input('Breakpoint condition: '))")
+-- vim.keymap.set("n", "lp", ":lua require('dap').set_breakpoint(nil, nil, vim.fn.input('Log point message: '))")
+-- vim.keymap.set("n", "dr", ":lua require('dap').repl.open()")
+-- vim.keymap.set("n", "dl", ":lua require('dap').run_last()")
diff --git a/lua/plugins/dashboard.lua b/lua/plugins/dashboard.lua
new file mode 100644
index 0000000..57c5e37
--- /dev/null
+++ b/lua/plugins/dashboard.lua
@@ -0,0 +1,68 @@
+local function default_header()
+ return {
+ "",
+ "",
+ "",
+
+ " ) (",
+ " ( ) )",
+ " ) ( (",
+ " mrf_______)_",
+ " .-'---------|",
+ "( C|/\\/\\/\\/\\/|",
+ " '-./\\/\\/\\/\\/|",
+ " '_________'",
+ " '-------'",
+
+ "",
+ "",
+ "",
+ }
+end
+require("dashboard").setup {
+ theme = "doom",
+ config = {
+ header = default_header(),
+ center = {
+ {
+ icon = " ",
+ icon_hl = "Title",
+ desc = "Open tree",
+ desc_hl = "String",
+ key = "o",
+ key_hl = "Number",
+ action = ":Neotree float",
+ },
+
+ {
+ icon = " ",
+ icon_hl = "Title",
+ desc = "New file",
+ desc_hl = "String",
+ key = "n",
+ key_hl = "Number",
+ action = ":ene",
+ },
+
+ {
+ icon = " ",
+ icon_hl = "Title",
+ desc = "Lazy",
+ desc_hl = "String",
+ key = "l",
+ key_hl = "Number",
+ action = ":Lazy",
+ },
+
+ {
+ icon = "⏻ ",
+ icon_hl = "Title",
+ desc = "Quit Neovim",
+ desc_hl = "String",
+ key = "q",
+ key_hl = "Number",
+ action = ":q",
+ },
+ },
+ },
+}
diff --git a/lua/plugins/gitsigns.lua b/lua/plugins/gitsigns.lua
new file mode 100644
index 0000000..d0bd650
--- /dev/null
+++ b/lua/plugins/gitsigns.lua
@@ -0,0 +1,45 @@
+local gitsigns = require("gitsigns")
+
+gitsigns.setup {
+ signs = {
+ add = { text = '│' },
+ change = { text = '│' },
+ delete = { text = '_' },
+ topdelete = { text = '‾' },
+ changedelete = { text = '~' },
+ untracked = { text = '┆' },
+ },
+ signcolumn = true, -- Toggle with `:Gitsigns toggle_signs`
+ numhl = false, -- Toggle with `:Gitsigns toggle_numhl`
+ linehl = false, -- Toggle with `:Gitsigns toggle_linehl`
+ word_diff = false, -- Toggle with `:Gitsigns toggle_word_diff`
+ watch_gitdir = {
+ follow_files = true
+ },
+ auto_attach = true,
+ attach_to_untracked = false,
+ current_line_blame = false, -- Toggle with `:Gitsigns toggle_current_line_blame`
+ current_line_blame_opts = {
+ virt_text = true,
+ virt_text_pos = 'eol', -- 'eol' | 'overlay' | 'right_align'
+ delay = 1000,
+ ignore_whitespace = false,
+ virt_text_priority = 100,
+ },
+ current_line_blame_formatter = ', - ',
+ sign_priority = 6,
+ update_debounce = 100,
+ status_formatter = nil, -- Use default
+ max_file_length = 40000, -- Disable if file is longer than this (in lines)
+ preview_config = {
+ -- Options passed to nvim_open_win
+ border = 'single',
+ style = 'minimal',
+ relative = 'cursor',
+ row = 0,
+ col = 1
+ },
+ yadm = {
+ enable = false
+ },
+}
diff --git a/lua/plugins/lsp.lua b/lua/plugins/lsp.lua
new file mode 100644
index 0000000..0b16c89
--- /dev/null
+++ b/lua/plugins/lsp.lua
@@ -0,0 +1,58 @@
+-- nvim-cmp supports LSP capabilities so set it as default LSP engine
+local capabilities = vim.lsp.protocol.make_client_capabilities()
+capabilities = require('cmp_nvim_lsp').default_capabilities(capabilities)
+
+
+-- LSP setup for different programming languages
+local lspconfig = require('lspconfig')
+local lsputil = require('lspconfig/util')
+
+lspconfig.omnisharp.setup {}
+
+-- lua_ls LSP setup via Neodev extension which provides additional functionality
+require("neodev").setup()
+lspconfig.lua_ls.setup {
+ settings = {
+ Lua = {
+ completion = {
+ callSnippet = "Replace"
+ }
+ }
+ }
+}
+
+-- Global mappings.
+-- See `:help vim.diagnostic.*` for documentation on any of the below functions
+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)
+
+-- Use LspAttach autocommand to only map the following keys
+-- after the language server attaches to the current buffer
+vim.api.nvim_create_autocmd('LspAttach', {
+ group = vim.api.nvim_create_augroup('UserLspConfig', {}),
+ callback = function(ev)
+ -- Enable completion triggered by
+ vim.bo[ev.buf].omnifunc = 'v:lua.vim.lsp.omnifunc'
+
+ -- Buffer local mappings.
+ -- See `:help vim.lsp.*` for documentation on any of the below functions
+ local opts = { buffer = ev.buf }
+ vim.keymap.set("n", "gD", "lua vim.lsp.buf.declaration()", opts)
+ vim.keymap.set("n", "gd", "lua vim.lsp.buf.definition()", opts)
+ vim.keymap.set("n", "K", "lua vim.lsp.buf.hover()", opts)
+ vim.keymap.set("n", "gI", "lua vim.lsp.buf.implementation()", opts)
+ vim.keymap.set("n", "gr", "lua vim.lsp.buf.references()", opts)
+ vim.keymap.set("n", "gl", "lua vim.diagnostic.open_float()", opts)
+ vim.keymap.set("n", "lf", "lua vim.lsp.buf.format{ async = true }", opts)
+ vim.keymap.set("n", "li", "LspInfo", opts)
+ vim.keymap.set("n", "lI", "LspInstallInfo", opts)
+ vim.keymap.set("n", "la", "lua vim.lsp.buf.code_action()", opts)
+ vim.keymap.set("n", "lj", "lua vim.diagnostic.goto_next({buffer=0})", opts)
+ vim.keymap.set("n", "lk", "lua vim.diagnostic.goto_prev({buffer=0})", opts)
+ vim.keymap.set("n", "lr", "lua vim.lsp.buf.rename()", opts)
+ vim.keymap.set("n", "ls", "lua vim.lsp.buf.signature_help()", opts)
+ vim.keymap.set("n", "lq", "lua vim.diagnostic.setloclist()", opts)
+ end,
+})
diff --git a/lua/plugins/lualine.lua b/lua/plugins/lualine.lua
new file mode 100644
index 0000000..cc917b5
--- /dev/null
+++ b/lua/plugins/lualine.lua
@@ -0,0 +1,86 @@
+require("lualine").setup {
+ options = {
+ icons_enabled = true,
+ theme = "auto",
+ component_separators = { left = "", right = "|" },
+ section_separators = { left = "", right = "" },
+ disabled_filetypes = {
+ statusline = { "neo-tree" },
+ winbar = {},
+ },
+ ignore_focus = {},
+ always_divide_middle = true,
+ globalstatus = false,
+ refresh = {
+ statusline = 1000,
+ tabline = 1000,
+ winbar = 1000,
+ }
+ },
+
+ --[[
+ Lualine has sections as shown below
+ +-------------------------------------------------+
+ | A | B | C X | Y | Z |
+ +-------------------------------------------------+
+ --]]
+
+ sections = {
+ lualine_a = { "mode" },
+ lualine_b = { "branch", "diff" },
+ lualine_c = {
+ { "filename", path = 1 },
+ {
+ "diagnostics",
+ sources = { "nvim_diagnostic", "nvim_lsp" },
+ sections = { "error", "warn", "info", "hint" },
+ diagnostics_color = {
+ error = "DiagnosticError",
+ warn = "DiagnosticWarn",
+ info = "DiagnosticInfo",
+ hint = "DiagnosticHint",
+ },
+ symbols = { error = " ", warn = " ", info = "", hint = " " },
+ colored = true,
+ update_in_insert = true,
+ always_visible = false,
+ }
+ },
+ lualine_x = { "filetype", "encoding", "fileformat", "filesize" },
+ lualine_y = { "progress" },
+ lualine_z = { "location" }
+ },
+ inactive_sections = {
+ lualine_a = {},
+ lualine_b = {},
+ lualine_c = { { "filename", path = 3 } },
+ lualine_x = { "filetype", "encoding", "fileformat", "filesize" },
+ lualine_y = {},
+ lualine_z = {},
+ },
+ tabline = {},
+ winbar = {},
+ inactive_winbar = {},
+ extensions = {}
+}
+
+--[[
+Available components
+ - branch (git branch)
+ - buffers (shows currently available buffers)
+ - diagnostics (diagnostics count from your preferred source)
+ - diff (git diff status)
+ - encoding (file encoding)
+ - fileformat (file format)
+ - filename
+ - filesize
+ - filetype
+ - hostname
+ - location (location in file in line:column format)
+ - mode (vim mode)
+ - progress (%progress in file)
+ - searchcount (number of search matches when hlsearch is active)
+ - selectioncount (number of selected characters or lines)
+ - tabs (shows currently available tabs)
+ - windows (shows currently available windows)
+--]]
diff --git a/lua/plugins/mason.lua b/lua/plugins/mason.lua
new file mode 100644
index 0000000..8692e4f
--- /dev/null
+++ b/lua/plugins/mason.lua
@@ -0,0 +1,129 @@
+require("mason").setup {
+ -- The directory in which to install packages.
+ -- install_root_dir = path.concat { vim.fn.stdpath "data", "mason" },
+
+ -- Where Mason should put its bin location in your PATH. Can be one of:
+ -- - "prepend" (default, Mason's bin location is put first in PATH)
+ -- - "append" (Mason's bin location is put at the end of PATH)
+ -- - "skip" (doesn't modify PATH)
+ ---@type '"prepend"' | '"append"' | '"skip"'
+ PATH = "prepend",
+
+ -- Controls to which degree logs are written to the log file. It's useful to set this to vim.log.levels.DEBUG when
+ -- debugging issues with package installations.
+ log_level = vim.log.levels.INFO,
+
+ -- Limit for the maximum amount of packages to be installed at the same time. Once this limit is reached, any further
+ -- packages that are requested to be installed will be put in a queue.
+ max_concurrent_installers = 4,
+
+ -- [Advanced setting]
+ -- The registries to source packages from. Accepts multiple entries. Should a package with the same name exist in
+ -- multiple registries, the registry listed first will be used.
+ registries = {
+ "github:mason-org/mason-registry",
+ },
+
+ -- The provider implementations to use for resolving supplementary package metadata (e.g., all available versions).
+ -- Accepts multiple entries, where later entries will be used as fallback should prior providers fail.
+ -- Builtin providers are:
+ -- - mason.providers.registry-api - uses the https://api.mason-registry.dev API
+ -- - mason.providers.client - uses only client-side tooling to resolve metadata
+ providers = {
+ "mason.providers.registry-api",
+ "mason.providers.client",
+ },
+
+ github = {
+ -- The template URL to use when downloading assets from GitHub.
+ -- The placeholders are the following (in order):
+ -- 1. The repository (e.g. "rust-lang/rust-analyzer")
+ -- 2. The release version (e.g. "v0.3.0")
+ -- 3. The asset name (e.g. "rust-analyzer-v0.3.0-x86_64-unknown-linux-gnu.tar.gz")
+ download_url_template = "https://github.com/%s/releases/download/%s/%s",
+ },
+
+ pip = {
+ -- Whether to upgrade pip to the latest version in the virtual environment before installing packages.
+ upgrade_pip = false,
+
+ -- These args will be added to `pip install` calls. Note that setting extra args might impact intended behavior
+ -- and is not recommended.
+ --
+ -- Example: { "--proxy", "https://proxyserver" }
+ install_args = {},
+ },
+
+ ui = {
+ -- Whether to automatically check for new versions when opening the :Mason window.
+ check_outdated_packages_on_open = true,
+
+ -- The border to use for the UI window. Accepts same border values as |nvim_open_win()|.
+ border = { "╭", "─", "╮", "│", "╯", "─", "╰", "│" }, -- рамка для окна
+
+ -- Width of the window. Accepts:
+ -- - Integer greater than 1 for fixed width.
+ -- - Float in the range of 0-1 for a percentage of screen width.
+ width = 0.8,
+
+ -- Height of the window. Accepts:
+ -- - Integer greater than 1 for fixed height.
+ -- - Float in the range of 0-1 for a percentage of screen height.
+ height = 0.9,
+
+ icons = {
+ -- The list icon to use for installed packages.
+ package_installed = "✓",
+ -- The list icon to use for packages that are installing, or queued for installation.
+ package_pending = "➜",
+ -- The list icon to use for packages that are not installed.
+ package_uninstalled = "✗"
+ },
+
+ keymaps = {
+ -- Keymap to expand a package
+ toggle_package_expand = "",
+ -- Keymap to install the package under the current cursor position
+ install_package = "i",
+ -- Keymap to reinstall/update the package under the current cursor position
+ update_package = "u",
+ -- Keymap to check for new version for the package under the current cursor position
+ check_package_version = "c",
+ -- Keymap to update all installed packages
+ update_all_packages = "U",
+ -- Keymap to check which installed packages are outdated
+ check_outdated_packages = "C",
+ -- Keymap to uninstall a package
+ uninstall_package = "X",
+ -- Keymap to cancel a package installation
+ cancel_installation = "",
+ -- Keymap to apply language filter
+ apply_language_filter = "",
+ -- Keymap to toggle viewing package installation log
+ toggle_package_install_log = "",
+ -- Keymap to toggle the help view
+ toggle_help = "g?",
+ },
+ }
+}
+
+require("mason-lspconfig").setup {
+ -- A list of servers to automatically install if they're not already installed. Example: { "rust_analyzer@nightly", "lua_ls" }
+ -- This setting has no relation with the `automatic_installation` setting.
+ ---@type string[]
+ ensure_installed = { "lua_ls" },
+
+ -- Whether servers that are set up (via lspconfig) should be automatically installed if they're not already installed.
+ -- This setting has no relation with the `ensure_installed` setting.
+ -- Can either be:
+ -- - false: Servers are not automatically installed.
+ -- - true: All servers set up via lspconfig are automatically installed.
+ -- - { exclude: string[] }: All servers set up via lspconfig, except the ones provided in the list, are automatically installed.
+ -- Example: automatic_installation = { exclude = { "rust_analyzer", "solargraph" } }
+ ---@type boolean
+ automatic_installation = false, -- Автоматическая установка
+
+ -- See `:h mason-lspconfig.setup_handlers()`
+ ---@type table?
+ handlers = nil,
+}
diff --git a/lua/plugins/neotree.lua b/lua/plugins/neotree.lua
new file mode 100644
index 0000000..a8f82f5
--- /dev/null
+++ b/lua/plugins/neotree.lua
@@ -0,0 +1,275 @@
+-- If you want icons for diagnostic errors, you'll need to define them somewhere:
+vim.fn.sign_define("DiagnosticSignError", { text = " ", texthl = "DiagnosticSignError" })
+vim.fn.sign_define("DiagnosticSignWarn", { text = " ", texthl = "DiagnosticSignWarn" })
+vim.fn.sign_define("DiagnosticSignInfo", { text = "", texthl = "DiagnosticSignInfo" })
+vim.fn.sign_define("DiagnosticSignHint", { text = "", texthl = "DiagnosticSignHint" })
+
+require("neo-tree").setup({
+ close_if_last_window = false, -- Close Neo-tree if it is the last window left in the tab
+ popup_border_style = "rounded",
+ enable_git_status = true,
+ enable_diagnostics = true,
+ enable_normal_mode_for_inputs = false, -- Enable normal mode for input dialogs.
+ open_files_do_not_replace_types = { "terminal", "trouble", "qf" }, -- when opening files, do not use windows containing these filetypes or buftypes
+ sort_case_insensitive = false, -- used when sorting files and directories in the tree
+ sort_function = nil, -- use a custom function for sorting files and directories in the tree
+ -- sort_function = function (a,b)
+ -- if a.type == b.type then
+ -- return a.path > b.path
+ -- else
+ -- return a.type > b.type
+ -- end
+ -- end , -- this sorts files and directories descendantly
+ default_component_configs = {
+ container = {
+ enable_character_fade = true
+ },
+ indent = {
+ indent_size = 2,
+ padding = 1, -- extra padding on left hand side
+ -- indent guides
+ with_markers = true,
+ indent_marker = "│",
+ last_indent_marker = "└",
+ highlight = "NeoTreeIndentMarker",
+ -- expander config, needed for nesting files
+ with_expanders = nil, -- if nil and file nesting is enabled, will enable expanders
+ expander_collapsed = "",
+ expander_expanded = "",
+ expander_highlight = "NeoTreeExpander",
+ },
+ icon = {
+ folder_closed = "",
+ folder_open = "",
+ folder_empty = "",
+ -- The next two settings are only a fallback, if you use nvim-web-devicons and configure default icons there
+ -- then these will never be used.
+ default = "*",
+ highlight = "NeoTreeFileIcon"
+ },
+ modified = {
+ symbol = "[+]",
+ highlight = "NeoTreeModified",
+ },
+ name = {
+ trailing_slash = false,
+ use_git_status_colors = true,
+ highlight = "NeoTreeFileName",
+ },
+ git_status = {
+ symbols = {
+ -- Change type
+ added = "", -- or "✚", but this is redundant info if you use git_status_colors on the name
+ modified = "", -- or "", but this is redundant info if you use git_status_colors on the name
+ deleted = "✖", -- this can only be used in the git_status source
+ renamed = "", -- this can only be used in the git_status source
+ -- Status type
+ untracked = "",
+ ignored = "",
+ unstaged = "",
+ staged = "",
+ conflict = "",
+ }
+ },
+ -- If you don't want to use these columns, you can set `enabled = false` for each of them individually
+ file_size = {
+ enabled = true,
+ required_width = 64, -- min width of window required to show this column
+ },
+ type = {
+ enabled = true,
+ required_width = 122, -- min width of window required to show this column
+ },
+ last_modified = {
+ enabled = true,
+ required_width = 88, -- min width of window required to show this column
+ },
+ created = {
+ enabled = true,
+ required_width = 110, -- min width of window required to show this column
+ },
+ symlink_target = {
+ enabled = false,
+ },
+ },
+ -- A list of functions, each representing a global custom command
+ -- that will be available in all sources (if not overridden in `opts[source_name].commands`)
+ -- see `:h neo-tree-custom-commands-global`
+ commands = {},
+ window = {
+ position = "left",
+ width = 40,
+ mapping_options = {
+ noremap = true,
+ nowait = true,
+ },
+ mappings = {
+ [""] = {
+ "toggle_node",
+ nowait = false, -- disable `nowait` if you have existing combos starting with this char that you want to use
+ },
+ [""] = "open",
+ ["l"] = "open",
+ [""] = "cancel", -- close preview or floating neo-tree window
+ ["P"] = { "toggle_preview", config = { use_float = true, use_image_nvim = true } },
+ -- Read `# Preview Mode` for more information
+ ["F"] = "focus_preview",
+ ["S"] = "open_split",
+ ["s"] = "open_vsplit",
+ -- ["S"] = "split_with_window_picker",
+ -- ["s"] = "vsplit_with_window_picker",
+ ["t"] = "open_tabnew",
+ -- [""] = "open_drop",
+ -- ["t"] = "open_tab_drop",
+ ["w"] = "open_with_window_picker",
+ --["P"] = "toggle_preview", -- enter preview mode, which shows the current node without focusing
+ ["C"] = "close_node",
+ ["h"] = "close_node",
+ -- ['C'] = 'close_all_subnodes',
+ ["z"] = "close_all_nodes",
+ --["Z"] = "expand_all_nodes",
+ ["a"] = {
+ "add",
+ -- this command supports BASH style brace expansion ("x{a,b,c}" -> xa,xb,xc). see `:h neo-tree-file-actions` for details
+ -- some commands may take optional config options, see `:h neo-tree-mappings` for details
+ config = {
+ show_path = "none" -- "none", "relative", "absolute"
+ }
+ },
+ ["A"] = "add_directory", -- also accepts the optional config.show_path option like "add". this also supports BASH style brace expansion.
+ ["d"] = "delete",
+ ["r"] = "rename",
+ ["y"] = "copy_to_clipboard",
+ ["x"] = "cut_to_clipboard",
+ ["p"] = "paste_from_clipboard",
+ ["c"] = "copy", -- takes text input for destination, also accepts the optional config.show_path option like "add":
+ -- ["c"] = {
+ -- "copy",
+ -- config = {
+ -- show_path = "none" -- "none", "relative", "absolute"
+ -- }
+ --}
+ ["m"] = "move", -- takes text input for destination, also accepts the optional config.show_path option like "add".
+ ["q"] = "close_window",
+ ["R"] = "refresh",
+ ["?"] = "show_help",
+ ["<"] = "prev_source",
+ [">"] = "next_source",
+ ["i"] = "show_file_details",
+ }
+ },
+ nesting_rules = {},
+ filesystem = {
+ filtered_items = {
+ visible = false, -- when true, they will just be displayed differently than normal items
+ hide_dotfiles = true,
+ hide_gitignored = true,
+ hide_hidden = true, -- only works on Windows for hidden files/directories
+ hide_by_name = {
+ --"node_modules"
+ },
+ hide_by_pattern = { -- uses glob style patterns
+ --"*.meta",
+ --"*/src/*/tsconfig.json",
+ },
+ always_show = { -- remains visible even if other settings would normally hide it
+ --".gitignored",
+ },
+ never_show = { -- remains hidden even if visible is toggled to true, this overrides always_show
+ --".DS_Store",
+ --"thumbs.db"
+ },
+ never_show_by_pattern = { -- uses glob style patterns
+ --".null-ls_*",
+ },
+ },
+ follow_current_file = {
+ enabled = false, -- This will find and focus the file in the active buffer every time
+ -- -- the current file is changed while the tree is open.
+ leave_dirs_open = false, -- `false` closes auto expanded dirs, such as with `:Neotree reveal`
+ },
+ group_empty_dirs = false, -- when true, empty folders will be grouped together
+ hijack_netrw_behavior = "open_default", -- netrw disabled, opening a directory opens neo-tree
+ -- in whatever position is specified in window.position
+ -- "open_current", -- netrw disabled, opening a directory opens within the
+ -- window like netrw would, regardless of window.position
+ -- "disabled", -- netrw left alone, neo-tree does not handle opening dirs
+ use_libuv_file_watcher = false, -- This will use the OS level file watchers to detect changes
+ -- instead of relying on nvim autocmd events.
+ window = {
+ mappings = {
+ [""] = "navigate_up",
+ ["."] = "set_root",
+ ["H"] = "toggle_hidden",
+ ["/"] = "fuzzy_finder",
+ ["D"] = "fuzzy_finder_directory",
+ ["#"] = "fuzzy_sorter", -- fuzzy sorting using the fzy algorithm
+ -- ["D"] = "fuzzy_sorter_directory",
+ ["f"] = "filter_on_submit",
+ [""] = "clear_filter",
+ ["[g"] = "prev_git_modified",
+ ["]g"] = "next_git_modified",
+ ["o"] = { "show_help", nowait = false, config = { title = "Order by", prefix_key = "o" } },
+ ["oc"] = { "order_by_created", nowait = false },
+ ["od"] = { "order_by_diagnostics", nowait = false },
+ ["og"] = { "order_by_git_status", nowait = false },
+ ["om"] = { "order_by_modified", nowait = false },
+ ["on"] = { "order_by_name", nowait = false },
+ ["os"] = { "order_by_size", nowait = false },
+ ["ot"] = { "order_by_type", nowait = false },
+ },
+ fuzzy_finder_mappings = { -- define keymaps for filter popup window in fuzzy_finder_mode
+ [""] = "move_cursor_down",
+ [""] = "move_cursor_down",
+ [""] = "move_cursor_up",
+ [""] = "move_cursor_up",
+ },
+ },
+
+ commands = {} -- Add a custom command or override a global one using the same function name
+ },
+ buffers = {
+ follow_current_file = {
+ enabled = true, -- This will find and focus the file in the active buffer every time
+ -- -- the current file is changed while the tree is open.
+ leave_dirs_open = false, -- `false` closes auto expanded dirs, such as with `:Neotree reveal`
+ },
+ group_empty_dirs = true, -- when true, empty folders will be grouped together
+ show_unloaded = true,
+ window = {
+ mappings = {
+ ["bd"] = "buffer_delete",
+ [""] = "navigate_up",
+ ["."] = "set_root",
+ ["o"] = { "show_help", nowait = false, config = { title = "Order by", prefix_key = "o" } },
+ ["oc"] = { "order_by_created", nowait = false },
+ ["od"] = { "order_by_diagnostics", nowait = false },
+ ["om"] = { "order_by_modified", nowait = false },
+ ["on"] = { "order_by_name", nowait = false },
+ ["os"] = { "order_by_size", nowait = false },
+ ["ot"] = { "order_by_type", nowait = false },
+ }
+ },
+ },
+ git_status = {
+ window = {
+ position = "float",
+ mappings = {
+ ["A"] = "git_add_all",
+ ["gu"] = "git_unstage_file",
+ ["ga"] = "git_add_file",
+ ["gr"] = "git_revert_file",
+ ["gc"] = "git_commit",
+ ["gp"] = "git_push",
+ ["gg"] = "git_commit_and_push",
+ ["o"] = { "show_help", nowait = false, config = { title = "Order by", prefix_key = "o" } },
+ ["oc"] = { "order_by_created", nowait = false },
+ ["od"] = { "order_by_diagnostics", nowait = false },
+ ["om"] = { "order_by_modified", nowait = false },
+ ["on"] = { "order_by_name", nowait = false },
+ ["os"] = { "order_by_size", nowait = false },
+ ["ot"] = { "order_by_type", nowait = false },
+ }
+ }
+ }
+})
diff --git a/lua/plugins/toggleterm.lua b/lua/plugins/toggleterm.lua
new file mode 100644
index 0000000..807e063
--- /dev/null
+++ b/lua/plugins/toggleterm.lua
@@ -0,0 +1,11 @@
+require("toggleterm").setup({ open_mapping = [[]] })
+
+function _G.set_terminal_keymaps()
+ local opts = { buffer = 0 }
+ -- Switching between terminal and normal mode inside terminal window
+ vim.keymap.set("t", "", [[]], opts)
+ vim.keymap.set("t", "jk", [[]], opts)
+ vim.keymap.set("t", "kj", [[]], opts)
+end
+
+vim.cmd("autocmd! TermOpen term://* lua set_terminal_keymaps()")
diff --git a/lua/plugins/treesitter.lua b/lua/plugins/treesitter.lua
new file mode 100644
index 0000000..edeaa03
--- /dev/null
+++ b/lua/plugins/treesitter.lua
@@ -0,0 +1,41 @@
+require("nvim-treesitter.configs").setup {
+ -- A list of parser names, or "all" (the five listed parsers should always be installed)
+ ensure_installed = { "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 = false,
+
+ -- List of parsers to ignore installing (or "all")
+ -- ignore_install = { "javascript" },
+
+ ---- If you need to change the installation directory of the parsers (see -> Advanced Setup)
+ -- parser_install_dir = "/some/path/to/store/parsers", -- Remember to run vim.opt.runtimepath:append("/some/path/to/store/parsers")!
+
+ 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 = { "c", "rust" },
+ -- 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,
+ }
+}
diff --git a/lua/plugins/whichkey.lua b/lua/plugins/whichkey.lua
new file mode 100644
index 0000000..10a39e1
--- /dev/null
+++ b/lua/plugins/whichkey.lua
@@ -0,0 +1,158 @@
+local setup = {
+ plugins = {
+ marks = true, -- shows a list of your marks on ' and `
+ registers = true, -- shows your registers on " in NORMAL or in INSERT mode
+ spelling = {
+ enabled = true, -- enabling this will show WhichKey when pressing z= to select spelling suggestions
+ suggestions = 20, -- how many suggestions should be shown in the list?
+ },
+ -- the presets plugin, adds help for a bunch of default keybindings in Neovim
+ -- No actual key bindings are created
+ presets = {
+ operators = true, -- adds help for operators like d, y, ... and registers them for motion / text object completion
+ motions = true, -- adds help for motions
+ text_objects = true, -- help for text objects triggered after entering an operator
+ windows = true, -- default bindings on
+ nav = true, -- misc bindings to work with windows
+ z = true, -- bindings for folds, spelling and others prefixed with z
+ g = true, -- bindings for prefixed with g
+ },
+ },
+ -- add operators that will trigger motion and text object completion
+ -- to enable all native operators, set the preset / operators plugin above
+ -- operators = { gc = "Comments" },
+ key_labels = {
+ -- override the label used to display some keys. It doesn't effect WK in any other way.
+ -- For example:
+ -- [""] = "SPC",
+ -- [""] = "RET",
+ -- [""] = "TAB",
+ },
+ icons = {
+ breadcrumb = "»", -- symbol used in the command line area that shows your active key combo
+ separator = "➜", -- symbol used between a key and it's label
+ group = "+", -- symbol prepended to a group
+ },
+ popup_mappings = {
+ scroll_down = "", -- binding to scroll down inside the popup
+ scroll_up = "", -- binding to scroll up inside the popup
+ },
+ window = {
+ border = "rounded", -- none, single, double, shadow
+ position = "bottom", -- bottom, top
+ margin = { 1, 0, 1, 0 }, -- extra window margin [top, right, bottom, left]
+ padding = { 2, 2, 2, 2 }, -- extra window padding [top, right, bottom, left]
+ winblend = 0,
+ },
+ layout = {
+ height = { min = 4, max = 25 }, -- min and max height of the columns
+ width = { min = 20, max = 50 }, -- min and max width of the columns
+ spacing = 3, -- spacing between columns
+ align = "left", -- align columns left, center or right
+ },
+ ignore_missing = true, -- enable this to hide mappings for which you didn't specify a label
+ hidden = { "", "", "", "", "call", "lua", "^:", "^ " }, -- hide mapping boilerplate
+ show_help = true, -- show help message on the command line when the popup is visible
+ triggers = "auto", -- automatically setup triggers
+ -- triggers = {""} -- or specify a list manually
+ triggers_blacklist = {
+ -- list of mode / prefixes that should never be hooked by WhichKey
+ -- this is mostly relevant for key maps that start with a native binding
+ -- most people should not need to change this
+ i = { "j", "k" },
+ v = { "j", "k" },
+ },
+}
+
+local opts = {
+ mode = "n", -- NORMAL mode
+ prefix = "",
+ buffer = nil, -- Global mappings. Specify a buffer number for buffer local mappings
+ silent = true, -- use `silent` when creating keymaps
+ noremap = true, -- use `noremap` when creating keymaps
+ nowait = true, -- use `nowait` when creating keymaps
+}
+
+local mappings = {
+ ["b"] = {
+ "lua require('telescope.builtin').buffers(require('telescope.themes').get_dropdown{previewer = false})",
+ "Buffers",
+ },
+ ["c"] = { "lua _G.close_and_go_right()", "Close Buffer" },
+ ["e"] = { "Neotree toggle left", "Explorer" },
+ ["f"] = {
+ "lua require('telescope.builtin').find_files(require('telescope.themes').get_dropdown{previewer = false})",
+ "Find files",
+ },
+ ["F"] = { "Telescope live_grep theme=ivy", "Find Text" },
+ ["h"] = { "nohlsearch", "No Highlight" },
+ ["m"] = { "MarkdownPreviewToggle", "Toggle markdow previewer" },
+
+ g = {
+ name = "Git",
+ g = { "lua _LAZYGIT_TOGGLE()", "Lazygit" },
+ j = { "lua require('gitsigns').next_hunk()", "Next Hunk" },
+ k = { "lua require('gitsigns').prev_hunk()", "Prev Hunk" },
+ l = { "lua require('gitsigns').blame_line()", "Blame" },
+ p = { "lua require('gitsigns').preview_hunk()", "Preview Hunk" },
+ r = { "lua require('gitsigns').reset_hunk()", "Reset Hunk" },
+ R = { "lua require('gitsigns').reset_buffer()", "Reset Buffer" },
+ s = { "lua require('gitsigns').stage_hunk()", "Stage Hunk" },
+ u = { "lua require('gitsigns').undo_stage_hunk()", "Undo Stage Hunk", },
+ o = { "Telescope git_status", "Open changed file" },
+ b = { "Telescope git_branches", "Checkout branch" },
+ c = { "Telescope git_commits", "Checkout commit" },
+ d = { "Gitsigns diffthis HEAD", "Diff", },
+ },
+
+ l = {
+ name = "LSP",
+ a = { "lua vim.lsp.buf.code_action()", "Code Action" },
+ d = { "Telescope diagnostics bufnr=0", "Document Diagnostics", },
+ w = { "Telescope diagnostics", "Workspace Diagnostics", },
+ f = { "lua vim.lsp.buf.format{async=true}", "Format" },
+ i = { "LspInfo", "Info" },
+ I = { "LspInstallInfo", "Installer Info" },
+ j = { "lua vim.lsp.diagnostic.goto_next()", "Next Diagnostic", },
+ k = { "lua vim.lsp.diagnostic.goto_prev()", "Prev Diagnostic", },
+ l = { "lua vim.lsp.codelens.run()", "CodeLens Action" },
+ q = { "lua vim.diagnostic.setloclist()", "Quickfix" },
+ r = { "lua vim.lsp.buf.rename()", "Rename" },
+ s = { "