Cursor搭配cmake实现C++程序的编译、运行和调试
Cursor是一个开源的AI编程编辑器,开源地址https://github.com/getcursor/cursor ,它其实是一个集成了Chat-GPT的VS Code。
关于VS Code和VS的对比可以参考这篇文章VS Code 和 Visual Studio 哪个更好?
1 准备工作
1.1 Cursor下载、安装和插件安装
1.下载Cursor
2.双击下载好的exe文件进行安装(安装过程很简单,就不赘述了)
3.安装插件
首先安装一个中文插件将cursor汉化,方便入门学习,安装好之后重启一下cursor就可以生效了,
然后安装以下几个必备插件用于C++开发
1.2 MinGW、CMake工具下载
我这里之前安装过QT5.12.2,在QT的安装目录下的Tool文件夹中已经包含了MinGW和CMake,直接进行环境变量配置就可以了。如果没有可以在公众号VSCode中回复cpp获取压缩包,比在网站上下载安装包一步步安装要快很多。
压缩包下载好之后,直接解压到自己电脑合适的路径下即可使用。
1.3 MinGW、CMake环境变量配置
1.右键“此电脑”,点击“属性”打开设置面板,选择“高级系统设置”,在弹出的系统属性面板中选择“高级”选项卡,然后点击“环境变量”按钮进入环境变量配置界面
2.在“系统变量”中选中“Path”,然后点击“编辑”,再点击“新建”,将cmake.exe、g++.exe、mingw32-make.exe三个文件所在的目录路径加进来
3.回到电脑桌面,按住Shift后点击右键,选择“在此处打开Powershell窗口”,分别在命令行输入gcc、g++、cmake后,如果是这样的结果,说明配置成功:
2 代码演练
2.1 使用AI辅助写代码
1.在自己电脑合适的位置新建一个文件夹,我这里是在D盘建了一个名为"VsCodeTest"的文件夹,
2.在Cursor中打开新建的文件夹
3.光标停留在文件夹名上,点击“新建文件”,新建一个main.cpp
4.在main.cpp中,按Ctrl+K,输入“写一个交换两个int型数据的函数”,按回车会自动生成一段代码:
5.检查无误后按Ctrl+Enter确认代码
6.继续按Ctrl+K,输入“写一个main函数调用上面的交换函数”,按回车会自动生成main函数:
7.导入头文件iostream解决代码报错
2.2 手动编译和运行
1.在Cursor菜单栏选择“终端”-“新建终端”
2.在终端窗口中的命令行里输入g++ .\main.cpp后回车对main.cpp进行编译,目录下会生成一个a.exe
3.在终端窗口中的命令行里输入.\a.exe运行a.exe
此时的a.exe不带调试信息,我们可以通过ls指令查看它的大小:
如果想要拥有一个带有调试信息的可执行文件,我们需要修改一下编译指令:
2.3 自动编译、运行和调试
1.在菜单栏选择“运行”-“启动调试”
2.选择编译器,配置tasks.json
此时工作目录下会自动生成一个.vscode文件夹,里面有一个tasks.json文件,按照我的理解,这个文件里面定义了一些编译的任务和对应的设置,我这边自动生成的tasks.json如下所示:
鼠标停留在某一项上会有一个tooltip提示你这一项是配置什么的。仔细观察会发现,其实"command"+"args"这两项对应我们在2.2节最后一步编译带调试信息的exe时的编译指令,所以我们将tasks.json修改如下:
3.在运行和调试页面点击“创建launch.json文件”
4.选择调试器:
5.在自动生成的launch.json文件中点击添加配置
此时会自动生成如下配置,需要重点关注和修改的已用红框标出
其中"program"配置的是我们要运行和调试的可执行文件,也就是前面tasks.json中编译生成的main.exe,"cwd"为目标工作目录,要与tasks.json中一致,"miDebuggerPath"配置的是调试器的路径,因为我的gdb.exe跟前面的g++.exe和mingw32-make.exe在同一目录下,该目录已经添加到系统环境变量中,所以这里写一个"gdb.exe"就可以了。另外再增加一个"preLaunchTask"属性设置让launch.json在每次启动调试前去调用tasks.json中的任务,最终launch.json修改如下:
6.在main.cpp增加几个断点,此时点击运行和调试即可以正常命中断点并进行调试了。
2.4 使用cmake进行多文件编译、运行和调试
1.删除之前生成的exe文件,在工作目录下创建swap.h和swap.cpp,将swap函数移出,另外新建CMakeLists.txt(文件名一定要写对),各文件内容如下:
2.如果电脑上装了VS,为了防止默认调用微软的MSVC编译器,在.vscode文件夹下新建一个settings.json(文件名一定要写对)添加如下设置,相当于用(cmake -G “MinGW Makefiles” …)代替(cmake …)
3.在搜索框输入>camke,选择cmake:配置(这一步等同于在终端窗口命令行输入cmake -D “CMAKE_BUILD_TYPE:STRING=Debug” -D “CMAKE_EXPORT_COMPILE_COMMANDS:BOOL=TRUE” -S ./ -B ./build -G “MinGW Makefiles”)
出现如下字眼说明构建成功:
此时工作目录下会自动生成build文件夹:
4.上面一步的动作也可以写成tasks.json中的任务自动被launch.json调用,修改tasks.json的配置如下
{
"version": "2.0.0",
"options": {
"cwd": "${workspaceFolder}/build"
},
"tasks": [
{
// 任务一: 创建 build 文件夹
"type": "shell",
"label": "CreateBuildDir", // lable 标记任务名称
"command": "mkdir", // 命令
"args": [
"-Force",
"build"
],
"options": {
"cwd": "${workspaceFolder}"
},
"problemMatcher": [
"$gcc"
],
},
{
// 任务二: 执行cmake指令根据CMakeLists.txt在build目录下生成Makefile
"type": "shell",
"label": "cmake",
"command": "cmake",
"args": [
"-D",
"CMAKE_BUILD_TYPE:STRING=Debug",//编译带调试信息的
"-D",
"CMAKE_EXPORT_COMPILE_COMMANDS:BOOL=TRUE",
"-G",
"MinGW Makefiles",
"-S",
".."//CMakeLists.txt在build的上一级目录中
],
"dependsOn":[
"CreateBuildDir"
]
},
{
// 任务三: 执行mingw32-make.exe根据Makefile编译可执行文件
"label": "make",
"group":{
"kind": "build",
"isDefault": true
},
"command": "mingw32-make.exe",
"args": [
],
"dependsOn":[
"cmake"
]
},
{
// 任务四: 调用任务三
"label":"C/C++: g++.exe 生成活动文件",
"dependsOn":[
"make"
]
}
],
"presentation": {
"panel": "new",
}
}
5.修改launch.json的配置如下:
6.此时点击运行和调试会自动在build目录下生成main.exe并且可以正常命中断点并进行调试了