From 07e589ef8e13bbd93ca84a20afae9631eeabcfd4 Mon Sep 17 00:00:00 2001
From: Friedemann Kleint <Friedemann.Kleint@nokia.com>
Date: Fri, 29 May 2009 11:34:06 +0200
Subject: [PATCH] Fixed b390e56d676cd0a838e4b59b51b431535f760bb0

Do not check for existence of the binary, breaks on Windows
due to .exe (and potentially paths). Use waitForStarted().
On this occasion, kill on timeout in case of password prompts.
---
 src/plugins/git/gitcommand.cpp | 11 +++++++----
 1 file changed, 7 insertions(+), 4 deletions(-)

diff --git a/src/plugins/git/gitcommand.cpp b/src/plugins/git/gitcommand.cpp
index e3fcd8571bf..77b945802ef 100644
--- a/src/plugins/git/gitcommand.cpp
+++ b/src/plugins/git/gitcommand.cpp
@@ -104,10 +104,6 @@ void GitCommand::execute()
     if (m_jobs.empty())
         return;
 
-    if(!QFileInfo(m_binaryPath).exists()){
-        emit errorText(QLatin1String("Error: Git not found.")+m_binaryPath);
-        return;
-    }
     // For some reason QtConcurrent::run() only works on this
     QFuture<void> task = QtConcurrent::run(this, &GitCommand::run);
     const QString taskName = QLatin1String("Git ") + m_jobs.front().arguments.at(0);
@@ -137,8 +133,15 @@ void GitCommand::run()
             qDebug() << "GitCommand::run" << j << '/' << count << m_jobs.at(j).arguments;
 
         process.start(m_binaryPath, m_jobs.at(j).arguments);
+        if(!process.waitForStarted()) {
+            ok = false;
+            error += QString::fromLatin1("Error: \"%1\" could not be started: %2").arg(m_binaryPath, process.errorString());
+            break;
+        }
+
         process.closeWriteChannel();
         if (!process.waitForFinished(m_jobs.at(j).timeout * 1000)) {
+            process.terminate();
             ok = false;
             error += QLatin1String("Error: Git timed out");
             break;
-- 
GitLab