J'ai testé clangd
pour voir si les fonctions surchargées sont réellement distinguées lors de la recherche de la définition correcte à partir d'une ligne de code où l'une des fonctions surchargées est utilisée. Dans ma configuration de test minimale en utilisant le plugin vim, vim-lsp
cela a fonctionné.
Configuration minimale
$MYVIMRC
est
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
Dont l' installation vim-lsp
nécessite async.vim
dans 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/
Maintenant, votre configuration vim devrait ressembler (en omettant les fichiers et dossiers plus profondément imbriqués)
~/.vim
❯ tree -L 4 -F
.
├── pack/
│ └── prabirshrestha/
│ └── start/
│ ├── async.vim/
│ └── vim-lsp/
└── vimrc
5 directories, 1 file
Tester
Considérez maintenant le fichier 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;
}
En appuyant gd
sur abc
de
abc(1,2)
saute à la première ligne et
abc(1,2,3)
saute à la cinquième ligne.
Environnement et versions:
vim
: MacVim 8.1.950 (155); installé à partir de DMG à partir de github sur macOS 10.14.3
clangd
: 7.0.0; installé avec $ brew install llvm
(pas $PATH
par défaut, utilisez le chemin absolu)
vim-lsp
: e3f6933 (7 mars 2019) et async.vim
: f301455 (13 févr.2019 )