mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 13:04:23 +00:00
WINDOWS: Fix python auto install, deletion of installer and use 3.5.x series for Vista+. Closes #5871.
This commit is contained in:
parent
05f4270d01
commit
841676fd36
@ -44,6 +44,7 @@
|
|||||||
#include <QCloseEvent>
|
#include <QCloseEvent>
|
||||||
#include <QShortcut>
|
#include <QShortcut>
|
||||||
#include <QScrollBar>
|
#include <QScrollBar>
|
||||||
|
#include <QSysInfo>
|
||||||
#include <QMimeData>
|
#include <QMimeData>
|
||||||
#include <QCryptographicHash>
|
#include <QCryptographicHash>
|
||||||
#include <QProcess>
|
#include <QProcess>
|
||||||
@ -1749,7 +1750,11 @@ void MainWindow::installPython()
|
|||||||
{
|
{
|
||||||
setCursor(QCursor(Qt::WaitCursor));
|
setCursor(QCursor(Qt::WaitCursor));
|
||||||
// Download python
|
// Download python
|
||||||
Net::DownloadHandler *handler = Net::DownloadManager::instance()->downloadUrl("https://www.python.org/ftp/python/3.4.3/python-3.4.3.msi", true);
|
Net::DownloadHandler *handler = nullptr;
|
||||||
|
if (QSysInfo::windowsVersion() >= QSysInfo::WV_VISTA)
|
||||||
|
handler = Net::DownloadManager::instance()->downloadUrl("https://www.python.org/ftp/python/3.5.2/python-3.5.2.exe", true);
|
||||||
|
else
|
||||||
|
handler = Net::DownloadManager::instance()->downloadUrl("https://www.python.org/ftp/python/3.4.4/python-3.4.4.msi", true);
|
||||||
connect(handler, SIGNAL(downloadFinished(QString, QString)), this, SLOT(pythonDownloadSuccess(QString, QString)));
|
connect(handler, SIGNAL(downloadFinished(QString, QString)), this, SLOT(pythonDownloadSuccess(QString, QString)));
|
||||||
connect(handler, SIGNAL(downloadFailed(QString, QString)), this, SLOT(pythonDownloadFailure(QString, QString)));
|
connect(handler, SIGNAL(downloadFailed(QString, QString)), this, SLOT(pythonDownloadFailure(QString, QString)));
|
||||||
}
|
}
|
||||||
@ -1758,19 +1763,29 @@ void MainWindow::pythonDownloadSuccess(const QString &url, const QString &filePa
|
|||||||
{
|
{
|
||||||
Q_UNUSED(url)
|
Q_UNUSED(url)
|
||||||
setCursor(QCursor(Qt::ArrowCursor));
|
setCursor(QCursor(Qt::ArrowCursor));
|
||||||
QFile::rename(filePath, filePath + ".msi");
|
|
||||||
QProcess installer;
|
QProcess installer;
|
||||||
qDebug("Launching Python installer in passive mode...");
|
qDebug("Launching Python installer in passive mode...");
|
||||||
|
|
||||||
installer.start(Utils::Misc::windowsSystemPath() + "\\msiexec.exe /passive /i " + Utils::Fs::toNativePath(filePath) + ".msi");
|
if (QSysInfo::windowsVersion() >= QSysInfo::WV_VISTA) {
|
||||||
|
QFile::rename(filePath, filePath + ".exe");
|
||||||
|
installer.start("\"" + Utils::Fs::toNativePath(filePath) + ".exe\" /passive");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
QFile::rename(filePath, filePath + ".msi");
|
||||||
|
installer.start(Utils::Misc::windowsSystemPath() + "\\msiexec.exe /passive /i \"" + Utils::Fs::toNativePath(filePath) + ".msi\"");
|
||||||
|
}
|
||||||
|
|
||||||
// Wait for setup to complete
|
// Wait for setup to complete
|
||||||
installer.waitForFinished();
|
installer.waitForFinished(10 * 60 * 1000);
|
||||||
|
|
||||||
qDebug("Installer stdout: %s", installer.readAllStandardOutput().data());
|
qDebug("Installer stdout: %s", installer.readAllStandardOutput().data());
|
||||||
qDebug("Installer stderr: %s", installer.readAllStandardError().data());
|
qDebug("Installer stderr: %s", installer.readAllStandardError().data());
|
||||||
qDebug("Setup should be complete!");
|
qDebug("Setup should be complete!");
|
||||||
// Delete temp file
|
// Delete temp file
|
||||||
Utils::Fs::forceRemove(filePath);
|
if (QSysInfo::windowsVersion() >= QSysInfo::WV_VISTA)
|
||||||
|
Utils::Fs::forceRemove(filePath + ".exe");
|
||||||
|
else
|
||||||
|
Utils::Fs::forceRemove(filePath + ".msi");
|
||||||
// Reload search engine
|
// Reload search engine
|
||||||
m_hasPython = addPythonPathToEnv();
|
m_hasPython = addPythonPathToEnv();
|
||||||
if (m_hasPython) {
|
if (m_hasPython) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user