Testowałem, clangd
aby sprawdzić, czy przeciążone funkcje są rzeczywiście rozróżniane, gdy szukamy poprawnej definicji z linii kodu, w której używana jest jedna z przeciążonych funkcji. W mojej minimalnej konfiguracji testowania przy użyciu wtyczki vim vim-lsp
działało.
Minimalna konfiguracja
$MYVIMRC
jest
source $VIMRUNTIME/defaults.vim
if executable('/usr/local/Cellar/llvm/7.0.0/bin/clangd')
augroup Clangd
autocmd User lsp_setup call lsp#register_server({
\ 'name': 'clangd',
\ 'cmd': {server_info->['/usr/local/Cellar/llvm/7.0.0/bin/clangd']},
\ 'whitelist': ['c', 'cpp', 'objc', 'objcpp'],
\ })
autocmd FileType c,cpp,objc,objcpp nmap <buffer> gd <plug>(lsp-definition)
autocmd FileType c,cpp,objc,objcpp setlocal omnifunc=lsp#complete
augroup END
endif
Instalacja tego vim-lsp
wymaga async.vim
w vim8 packpath
$ cd ~/.vim
$ git clone https://github.com/prabirshrestha/async.vim pack/prabirshrestha/start/async.vim/
$ git clone https://github.com/prabirshrestha/vim-lsp pack/prabirshrestha/start/vim-lsp/
Teraz powinna wyglądać twoja konfiguracja vima (z pominięciem bardziej zagnieżdżonych plików i folderów)
~/.vim
❯ tree -L 4 -F
.
├── pack/
│ └── prabirshrestha/
│ └── start/
│ ├── async.vim/
│ └── vim-lsp/
└── vimrc
5 directories, 1 file
Test
Teraz rozważ plik cpp
void abc(int a, int b) {
}
void abc(int a, int b, int c) {
}
int main(int argc, char const *argv[])
{
abc(1,2);
abc(1,2,3);
return 0;
}
Naciśnięcie gd
na abc
od
abc(1,2)
przeskakuje do pierwszej linii i
abc(1,2,3)
przeskakuje do piątej linii.
Środowisko i wersje:
vim
: MacVim 8.1.950 (155); zainstalowany z DMG z github na macOS 10.14.3
clangd
: 7.0.0; zainstalowany z $ brew install llvm
( $PATH
domyślnie nie jest używany, użyj ścieżki bezwzględnej)
vim-lsp
: e3f6933 (7 marca 2019 r.) i async.vim
: f301455 (13 lutego 2019 r.)