Testowałem, clangdaby 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-lspdział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-lspwymaga async.vimw 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 gdna abcod
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( $PATHdomyś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.)