You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
4.6 KiB
Lua
155 lines
4.6 KiB
Lua
local fn = vim.fn
|
|
|
|
-- Automatically install packer
|
|
local install_path = fn.stdpath "data" .. "/site/pack/packer/start/packer.nvim"
|
|
if fn.empty(fn.glob(install_path)) > 0 then
|
|
PACKER_BOOTSTRAP = fn.system {
|
|
"git",
|
|
"clone",
|
|
"--depth",
|
|
"1",
|
|
"https://github.com/wbthomason/packer.nvim",
|
|
install_path,
|
|
}
|
|
print "Installing packer close and reopen Neovim..."
|
|
vim.cmd [[packadd packer.nvim]]
|
|
end
|
|
|
|
-- Autocommand that reloads neovim whenever you save the plugins.lua file
|
|
vim.cmd [[
|
|
augroup packer_user_config
|
|
autocmd!
|
|
autocmd BufWritePost plugins.lua source <afile> | PackerSync
|
|
augroup end
|
|
]]
|
|
|
|
-- Use a protected call so we don't error out on first use
|
|
local status_ok, packer = pcall(require, "packer")
|
|
if not status_ok then
|
|
return
|
|
end
|
|
|
|
-- Have packer use a popup window
|
|
packer.init {
|
|
display = {
|
|
open_fn = function()
|
|
return require("packer.util").float { border = "rounded" }
|
|
end,
|
|
},
|
|
}
|
|
|
|
-- Install your plugins here
|
|
return packer.startup(function(use)
|
|
-- My plugins here
|
|
use "wbthomason/packer.nvim" -- Have packer manage itself
|
|
use "nvim-lua/popup.nvim" -- An implementation of the Popup API from vim in Neovim
|
|
use "nvim-lua/plenary.nvim" -- Useful lua functions used ny lots of plugins
|
|
use {'dracula/vim', as = 'dracula'}
|
|
|
|
-- Colorschemes
|
|
-- use "lunarvim/colorschemes" -- A bunch of colorschemes you can try out
|
|
use "lunarvim/darkplus.nvim"
|
|
use {'colepeters/spacemacs-theme.vim', as = 'spacemacs'}
|
|
|
|
-- cmp plugins
|
|
use "hrsh7th/nvim-cmp" -- The completion plugin
|
|
use "hrsh7th/cmp-buffer" -- The buffer completions
|
|
use "hrsh7th/cmp-path" -- path completions
|
|
use "hrsh7th/cmp-cmdline" -- cmdline completions
|
|
use "saadparwaiz1/cmp_luasnip" -- snippet completions
|
|
use "hrsh7th/cmp-nvim-lsp" -- LSP
|
|
use "hrsh7th/cmp-nvim-lua" -- LUA
|
|
|
|
-- -- LSP
|
|
use 'mhartington/formatter.nvim'
|
|
use "neovim/nvim-lspconfig" -- enable lsp
|
|
use "williamboman/nvim-lsp-installer" -- simple to use language server installer
|
|
use "tamago324/nlsp-settings.nvim" -- language server settings defined in json
|
|
|
|
-- snippets
|
|
use "L3MON4D3/LuaSnip" -- snippet engine
|
|
use "rafamadriz/friendly-snippets" -- a bunch of snippets to use
|
|
|
|
-- Telescope
|
|
use "nvim-telescope/telescope.nvim"
|
|
use "nvim-telescope/telescope-media-files.nvim"
|
|
-- use "nvim-telescope/telescope-project.nvim"
|
|
|
|
-- TreeSitter
|
|
use {
|
|
"nvim-treesitter/nvim-treesitter",
|
|
run = ":TSUpdate",
|
|
commit = "668de0951a36ef17016074f1120b6aacbe6c4515"
|
|
}
|
|
use "p00f/nvim-ts-rainbow"
|
|
use "nvim-treesitter/playground"
|
|
|
|
-- Autopairs
|
|
use "windwp/nvim-autopairs" -- autopairs
|
|
|
|
-- Comment
|
|
use "numToStr/Comment.nvim" -- easily comment stuff
|
|
use "JoosepAlviste/nvim-ts-context-commentstring"
|
|
|
|
-- Git
|
|
use "lewis6991/gitsigns.nvim"
|
|
|
|
-- Nvim Tree
|
|
use "kyazdani42/nvim-web-devicons"
|
|
use "kyazdani42/nvim-tree.lua"
|
|
|
|
use "moll/vim-bbye"
|
|
use "akinsho/bufferline.nvim"
|
|
|
|
use "akinsho/toggleterm.nvim"
|
|
|
|
use "liuchengxu/space-vim-dark"
|
|
use "romgrk/nvim-treesitter-context"
|
|
require"treesitter-context".setup{
|
|
enable = true, -- Enable this plugin (Can be enabled/disabled later via commands)
|
|
throttle = true, -- Throttles plugin updates (may improve performance)
|
|
max_lines = 0, -- How many lines the window should span. Values <= 0 mean no limit.
|
|
patterns = { -- Match patterns for TS nodes. These get wrapped to match at word boundaries.
|
|
-- For all filetypes
|
|
-- Note that setting an entry here replaces all other patterns for this entry.
|
|
-- By setting the 'default' entry below, you can control which nodes you want to
|
|
-- appear in the context window.
|
|
default = {
|
|
'class',
|
|
'function',
|
|
'method',
|
|
-- 'for', -- These won't appear in the context
|
|
-- 'while',
|
|
-- 'if',
|
|
-- 'switch',
|
|
-- 'case',
|
|
},
|
|
-- Example for a specific filetype.
|
|
-- If a pattern is missing, *open a PR* so everyone can benefit.
|
|
-- rust = {
|
|
-- 'impl_item',
|
|
-- },
|
|
},
|
|
exact_patterns = {
|
|
-- Example for a specific filetype with Lua patterns
|
|
-- Treat patterns.rust as a Lua pattern (i.e "^impl_item$" will
|
|
-- exactly match "impl_item" only)
|
|
-- rust = true,
|
|
}
|
|
}
|
|
|
|
|
|
-- whichkey
|
|
use "folke/which-key.nvim"
|
|
use {"ellisonleao/glow.nvim"}
|
|
vim.g.glow_binary_path = vim.env.HOME .. "/Documents/glow"
|
|
|
|
use "mfussenegger/nvim-dap"
|
|
|
|
-- Automatically set up your configuration after cloning packer.nvim
|
|
-- Put this at the end after all plugins
|
|
if PACKER_BOOTSTRAP then
|
|
require("packer").sync()
|
|
end
|
|
end)
|