vscode调试makefile项目

本文提供了一份详细的s3fs-fuse编译及调试教程,包括使用minio作为S3服务,通过VSCode进行源码下载、json配置文件创建、调试配置,并解释了关键配置项的作用。

这里以s3fs为例

s3用的是minio,默认配置启动即可,启动minio后,执行

echo minioadmin:minioadmin >~/.passwd-s3fs

后面s3fs需要用到。

开始干活吧

1、下载源码

git clone GitHub - s3fs-fuse/s3fs-fuse: FUSE-based file system backed by Amazon S3

2、创建json文件

  • tasks.json
{
    "tasks": [
        {
            "label": "build_debug", // 任务名称,调试时可以指定不用任务进行处理 
            "type": "shell", // [shell, process], 定义任务作为作为进程运行还是在shell中作为命令运行; (测试没看出啥区别...)
            "command": "make", // 要执行的命令,可以是外部程序或者是shell命令。这里使用make编译命令
            "problemMatcher": [ // 要使用的问题匹配程序。可以是一个字符串或一个问题匹配程序定义,也可以是一个字符串数组和多个问题匹配程序。
                "$gcc"
            ],
            "group": { // 定义此任务属于的执行组。它支持 "build" 以将其添加到生成组,也支持 "test" 以将其添加到测试组。
                "kind": "build",
                "isDefault": true
            },
            "presentation": { // 配置用于显示任务输出并读取其输入的面板
                "echo": true, // 控制是否将执行的命令显示到面板中。默认值为“true”。
                "reveal": "always", // 控制运行任务的终端是否显示。可按选项 "revealProblems" 进行替代。默认设置为“始终”。
                "focus": false, // 控制面板是否获取焦点。默认值为“false”。如果设置为“true”,面板也会显示。
                "panel": "shared", // 控制是否在任务间共享面板。同一个任务使用相同面板还是每次运行时新创建一个面板。
                "showReuseMessage": true, // 控制是否显示“终端将被任务重用,按任意键关闭”提示
                "clear": false // 运行前清屏
            }
        },
        {
            "label": "build_release",//可以手动执行
            "type": "shell",
            "command": "make",
            "args": ["CFLAGS = -O2"], // 编译参数, 替换makefile中让CFLAGS字段
            "dependsOn":["build_clean"], // 指定依赖让task, 即会先执行build_clean,然后再执行build_release
            "problemMatcher": [
                "$gcc"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            }
        },
        {
            "label": "build_clean",//可以手动执行
            "type": "shell",
            "command": "make",
            "args": ["clean"], // 相当于执行 make clean命令
            "problemMatcher": [
                "$gcc"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            }
        }
    ],
    "version": "2.0.0"
}
  • launch.json
{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Lauch", // 启动配置的下拉菜单中显示的名称
            "type": "cppdbg",
            "request": "launch",
            "program": "${workspaceFolder}/src/s3fs", // 将要进行调试的程序的路径, workspaceFolder指当前工作目录(即vscode打开的目录:hello),main指的是makefile编译后目标码(可执行程序)的名字
            "args": [
                "bkname", "/mnt/s3", "-o", "passwd_file=/home/yourname/.passwd-s3fs", "-s","-o","url=http://127.0.0.1:9000", "-o", "use_path_request_style" ,"-f", "-o", "curldbg", "-o", "dbglevel=debug", "-o", "umask=0", "-o"," mp_umask=0"
            ], // 程序启动的参数
            "stopAtEntry": false, // 设置true时,程序将暂停在程序入口处, 即main()的第一个{位置
            "cwd": "${workspaceFolder}", // 调试时的工作目录
            "environment": [],
            "externalConsole": false, // 调试时,是否显示控制台串口
            "MIMode": "gdb", // 调试命令
            "setupCommands": [
                {
                    "description": "为 gdb 启用整齐打印",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                },
                {
                    "description": "将反汇编风格设置为 Intel",
                    "text": "-gdb-set disassembly-flavor intel",
                    "ignoreFailures": true
                }
            ],
            "preLaunchTask": "build_debug", // 使用哪个任务进行编译,需要指定tasks.json中的一个,这里选择用build_debug任务进行编译
            "miDebuggerPath": "/usr/bin/gdb" // 调试命令的路径
        }
    ]
}

3、找到需要打断点的地方

这里以main函数为例

4、执行调试

按F5或者按下图点击启动调试

<think>我们正在处理一个关于VSCodeMakefile配置的问题。根据用户的需求,我们需要提供一份清晰的指南,帮助用户配置VSCode以使用Makefile进行项目构建。 参考引用: [^1]:介绍了在VSCode中配置OpenCV进行C++开发,包括安装mingw-w64、cmake、OpenCV和ffmpeg库,以及配置VSCode的步骤。 [^2]:关于VSCode Makefile工具安装与配置的指南,说明了该工具支持Makefile项目的自动化构建、调试和运行。 [^4]:提到了在VSCode中执行Makefile时遇到的一些问题,比如rm命令无法执行,需要使用del命令(在Windows环境下)。 根据这些引用,我们可以推断用户可能是在Windows环境下使用VSCode,并且需要配置Makefile来构建项目。因此,我们的指南需要包括以下内容: 1. 安装必要的工具(如make工具链,在Windows上可能是MinGW或MSYS2)。 2. 安装VSCodeMakefile Tools扩展。 3. 配置Makefile Tools扩展。 4. 解决常见问题(如命令兼容性问题,特别是在Windows上)。 由于引用[^4]提到在Windows下使用rm命令的问题,我们需要提醒用户在Windows环境下可能需要调整Makefile中的命令(例如使用del代替rm)或者使用提供Unix命令环境的工具(如MSYS2)。 步骤规划: 1. 安装构建工具(如MinGW或MSYS2,以便使用make命令)。 2. 在VSCode中安装Makefile Tools扩展。 3. 配置工作区,设置Makefile Tools扩展。 4. 编写一个简单的Makefile示例并测试。 5. 常见问题及解决方案。 现在,我们按照这个步骤来编写指南。</think>### VSCode Makefile 配置指南 #### 1. **安装必要工具链** - **MinGW-w64**:提供Windows下的GCC编译器和`make`工具 ```bash # MSYS2 安装示例 pacman -S --needed base-devel mingw-w64-ucrt-x86_64-toolchain ``` - **添加环境变量**:将MinGW的`bin`目录(如`C:\msys64\ucrt64\bin`)添加到系统PATH[^2][^4] #### 2. **安装VSCode扩展** 1. 官方扩展市场安装: - **C/C++** (Microsoft官方扩展) - **Makefile Tools** (Microsoft提供Makefile支持)[^2] 2. 或手动安装VSIX: ```bash # 在扩展项目目录执行 npm run compile # 通过"Extensions: Install from VSIX"安装生成的.vsix文件[^5] ``` #### 3. **配置工作区** 创建`.vscode/settings.json`: ```json { "makefile.makePath": "mingw32-make.exe", // Windows环境 "makefile.buildDirectory": "${workspaceRoot}/build", "C_Cpp.default.configurationProvider": "ms-vscode.makefile-tools" } ``` > 注:Linux/macOS设置`"makefile.makePath": "make"`[^2] #### 4. **编写Makefile示例** 创建`Makefile`: ```makefile CC = g++ TARGET = app SRCS = main.cpp utils.cpp $(TARGET): $(SRCS) $(CC) -o $@ $^ clean: del $(TARGET).exe # Windows用del # rm -f $(TARGET) # Linux/macOS用rm[^4] ``` #### 5. **关键功能操作** - **构建**:`Ctrl+Shift+P` → `Makefile: Build Target` - **调试**:配置`launch.json`: ```json { "program": "${workspaceFolder}/build/app", "preLaunchTask": "make: build" } ``` - **问题诊断**:通过`Makefile: Scan for Build Problems`解析错误[^2] #### 6. **常见问题解决** - **命令兼容性问题**:Windows下替换`rm`为`del`或使用MSYS2环境[^4] - **路径错误**:在`settings.json`中显式指定路径: ```json "makefile.makeDirectory": "C:/msys64/ucrt64/bin" ``` - **并行编译**:添加`-j4`参数提升速度: ```makefile build: $(MAKE) -j4 all ``` #### 7. **远程开发配置** 通过**Remote - SSH**扩展连接Linux服务器: 1. 安装扩展后连接远程主机 2. 在远程环境安装`make`和`gcc` 3. 直接使用Linux原生Makefile语法[^3] > 完整配置示例可参考:[VSCode官方Makefile教程](https://code.visualstudio.com/docs/cpp/config-mingw)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值