summaryrefslogtreecommitdiff
path: root/lua
diff options
context:
space:
mode:
Diffstat (limited to 'lua')
-rw-r--r--lua/custom/plugins/init.lua5
-rw-r--r--lua/kickstart/plugins/autoformat.lua74
-rw-r--r--lua/kickstart/plugins/debug.lua85
3 files changed, 164 insertions, 0 deletions
diff --git a/lua/custom/plugins/init.lua b/lua/custom/plugins/init.lua
new file mode 100644
index 0000000..be0eb9d
--- /dev/null
+++ b/lua/custom/plugins/init.lua
@@ -0,0 +1,5 @@
+-- You can add your own plugins here or in other files in this directory!
+-- I promise not to create any merge conflicts in this directory :)
+--
+-- See the kickstart.nvim README for more information
+return {}
diff --git a/lua/kickstart/plugins/autoformat.lua b/lua/kickstart/plugins/autoformat.lua
new file mode 100644
index 0000000..bc56b15
--- /dev/null
+++ b/lua/kickstart/plugins/autoformat.lua
@@ -0,0 +1,74 @@
+-- autoformat.lua
+--
+-- Use your language server to automatically format your code on save.
+-- Adds additional commands as well to manage the behavior
+
+return {
+ 'neovim/nvim-lspconfig',
+ config = function()
+ -- Switch for controlling whether you want autoformatting.
+ -- Use :KickstartFormatToggle to toggle autoformatting on or off
+ local format_is_enabled = true
+ vim.api.nvim_create_user_command('KickstartFormatToggle', function()
+ format_is_enabled = not format_is_enabled
+ print('Setting autoformatting to: ' .. tostring(format_is_enabled))
+ end, {})
+
+ -- Create an augroup that is used for managing our formatting autocmds.
+ -- We need one augroup per client to make sure that multiple clients
+ -- can attach to the same buffer without interfering with each other.
+ local _augroups = {}
+ local get_augroup = function(client)
+ if not _augroups[client.id] then
+ local group_name = 'kickstart-lsp-format-' .. client.name
+ local id = vim.api.nvim_create_augroup(group_name, { clear = true })
+ _augroups[client.id] = id
+ end
+
+ return _augroups[client.id]
+ end
+
+ -- Whenever an LSP attaches to a buffer, we will run this function.
+ --
+ -- See `:help LspAttach` for more information about this autocmd event.
+ vim.api.nvim_create_autocmd('LspAttach', {
+ group = vim.api.nvim_create_augroup('kickstart-lsp-attach-format', { clear = true }),
+ -- This is where we attach the autoformatting for reasonable clients
+ callback = function(args)
+ local client_id = args.data.client_id
+ local client = vim.lsp.get_client_by_id(client_id)
+ local bufnr = args.buf
+
+ -- Only attach to clients that support document formatting
+ if not client.server_capabilities.documentFormattingProvider then
+ return
+ end
+
+ -- Tsserver usually works poorly. Sorry you work with bad languages
+ -- You can remove this line if you know what you're doing :)
+ if client.name == 'tsserver' then
+ return
+ end
+
+ -- Create an autocmd that will run *before* we save the buffer.
+ -- Run the formatting command for the LSP that has just attached.
+ vim.api.nvim_create_autocmd('BufWritePre', {
+ group = get_augroup(client),
+ buffer = bufnr,
+ callback = function()
+ if not format_is_enabled then
+ return
+ end
+
+ vim.lsp.buf.format {
+ async = false,
+ filter = function(c)
+ return c.id == client.id
+ end,
+ }
+ end,
+ })
+ end,
+ })
+ end,
+}
diff --git a/lua/kickstart/plugins/debug.lua b/lua/kickstart/plugins/debug.lua
new file mode 100644
index 0000000..0b68c43
--- /dev/null
+++ b/lua/kickstart/plugins/debug.lua
@@ -0,0 +1,85 @@
+-- debug.lua
+--
+-- Shows how to use the DAP plugin to debug your code.
+--
+-- Primarily focused on configuring the debugger for Go, but can
+-- be extended to other languages as well. That's why it's called
+-- kickstart.nvim and not kitchen-sink.nvim ;)
+
+return {
+ -- NOTE: Yes, you can install new plugins here!
+ 'mfussenegger/nvim-dap',
+
+ -- NOTE: And you can specify dependencies as well
+ dependencies = {
+ -- Creates a beautiful debugger UI
+ 'rcarriga/nvim-dap-ui',
+
+ -- Installs the debug adapters for you
+ 'williamboman/mason.nvim',
+ 'jay-babu/mason-nvim-dap.nvim',
+
+ -- Add your own debuggers here
+ 'leoluz/nvim-dap-go',
+ },
+
+ config = function()
+ local dap = require 'dap'
+ local dapui = require 'dapui'
+
+ require('mason-nvim-dap').setup {
+ -- Makes a best effort to setup the various debuggers with
+ -- reasonable debug configurations
+ automatic_setup = true,
+
+ -- You'll need to check that you have the required things installed
+ -- online, please don't ask me how to install them :)
+ ensure_installed = {
+ -- Update this to ensure that you have the debuggers for the langs you want
+ 'delve',
+ },
+ }
+
+ -- You can provide additional configuration to the handlers,
+ -- see mason-nvim-dap README for more information
+ require('mason-nvim-dap').setup_handlers()
+
+ -- Basic debugging keymaps, feel free to change to your liking!
+ vim.keymap.set('n', '<F5>', dap.continue)
+ vim.keymap.set('n', '<F1>', dap.step_into)
+ vim.keymap.set('n', '<F2>', dap.step_over)
+ vim.keymap.set('n', '<F3>', dap.step_out)
+ vim.keymap.set('n', '<leader>b', dap.toggle_breakpoint)
+ vim.keymap.set('n', '<leader>B', function()
+ dap.set_breakpoint(vim.fn.input 'Breakpoint condition: ')
+ end)
+
+ -- Dap UI setup
+ -- For more information, see |:help nvim-dap-ui|
+ dapui.setup {
+ -- Set icons to characters that are more likely to work in every terminal.
+ -- Feel free to remove or use ones that you like more! :)
+ -- Don't feel like these are good choices.
+ icons = { expanded = '▾', collapsed = '▸', current_frame = '*' },
+ controls = {
+ icons = {
+ pause = '⏸',
+ play = '▶',
+ step_into = '⏎',
+ step_over = '⏭',
+ step_out = '⏮',
+ step_back = 'b',
+ run_last = '▶▶',
+ terminate = '⏹',
+ },
+ },
+ }
+
+ dap.listeners.after.event_initialized['dapui_config'] = dapui.open
+ dap.listeners.before.event_terminated['dapui_config'] = dapui.close
+ dap.listeners.before.event_exited['dapui_config'] = dapui.close
+
+ -- Install golang specific config
+ require('dap-go').setup()
+ end,
+}