It is a CMake lsp based on tower-lsp and treesitter
cargo install neocmakelsp
The config of neocmakelsp is in nvim-lsp-config
, so just follow nvim-lsp-config
to setup it
neocmakelsp has two start ways: stdio
and Tcp
. Tcp
is for debug. If you want to help me and debug is , you should start it with Tcp
way.
local configs = require("lspconfig.configs")
local nvim_lsp = require("lspconfig")
if not configs.neocmake then
configs.neocmake = {
default_config = {
cmd = { "neocmakelsp", "--stdio" },
filetypes = { "cmake" },
root_dir = function(fname)
return nvim_lsp.util.find_git_ancestor(fname)
end,
single_file_support = true,-- suggested
on_attach = on_attach -- on_attach is the on_attach function you defined
}
}
nvim_lsp.neocmake.setup({})
end
if not configs.neocmake then
configs.neocmake = {
default_config = {
cmd = vim.lsp.rpc.connect('127.0.0.1','9257'),
filetypes = { "cmake" },
root_dir = function(fname)
return nvim_lsp.util.find_git_ancestor(fname)
end,
single_file_support = true,-- suggested
on_attach = on_attach -- on_attach is the on_attach function you defined
}
}
nvim_lsp.neocmake.setup({})
end
new version will not work on mac and windows, so I need your help
- watchfile
- complete
- symbol_provider
- On hover
- Format
- GO TO Definitation
- find_package
- include
- Search cli
- Get the project struct
- It is also a cli tool to format
capabilities = {
workspace = {
didChangeWatchedFiles = {
dynamicRegistration = true,
},
},
}
It will check CMakeCache.txt, and get weather the package is exist
- Undefined function check
format the file
Usage: neocmakelsp {format|--format|-F} [OPTIONS] <FormatPath>...
Arguments:
<FormatPath>... file or folder to format
Options:
-o, --override override
-h, --help Print help
It will read .editconfig file to format files, just set like
[CMakeLists.txt]
indent_style = tab
indent_size = 2
If you don't want to format a part, just comment Not Format Me
before that block