summaryrefslogtreecommitdiff
path: root/lua/plugins.lua
diff options
context:
space:
mode:
authorchristianchiarulli <[email protected]>2021-07-05 16:26:31 -0400
committerchristianchiarulli <[email protected]>2021-07-05 16:26:31 -0400
commit20485971641a9d916640ccad05586a641c984ed6 (patch)
treed397a3a9adba502b4c26b802d897b8310972f76f /lua/plugins.lua
parent56e82dac4497293541099185441485dd31e98dc8 (diff)
parenta469c710bfc01f291df68dba40464caaa2b496da (diff)
Merge branch 'master' of github.com:ChristianChiarulli/LunarVim into stable
Diffstat (limited to 'lua/plugins.lua')
-rw-r--r--lua/plugins.lua881
1 files changed, 470 insertions, 411 deletions
diff --git a/lua/plugins.lua b/lua/plugins.lua
index bdda5847..2b215291 100644
--- a/lua/plugins.lua
+++ b/lua/plugins.lua
@@ -1,426 +1,485 @@
local execute = vim.api.nvim_command
local fn = vim.fn
-local install_path = fn.stdpath("data") .. "/site/pack/packer/start/packer.nvim"
+local install_path = fn.stdpath "data" .. "/site/pack/packer/start/packer.nvim"
if fn.empty(fn.glob(install_path)) > 0 then
- execute("!git clone https://github.com/wbthomason/packer.nvim " ..
- install_path)
- execute "packadd packer.nvim"
+ execute("!git clone https://github.com/wbthomason/packer.nvim " .. install_path)
+ execute "packadd packer.nvim"
end
local packer_ok, packer = pcall(require, "packer")
-if not packer_ok then return end
+if not packer_ok then
+ return
+end
packer.init {
- -- compile_path = vim.fn.stdpath('data')..'/site/pack/loader/start/packer.nvim/plugin/packer_compiled.vim',
- compile_path = require("packer.util").join_paths(vim.fn.stdpath('config'),
- 'plugin',
- 'packer_compiled.vim'),
- git = {clone_timeout = 300},
- display = {
- open_fn = function()
- return require("packer.util").float {border = "single"}
- end
- }
+ -- compile_path = vim.fn.stdpath('data')..'/site/pack/loader/start/packer.nvim/plugin/packer_compiled.vim',
+ compile_path = require("packer.util").join_paths(vim.fn.stdpath "config", "plugin", "packer_compiled.vim"),
+ git = { clone_timeout = 300 },
+ display = {
+ open_fn = function()
+ return require("packer.util").float { border = "single" }
+ end,
+ },
}
-vim.cmd "autocmd BufWritePost plugins.lua PackerCompile" -- Auto compile when there are changes in plugins.lua
+vim.cmd "autocmd BufWritePost plugins.lua PackerCompile"
return require("packer").startup(function(use)
- -- Packer can manage itself as an optional plugin
- use "wbthomason/packer.nvim"
-
- -- TODO refactor all of this (for now it works, but yes I know it could be wrapped in a simpler function)
- use {"neovim/nvim-lspconfig"}
- use {"glepnir/lspsaga.nvim"}
- use {"kabouzeid/nvim-lspinstall"}
- -- Telescope
- use {"nvim-lua/popup.nvim"}
- use {"nvim-lua/plenary.nvim"}
- use {"tjdevries/astronauta.nvim"}
- use {
- "nvim-telescope/telescope.nvim",
- config = [[require('lv-telescope')]],
- cmd = "Telescope"
- }
- -- Snap TODO disable for now, need to only install fzy when user specifies they want to use snap
- -- use {
- -- "camspiers/snap",
- -- rocks = "fzy",
- -- config = function()
- -- require("lv-snap").config()
- -- end,
- -- disable = not O.plugin.snap.active
- -- }
- -- Autocomplete
- use {
- "hrsh7th/nvim-compe",
- config = function()
- require("lv-compe").config()
- end
- }
-
- use {"hrsh7th/vim-vsnip", event = "InsertEnter"}
- use {"rafamadriz/friendly-snippets", event = "InsertEnter"}
-
- -- Treesitter
- use {"nvim-treesitter/nvim-treesitter", run = ":TSUpdate"}
-
- use {
- "kyazdani42/nvim-tree.lua",
- -- cmd = "NvimTreeToggle",
- config = function()
- require("lv-nvimtree").config()
- end
- }
-
- use {
- "lewis6991/gitsigns.nvim",
-
- config = function()
- require("lv-gitsigns").config()
- end,
- event = "BufRead"
- }
-
- -- whichkey
- use {"folke/which-key.nvim"}
-
- -- Autopairs
- use {
- "windwp/nvim-autopairs",
- config = function()
- require 'lv-autopairs'
- end
- }
-
- -- Comments
- use {
- "terrortylor/nvim-comment",
- cmd = "CommentToggle",
- config = function()
- require('nvim_comment').setup()
- end
- }
-
- -- Color
- use {"christianchiarulli/nvcode-color-schemes.vim", opt = true}
-
- -- Icons
- use {"kyazdani42/nvim-web-devicons"}
-
- -- Status Line and Bufferline
- use {"glepnir/galaxyline.nvim"}
-
- use {
- "akinsho/nvim-bufferline.lua",
- config = function()
- require("lv-bufferline").config()
- end,
- event = "BufRead"
-
- }
-
- -- Extras, these do not load by default
-
- -- Better motions
- use {
- 'phaazon/hop.nvim',
- event = 'BufRead',
- config = function()
- require('lv-hop').config()
- end,
- disable = not O.plugin.hop.active,
- opt = true
- }
- -- Enhanced increment/decrement
- use {
- 'monaqa/dial.nvim',
- event = 'BufRead',
- config = function()
- require('lv-dial').config()
- end,
- disable = not O.plugin.dial.active,
- opt = true
- }
- -- Dashboard
- use {
- "ChristianChiarulli/dashboard-nvim",
- event = 'BufWinEnter',
- cmd = {"Dashboard", "DashboardNewFile", "DashboardJumpMarks"},
- config = function()
- require('lv-dashboard').config()
- end,
- disable = not O.plugin.dashboard.active,
- opt = true
- }
- -- Zen Mode
- use {
- "folke/zen-mode.nvim",
- cmd = "ZenMode",
- -- event = "BufRead",
- config = function()
- require('lv-zen').config()
- end,
- disable = not O.plugin.zen.active
- }
- -- Ranger
- use {
- "kevinhwang91/rnvimr",
- cmd = "Rnvimr",
- config = function()
- require('lv-rnvimr').config()
- end,
- disable = not O.plugin.ranger.active
- }
-
- -- matchup
- use {
- 'andymass/vim-matchup',
- event = "CursorMoved",
- config = function()
- require('lv-matchup').config()
- end,
- disable = not O.plugin.matchup.active
- }
-
- use {
- "norcalli/nvim-colorizer.lua",
- event = "BufRead",
- config = function()
- require("colorizer").setup()
- vim.cmd("ColorizerReloadAllBuffers")
- end,
- disable = not O.plugin.colorizer.active
- }
-
- use {
- "nacro90/numb.nvim",
- event = "BufRead",
- config = function()
- require('numb').setup {
- show_numbers = true, -- Enable 'number' for the window while peeking
- show_cursorline = true -- Enable 'cursorline' for the window while peeking
- }
- end,
- disable = not O.plugin.numb.active
- }
-
- -- Treesitter playground
- use {
- 'nvim-treesitter/playground',
- event = "BufRead",
- disable = not O.plugin.ts_playground.active
- }
-
- use {
- "lukas-reineke/indent-blankline.nvim",
- event = "BufRead",
- setup = function()
-
- vim.g.indentLine_enabled = 1
- vim.g.indent_blankline_char = "▏"
-
- vim.g.indent_blankline_filetype_exclude = {
- "help", "terminal", "dashboard"
- }
- vim.g.indent_blankline_buftype_exclude = {"terminal"}
-
- vim.g.indent_blankline_show_trailing_blankline_indent = false
- vim.g.indent_blankline_show_first_indent_level = true
- end,
- disable = not O.plugin.indent_line.active
- }
-
- -- comments in context
- use {
- 'JoosepAlviste/nvim-ts-context-commentstring',
- event = "BufRead",
- disable = not O.plugin.ts_context_commentstring.active
- }
-
- -- Symbol Outline
- use {
- 'simrat39/symbols-outline.nvim',
- cmd = 'SymbolsOutline',
- disable = not O.plugin.symbol_outline.active
- }
- -- diagnostics
- use {
- "folke/trouble.nvim",
- cmd = 'TroubleToggle',
- disable = not O.plugin.trouble.active
- }
- -- Debugging
- use {
- "mfussenegger/nvim-dap",
- event = "BufRead",
- disable = not O.plugin.debug.active
- }
- -- Better quickfix
- use {
- "kevinhwang91/nvim-bqf",
- event = "BufRead",
- disable = not O.plugin.bqf.active
- }
- -- Floating terminal
- use {
- 'numToStr/FTerm.nvim',
- event = "BufRead",
- config = function()
- require'FTerm'.setup({
- dimensions = {height = 0.8, width = 0.8, x = 0.5, y = 0.5},
- border = 'single' -- or 'double'
- })
- end,
- disable = not O.plugin.floatterm.active
- }
- -- Search & Replace
- use {
- 'windwp/nvim-spectre',
- event = "BufRead",
- config = function()
- require('spectre').setup()
- end,
- disable = not O.plugin.spectre.active
- }
- -- lsp root with this nvim-tree will follow you
- use {
- "ahmedkhalf/lsp-rooter.nvim",
- event = "BufRead",
- config = function()
- require("lsp-rooter").setup()
- end,
- disable = not O.plugin.lsp_rooter.active
- }
- -- Markdown preview
- use {
- 'iamcco/markdown-preview.nvim',
- run = 'cd app && npm install',
- ft = 'markdown',
- disable = not O.plugin.markdown_preview.active
- }
- -- Interactive scratchpad
- use {
- 'metakirby5/codi.vim',
- cmd = 'Codi',
- disable = not O.plugin.codi.active
- }
- -- Use fzy for telescope
- use {
- "nvim-telescope/telescope-fzy-native.nvim",
- event = "BufRead",
- disable = not O.plugin.telescope_fzy.active
- }
- -- Use project for telescope
- use {
- "nvim-telescope/telescope-project.nvim",
- event = "BufRead",
- after = "telescope.nvim",
- disable = not O.plugin.telescope_project.active
- }
- -- Sane gx for netrw_gx bug
- use {
- "felipec/vim-sanegx",
- event = "BufRead",
- disable = not O.plugin.sanegx.active
- }
- -- Sane gx for netrw_gx bug
- use {
- "folke/todo-comments.nvim",
- event = "BufRead",
- disable = not O.plugin.todo_comments.active
- }
- -- LSP Colors
- use {
- "folke/lsp-colors.nvim",
- event = "BufRead",
- disable = not O.plugin.lsp_colors.active
- }
- -- Git Blame
- use {
- "f-person/git-blame.nvim",
- event = "BufRead",
- disable = not O.plugin.git_blame.active
- }
- use {
- 'ruifm/gitlinker.nvim',
- event = "BufRead",
- config = function()
- require"gitlinker".setup({
- opts = {
- -- remote = 'github', -- force the use of a specific remote
- -- adds current line nr in the url for normal mode
- add_current_line_on_normal_mode = true,
- -- callback for what to do with the url
- action_callback = require"gitlinker.actions".open_in_browser,
- -- print the url after performing the action
- print_url = false,
- -- mapping to call url generation
- mappings = "<leader>gy"
- }
- })
-
- end,
- disable = not O.plugin.gitlinker.active,
- requires = 'nvim-lua/plenary.nvim'
-
- }
- -- Lazygit
- use {
- "kdheepak/lazygit.nvim",
- cmd = "LazyGit",
- disable = not O.plugin.lazygit.active
- }
- -- Octo
- use {
- "pwntester/octo.nvim",
- event = "BufRead",
- disable = not O.plugin.octo.active
- }
- -- Diffview
- use {
- "sindrets/diffview.nvim",
- event = "BufRead",
- disable = not O.plugin.diffview.active
- }
- -- Easily Create Gists
- use {
- "mattn/vim-gist",
- event = "BufRead",
- disable = not O.plugin.gist.active,
- requires = 'mattn/webapi-vim'
- }
- -- Lush Create Color Schemes
- use {
- "rktjmp/lush.nvim",
- -- cmd = {"LushRunQuickstart", "LushRunTutorial", "Lushify"},
- disable = not O.plugin.lush.active
- }
- -- HTML preview
- use {
- 'turbio/bracey.vim',
- event = "BufRead",
- run = 'npm install --prefix server',
- disable = not O.plugin.bracey.active
- }
- -- Debugger management
- use {
- 'Pocco81/DAPInstall.nvim',
- event = "BufRead",
- disable = not O.plugin.dap_install.active
- }
-
- -- LANGUAGE SPECIFIC GOES HERE
-
- -- Latex TODO what filetypes should this be active for?
- use {"lervag/vimtex", ft = "latex"}
-
- -- Rust tools
- -- TODO: use lazy loading maybe?
- use {"simrat39/rust-tools.nvim", ft = "rust"}
-
- -- Elixir
- use {"elixir-editors/vim-elixir", ft = {"elixir", "eelixir", "euphoria3"}}
+ -- Packer can manage itself as an optional plugin
+ use "wbthomason/packer.nvim"
+
+ -- TODO refactor all of this (for now it works, but yes I know it could be wrapped in a simpler function)
+ use { "neovim/nvim-lspconfig" }
+ use { "kabouzeid/nvim-lspinstall" }
+ -- Telescope
+ use { "nvim-lua/popup.nvim" }
+ use { "nvim-lua/plenary.nvim" }
+ use { "tjdevries/astronauta.nvim" }
+ use {
+ "nvim-telescope/telescope.nvim",
+ config = [[require('lv-telescope')]],
+ cmd = "Telescope",
+ }
+ -- Snap TODO disable for now, need to only install fzy when user specifies they want to use snap
+ -- use {
+ -- "camspiers/snap",
+ -- rocks = "fzy",
+ -- config = function()
+ -- require("lv-snap").config()
+ -- end,
+ -- disable = not O.plugin.snap.active
+ -- }
+ -- Autocomplete
+ use {
+ "hrsh7th/nvim-compe",
+ event = "InsertEnter",
+ config = function()
+ require("lv-compe").config()
+ end,
+ }
+
+ use { "hrsh7th/vim-vsnip", event = "InsertEnter" }
+ use { "rafamadriz/friendly-snippets", event = "InsertEnter" }
+
+ -- Treesitter
+ use { "nvim-treesitter/nvim-treesitter", run = ":TSUpdate" }
+
+ -- Neoformat
+ use { "sbdchd/neoformat", event = "BufEnter" }
+
+ use {
+ "kyazdani42/nvim-tree.lua",
+ -- cmd = "NvimTreeToggle",
+ config = function()
+ require("lv-nvimtree").config()
+ end,
+ }
+
+ use {
+ "lewis6991/gitsigns.nvim",
+
+ config = function()
+ require("lv-gitsigns").config()
+ end,
+ event = "BufRead",
+ }
+
+ -- whichkey
+ use { "folke/which-key.nvim" }
+
+ -- Autopairs
+ use {
+ "windwp/nvim-autopairs",
+ event = "InsertEnter",
+ after = { "telescope.nvim", "nvim-compe" },
+ config = function()
+ require "lv-autopairs"
+ end,
+ }
+
+ -- Comments
+ use {
+ "terrortylor/nvim-comment",
+ cmd = "CommentToggle",
+ config = function()
+ require("nvim_comment").setup()
+ end,
+ }
+
+ -- Color
+ use { "christianchiarulli/nvcode-color-schemes.vim", opt = true }
+
+ -- Icons
+ use { "kyazdani42/nvim-web-devicons" }
+
+ -- Status Line and Bufferline
+ use { "glepnir/galaxyline.nvim" }
+
+ use {
+ "romgrk/barbar.nvim",
+ config = function()
+ vim.api.nvim_set_keymap("n", "<TAB>", ":BufferNext<CR>", { noremap = true, silent = true })
+ vim.api.nvim_set_keymap("n", "<S-TAB>", ":BufferPrevious<CR>", { noremap = true, silent = true })
+ vim.api.nvim_set_keymap("n", "<S-x>", ":BufferClose<CR>", { noremap = true, silent = true })
+ end,
+ -- event = "BufRead",
+ }
+
+ -- use {
+ -- "akinsho/nvim-bufferline.lua",
+ -- config = function() require("lv-bufferline").config() end,
+ -- event = "BufRead"
+ -- }
+
+ -- Extras, these do not load by default
+
+ -- Better motions
+ use {
+ "phaazon/hop.nvim",
+ event = "BufRead",
+ config = function()
+ require("lv-hop").config()
+ end,
+ disable = not O.plugin.hop.active,
+ opt = true,
+ }
+ -- Enhanced increment/decrement
+ use {
+ "monaqa/dial.nvim",
+ event = "BufRead",
+ config = function()
+ require("lv-dial").config()
+ end,
+ disable = not O.plugin.dial.active,
+ opt = true,
+ }
+ -- Dashboard
+ use {
+ "ChristianChiarulli/dashboard-nvim",
+ event = "BufWinEnter",
+ cmd = { "Dashboard", "DashboardNewFile", "DashboardJumpMarks" },
+ config = function()
+ require("lv-dashboard").config()
+ end,
+ disable = not O.plugin.dashboard.active,
+ opt = true,
+ }
+ -- Zen Mode
+ use {
+ "folke/zen-mode.nvim",
+ cmd = "ZenMode",
+ -- event = "BufRead",
+ config = function()
+ require("lv-zen").config()
+ end,
+ disable = not O.plugin.zen.active,
+ }
+ -- Ranger
+ use {
+ "kevinhwang91/rnvimr",
+ cmd = "Rnvimr",
+ config = function()
+ require("lv-rnvimr").config()
+ end,
+ disable = not O.plugin.ranger.active,
+ }
+
+ -- matchup
+ use {
+ "andymass/vim-matchup",
+ event = "CursorMoved",
+ config = function()
+ require("lv-matchup").config()
+ end,
+ disable = not O.plugin.matchup.active,
+ }
+
+ use {
+ "norcalli/nvim-colorizer.lua",
+ event = "BufRead",
+ config = function()
+ require("colorizer").setup()
+ vim.cmd "ColorizerReloadAllBuffers"
+ end,
+ disable = not O.plugin.colorizer.active,
+ }
+
+ use {
+ "nacro90/numb.nvim",
+ event = "BufRead",
+ config = function()
+ require("numb").setup {
+ show_numbers = true, -- Enable 'number' for the window while peeking
+ show_cursorline = true, -- Enable 'cursorline' for the window while peeking
+ }
+ end,
+ disable = not O.plugin.numb.active,
+ }
+
+ -- Treesitter playground
+ use {
+ "nvim-treesitter/playground",
+ event = "BufRead",
+ disable = not O.plugin.ts_playground.active,
+ }
+
+ use {
+ "lukas-reineke/indent-blankline.nvim",
+ event = "BufRead",
+ setup = function()
+ vim.g.indentLine_enabled = 1
+ vim.g.indent_blankline_char = "▏"
+
+ vim.g.indent_blankline_filetype_exclude = {
+ "help",
+ "terminal",
+ "dashboard",
+ }
+ vim.g.indent_blankline_buftype_exclude = { "terminal" }
+
+ vim.g.indent_blankline_show_trailing_blankline_indent = false
+ vim.g.indent_blankline_show_first_indent_level = true
+ end,
+ disable = not O.plugin.indent_line.active,
+ }
+
+ -- comments in context
+ use {
+ "JoosepAlviste/nvim-ts-context-commentstring",
+ event = "BufRead",
+ disable = not O.plugin.ts_context_commentstring.active,
+ }
+
+ -- Symbol Outline
+ use {
+ "simrat39/symbols-outline.nvim",
+ cmd = "SymbolsOutline",
+ disable = not O.plugin.symbol_outline.active,
+ }
+ -- diagnostics
+ use {
+ "folke/trouble.nvim",
+ cmd = "TroubleToggle",
+ disable = not O.plugin.trouble.active,
+ }
+ -- Debugging
+ use {
+ "mfussenegger/nvim-dap",
+ config = function()
+ require "dap"
+ vim.fn.sign_define("DapBreakpoint", {
+ text = "",
+ texthl = "LspDiagnosticsSignError",
+ linehl = "",
+ numhl = "",
+ })
+ require("dap").defaults.fallback.terminal_win_cmd = "50vsplit new"
+ end,
+ disable = not O.plugin.debug.active,
+ }
+ -- Better quickfix
+ use {
+ "kevinhwang91/nvim-bqf",
+ event = "BufRead",
+ disable = not O.plugin.bqf.active,
+ }
+ -- Floating terminal
+ use {
+ "numToStr/FTerm.nvim",
+ event = "BufRead",
+ config = function()
+ require("FTerm").setup {
+ dimensions = { height = 0.8, width = 0.8, x = 0.5, y = 0.5 },
+ border = "single", -- or 'double'
+ }
+ end,
+ disable = not O.plugin.floatterm.active,
+ }
+ -- Search & Replace
+ use {
+ "windwp/nvim-spectre",
+ event = "BufRead",
+ config = function()
+ require("spectre").setup()
+ end,
+ disable = not O.plugin.spectre.active,
+ }
+ -- lsp root with this nvim-tree will follow you
+ use {
+ "ahmedkhalf/lsp-rooter.nvim",
+ event = "BufRead",
+ config = function()
+ require("lsp-rooter").setup()
+ end,
+ disable = not O.plugin.lsp_rooter.active,
+ }
+ -- Markdown preview
+ use {
+ "iamcco/markdown-preview.nvim",
+ run = "cd app && npm install",
+ ft = "markdown",
+ disable = not O.plugin.markdown_preview.active,
+ }
+ -- Interactive scratchpad
+ use {
+ "metakirby5/codi.vim",
+ cmd = "Codi",
+ disable = not O.plugin.codi.active,
+ }
+ -- Use fzy for telescope
+ use {
+ "nvim-telescope/telescope-fzy-native.nvim",
+ event = "BufRead",
+ disable = not O.plugin.telescope_fzy.active,
+ }
+ -- Use project for telescope
+ use {
+ "nvim-telescope/telescope-project.nvim",
+ event = "BufRead",
+ after = "telescope.nvim",
+ disable = not O.plugin.telescope_project.active,
+ }
+ -- Sane gx for netrw_gx bug
+ use {
+ "felipec/vim-sanegx",
+ event = "BufRead",
+ disable = not O.plugin.sanegx.active,
+ }
+ -- Sane gx for netrw_gx bug
+ use {
+ "folke/todo-comments.nvim",
+ event = "BufRead",
+ disable = not O.plugin.todo_comments.active,
+ }
+ -- LSP Colors
+ use {
+ "folke/lsp-colors.nvim",
+ event = "BufRead",
+ disable = not O.plugin.lsp_colors.active,
+ }
+ -- Git Blame
+ use {
+ "f-person/git-blame.nvim",
+ event = "BufRead",
+ disable = not O.plugin.git_blame.active,
+ }
+ use {
+ "ruifm/gitlinker.nvim",
+ event = "BufRead",
+ config = function()
+ require("gitlinker").setup {
+ opts = {
+ -- remote = 'github', -- force the use of a specific remote
+ -- adds current line nr in the url for normal mode
+ add_current_line_on_normal_mode = true,
+ -- callback for what to do with the url
+ action_callback = require("gitlinker.actions").open_in_browser,
+ -- print the url after performing the action
+ print_url = false,
+ -- mapping to call url generation
+ mappings = "<leader>gy",
+ },
+ }
+ end,
+ disable = not O.plugin.gitlinker.active,
+ requires = "nvim-lua/plenary.nvim",
+ }
+ -- Lazygit
+ use {
+ "kdheepak/lazygit.nvim",
+ cmd = "LazyGit",
+ disable = not O.plugin.lazygit.active,
+ }
+ -- Octo
+ use {
+ "pwntester/octo.nvim",
+ event = "BufRead",
+ disable = not O.plugin.octo.active,
+ }
+ -- Diffview
+ use {
+ "sindrets/diffview.nvim",
+ event = "BufRead",
+ disable = not O.plugin.diffview.active,
+ }
+ -- Easily Create Gists
+ use {
+ "mattn/vim-gist",
+ event = "BufRead",
+ disable = not O.plugin.gist.active,
+ requires = "mattn/webapi-vim",
+ }
+ -- Lush Create Color Schemes
+ use {
+ "rktjmp/lush.nvim",
+ -- cmd = {"LushRunQuickstart", "LushRunTutorial", "Lushify"},
+ disable = not O.plugin.lush.active,
+ }
+ -- HTML preview
+ use {
+ "turbio/bracey.vim",
+ event = "BufRead",
+ run = "npm install --prefix server",
+ disable = not O.plugin.bracey.active,
+ }
+ -- Debugger management
+ use {
+ "Pocco81/DAPInstall.nvim",
+ -- event = "BufRead",
+ disable = not O.plugin.dap_install.active,
+ }
+
+ -- LANGUAGE SPECIFIC GOES HERE
+
+ use { "lervag/vimtex", ft = "tex" }
+
+ -- Rust tools
+ -- TODO: use lazy loading maybe?
+ use {
+ "simrat39/rust-tools.nvim",
+ disable = not O.lang.rust.rust_tools.active,
+ }
+
+ -- Elixir
+ use { "elixir-editors/vim-elixir", ft = { "elixir", "eelixir", "euphoria3" } }
+
+ -- Javascript / Typescript
+ use {
+ "jose-elias-alvarez/nvim-lsp-ts-utils",
+ ft = {
+ "javascript",
+ "javascriptreact",
+ "javascript.jsx",
+ "typescript",
+ "typescriptreact",
+ "typescript.tsx",
+ },
+ }
+ -- use {
+ -- "jose-elias-alvarez/null-ls.nvim",
+ -- ft = {
+ -- "javascript",
+ -- "javascriptreact",
+ -- "javascript.jsx",
+ -- "typescript",
+ -- "typescriptreact",
+ -- "typescript.tsx",
+ -- },
+ -- config = function()
+ -- require("null-ls").setup()
+ -- end,
+ -- }
+
+ -- Tabnine
+ use {
+ "tzachar/compe-tabnine",
+ run = "./install.sh",
+ requires = "hrsh7th/nvim-compe",
+ disable = not O.plugin.tabnine.active,
+ }
+ for _, plugin in pairs(O.custom_plugins) do
+ packer.use(plugin)
+ end
end)