处理多个项目

[English]

对于大型项目,通常需要构建、烧录或监视多个项目。ESP-IDF 扩展遵循 VS Code 工作区文件架构 来识别当前工作区(即根目录)下的所有项目文件夹。详情请参阅 用户和工作区设置

配置将按照如下优先级进行覆盖:

  • 工作区文件夹中 ${workspaceFolder}/.vscode/settings.json 文件里定义的设置

  • 工作区中 <name>.code-workspace 文件里定义的配置

  • settings.json 文件中定义的用户设置

  • Windows %APPDATA%\Code\User\settings.json

  • MacOS $HOME/Library/Application Support/Code/User/settings.json

  • Linux $HOME/.config/Code/User/settings.json

  • 此扩展使用 idf.saveScope 配置选项来确定在某些功能(如设置向导)中,配置设置应该保存到哪里。若想改变位置,可以使用 ESP-IDF:选择配置存储位置 命令进行修改。

    点击 VS Code 状态栏中的 ESP-IDF:当前项目 图标或按 F1 唤醒命令面板,输入 ESP-IDF:选择工作区文件夹 来选择当前项目,确定 ESP-IDF 设置(如当前设备的 USB 端口、ESP-IDF 路径等)将应用于哪个文件夹。

    <name>.code-workspace 文件定义了项目文件夹(即 VS Code 中的工作区文件夹)和工作区级别的设置,如下所示:

    "folders" : [ "path" : "./project1" "path" : "./project2" "settings" : { "idf.port" : "/dev/ttyUSB1" , "idf.espIdfPath" : "${env:HOME}/esp/esp-idf"

    ESP-IDF:当前项目 目录中不包含 .vscode/settings.json 文件,则使用根目录下 .code-workspace 中的设置。

    若想在 VS Code 中打开一个包含多个子项目的项目,请前往菜单栏中的 文件 > 打开工作区 ,选择描述你工作区的 .code-workspace 文件。

    你可以手动创建 .code-workspace 文件并定义所有子文件夹(子项目),也可以点击菜单栏中的 文件 > 将工作区另存为 来保存当前的工作区,但要注意后者不会自动包含当前目录下的任何文件夹。

    前往菜单栏中的 文件 > 将文件夹添加到工作区 ,可以将文件夹添加到工作区。

    必须在当前工作区文件夹的 调试 选项卡中手动选择相应的调试配置。每个调试配置都有一个项目目录后缀。

    请参考以下多项目目录树示例:

    ---> /my-projects-root
    ------> /my-projects-root/project1
    ------> /my-projects-root/project2
    ------------> /my-projects-root/project2/.vscode/settings.json
    

    以及 my-ws.code-workspace

    "folders": [ "path": "/my-projects-root/project1" "path": "/my-projects-root/project2" "settings": { "idf.port": "/dev/ttyUSB1", "idf.espIdfPath": "${env:HOME}/esp/esp-idf"
  • 打开 VS Code,前往菜单栏中的 文件 > 打开工作区 并打开 my-ws.code-workspace,你只能看到在当前工作区中定义的文件夹(/my-projects-root/project1/my-projects-root/project2)。

  • 对于 project1,VS Code 优先使用 my-ws.code-workspace 中的设置,然后再从用户设置中获取其他所需的设置。

  • 对于 project2,VS Code 优先使用 /my-projects-root/project2/.vscode/settings.json 中的设置,其次从 my-ws.code-workspace 中获取缺失的设置,最后从用户设置中获取其余设置。

  • 打开 /my-projects-root/my-projects-root/project1 目录,VS Code 将使用用户设置。

  • 如果只打开 /my-projects-root/project2 目录,VS Code 将首先使用 /my-projects-root/project2/.vscode/settings.json 中定义的设置,然后使用用户设置中定义的其他必要设置。

  • 若打开 /my-projects-root,任何子项目都不会被识别为工作区文件夹。你需要将这些项目添加到 my-ws.code-workspace (手动添加或点击菜单栏中的 文件 > 将文件夹添加到工作区),并按照之前指定的方式打开此工作区。

    创建好配置文件并为每个文件都设置好配置项后,点击 保存 按钮。使用 ESP-IDF:选择项目配置 命令来选择要覆盖的扩展配置。

    选定配置文件后,所选文件将显示在 VS Code 状态栏中。

    使用 ESP-IDF:构建项目 命令,为配置文件 prod1prod2 构建项目。指定路径中将出现每个配置文件生成的二进制文件。使用 ESP-IDF:选择项目配置 命令,可以切换不同的构建配置。

    使用 ESP-IDF:打开项目配置 命令,可以修改、添加或删除配置文件。如果不再需要这些配置文件,删除即可。

    多个 ESP-IDF 版本

    在 VS Code 中可以使用多个 ESP-IDF 版本,每个项目配置一个不同的版本。只要在当前项目目录下的 .vscode/settings.json 文件中显式定义项目配置。

  • 使用 ESP-IDF:选择配置存储位置 命令或在 VS Code 中打开所需项目的 .vscode/settings.json 文件进行编辑,将 idf.saveScope 设置为工作区文件夹级别。

  • 参照 安装 ESP-IDF 和工具,配置扩展。

  • 删除先前的构建目录。若存在先前构建的缓存,则不同的 ESP-IDF 版本将无法工作。

  • 如果你希望使用与全局用户设置版本不同的 ESP-IDF,请在所需项目中重复步骤 1。

  • 手动使用多种构建配置

    如 ESP-IDF CMake 多种构建配置示例 所示,可以使用多个构建目录和多个 sdkconfig 默认文件来生成不同版本的最终产品。

    在此扩展中,可以使用 idf.buildPath (Windows 系统中使用 idf.buildPathWin)来定义构建目录,并使用 idf.sdkconfigDefaults 来定义 sdkconfig 默认文件列表。扩展构建命令会使用这些定义好的配置。

    例如,如果要制作产品 1:

  • 创建 sdkconfig 文件 sdkconfig.prod_commonsdkconfig.prod1,之后 <your-project>/build_prod1build_prod1 是自定义构建文件夹的名称)中将生成固件。

  • 在当前项目的 .vscode/settings.json 文件中添加下列设置:

    // ... "idf.buildPath": "${workspaceFolder}/build_prod1", "idf.sdkconfigDefaults": ["sdkconfig.prod_common", "sdkconfig.prod1"] // ...
  • 使用 ESP-IDF:构建项目 命令构建你的项目。

  • <your-project>/build_prod1 中将生成固件文件,而 SDK 配置编辑器使用的 sdkconfig 文件位于 <your-project>/build_prod1/sdkconfig

  • 对于不同的产品和配置,请在步骤 2 中更改相应的值。

  •