diff --git a/src/plugins/debugger/cdb/cdbdebugengine.cpp b/src/plugins/debugger/cdb/cdbdebugengine.cpp index bccad9cc7a562ff231b4b3286cd2cb970501b99e..910a915b713f43ee1dbaa5996fc02cfe7f8f9b11 100644 --- a/src/plugins/debugger/cdb/cdbdebugengine.cpp +++ b/src/plugins/debugger/cdb/cdbdebugengine.cpp @@ -635,7 +635,12 @@ bool CdbDebugEngine::startDebuggerWithExecutable(DebuggerStartMode sm, QString * imagePath += QLatin1Char(';'); imagePath += m_d->m_baseImagePath; } - m_d->m_cif.debugSymbols->SetImagePathWide(reinterpret_cast<PCWSTR>(imagePath.utf16())); + HRESULT hr = m_d->m_cif.debugSymbols->SetImagePathWide(reinterpret_cast<PCWSTR>(imagePath.utf16())); + if (FAILED(hr)) { + *errorMessage = tr("Unable to set the image path to %1: %2").arg(imagePath, msgComFailed("SetImagePathWide", hr)); + return false; + } + if (debugCDB) qDebug() << Q_FUNC_INFO <<'\n' << filename << imagePath; @@ -653,12 +658,15 @@ bool CdbDebugEngine::startDebuggerWithExecutable(DebuggerStartMode sm, QString * envData = Core::Utils::AbstractProcess::createWinEnvironment(Core::Utils::AbstractProcess::fixWinEnvironment(sp->environment)); env = reinterpret_cast<PCWSTR>(envData.data()); } - const HRESULT hr = m_d->m_cif.debugClient->CreateProcess2Wide(NULL, - reinterpret_cast<PWSTR>(const_cast<ushort *>(cmd.utf16())), - &dbgopts, - sizeof(dbgopts), - reinterpret_cast<PCWSTR>(sp->workingDir.utf16()), - env); + // The working directory cannot be empty. + PCWSTR workingDirC = 0; + const QString workingDir = sp->workingDir.isEmpty() ? QString() : QDir::toNativeSeparators(sp->workingDir); + if (!workingDir.isEmpty()) + workingDirC = workingDir.utf16(); + hr = m_d->m_cif.debugClient->CreateProcess2Wide(NULL, + reinterpret_cast<PWSTR>(const_cast<ushort *>(cmd.utf16())), + &dbgopts, sizeof(dbgopts), + workingDirC, env); if (FAILED(hr)) { *errorMessage = tr("Unable to create a process '%1': %2").arg(cmd, msgDebugEngineComResult(hr)); m_d->m_debuggerManagerAccess->notifyInferiorExited();