Compare commits

..

3 Commits

Author SHA1 Message Date
Kenneth Benzie (Benie)
94a4116235 Of course pyright is an npm package 2024-04-15 13:11:17 -07:00
298cc9dcfe Cleanup conditional language server installs 2024-04-15 20:50:06 +01:00
Kenneth Benzie (Benie)
a3bd327696 Handle mason.nvim install deps not existing 2024-04-15 05:19:39 -07:00
30 changed files with 60 additions and 156 deletions

View File

@@ -0,0 +1 @@
autocmd BufNewFile,BufReadPost CMakeCache.txt set filetype=cmakecache

2
after/ftdetect/cpp.vim Normal file
View File

@@ -0,0 +1,2 @@
" Force *.def to C++ filetype for LLVM
au BufNewFile,BufReadPost *.def set filetype=cpp

3
after/ftdetect/llvm.vim Normal file
View File

@@ -0,0 +1,3 @@
" Set .ll files to LLVM IR filetype
au BufNewFile,BufReadPost *.ll set filetype=llvm
au BufNewFile,BufReadPost *.test set filetype=llvm

View File

@@ -0,0 +1,3 @@
" Force *.md to markdown filetype
au BufNewFile,BufReadPost *.md set filetype=markdown
au BufNewFile,BufReadPost *.ronn set filetype=markdown

View File

@@ -0,0 +1,2 @@
" Force *.cl to OpenCL C filetype
au BufNewFile,BufReadPost *.cl set filetype=opencl

View File

@@ -0,0 +1,3 @@
" Force lit.cfg/lit.local.cfg to be Python
au BufNewFile,BufReadPost lit.cfg set filetype=python
au BufNewFile,BufReadPost lit.local.cfg set filetype=python

View File

@@ -0,0 +1 @@
autocmd BufNewFile,BufReadPost */requirements.txt set filetype=requirements

View File

@@ -0,0 +1,2 @@
" Force *.td to tablegen filetype
au BufNewFile,BufReadPost *.td set filetype=tablegen

3
after/ftdetect/zsh.vim Normal file
View File

@@ -0,0 +1,3 @@
" Force .enter/.exit to be zsh
au BufNewFile,BufReadPost .enter set filetype=zsh
au BufNewFile,BufReadPost .exit set filetype=zsh

View File

@@ -1,5 +1,4 @@
vim.opt.spell = true vim.opt.spell = true
vim.opt.textwidth = 72
-- Auto-wrap text using textwidth -- Auto-wrap text using textwidth
vim.opt.formatoptions:append('t') vim.opt.formatoptions:append('t')

View File

@@ -1,6 +0,0 @@
vim.opt.expandtab = false
vim.opt.tabstop = 4
vim.opt.shiftwidth = 4
vim.opt.softtabstop = 4
vim.wo.listchars = 'extends:»,nbsp:⦸,precedes:«,tab: ,trail:·'
vim.bo.formatprg = 'gofmt'

View File

@@ -1,5 +1,11 @@
vim.g.mapleader = ' ' require('settings')
vim.g.maplocalleader = ' ' require('mappings')
require('commands')
require('netrw')
require('autocmds')
require('statusline')
require('ui')
require('build')
local lazypath = vim.fn.stdpath('data') .. '/lazy/lazy.nvim' local lazypath = vim.fn.stdpath('data') .. '/lazy/lazy.nvim'
if not vim.loop.fs_stat(lazypath) then if not vim.loop.fs_stat(lazypath) then

View File

@@ -1,40 +1,41 @@
local opts = { remap = false, silent = true } vim.g.mapleader = ' '
-- Quick write -- Quick write
vim.keymap.set('n', '<leader>w', ':w!<CR>', opts) vim.keymap.set('n', '<leader>w', ':w!<CR>', { remap = false })
-- Treat long lines as line containing breaks -- Treat long lines as line containing breaks
vim.keymap.set('n', 'j', 'gj', opts) vim.keymap.set('n', 'j', 'gj', { remap = false })
vim.keymap.set('n', 'k', 'gk', opts) vim.keymap.set('n', 'k', 'gk', { remap = false })
vim.keymap.set('n', '<leader>tn', ':tabnew<Space>', { remap = false }) vim.keymap.set('n', '<leader>tn', ':tabnew<Space>', { remap = false })
vim.keymap.set('n', '<leader>tc', ':tabclose<CR>', { remap = false })
vim.keymap.set('n', '<leader>to', ':tabonly<CR>', { remap = false })
vim.keymap.set('n', '<leader>tm', ':tabmove<Space>', { remap = false }) vim.keymap.set('n', '<leader>tm', ':tabmove<Space>', { remap = false })
vim.keymap.set('n', '<leader>tc', ':tabclose<CR>', opts)
vim.keymap.set('n', '<leader>to', ':tabonly<CR>', opts)
-- Quickly access spelling menu -- Quickly access spelling menu
vim.keymap.set('i', '<C-s>', '<C-g>u<C-X>s', opts) vim.keymap.set('i', '<C-s>', '<C-g>u<C-X>s', { remap = false })
vim.keymap.set('n', '<C-s>', 'i<C-g>u<C-X>s', opts) vim.keymap.set('n', '<C-s>', 'i<C-g>u<C-X>s', { remap = false })
-- Clear search highlights -- Clear search highlights
vim.keymap.set('n', '<leader><Space>', ':nohlsearch<CR>', opts) vim.keymap.set('n', '<leader><Space>', ':nohlsearch<CR>', { remap = false })
-- Disable 'Q' from opening Ex mode -- Disable 'Q' from opening Ex mode
vim.keymap.set('n', 'Q', '<nop>', opts) vim.keymap.set('n', 'Q', '<nop>', { remap = false })
-- System clipboard yank/put -- System clipboard yank/put
vim.keymap.set('', '<leader>y', '"+y', opts) vim.keymap.set('', '<leader>y', '"+y', { remap = false })
vim.keymap.set('', '<leader>Y', '"+Y', opts) vim.keymap.set('', '<leader>Y', '"+Y', { remap = false })
vim.keymap.set('', '<leader>p', '"+p', opts) vim.keymap.set('', '<leader>p', '"+p', { remap = false })
vim.keymap.set('', '<leader>P', '"+P', opts) vim.keymap.set('', '<leader>P', '"+P', { remap = false })
-- Undo neovim's default mapping of Y to y$ -- Undo neovim's default mapping of Y to y$
vim.cmd.unmap('Y') vim.cmd.unmap('Y')
-- Make nvim :terminal more like vim :terminal -- Make nvim :terminal more like vim :terminal
vim.keymap.set('t', '<C-w>N', '<C-\\><C-n>', opts) vim.keymap.set('t', '<C-w>N', '<C-\\><C-n>', { remap = true })
-- Mappings to make navigating :Termdebug -- Mappings to make navigating :Termdebug
local opts = { remap = false, silent = true }
vim.keymap.set('n', '<C-w><C-g>', ':Gdb<CR>:startinsert<CR>', opts) vim.keymap.set('n', '<C-w><C-g>', ':Gdb<CR>:startinsert<CR>', opts)
vim.keymap.set('n', '<C-w><C-e>', ':Program<CR>', opts) vim.keymap.set('n', '<C-w><C-e>', ':Program<CR>', opts)
vim.keymap.set('n', '<C-w><C-s>', ':Source<CR>', opts) vim.keymap.set('n', '<C-w><C-s>', ':Source<CR>', opts)

View File

@@ -1,4 +1,4 @@
local kanagawa = { return {
'rebelot/kanagawa.nvim', 'rebelot/kanagawa.nvim',
config = function() config = function()
local kanagawa = require('kanagawa') local kanagawa = require('kanagawa')
@@ -25,15 +25,9 @@ local kanagawa = {
kanagawa.load('dragon') kanagawa.load('dragon')
-- Override highlight groups -- Override highlight groups
vim.cmd.highlight('TabLine', 'guifg=#949494', 'guibg=' .. dragon.ui.bg_m3)
vim.cmd.highlight('TabLineFill', 'guibg=' .. dragon.ui.bg_gutter)
vim.cmd.highlight('TabLineSel', 'guifg=#c8c093', 'guibg=' .. dragon.ui.bg_m3)
vim.cmd.highlight('WinSeparator', 'guifg=' .. dragon.ui.bg_m3, 'guibg=' .. dragon.ui.bg_m3) vim.cmd.highlight('WinSeparator', 'guifg=' .. dragon.ui.bg_m3, 'guibg=' .. dragon.ui.bg_m3)
vim.cmd.highlight('MsgSeparator', 'guifg=' .. dragon.ui.bg_m3, 'guibg=' .. dragon.ui.bg_m3) vim.cmd.highlight('MsgSeparator', 'guifg=' .. dragon.ui.bg_m3, 'guibg=' .. dragon.ui.bg_m3)
vim.cmd.highligh('TreesitterContext', 'guibg=' .. dragon.ui.bg_gutter) vim.cmd.highligh('TreesitterContext', 'guibg=' .. dragon.ui.bg_gutter)
vim.cmd.highlight('link zshTodo Comment') vim.cmd.highlight('link zshTodo Comment')
end end
} }
return kanagawa

View File

@@ -41,8 +41,7 @@ return {
'neovim/nvim-lspconfig', 'neovim/nvim-lspconfig',
dependencies = { dependencies = {
-- Language server management plugins -- Language server management plugins
-- 'williamboman/mason.nvim', 'williamboman/mason.nvim',
'kbenzie/mason.nvim',
'williamboman/mason-lspconfig.nvim', 'williamboman/mason-lspconfig.nvim',
-- Completion sources plugins -- Completion sources plugins
@@ -72,10 +71,6 @@ return {
}, },
config = function() config = function()
local capabilities = vim.lsp.protocol.make_client_capabilities()
capabilities = vim.tbl_deep_extend(
'force', capabilities, require('cmp_nvim_lsp').default_capabilities())
require('mason').setup() require('mason').setup()
require('mason-lspconfig').setup({ require('mason-lspconfig').setup({
automatic_installation = false, automatic_installation = false,
@@ -85,22 +80,12 @@ return {
-- Default handler, sets up everything unless a custom language server -- Default handler, sets up everything unless a custom language server
-- setup handler is defined below -- setup handler is defined below
function(server_name) function(server_name)
require('lspconfig')[server_name].setup({ require('lspconfig')[server_name].setup({})
capabilities = capabilities,
})
end,
['clangd'] = function()
require('lspconfig').clangd.setup({
capabilities = capabilities,
cmd = { 'clangd', '--completion-style=detailed' }
})
end, end,
['lua_ls'] = function() ['lua_ls'] = function()
require('neodev').setup() require('neodev').setup()
require('lspconfig').lua_ls.setup({ require('lspconfig').lua_ls.setup({
capabilities = capabilities,
settings = { settings = {
Lua = { Lua = {
diagnostics = { diagnostics = {
@@ -114,7 +99,6 @@ return {
['pyright'] = function() ['pyright'] = function()
require('lspconfig').pyright.setup({ require('lspconfig').pyright.setup({
capabilities = capabilities,
settings = { settings = {
pyright = { pyright = {
disableOrganizeImports = true, -- Use ruff import sorter instead disableOrganizeImports = true, -- Use ruff import sorter instead
@@ -154,20 +138,6 @@ return {
{ name = 'git' }, { name = 'git' },
}, },
formatting = {
format = function(entry, vim_item)
-- Set a limit to how wide the completion menu can be
local winwidth = vim.fn.winwidth(vim.api.nvim_get_current_win())
local menuwidth = math.min(winwidth / 2, 70)
if menuwidth < 70 then
vim_item.menu = ''
vim_item.kind = ''
end
vim_item.abbr = string.sub(vim_item.abbr, 1, menuwidth)
return vim_item
end
},
window = { window = {
completion = cmp.config.window.bordered(), completion = cmp.config.window.bordered(),
documentation = cmp.config.window.bordered(), documentation = cmp.config.window.bordered(),
@@ -209,10 +179,6 @@ return {
-- Format whole buffer mapping -- Format whole buffer mapping
vim.keymap.set('n', '<leader>gq', vim.lsp.buf.format, opts) vim.keymap.set('n', '<leader>gq', vim.lsp.buf.format, opts)
-- Swtich file using clangd extension
-- TODO: limit this to only filetypes supported by clangd
vim.keymap.set('n', '<leader>sf', ':ClangdSwitchSourceHeader<CR>', { silent = true })
end end
}) })

View File

@@ -1,5 +1,4 @@
return { return {
-- TODO: v0.10.0 might have builtins snippets?
'L3MON4D3/LuaSnip', 'L3MON4D3/LuaSnip',
build = 'make install_jsregexp', build = 'make install_jsregexp',
config = function() config = function()

View File

@@ -5,11 +5,9 @@ return {
'nvim-telescope/telescope-fzy-native.nvim', 'nvim-telescope/telescope-fzy-native.nvim',
'nvim-tree/nvim-web-devicons', 'nvim-tree/nvim-web-devicons',
'axkirillov/easypick.nvim', 'axkirillov/easypick.nvim',
'catgoose/telescope-helpgrep.nvim',
}, },
config = function() config = function()
local telescope = require('telescope') local telescope = require('telescope')
local actions = require('telescope.actions')
telescope.setup({ telescope.setup({
defaults = { defaults = {
mappings = { mappings = {
@@ -22,39 +20,23 @@ return {
['<C-s>'] = 'select_horizontal', ['<C-s>'] = 'select_horizontal',
['<C-h>'] = 'preview_scrolling_left', ['<C-h>'] = 'preview_scrolling_left',
['<C-l>'] = 'preview_scrolling_right', ['<C-l>'] = 'preview_scrolling_right',
}, }
}, },
layout_config = { layout_config = {
height = 0.7, height = 0.7,
}, }
},
extensions = {
helpgrep = {
mappings = {
i = {
["<CR>"] = actions.select_default,
["<C-v>"] = actions.select_vertical,
},
n = {
["<CR>"] = actions.select_default,
["<C-s>"] = actions.select_horizontal,
}
},
},
}, },
}) })
telescope.load_extension('fzy_native') telescope.load_extension('fzy_native')
local builtin = require('telescope.builtin') -- TODO: Add more mappings?
local opts = { noremap = true } local opts = { noremap = true }
vim.keymap.set('n', '<leader>gF', builtin.find_files, opts) vim.keymap.set('n', '<leader>gF', ':Telescope find_files<CR>', opts)
vim.keymap.set('n', '<leader>gf', builtin.git_files, opts) vim.keymap.set('n', '<leader>gf', ':Telescope git_files<CR>', opts)
vim.keymap.set('n', '<leader>gg', builtin.live_grep, opts) vim.keymap.set('n', '<leader>gg', ':Telescope live_grep<CR>', opts)
vim.keymap.set('n', '<leader>rg', builtin.grep_string, opts) vim.keymap.set('n', '<leader>rg', ':Telescope grep_string<CR>', opts)
vim.keymap.set('n', '<leader>gb', builtin.buffers, opts) vim.keymap.set('n', '<leader>gb', ':Telescope buffers<CR>', opts)
vim.keymap.set('n', '<leader>ht', builtin.help_tags, opts) vim.keymap.set('n', '<leader>gh', ':Telescope help_tags<CR>', opts)
vim.keymap.set('n', '<leader>gh', require('telescope-helpgrep').live_grep, opts)
vim.keymap.set('n', '<leader>bl', builtin.current_buffer_fuzzy_find, opts)
require('easypick').setup({ require('easypick').setup({
pickers = { }, pickers = { },

View File

@@ -48,7 +48,6 @@ return {
'lua', 'lua',
'make', 'make',
'markdown', 'markdown',
'markdown_inline',
'meson', 'meson',
'ninja', 'ninja',
'objc', 'objc',
@@ -80,9 +79,6 @@ return {
lookahead = true, lookahead = true,
-- include_surrounding_whitespace = true, -- include_surrounding_whitespace = true,
keymaps = { keymaps = {
-- Class text objects
['ac'] = '@class.outer',
['ic'] = '@class.inner',
-- Function text objects -- Function text objects
['af'] = '@function.outer', ['af'] = '@function.outer',
['if'] = '@function.inner', ['if'] = '@function.inner',

View File

@@ -22,7 +22,6 @@ local noice = {
signature = { enable = false }, signature = { enable = false },
message = { enable = false }, message = { enable = false },
}, },
signature = { enabled = false },
}) })
-- Override highlight groups -- Override highlight groups

View File

@@ -109,7 +109,7 @@ end
-- Define active statusline, this statusline is dynamic with StatusLineLight -- Define active statusline, this statusline is dynamic with StatusLineLight
-- being updated based on the current mode and only used for current buffer. -- being updated based on the current mode and only used for current buffer.
function _G.statusline_active() function statusline.active()
local mode = get_mode() local mode = get_mode()
if vim.o.buftype == 'help' then if vim.o.buftype == 'help' then
if mode == 'Normal' then mode = 'Help' end if mode == 'Normal' then mode = 'Help' end
@@ -138,7 +138,7 @@ function _G.statusline_active()
return generic('StatusLineLight', mode, true) return generic('StatusLineLight', mode, true)
end end
function _G.statusline_inactive() function statusline.inactive()
local mode = modes[vim.fn.char2nr(vim.fn.mode())].name local mode = modes[vim.fn.char2nr(vim.fn.mode())].name
local line = '' local line = ''
if vim.o.buftype == 'help' then if vim.o.buftype == 'help' then
@@ -169,7 +169,7 @@ vim.api.nvim_create_autocmd({ 'BufEnter', 'WinEnter', 'BufWinEnter' }, {
pattern = '*', pattern = '*',
group = group, group = group,
callback = function() callback = function()
vim.cmd.setlocal("statusline=%{%v:lua.statusline_active()%}") vim.cmd.setlocal("statusline=%{%v:lua.require('statusline').active()%}")
end end
}) })
@@ -178,7 +178,7 @@ vim.api.nvim_create_autocmd({ 'BufLeave', 'WinLeave' }, {
pattern = '*', pattern = '*',
group = group, group = group,
callback = function() callback = function()
vim.cmd.setlocal("statusline=%{%v:lua.statusline_inactive()%}") vim.cmd.setlocal("statusline=%{%v:lua.require('statusline').inactive()%}")
end end
}) })

View File

@@ -1,19 +0,0 @@
vim.filetype.add({
extension = {
cl = 'opencl',
def = 'cpp',
ll = 'llvm',
md = 'markdown',
ronn = 'markdown',
td = 'tablegen',
test = 'llvm',
},
filename = {
['.enter'] = 'zsh',
['.exit'] = 'zsh',
['CMakeCache.txt'] = 'cmakecache',
['lit.cfg'] = 'python',
['lit.local.cfg'] = 'python',
['requirements.txt'] = 'requirements',
},
})

View File

@@ -1,19 +1,7 @@
# Global SnipMate snippets # Global SnipMate snippets
snippet joy
(◦U ◡ U◦)
snippet shrug snippet shrug
¯\_(ツ)_/¯ ¯\_(ツ)_/¯
snippet confuse
(ノ*・_・)ノ
snippet tableflip snippet tableflip
(╯°▪°)╯︵┻━┻ (╯°▪°)╯︵┻━┻
snippet cry
(ㅠ﹏ㅠ)
snippet think
(╭ರ_•́)

View File

@@ -1,15 +0,0 @@
# Python SnipMate snippets
snippet main
def main():
${0:pass}
if __name__ == '__main__':
try:
main()
except KeyboardInterrupt:
exit(130)
snippet debug
import ipdb; ipdb.set_trace()

View File

@@ -1,6 +0,0 @@
# reStructuredText snippets
snippet code
.. code-block:: ${1:language}
$0