Skip to content

Commit 822c53b

Browse files
author
li.tao
committed
[doc] add workspace tool
1 parent 0f587dd commit 822c53b

11 files changed

+136
-0
lines changed
Lines changed: 130 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,130 @@
1+
# 在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
2+
3+
## 简介
4+
5+
vscode 号称宇宙第一编辑器,但是在用master开发RT-THREAD的时候,大家似乎都会遇到以下问题:
6+
7+
- master上bsp下面的文件太多
8+
- Keil开发起来倒是干净了很多,但上古的编辑器很不美观
9+
- 想用vscode,在根目录打开的是,文件太多
10+
- 在bsp打开vscode的时候,又不能看rtthread的src源码或者其他driver的文件
11+
- `scons --dist` 到处单独的工程开发,又发现没有git版本控制了。
12+
- clangd的方式,又不能看到所有文件
13+
14+
**是不是即想要在RT-THREAD的master上开发,又想要vscode来编辑,又要能函数鼠标一点就能跳转,而且还要搜索的时候,不要太多不相干的函数名?**
15+
16+
这个既要,又要,还要,还想要的如何满足呢?
17+
18+
如果想要可以按照下面的步骤来,你就可以
19+
20+
- 很干净的,像开发keil一样,只显示想要的文件。
21+
- 在vscode上开发。
22+
- 而且宏定义和跳转都是完全准确的,根据你的编译来的。
23+
24+
最近提交了一个PR, 来满足大家对于vscode的期待,可以算得上满足了大家对vscode的编译器的要求,效果如下所示:
25+
26+
![image-20241214125159408](figure/01_workspace/image-20241214125159408.png)
27+
28+
想不想要有这样的干净的工作区?
29+
30+
是不是觉得这样的话,可能会很麻烦,在RT-THREAD上一点也不麻烦,只需要最简单的几个scons命令即可。
31+
32+
请用RT-THREAD以下commit之后的版本,后面如果不行了,可以重置到该版本试下。
33+
34+
https://github.com/RT-Thread/rt-thread/commit/7ff75e21fad3e851090a9f9fcb14d0411949f2f8
35+
36+
只要简单的几步就可以操作,
37+
38+
现在让我们跟随以下步骤来操作一下:
39+
40+
## 操作步骤
41+
42+
### 第一步 安装clangd
43+
44+
如果经常用clangd,或者已经装clangd的可以跳过这一步,
45+
46+
![image-20241214125834167](figure/01_workspace/image-20241214125834167.png)
47+
48+
vscode插件商场上安装clangd,然后打开.c文件,会弹出下面的图标,点击install安装。
49+
50+
![image-20241214125555068](figure/01_workspace/image-20241214125555068.png)
51+
52+
### 第二步 生成compile_compand.json 文件
53+
54+
这边参考了论坛中的其他文章,见最下面的引用。
55+
56+
只需要几个步骤即可。首先要确保你的`scons`是4.0以上的版本,执行`scons --version` 可以看到版本号, env更新到最新2.0的就可以,直接就可以用,不要安装。
57+
58+
```
59+
# scons --version
60+
SCons by Steven Knight et al.:
61+
SCons: v4.8.1.08661ed4c552323ef3a7f0ff1af38868cbabb05e, Tue, 03 Sep 2024 17:46:32 -0700, by bdbaddog on M1Dog2021
62+
SCons path: ['J:\\06_software\\01_green_software\\env-windows-v2.0.0\\env-windows\\.venv\\Lib\\site-packages\\SCons']
63+
Copyright (c) 2001 - 2024 The SCons Foundation
64+
```
65+
66+
然后找到你常用的bsp中的`SConstruct`
67+
68+
比如我这边进入下面的目录`bsp\stm32\stm32f103-blue-pill`
69+
70+
在文件`SConstruct`最下面添加下面两行即可,之后执行`scons` 即可以生成compile_compand.json
71+
72+
```
73+
env.Tool('compilation_db')
74+
env.CompilationDatabase()
75+
```
76+
77+
添加的位置如下所示
78+
79+
```
80+
objs.extend(SConscript(os.path.join(libraries_path_prefix, 'HAL_Drivers', 'SConscript'),variant_dir='build/libraries/'+'HAL_Drivers', duplicate=0))
81+
82+
env.Tool('compilation_db')
83+
env.CompilationDatabase()
84+
85+
# make a building
86+
DoBuilding(TARGET, objs)
87+
```
88+
89+
记得这里执行一下`scons` 确认可以生成`compile_compand.json`
90+
91+
![image-20241214130512198](figure/01_workspace/image-20241214130512198.png)
92+
93+
### 第三步 执行`scons --target=vsc`
94+
95+
最后一步很简单,执行一下`scosn --target=vsc` 为的是生成workspace
96+
97+
执行的时候会生成一个`code-workspace` 文件
98+
99+
![image-20241214130618147](figure/01_workspace/image-20241214130618147.png)
100+
101+
### 第四步 打开stm32f103-blue-pill.code-workspace文件即可
102+
103+
最后双击打开`stm32f103-blue-pill.code-workspace`之后,vscode打开,就可以使用啦。这个时候,所有的引用都是根据`scons`编译来的
104+
105+
![image-20241214130716362](figure/01_workspace/image-20241214130716362.png)
106+
107+
这个时候你就可以如下所示,愉快的跳转了,而且搜索的时候,也会排除其他bsp和libcpu.
108+
109+
![跳转](figure/01_workspace/跳转.gif)
110+
111+
112+
113+
## 添加文件夹
114+
115+
如果还想看其他文件夹,可以直接用vscode打开`stm32f103-blue-pill.code-workspace` 可以自行修改需要添加的文件,如果想加`.git` 只要把`file.exclude`中对应的文件夹删了,或者置`false`即可。
116+
117+
![image-20241214131424860](figure/01_workspace/image-20241214131424860.png)
118+
119+
## 欢迎提建议
120+
121+
大家可以试用看看,如果有任何问题和建议,可以评论区讨论,也可以issue讨论。
122+
123+
# 这个功能最近用起来很酷哦,大家可以体验一下
124+
125+
## 参考链接
126+
127+
[1] 简单两步配置RTT源码阅读环境 vsc+clangd插件 https://club.rt-thread.org/ask/article/612660a972d45e43.html
128+
129+
[2] 在RT-Thread的scons基础上,使用clang-tidy做静态分析https://club.rt-thread.org/ask/article/1b1df03e18ffc73d.html
130+
Lines changed: 5 additions & 0 deletions
Loading
Loading
Loading
Loading
Loading
Loading
Loading
Loading
Loading

source/RTTHREAD/index.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,3 +24,4 @@ RTTHRED: RT-Thread
2424
08_action/01_github_action.md
2525
09_package/01_package.md
2626
12_yml/01_yml_bsp.md
27+
13_workspace/01_workspace.md

0 commit comments

Comments
 (0)