From c48b2ecccd27b561e1a8bb099167ba187f49cd12 Mon Sep 17 00:00:00 2001 From: paulober <44974737+paulober@users.noreply.github.com> Date: Tue, 15 Oct 2024 19:14:13 +0100 Subject: [PATCH] Fix #98, CMake configure not awaited Signed-off-by: paulober <44974737+paulober@users.noreply.github.com> --- src/commands/configureCmake.mts | 2 +- src/utils/cmakeUtil.mts | 77 ++++++++++++++------------------- 2 files changed, 34 insertions(+), 45 deletions(-) diff --git a/src/commands/configureCmake.mts b/src/commands/configureCmake.mts index c02bd0f4..32472045 100644 --- a/src/commands/configureCmake.mts +++ b/src/commands/configureCmake.mts @@ -44,7 +44,7 @@ export default class ConfigureCmakeCommand extends Command { if (await configureCmakeNinja(workspaceFolder.uri)) { void window.showInformationMessage("CMake has configured your build."); } else { - void window.showWarningMessage("CMake has not configured your build."); + void window.showWarningMessage("CMake failed to configure your build."); } } } diff --git a/src/utils/cmakeUtil.mts b/src/utils/cmakeUtil.mts index 8608c306..dc589dba 100644 --- a/src/utils/cmakeUtil.mts +++ b/src/utils/cmakeUtil.mts @@ -165,7 +165,7 @@ export async function configureCmakeNinja(folder: Uri): Promise { folder.with({ path: join(folder.fsPath, "CMakeLists.txt") }) ); - void window.withProgress( + await window.withProgress( { location: ProgressLocation.Notification, cancellable: true, @@ -178,8 +178,6 @@ export async function configureCmakeNinja(folder: Uri): Promise { ?.replace(HOME_VAR, homedir().replaceAll("\\", "/")) || "cmake"; // TODO: analyze command result - // TODO: option for the user to choose the generator - // TODO: maybe delete the build folder before running cmake so // all configuration files in build get updates const customEnv = process.env; /*customEnv["PYTHONHOME"] = pythonPath.includes("/") @@ -201,49 +199,40 @@ export async function configureCmakeNinja(folder: Uri): Promise { : "" }` + `-G Ninja -B ./build "${folder.fsPath}"`; - const child = exec( - command, - { - env: customEnv, - cwd: folder.fsPath, - }, - (error, stdout, stderr) => { - if (error) { - Logger.error(LoggerSource.cmake, error); - Logger.warn( - LoggerSource.cmake, - `Stdout of failed cmake: ${stdout}` - ); - Logger.warn( - LoggerSource.cmake, - `Stderr of failed cmake: ${stderr}` - ); + await new Promise((resolve, reject) => { + // use exec to be able to cancel the process + const child = exec( + command, + { + env: customEnv, + cwd: folder.fsPath, + }, + error => { + progress.report({ increment: 100 }); + if (error) { + if (error.signal === "SIGTERM") { + Logger.warn( + LoggerSource.cmake, + "CMake configuration process was canceled." + ); + } else { + Logger.error( + LoggerSource.cmake, + `Failed to configure CMake:`, + error + ); + } + + reject(error); + } + + resolve(); } + ); - return; - } - ); - - child.on("error", err => { - Logger.error(LoggerSource.cmake, err); - }); - - //child.stdout?.on("data", data => {}); - child.on("close", () => { - progress.report({ increment: 100 }); - }); - child.on("exit", code => { - if (code !== 0) { - Logger.error( - LoggerSource.cmake, - `CMake exited with code ${code ?? "N/A"}` - ); - } - progress.report({ increment: 100 }); - }); - - token.onCancellationRequested(() => { - child.kill(); + token.onCancellationRequested(() => { + child.kill(); + }); }); } );