使用 clangd 取代 cpptools 作为 vscode 的 C/C++ LSP
起因
vscode 官方推荐的 C/C++ 插件是 cpptools,但是这个插件十分吃资源,并且容易崩溃。在网上看了一下,吐槽这个问题的并不是我一个人,遂决定换一个。经过一番比较,决定使用 clangd 来取代 cpptools 作为新的 C/C++ LSP。
我们直接在扩展里选择 clangd 安装并启用,这里注意 clangd 与 cpptools 存在冲突,所以首先要把 cpptools 卸载。
问题
接下来的问题是,clangd 需要有一个 compile_commands.json
文件才能工作,这一点是比不上之前的 cpptools 安装即用方便的。
解决方案
CMAKE 项目
对于 CMake 项目,比较简单,只需要定义 CMAKE_EXPORT_COMPILE_COMMANDS
即可导出该文件,这也是最容易的操作方案:
cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1
Makefile 项目
对于 Makefile 项目,官方并没有给出推荐的解决办法,这里我找到了两个解决办法:
- 一个是使用
bear
。
一般Linux发行版都可以用自带包管理器安装,Ununtu下安装命令为:
sudo apt install bear
使用 bear 生成 compile_commands.json 时,只需要在原本的编译命令前添加 bear 前缀即可,如:
bear make -C src
- 另一种方式是使用python编写的工具
compiledb
。
安装命令:
sudo pip install compiledb
使用方式同样是在原有make命令前添加 compiledb 前缀。特别的,只生成 compile_commands.json 不编译项目,可以使用 -n
选项:
compiledb -n make