vim YouCompleteMe(YCM) llvm编译配置

编译环境及源码版本

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. 创建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开发环境

yum install python-devel

4. 拷贝YouCompleteMe到~/.vim/bundle 目录

5. 在 YouCompleteMe 目录下新建 ycm_build,并进入目录执行下面命令生成 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 :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 :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

    将 系统和项目的头文件地址加到 flags 中

  4.1 添加是系统 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,跳到 声明或定义处

你可能感兴趣的:(vim YouCompleteMe(YCM) llvm编译配置)