vscode-server使用clangd语言服务器阅读代码

服务器端安装vscode-server

先查看pc端vscode版本,关注commit
在这里插入图片描述

接着根据commit id,通过如下网址可下载对应版本的vscode-server即 vscode-server-linux-x64.tar.gz

https://update.code.visualstudio.com/commit:${commit_id}/server-linux-x64/stable

将vscode-server-linux-x64.tar.gz拷贝到编译服务器的家目录下,接着在家目录下执行

mkdir .vscode-server/bin
tar -xf ./vscode-server-linux-x64.tar.gz -C ./.vscode-server/bin/
mv ./.vscode-server/bin/vscode-server-linux-x64 ./.vscode-server/bin/${commit_id} #这里${commit_id}替换成自己的

使用remote-ssh插件远程连接编译服务器

这里的操作步骤可参考https://blog.csdn.net/2201_75718536/article/details/137749653
正确连接上,如下图,在设置界面可以看到Remote [SSH: xxxxx]说明连接成功,在这里可以配置vscode-server的设置项
在这里插入图片描述

vscode-server安装clangd插件

插件的安装方式可自行百度,如果编译服务器不能连网,可以先在主机pc上安装好,然后从pc上的.vscode/extensions目录将需要的插件拷贝到服务器.vscode-server/extensions下,成功如下图:
在这里插入图片描述

​ 其他插件可以根据需要自行安装。

安装clangd语言服务器

clangd语言服务器是llvm工具集里的一个,所以其实需要安装的是llvm,可以选择自行下载源码编译,也可以使用官方发布的版本直接使用。下载链接
如果是ubuntu18.04 可以使用链接里的clang+llvm-15.0.0-powerpc64le-linux-ubuntu-18.04.6.tar.xz
下载下来后,在自己的编译服务器安装软件的地方解压,进入文件夹,直接执行一下文件夹内的bin/clangd,能运行起来就是能用的,
​ 之后将clangd依赖的动态库导出:

export LD_LIBRARY_PATH=/home/nx666/local/clangd/lib:$LD_LIBRARY_PATH   #/home/nx666/local/clangd/lib 是刚刚解压出来的绝对路径,可用pwd查看

​ 之后将clangd所在的路径配置到vscode-server里,图里显示的是我安装在root目录下的clangd,各位需要根据自己的clangd安装路径设置,路径最后需要指定到可执行文件clangd。

在这里插入图片描述

准备compile_commands.json文件

​ clangd需要compile_commands.json里的信息解析代码工程,笔者涉及的代码大多是用make编译的,所以使用bear来产生compile_commands.json。可自行编译bear,如果服务器环境和笔者一样可以使用

useful_tools: 收集好用的工具 - Gitee.com

指定clangd的配置信息

在.vscode/settings.json文件里面写入clangd的配置信息
需要注意的是:
–compile-commands-dir
–query-driver

"clangd.arguments": [
		//指定配置文件compelie_commands.json所在目录,compelie_commands.json的生成方法有:bear,cmake...
        "--compile-commands-dir=${workspaceFolder}/.vscode",
        // 在后台自动分析文件(基于complie_commands)
        "--background-index",
        // 同时开启的任务数量
        "-j=12",
        "--folding-ranges",
        // 指定交叉编译工具链的路径
        "--query-driver=/home/nx666/local/gcc-riscv/wch-riscv-embed-gcc/bin/riscv-none-embed*",
        // clang-tidy功能
        "--clang-tidy",
        "--clang-tidy-checks=performance-*,bugprone-*",
        // 全局补全(会自动补充头文件)
        "--all-scopes-completion",
        // 更详细的补全内容
        "--completion-style=detailed",
        "--function-arg-placeholders",
        // 补充头文件的形式
        "--header-insertion=iwyu",
        // pch优化的位置
        "--pch-storage=memory",
    ],
  • 8
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值