Merge branch 'master' of github.com:ChristianChiarulli/LunarVim into stable

This commit is contained in:
christianchiarulli 2021-07-03 23:46:16 -04:00
commit ddc0c71dae
14 changed files with 99 additions and 65 deletions

View file

@ -19,3 +19,13 @@ require'lspconfig'.clangd.setup {
}) })
} }
} }
if O.lang.clang.autoformat then
require('lv-utils').define_augroups({
_clang_autoformat = {
{'BufWritePre *.c lua vim.lsp.buf.formatting_sync(nil,1000)'},
{'BufWritePre *.h lua vim.lsp.buf.formatting_sync(nil,1000)'},
{'BufWritePre *.cpp lua vim.lsp.buf.formatting_sync(nil,1000)'},
{'BufWritePre *.hpp lua vim.lsp.buf.formatting_sync(nil,1000)'},
}})
end

View file

@ -36,6 +36,8 @@ require'lspconfig'.tsserver.setup {
} }
} }
require'lsp.ts-fmt-lint'.setup()
if O.lang.tsserver.autoformat then if O.lang.tsserver.autoformat then
require('lv-utils').define_augroups({ require('lv-utils').define_augroups({
_javascript_autoformat = { _javascript_autoformat = {

View file

@ -36,6 +36,8 @@ require'lspconfig'.tsserver.setup {
} }
} }
require'lsp.ts-fmt-lint'.setup()
if O.lang.tsserver.autoformat then if O.lang.tsserver.autoformat then
require('lv-utils').define_augroups({ require('lv-utils').define_augroups({
_javascript_autoformat = { _javascript_autoformat = {

View file

@ -36,6 +36,8 @@ require'lspconfig'.tsserver.setup {
} }
} }
require'lsp.ts-fmt-lint'.setup()
if O.lang.tsserver.autoformat then if O.lang.tsserver.autoformat then
require('lv-utils').define_augroups({ require('lv-utils').define_augroups({
_javascript_autoformat = { _javascript_autoformat = {

View file

@ -36,6 +36,8 @@ require'lspconfig'.tsserver.setup {
} }
} }
require'lsp.ts-fmt-lint'.setup()
if O.lang.tsserver.autoformat then if O.lang.tsserver.autoformat then
require('lv-utils').define_augroups({ require('lv-utils').define_augroups({
_javascript_autoformat = { _javascript_autoformat = {

View file

@ -150,7 +150,8 @@ O = {
underline = true, underline = true,
}, },
cross_file_rename = true, cross_file_rename = true,
header_insertion = 'never' header_insertion = 'never',
autoformat = false -- update this to true for enabling autoformat
}, },
ruby = { ruby = {
diagnostics = { diagnostics = {

View file

@ -1,58 +0,0 @@
-- Example configuations here: https://github.com/mattn/efm-langserver
-- tsserver/web javascript react, vue, json, html, css, yaml
local prettier = {formatCommand = "prettier --stdin-filepath ${INPUT}", formatStdin = true}
-- You can look for project scope Prettier and Eslint with e.g. vim.fn.glob("node_modules/.bin/prettier") etc. If it is not found revert to global Prettier where needed.
-- local prettier = {formatCommand = "./node_modules/.bin/prettier --stdin-filepath ${INPUT}", formatStdin = true}
local eslint = {
lintCommand = "./node_modules/.bin/eslint -f unix --stdin --stdin-filename ${INPUT}",
lintIgnoreExitCode = true,
lintStdin = true,
lintFormats = {"%f:%l:%c: %m"},
formatCommand = "./node_modules/.bin/eslint --fix-to-stdout --stdin --stdin-filename=${INPUT}",
formatStdin = true
}
local tsserver_args = {}
if O.lang.tsserver.formatter == 'prettier' then table.insert(tsserver_args, prettier) end
if O.lang.tsserver.linter == 'eslint' then table.insert(tsserver_args, eslint) end
-- local markdownlint = {
-- -- TODO default to global lintrc
-- -- lintcommand = 'markdownlint -s -c ./markdownlintrc',
-- lintCommand = 'markdownlint -s',
-- lintStdin = true,
-- lintFormats = {'%f:%l %m', '%f:%l:%c %m', '%f: %l: %m'}
-- }
local markdownPandocFormat = {formatCommand = 'pandoc -f markdown -t gfm -sp --tab-stop=2', formatStdin = true}
require"lspconfig".efm.setup {
-- init_options = {initializationOptions},
cmd = {DATA_PATH .. "/lspinstall/efm/efm-langserver"},
init_options = {documentFormatting = true, codeAction = false},
filetypes = {"lua", "python", "javascriptreact", "javascript", "typescript","typescriptreact","sh", "html", "css", "yaml", "markdown", "vue"},
settings = {
rootMarkers = {".git/"},
languages = {
javascript = tsserver_args,
javascriptreact = tsserver_args,
typescript = tsserver_args,
typescriptreact = tsserver_args,
html = {prettier},
css = {prettier},
json = {prettier},
yaml = {prettier},
markdown = {markdownPandocFormat}
-- javascriptreact = {prettier, eslint},
-- javascript = {prettier, eslint},
-- markdown = {markdownPandocFormat, markdownlint},
}
}
}
-- Also find way to toggle format on save
-- maybe this will help: https://superuser.com/questions/439078/how-to-disable-autocmd-or-augroup-in-vim

66
lua/lsp/ts-fmt-lint.lua Normal file
View file

@ -0,0 +1,66 @@
-- Example configuations here: https://github.com/mattn/efm-langserver
-- You can look for project scope Prettier and Eslint with e.g. vim.fn.glob("node_modules/.bin/prettier") etc. If it is not found revert to global Prettier where needed.
local M = {}
M.setup = function()
local tsserver_args = {}
local prettier = {
formatCommand = "prettier --stdin-filepath ${INPUT}",
formatStdin = true
}
if vim.fn.glob("node_modules/.bin/prettier") then
prettier = {
formatCommand = "./node_modules/.bin/prettier --stdin-filepath ${INPUT}",
formatStdin = true
}
end
-- TODO global eslint?
local eslint = {
lintCommand = "./node_modules/.bin/eslint -f unix --stdin --stdin-filename ${INPUT}",
lintIgnoreExitCode = true,
lintStdin = true,
lintFormats = {"%f:%l:%c: %m"},
-- formatCommand = "./node_modules/.bin/eslint -f unix --fix --stdin-filename ${INPUT}", -- TODO check if eslint is the formatter then add this
formatStdin = true
}
if O.lang.tsserver.formatter == 'prettier' then
table.insert(tsserver_args, prettier)
end
if O.lang.tsserver.linter == 'eslint' then
table.insert(tsserver_args, eslint)
end
require"lspconfig".efm.setup {
-- init_options = {initializationOptions},
cmd = {DATA_PATH .. "/lspinstall/efm/efm-langserver"},
init_options = {documentFormatting = true, codeAction = false},
filetypes = {
"javascriptreact", "javascript", "typescript", "typescriptreact",
"html", "css", "yaml", "vue"
},
settings = {
rootMarkers = {".git/", "package.json"},
languages = {
javascript = tsserver_args,
javascriptreact = tsserver_args,
typescript = tsserver_args,
typescriptreact = tsserver_args,
html = {prettier},
css = {prettier},
json = {prettier},
yaml = {prettier}
-- javascriptreact = {prettier, eslint},
-- javascript = {prettier, eslint},
-- markdown = {markdownPandocFormat, markdownlint},
}
}
}
end
return M

View file

@ -30,7 +30,7 @@ M.config = function()
}, },
f = { f = {
description = {' Neovim Config Files'}, description = {' Neovim Config Files'},
command = 'lua require(\'telescope.builtin\').find_files({search_dirs = {"~/.config/nvim"}})' command = 'Telescope find_files cwd=' .. CONFIG_PATH
} }
-- e = {description = {' Marks '}, command = 'Telescope marks'} -- e = {description = {' Marks '}, command = 'Telescope marks'}
} }

View file

@ -213,7 +213,8 @@ local mappings = {
r = {"<cmd>Lspsaga rename<cr>", "Rename"}, r = {"<cmd>Lspsaga rename<cr>", "Rename"},
t = {"<cmd>LspTypeDefinition<cr>", "Type Definition"}, t = {"<cmd>LspTypeDefinition<cr>", "Type Definition"},
x = {"<cmd>cclose<cr>", "Close Quickfix"}, x = {"<cmd>cclose<cr>", "Close Quickfix"},
s = {"<cmd>Telescope lsp_document_symbols<cr>", "Document Symbols"}, s = {O.plugin.symbol_outline.active and "<cmd>SymbolsOutline<cr>" or
"<cmd> Telescope lsp_document_symbols<cr>", "Document Symbols"},
S = { S = {
"<cmd>Telescope lsp_dynamic_workspace_symbols<cr>", "<cmd>Telescope lsp_dynamic_workspace_symbols<cr>",
"Workspace Symbols" "Workspace Symbols"

View file

@ -1,2 +1,2 @@
#!/bin/bash #!/bin/bash
nvim -u ~/.config/nvcode/init.lua nvim -u ~/.config/nvim/init.lua

View file

@ -192,16 +192,16 @@ else
fi fi
if [ -e "$HOME/.config/nvim/init.lua" ]; then if [ -e "$HOME/.config/nvim/init.lua" ]; then
echo 'nvcode already installed' echo 'LunarVim already installed'
else else
# clone config down # clone config down
cloneconfig cloneconfig
# echo 'export PATH=$HOME/.config/nvim/utils/bin:$PATH' >>~/.zshrc # echo 'export PATH=$HOME/.config/nvim/utils/bin:$PATH' >>~/.zshrc
# echo 'export PATH=$HOME/.config/nvcode/utils/bin:$PATH' >>~/.bashrc # echo 'export PATH=$HOME/.config/lunarvim/utils/bin:$PATH' >>~/.bashrc
fi fi
echo "I recommend you also install and activate a font from here: https://github.com/ryanoasis/nerd-fonts" echo "I recommend you also install and activate a font from here: https://github.com/ryanoasis/nerd-fonts"
# echo "I also recommend you add 'set preview_images_method ueberzug' to ~/.config/ranger/rc.conf" # echo "I also recommend you add 'set preview_images_method ueberzug' to ~/.config/ranger/rc.conf"
# echo 'export PATH=/home/$USER/.config/nvcode/utils/bin:$PATH appending to zshrc/bashrc' # echo 'export PATH=/home/$USER/.config/lunarvim/utils/bin:$PATH appending to zshrc/bashrc'

View file

@ -83,6 +83,12 @@ O.lang.go.autoformat = true
-- rust -- rust
O.lang.rust.autoformat = true O.lang.rust.autoformat = true
-- clang
O.lang.clang.autoformat = false -- Set to true to enable auto-format in C/C++ files.
-- create custom autocommand field (This would be easy with lua) -- create custom autocommand field (This would be easy with lua)
-- Turn off relative_numbers -- Turn off relative_numbers