|
@@ -21,7 +21,7 @@ namespace O3DE::ProjectManager
|
|
|
{
|
|
|
namespace ProjectUtils
|
|
|
{
|
|
|
- AZ::Outcome<QProcessEnvironment, QString> GetCommandLineProcessEnvironment()
|
|
|
+ AZ::Outcome<void, QString> SetupCommandLineProcessEnvironment()
|
|
|
{
|
|
|
// Use the engine path to insert a path for cmake
|
|
|
auto engineInfoResult = PythonBindingsInterface::Get()->GetEngineInfo();
|
|
@@ -31,26 +31,30 @@ namespace O3DE::ProjectManager
|
|
|
}
|
|
|
auto engineInfo = engineInfoResult.GetValue();
|
|
|
|
|
|
- QProcessEnvironment currentEnvironment(QProcessEnvironment::systemEnvironment());
|
|
|
-
|
|
|
- // Append cmake path to PATH incase it is missing
|
|
|
+ // Append cmake path to the current environment PATH incase it is missing, since if
|
|
|
+ // we are starting CMake itself the current application needs to find it using Path
|
|
|
+ // This also takes affect for all child processes.
|
|
|
QDir cmakePath(engineInfo.m_path);
|
|
|
cmakePath.cd("cmake/runtime/bin");
|
|
|
- QString pathValue = currentEnvironment.value("PATH");
|
|
|
- pathValue += ";" + cmakePath.path();
|
|
|
- currentEnvironment.insert("PATH", pathValue);
|
|
|
- return AZ::Success(currentEnvironment);
|
|
|
+ QString pathEnv = qEnvironmentVariable("Path");
|
|
|
+ if (!pathEnv.contains(cmakePath.path()))
|
|
|
+ {
|
|
|
+ pathEnv += ";" + cmakePath.path();
|
|
|
+ qputenv("Path", pathEnv.toStdString().c_str());
|
|
|
+ }
|
|
|
+
|
|
|
+ return AZ::Success();
|
|
|
}
|
|
|
|
|
|
AZ::Outcome<QString, QString> FindSupportedCompilerForPlatform()
|
|
|
{
|
|
|
// Validate that cmake is installed
|
|
|
- auto cmakeProcessEnvResult = GetCommandLineProcessEnvironment();
|
|
|
+ auto cmakeProcessEnvResult = SetupCommandLineProcessEnvironment();
|
|
|
if (!cmakeProcessEnvResult.IsSuccess())
|
|
|
{
|
|
|
return AZ::Failure(cmakeProcessEnvResult.GetError());
|
|
|
}
|
|
|
- auto cmakeVersionQueryResult = ExecuteCommandResult("cmake", QStringList{"--version"}, cmakeProcessEnvResult.GetValue());
|
|
|
+ auto cmakeVersionQueryResult = ExecuteCommandResult("cmake", QStringList{"--version"});
|
|
|
if (!cmakeVersionQueryResult.IsSuccess())
|
|
|
{
|
|
|
return AZ::Failure(QObject::tr("CMake not found. \n\n"
|
|
@@ -104,7 +108,7 @@ namespace O3DE::ProjectManager
|
|
|
|
|
|
AZ::Outcome<void, QString> OpenCMakeGUI(const QString& projectPath)
|
|
|
{
|
|
|
- AZ::Outcome processEnvResult = GetCommandLineProcessEnvironment();
|
|
|
+ AZ::Outcome processEnvResult = SetupCommandLineProcessEnvironment();
|
|
|
if (!processEnvResult.IsSuccess())
|
|
|
{
|
|
|
return AZ::Failure(processEnvResult.GetError());
|
|
@@ -118,7 +122,6 @@ namespace O3DE::ProjectManager
|
|
|
}
|
|
|
|
|
|
QProcess process;
|
|
|
- process.setProcessEnvironment(processEnvResult.GetValue());
|
|
|
|
|
|
// if the project build path is relative, it should be relative to the project path
|
|
|
process.setWorkingDirectory(projectPath);
|
|
@@ -139,7 +142,6 @@ namespace O3DE::ProjectManager
|
|
|
return ExecuteCommandResultModalDialog(
|
|
|
"cmd.exe",
|
|
|
QStringList{"/c", batPath},
|
|
|
- QProcessEnvironment::systemEnvironment(),
|
|
|
QObject::tr("Running get_python script..."));
|
|
|
}
|
|
|
|
|
@@ -157,7 +159,7 @@ namespace O3DE::ProjectManager
|
|
|
.arg(shortcutPath)
|
|
|
.arg(targetPath)
|
|
|
.arg(arguments.join(' '));
|
|
|
- auto createShortcutResult = ExecuteCommandResult(cmd, QStringList{"-Command", arg}, QProcessEnvironment::systemEnvironment());
|
|
|
+ auto createShortcutResult = ExecuteCommandResult(cmd, QStringList{"-Command", arg});
|
|
|
if (!createShortcutResult.IsSuccess())
|
|
|
{
|
|
|
return AZ::Failure(QObject::tr("Failed to create desktop shortcut %1 <br><br>"
|