vim YouCompleteMe(YCM) llvm編譯配置

編譯環(huán)境及源碼版本

cmake-3.12.0

llvm-4.0.1

vim-81

一. llvm-clang 編譯安裝

1. 從clang官網上下載包含llvm、clang和libcxx等7個文件:

wget -c http://releases.llvm.org/4.0.1/llvm-4.0.1.src.tar.xz

wget -c http://releases.llvm.org/4.0.1/cfe-4.0.1.src.tar.xz

wget -c http://releases.llvm.org/4.0.1/clang-tools-extra-4.0.1.src.tar.xz

wget -c http://releases.llvm.org/4.0.1/compiler-rt-4.0.1.src.tar.xz

wget -c http://releases.llvm.org/4.0.1/libcxx-4.0.1.src.tar.xz

wget -c http://releases.llvm.org/4.0.1/libcxxabi-4.0.1.src.tar.xz

wget -c http://releases.llvm.org/4.0.1/libunwind-4.0.1.src.tar.xz

2. 解壓所有文件,并按以下操作移動目錄到指定位置

?mv llvm-4.0.1.src llvm

?mv cfe-4.0.1.src llvm/tools/clang

?mv clang-tools-extra-4.0.1.src llvm/tools/clang/tools/extra

?mv compiler-rt-4.0.1.src llvm/projects/compiler-rt

?mv libcxx-4.0.1.src llvm/projects/libcxx

?mv libcxxabi-4.0.1.src llvm/projects/libcxxabi

?mv libunwind-4.0.1.src llvm/projects/libunwind

3. 創(chuàng)建cmake的編譯目錄:build

4. 進入build目錄,開始編譯生成Makefile文件

cmake -G "Unix Makefiles" -DCMAKE_C_COMPILER=gcc -DCMAKE_CXX_COMPILER=g++ -DCLANG_DEFAULT_CXX_STDLIB=libc++ -DCMAKE_BUILD_TYPE="Release" ../llvm

5. 開始編譯

make -j4

6. 編譯完成,安裝llvm

make install

7. 安裝 libcxx 和 libcxxabi

使用命令 make install-cxx install-cxxabi 安裝 clang/clang++ 所需要的 libc++ 庫

二. 編譯vim81

1. 下載并解壓vim81源碼

wget -c ftp://ftp.vim.org/pub/vim/unix/vim-8.1.tar.bz2 tar jxf vim-8.1.tar.bz2

2. 編譯安裝

cd vim-8.1

./configure --with-features=huge --enable-pythoninterp=yes --enable-cscope --enable-perlinterp=yes --enable-rubyinterp=yes --enable-multibyte --with-x --enable-fail-if-missing --with-python-config-dir=/usr/lib64/python2.7/config/ --prefix=/opt/vim81

make -j4

make install

三. 編譯ycm_core

1. 下載最新的 YouCompleteMe

git clone --recursive https://github.com/Valloric/YouCompleteMe.git

2. 檢查完整性

git submodule update --init --recursive

3. 安裝python開發(fā)環(huán)境

yum install python-devel

4. 拷貝YouCompleteMe到~/.vim/bundle 目錄

5. 在 YouCompleteMe 目錄下新建 ycm_build,并進入目錄執(zhí)行下面命令生成 Makefile 文件

cmake -G "Unix Makefiles" -DUSE_CLANG_COMPLETER=ON -DPATH_TO_LLVM_ROOT=/opt/llvm-4.0.1/ -DEXTERNAL_LIBCLANG_PATH=/opt/llvm-4.0.1/lib/libclang.so ~/.vim/bundle/YouCompleteMe/third_party/ycmd/cpp/

6. 編譯以生成 ycm_core 文件

make ycm_core

至此,YouCompleteMe 安裝成功

四. 詳細配置

1. 配置 ycm_extra_conf.py

cp ~/.vim/bundle/YouCompleteMe/third_party/ycmd/examples/.ycm_extra_conf.py ~/

2. 配置 .vimrc

2.1 加載YCM插件

call vundle#begin()

Plugin 'gmarik/Vundle.vim'

Plugin 'Valloric/YouCompleteMe'

call vundle#end()

2.2 YCM配置

----------------- YCM CONFIG BEGIN -----------------

set completeopt=longest,menu "讓Vim的補全菜單行為與一般IDE一致(參考VimTip1228)

autocmd InsertLeave * if pumvisible() == 0|pclose|endif "離開插入模式后自動關閉預覽窗口

inoremappumvisible() ? "\" : "\" "回車即選中當前項

let g:ycm_show_diagnostics_ui = 0 "關閉語法提示

let g:ycm_global_ycm_extra_conf = '/opt/vim81/share/vim/ycm_extra_conf.py'

let g:ycm_confirm_extra_conf=0 "關閉加載.ycm_extra_conf.py提示

let g:ycm_autoclose_preview_window_after_completion=1

let g:ycm_collect_identifiers_from_tags_files=1 " 開啟 YCM 基于標簽引擎

let g:ycm_min_num_of_chars_for_completion=1 " 從第2個鍵入字符就開始羅列匹配項

let g:ycm_cache_omnifunc=0 " 禁止緩存匹配項,每次都重新生成匹配項

let g:ycm_seed_identifiers_with_syntax=0 " 語法關鍵字補全

" force recomile with syntastic

nnoremap <F5> :YcmForceCompileAndDiagnostics

let g:ycm_complete_in_comments = 0 "在注釋輸入中也能補全

let g:ycm_complete_in_strings = 0"在字符串輸入中也能補全

let g:ycm_collect_identifiers_from_comments_and_strings = 0 "注釋和字符串中的文字也會被收入補全

let g:clang_user_options='|| exit 0'

let g:ycm_keep_logfiles = 1

let g:ycm_log_level = 'debug'

"同時,YCM可以打開location-list來顯示警告和錯誤的信息:YcmDiags

let g:ycm_error_symbol = '?'

let g:ycm_warning_symbol = '?'

nmap <F6> :YcmDiags

set tags+=/usr/include/c++/4.8.5/stdcpp.tags

let OmniCpp_DefaultNamespaces = ["_GLIBCXX_STD"]

let mapleader=";"

let maplocalleader=";"

nnoremap:YcmCompleter GoToDefinitionElseDeclaration " 按 F3鍵 跳轉到定義處

----------------- YCM CONFIG END? -----------------

3. 自動補全C++

編譯支持 clang golang 自動補全

cd ~/.vim/bundle/YouCompleteMe$

../install.py --clang-completer --go-completer

? cd /usr/include/c++/4.8.5

? ctags -R --c++-kinds=+l+x+p --fields=+iaSl --extra=+q --language-force=c++ -f stdcpp.tags

? 在 vim 中引入該標簽文件。在 .vimrc 中增加如下內容:

? ? set tags+=/usr/include/c++/4.8/stdcpp.tags

? ? let OmniCpp_DefaultNamespaces = ["_GLIBCXX_STD"]?

讓 OmniCppComplete 成功識別標簽文件中的標準庫接口。C++ 標準庫源碼文件中使用了 _GLIBCXX_STD 名字空間,

(GNU C++ 標準庫的實現是這樣,如果你使用其他版本的標準庫,需要自行查找對應的名字空間名稱),

標簽文件里面的各個標簽都嵌套在該名字空間下,要讓 OmniCppComplete 正確識別這些標簽,

必須顯式告知 OmniCppComplete 相應的名字空間名稱。

4. 配置 ycm_extra_conf.py

? ? 將 系統(tǒng)和項目的頭文件地址加到 flags 中

? 4.1 添加是系統(tǒng) include 路徑

用命令查看庫路徑

echo | clang -v -E -x c++ -

#include "..." search starts here:

#include <...> search starts here:

/opt/llvm-4.0.1/bin/../include/c++/v1

/usr/local/include

/opt/llvm-4.0.1/bin/../lib/clang/4.0.1/include

/usr/include

End of search list.

將上面的 include 目錄加入到 flags中

'-isystem',

'/opt/llvm-4.0.1/bin/../include/c++/v1',

'-isystem',

'/usr/local/include',

'-isystem',

'/opt/llvm-4.0.1/bin/../lib/clang/4.0.1/include',

'-isystem',

'/usr/include',

? 4.2 添加項目頭文件路徑到 flags 中

'-I',

'/home/user/projects/include', # 此處填寫項目頭文件路徑

5. 驗證YCM

? ? 用 vim81 打開一個cpp源碼文件,輸入命令? :YcmDiags,查看 ycmd 正常運行

? ? 將光標移動到一個函數名上,按F3或輸入命令 :YcmCompleter GoToDefinitionElseDeclaration,跳到 聲明或定義處

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容