Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[VSC-1572] add app bootloader partition table build flash cmds #1436

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions l10n/bundle.l10n.es.json
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@
"Error encountered while calling idf_size.py": "Error encontrado al llamar a idf_size.py",
"Select the available serial port where your device is connected.": "Seleccione el puerto serie disponible donde está conectado su dispositivo.",
"Port has been updated to ": "El puerto ha sido actualizado a ",
"{buildFile} doesn't exist. Build first.": "{buildFile} no existe. Compile primero.",
"SDK Configuration editor": "Editor de configuración del SDK",
"Save": "Ahorrar",
"Discard": "Desechar",
Expand Down
1 change: 1 addition & 0 deletions l10n/bundle.l10n.pt.json
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@
"Error encountered while calling idf_size.py": "Erro encontrado ao chamar idf_size.py",
"Select the available serial port where your device is connected.": "Selecione a porta serial disponível onde seu dispositivo está conectado.",
"Port has been updated to ": "A porta foi atualizada para ",
"{buildFile} doesn't exist. Build first.": "{buildFile} {buildFile} não existe. Crie primeiro.",
"SDK Configuration editor": "Editor de configuração do SDK",
"Save": "Salvar",
"Discard": "Descartar",
Expand Down
1 change: 1 addition & 0 deletions l10n/bundle.l10n.ru.json
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@
"Error encountered while calling idf_size.py": "Ошибка при вызове idf_size.py",
"Select the available serial port where your device is connected.": "Выберите доступный последовательный порт, к которому подключено ваше устройство.",
"Port has been updated to ": "Порт обновлен до ",
"{buildFile} doesn't exist. Build first.": "{buildFile} не существует. Сначала выполните сборку.",
"SDK Configuration editor": "Редактор конфигурации SDK",
"Save": "Сохранить",
"Discard": "Отменить",
Expand Down
1 change: 1 addition & 0 deletions l10n/bundle.l10n.zh-CN.json
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@
"Error encountered while calling idf_size.py": "调用 idf_size.py 时出错",
"Select the available serial port where your device is connected.": "为设备选择可用的串口。",
"Port has been updated to ": "端口已更新为 ",
"{buildFile} doesn't exist. Build first.": "{buildFile}不存在,请先进行生成。",
"SDK Configuration editor": "SDK 配置编辑器",
"Save": "保存",
"Discard": "丢弃",
Expand Down
38 changes: 37 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -408,6 +408,11 @@
"group": "navigation",
"when": "view == idfPartitionExplorer"
},
{
"command": "esp.webview.open.partition-table",
"group": "navigation@2",
"when": "view == idfPartitionExplorer"
},
{
"command": "espIdf.apptrace.customize",
"when": "view == idfAppTracer"
Expand Down Expand Up @@ -1273,6 +1278,36 @@
"title": "%espIdf.buildDevice.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.buildApp",
"title": "%espIdf.buildApp.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.flashAppUart",
"title": "%espIdf.flashAppUart.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.buildBootloader",
"title": "%espIdf.buildBootloader.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.flashBootloaderUart",
"title": "%espIdf.flashBootloaderUart.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.buildPartitionTable",
"title": "%espIdf.buildPartitionTable.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.flashPartitionTableUart",
"title": "%espIdf.flashPartitionTableUart.title%",
"category": "ESP-IDF"
},
{
"command": "espIdf.flashDevice",
"title": "%espIdf.flashDevice.title%",
Expand Down Expand Up @@ -1481,7 +1516,8 @@
},
{
"command": "esp.webview.open.partition-table",
"title": "%esp.webview.open.partition-table.title%"
"title": "%esp.webview.open.partition-table.title%",
"icon": "$(output)"
},
{
"command": "espIdf.jtag_flash",
Expand Down
6 changes: 6 additions & 0 deletions package.nls.es.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,11 @@
"espIdf.apptrace.archive.showReport.title": "Mostrar informe de rastreo",
"espIdf.apptrace.customize.title": "Personalizar parámetros para rastreo de aplicaciones",
"espIdf.apptrace.title": "Rastreo de aplicaciones",
"espIdf.buildApp.title": "Aplicación de compilación solo",
"espIdf.buildBootloader.title": "Construir cargador de arranque solamente",
"espIdf.buildDevice.title": "Construir su proyecto",
"espIdf.buildFlashMonitor.title": "Construir, Flashear y Arrancar un Monitor en su Dispositivo",
"espIdf.buildPartitionTable.title": "Construir tabla de partición",
"espIdf.clearDocsSearchResult.title": "Limpiar resultados de búsqueda de ESP-IDF",
"espIdf.clearSavedIdfSetups.title": "Limpiar configuraciones de ESP-IDF guardadas",
"espIdf.cmakeListsEditor.start.title": "Editor CMakeLists.txt",
Expand All @@ -36,11 +39,14 @@
"espIdf.efuse.clearResults.title": "Limpiar resumen de efuse",
"espIdf.eraseFlash.title": "Borrar memoria Flash del dispositivo",
"espIdf.examples.title": "Mostrar proyectos de ejemplo",
"espIdf.flashAppUart.title": "Solo aplicación Flash (UART)",
"espIdf.flashAndEncryptDevice.title": "Encriptar y Flashear su Proyecto",
"espIdf.flashBootloaderUart.title": "SOLO ROBAJE DE BOOTOLA FLASH (UART)",
"espIdf.flashBinaryToPartition.title": "Flashear binario a partición...",
"espIdf.flashDFU.title": "Flashear (DFU) su Proyecto",
"espIdf.flashDevice.title": "Flashear su Proyecto",
"espIdf.flashUart.title": "Flashear (UART) su Proyecto",
"espIdf.flashPartitionTableUart.title": "Tabla de partición flash (UART)",
"espIdf.fullClean.title": "Limpieza completa del proyecto",
"espIdf.genCoverage.title": "Agregar cobertura de editor",
"espIdf.getCoverageReport.title": "Obtener informe de cobertura HTML para proyecto",
Expand Down
6 changes: 6 additions & 0 deletions package.nls.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,11 @@
"espIdf.apptrace.archive.showReport.title": "Show Trace Report",
"espIdf.apptrace.customize.title": "Customize Parameters for App Trace",
"espIdf.apptrace.title": "App Trace",
"espIdf.buildApp.title": "Build App Only",
"espIdf.buildBootloader.title": "Build Bootloader Only",
"espIdf.buildDevice.title": "Build Your Project",
"espIdf.buildFlashMonitor.title": "Build, Flash and Start a Monitor on Your Device",
"espIdf.buildPartitionTable.title": "Build Partition Table",
"espIdf.clearDocsSearchResult.title": "Clear ESP-IDF Search Results",
"espIdf.clearSavedIdfSetups.title": "Clear Saved ESP-IDF Setups",
"espIdf.cmakeListsEditor.start.title": "CMakeLists.txt Editor",
Expand All @@ -36,10 +39,13 @@
"espIdf.efuse.clearResults.title": "Clear eFuse Summary",
"espIdf.eraseFlash.title": "Erase Flash Memory from Device",
"espIdf.examples.title": "Show Example Projects",
"espIdf.flashAppUart.title": "Flash App Only (UART)",
"espIdf.flashAndEncryptDevice.title": "Encrypt and Flash Your Project",
"espIdf.flashBinaryToPartition.title": "Flash Binary to Partition...",
"espIdf.flashBootloaderUart.title": "Flash Bootloader Only (UART)",
"espIdf.flashDFU.title": "Flash (DFU) Your Project",
"espIdf.flashDevice.title": "Flash Your Project",
"espIdf.flashPartitionTableUart.title": "Flash Partition Table (UART)",
"espIdf.flashUart.title": "Flash (UART) Your Project",
"espIdf.fullClean.title": "Full Clean Project",
"espIdf.genCoverage.title": "Add Editor Coverage",
Expand Down
6 changes: 6 additions & 0 deletions package.nls.pt.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,11 @@
"espIdf.apptrace.archive.showReport.title": "Mostrar relatório de rastreamento",
"espIdf.apptrace.customize.title": "Personalize parâmetros para rastreamento de aplicativos",
"espIdf.apptrace.title": "Rastreamento de aplicativo",
"espIdf.buildApp.title": "Crie apenas aplicativo",
"espIdf.buildBootloader.title": "Construa apenas o carregador de inicialização",
"espIdf.buildDevice.title": "Construa seu projeto",
"espIdf.buildFlashMonitor.title": "Crie, atualize e inicie um monitor no seu dispositivo",
"espIdf.buildPartitionTable.title": "Tabela de partição de construção",
"espIdf.clearDocsSearchResult.title": "Limpar resultados da pesquisa ESP-IDF",
"espIdf.clearSavedIdfSetups.title": "Limpar configurações ESP-IDF salvas",
"espIdf.cmakeListsEditor.start.title": "Editor CMakeLists.txt",
Expand All @@ -36,10 +39,13 @@
"espIdf.efuse.clearResults.title": "Limpar resumo do eFuse",
"espIdf.eraseFlash.title": "Apagar memória flash do dispositivo",
"espIdf.examples.title": "Mostrar exemplos de projetos",
"espIdf.flashAppUart.title": "Apenas aplicativo flash (UART)",
"espIdf.flashAndEncryptDevice.title": "Criptografe e atualize seu projeto",
"espIdf.flashBinaryToPartition.title": "Flash binário para partição...",
"espIdf.flashBootloaderUart.title": "Flash Bootloader apenas (UART)",
"espIdf.flashDFU.title": "Flash (DFU) seu projeto",
"espIdf.flashDevice.title": "Atualize seu projeto",
"espIdf.flashPartitionTableUart.title": "Tabela de partição flash (UART)",
"espIdf.flashUart.title": "Flash (UART) seu projeto",
"espIdf.fullClean.title": "Projeto Totalmente Limpo",
"espIdf.genCoverage.title": "Adicionar cobertura do editor",
Expand Down
6 changes: 6 additions & 0 deletions package.nls.ru.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,11 @@
"espIdf.apptrace.archive.showReport.title": "Показать отчет трассировки",
"espIdf.apptrace.customize.title": "Пользовательские параметры Трассировщика приложения",
"espIdf.apptrace.title": "Трассировка приложения",
"espIdf.buildApp.title": "Создайте только приложение",
"espIdf.buildBootloader.title": "Постройте только загрузчик",
"espIdf.buildDevice.title": "Собрать проект",
"espIdf.buildFlashMonitor.title": "Собрать, прошить устойство и запустить монитор",
"espIdf.buildPartitionTable.title": "Построить таблицу перегородков",
"espIdf.clearDocsSearchResult.title": "Очистить результаты поиска ESP-IDF",
"espIdf.clearSavedIdfSetups.title": "Очистить сохраненные настройки ESP-IDF",
"espIdf.cmakeListsEditor.start.title": "Редактор CMakeLists.txt",
Expand All @@ -37,11 +40,14 @@
"espIdf.eraseFlash.title": "Очистить Flash-память устройства",
"espIdf.examples.title": "Показать примеры проектов",
"espIdf.flashAndEncryptDevice.title": "Зашифровать и прошить проект",
"espIdf.flashAppUart.title": "Только приложение Flash (UART)",
"espIdf.flashBootloaderUart.title": "Только Flash Bootloader (UART)",
"espIdf.flashBinaryToPartition.title": "Прошить бинарник в раздел...",
"espIdf.flashDFU.title": "Прошить (DFU) проект",
"espIdf.flashDevice.title": "Прошить проект",
"espIdf.flashUart.title": "Прошить (UART) проект",
"espIdf.fullClean.title": "Полная очистка проекта",
"espIdf.flashPartitionTableUart.title": "Таблица раздела Flash (UART)",
"espIdf.genCoverage.title": "Добавить покрытие редактора",
"espIdf.getCoverageReport.title": "Получить HTML-отчет о покрытии проекта",
"espIdf.getEspAdf.title": "Установить ESP-ADF",
Expand Down
12 changes: 9 additions & 3 deletions package.nls.zh-CN.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,17 @@
"esp.rainmaker.backend.remove_node.title": "移除此节点",
"esp.rainmaker.backend.sync.title": "同步 ESP-Rainmaker 云服务器",
"esp.rainmaker.backend.update_node_param.title": "为设备更新参数",
"esp.webview.open.partition-table.title": "ESP-IDF打开分区表编辑器 UI",
"esp.webview.open.partition-table.title": "ESP-IDF 打开分区表编辑器 UI",
"espIdf.addArduinoAsComponentToCurFolder.title": "添加 Arduino ESP32 为 ESP-IDF 组件",
"espIdf.apptrace.archive.refresh.title": "刷新跟踪存档列表",
"espIdf.apptrace.archive.showReport.title": "显示跟踪报告",
"espIdf.apptrace.customize.title": "自定义应用程序跟踪参数",
"espIdf.apptrace.title": "应用程序跟踪",
"espIdf.buildApp.title": "仅构建应用程序",
"espIdf.buildBootloader.title": "仅构建引导加载程序",
"espIdf.buildDevice.title": "构建项目",
"espIdf.buildFlashMonitor.title": "构建、烧录项目并监视设备",
"espIdf.buildPartitionTable.title": "构建分区表",
"espIdf.clearDocsSearchResult.title": "清除 ESP-IDF 搜索结果",
"espIdf.clearSavedIdfSetups.title": "清除已保存的 ESP-IDF 设置",
"espIdf.cmakeListsEditor.start.title": "CMakeLists.txt 编辑器",
Expand All @@ -32,15 +35,18 @@
"espIdf.customTask.title": "执行自定义任务",
"espIdf.disposeConfserverProcess.title": "清理当前 SDK 配置编辑器服务器进程",
"espIdf.doctorCommand.title": "诊断命令",
"espIdf.troubleshootPanel.title": "ESP-IDF故障排除表",
"espIdf.troubleshootPanel.title": "ESP-IDF 故障排除表",
"espIdf.efuse.clearResults.title": "清除 eFuse 摘要",
"espIdf.eraseFlash.title": "擦除设备 flash 数据",
"espIdf.examples.title": "展示示例项目",
"espIdf.flashAndEncryptDevice.title": "加密并烧录项目",
"espIdf.flashAppUart.title": "仅Flash AppUART",
"espIdf.flashBinaryToPartition.title": "将二进制文件烧录到分区…",
"espIdf.flashBootloaderUart.title": "仅Flash Boot Loader UART",
"espIdf.flashDFU.title": "通过 DFU 接口烧录项目",
"espIdf.flashDevice.title": "烧录项目",
"espIdf.flashUart.title": "通过 UART 接口烧录项目",
"espIdf.flashPartitionTableUart.title": "闪存分区表 UART",
"espIdf.fullClean.title": "彻底清理项目",
"espIdf.genCoverage.title": "添加编辑器覆盖率功能",
"espIdf.getCoverageReport.title": "生成 HTML 格式的代码覆盖率报告",
Expand All @@ -50,7 +56,7 @@
"espIdf.getEspMdf.title": "安装 ESP-MDF",
"espIdf.getEspRainmaker.title": "安装 ESP-Rainmaker",
"espIdf.heaptrace.title": "堆跟踪",
"espIdf.idfReconfigureTask.title": "ESP-IDF: 运行 idf.py reconfigure 任务",
"espIdf.idfReconfigureTask.title": "ESP-IDF: 运行 idf.py reconfigure 任务",
"espIdf.importProject.title": "导入 ESP-IDF 项目",
"espIdf.installEspMatterPyReqs.title": "安装 ESP-Matter Python 包",
"espIdf.installPyReqs.title": "安装 ESP-IDF 扩展 Python 包",
Expand Down
7 changes: 4 additions & 3 deletions src/build/buildCmd.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,8 @@ import { OutputChannel } from "../logger/outputChannel";
export async function buildCommand(
workspace: vscode.Uri,
cancelToken: vscode.CancellationToken,
flashType: ESP.FlashType
flashType: ESP.FlashType,
buildType?: ESP.BuildType
) {
let continueFlag = true;
const buildTask = new BuildTask(workspace);
Expand All @@ -57,13 +58,13 @@ export async function buildCommand(
});
try {
await customTask.addCustomTask(CustomTaskType.PreBuild);
await buildTask.build();
await buildTask.build(buildType);
await TaskManager.runTasks();
const enableSizeTask = (await readParameter(
"idf.enableSizeTaskAfterBuildTask",
workspace
)) as boolean;
if (enableSizeTask) {
if (enableSizeTask && typeof buildType === undefined) {
const sizeTask = new IdfSizeTask(workspace);
await sizeTask.getSizeInfo();
}
Expand Down
6 changes: 5 additions & 1 deletion src/build/buildTask.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ import { TaskManager } from "../taskManager";
import { selectedDFUAdapterId } from "../flash/dfu";
import { getVirtualEnvPythonPath } from "../pythonManager";
import { getIdfTargetFromSdkconfig } from "../workspaceConfig";
import { ESP } from "../config";

export class BuildTask {
public static isBuilding: boolean;
Expand Down Expand Up @@ -64,7 +65,7 @@ export class BuildTask {
}
}

public async build() {
public async build(buildType?: ESP.BuildType) {
try {
await this.saveBeforeBuild();
} catch (error) {
Expand Down Expand Up @@ -204,6 +205,9 @@ export class BuildTask {
(idfConf.readParameter("idf.ninjaArgs", this.currentWorkspace) as Array<
string
>) || [];
if (buildType && buildArgs.indexOf(buildType) === -1) {
buildArgs.push(buildType);
}
const ninjaCommand = "ninja";
const buildExecution = new vscode.ProcessExecution(
ninjaCommand,
Expand Down
6 changes: 6 additions & 0 deletions src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,12 @@ export namespace ESP {
"esp_idf_project_configuration.json";
}

export enum BuildType {
App = "app",
Bootloader = "bootloader",
PartitionTable = "partition-table",
}

export enum FlashType {
JTAG = "JTAG",
UART = "UART",
Expand Down
Loading