summaryrefslogtreecommitdiff
path: root/ale_linters
diff options
context:
space:
mode:
authorw0rp <w0rp@users.noreply.github.com>2018-07-22 20:55:01 +0100
committerGitHub <noreply@github.com>2018-07-22 20:55:01 +0100
commit9c849da8c471aa9f31ff0217a71f9d6178938a13 (patch)
treed9e1b292e570a4734602829ba4ae1db8c180c168 /ale_linters
parent6dc737cda1d640d2067b417ec270fbb623e3f960 (diff)
parent9b4963847d71ea7b53c0bf90a27d4b55fc0696fe (diff)
downloadale-9c849da8c471aa9f31ff0217a71f9d6178938a13.zip
Merge pull request #1751 from melentye/master
Add Clangd language server support for C
Diffstat (limited to 'ale_linters')
-rw-r--r--ale_linters/c/clangd.vim29
1 files changed, 29 insertions, 0 deletions
diff --git a/ale_linters/c/clangd.vim b/ale_linters/c/clangd.vim
new file mode 100644
index 00000000..5aa2e221
--- /dev/null
+++ b/ale_linters/c/clangd.vim
@@ -0,0 +1,29 @@
+" Author: Andrey Melentyev <andrey.melentyev@protonmail.com>
+" Description: Clangd language server
+
+call ale#Set('c_clangd_executable', 'clangd')
+call ale#Set('c_clangd_options', '')
+
+function! ale_linters#c#clangd#GetProjectRoot(buffer) abort
+ let l:project_root = ale#path#FindNearestFile(a:buffer, 'compile_commands.json')
+ return !empty(l:project_root) ? fnamemodify(l:project_root, ':h') : ''
+endfunction
+
+function! ale_linters#c#clangd#GetExecutable(buffer) abort
+ return ale#Var(a:buffer, 'c_clangd_executable')
+endfunction
+
+function! ale_linters#c#clangd#GetCommand(buffer) abort
+ let l:executable = ale_linters#c#clangd#GetExecutable(a:buffer)
+ let l:options = ale#Var(a:buffer, 'c_clangd_options')
+
+ return ale#Escape(l:executable) . (!empty(l:options) ? ' ' . l:options : '')
+endfunction
+
+call ale#linter#Define('c', {
+\ 'name': 'clangd',
+\ 'lsp': 'stdio',
+\ 'executable_callback': 'ale_linters#c#clangd#GetExecutable',
+\ 'command_callback': 'ale_linters#c#clangd#GetCommand',
+\ 'project_root_callback': 'ale_linters#c#clangd#GetProjectRoot',
+\})