mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-02-03 02:14:16 +00:00
Merge pull request #9113 from Chocobo1/python
Reduce queries to python version
This commit is contained in:
commit
1a7021156e
@ -49,6 +49,7 @@ search/searchdownloadhandler.h
|
|||||||
search/searchhandler.h
|
search/searchhandler.h
|
||||||
search/searchpluginmanager.h
|
search/searchpluginmanager.h
|
||||||
utils/bytearray.h
|
utils/bytearray.h
|
||||||
|
utils/foreignapps.h
|
||||||
utils/fs.h
|
utils/fs.h
|
||||||
utils/gzip.h
|
utils/gzip.h
|
||||||
utils/misc.h
|
utils/misc.h
|
||||||
@ -117,6 +118,7 @@ search/searchdownloadhandler.cpp
|
|||||||
search/searchhandler.cpp
|
search/searchhandler.cpp
|
||||||
search/searchpluginmanager.cpp
|
search/searchpluginmanager.cpp
|
||||||
utils/bytearray.cpp
|
utils/bytearray.cpp
|
||||||
|
utils/foreignapps.cpp
|
||||||
utils/fs.cpp
|
utils/fs.cpp
|
||||||
utils/gzip.cpp
|
utils/gzip.cpp
|
||||||
utils/misc.cpp
|
utils/misc.cpp
|
||||||
|
@ -64,6 +64,7 @@ HEADERS += \
|
|||||||
$$PWD/types.h \
|
$$PWD/types.h \
|
||||||
$$PWD/unicodestrings.h \
|
$$PWD/unicodestrings.h \
|
||||||
$$PWD/utils/bytearray.h \
|
$$PWD/utils/bytearray.h \
|
||||||
|
$$PWD/utils/foreignapps.h \
|
||||||
$$PWD/utils/fs.h \
|
$$PWD/utils/fs.h \
|
||||||
$$PWD/utils/gzip.h \
|
$$PWD/utils/gzip.h \
|
||||||
$$PWD/utils/misc.h \
|
$$PWD/utils/misc.h \
|
||||||
@ -127,6 +128,7 @@ SOURCES += \
|
|||||||
$$PWD/torrentfilter.cpp \
|
$$PWD/torrentfilter.cpp \
|
||||||
$$PWD/tristatebool.cpp \
|
$$PWD/tristatebool.cpp \
|
||||||
$$PWD/utils/bytearray.cpp \
|
$$PWD/utils/bytearray.cpp \
|
||||||
|
$$PWD/utils/foreignapps.cpp \
|
||||||
$$PWD/utils/fs.cpp \
|
$$PWD/utils/fs.cpp \
|
||||||
$$PWD/utils/gzip.cpp \
|
$$PWD/utils/gzip.cpp \
|
||||||
$$PWD/utils/misc.cpp \
|
$$PWD/utils/misc.cpp \
|
||||||
|
@ -30,8 +30,8 @@
|
|||||||
|
|
||||||
#include <QProcess>
|
#include <QProcess>
|
||||||
|
|
||||||
|
#include "../utils/foreignapps.h"
|
||||||
#include "../utils/fs.h"
|
#include "../utils/fs.h"
|
||||||
#include "../utils/misc.h"
|
|
||||||
#include "searchpluginmanager.h"
|
#include "searchpluginmanager.h"
|
||||||
|
|
||||||
SearchDownloadHandler::SearchDownloadHandler(const QString &siteUrl, const QString &url, SearchPluginManager *manager)
|
SearchDownloadHandler::SearchDownloadHandler(const QString &siteUrl, const QString &url, SearchPluginManager *manager)
|
||||||
@ -48,7 +48,7 @@ SearchDownloadHandler::SearchDownloadHandler(const QString &siteUrl, const QStri
|
|||||||
url
|
url
|
||||||
};
|
};
|
||||||
// Launch search
|
// Launch search
|
||||||
m_downloadProcess->start(Utils::Misc::pythonExecutable(), params, QIODevice::ReadOnly);
|
m_downloadProcess->start(Utils::ForeignApps::pythonInfo().executableName, params, QIODevice::ReadOnly);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SearchDownloadHandler::downloadProcessFinished(int exitcode)
|
void SearchDownloadHandler::downloadProcessFinished(int exitcode)
|
||||||
|
@ -32,8 +32,8 @@
|
|||||||
#include <QProcess>
|
#include <QProcess>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
|
|
||||||
|
#include "../utils/foreignapps.h"
|
||||||
#include "../utils/fs.h"
|
#include "../utils/fs.h"
|
||||||
#include "../utils/misc.h"
|
|
||||||
#include "searchpluginmanager.h"
|
#include "searchpluginmanager.h"
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
@ -70,7 +70,7 @@ SearchHandler::SearchHandler(const QString &pattern, const QString &category, co
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Launch search
|
// Launch search
|
||||||
m_searchProcess->setProgram(Utils::Misc::pythonExecutable());
|
m_searchProcess->setProgram(Utils::ForeignApps::pythonInfo().executableName);
|
||||||
m_searchProcess->setArguments(params + m_pattern.split(" "));
|
m_searchProcess->setArguments(params + m_pattern.split(" "));
|
||||||
|
|
||||||
#if (QT_VERSION >= QT_VERSION_CHECK(5, 6, 0))
|
#if (QT_VERSION >= QT_VERSION_CHECK(5, 6, 0))
|
||||||
|
@ -46,6 +46,7 @@
|
|||||||
#include "base/net/downloadmanager.h"
|
#include "base/net/downloadmanager.h"
|
||||||
#include "base/preferences.h"
|
#include "base/preferences.h"
|
||||||
#include "base/profile.h"
|
#include "base/profile.h"
|
||||||
|
#include "base/utils/foreignapps.h"
|
||||||
#include "base/utils/fs.h"
|
#include "base/utils/fs.h"
|
||||||
#include "base/utils/misc.h"
|
#include "base/utils/misc.h"
|
||||||
#include "searchdownloadhandler.h"
|
#include "searchdownloadhandler.h"
|
||||||
@ -63,7 +64,7 @@ namespace
|
|||||||
QPointer<SearchPluginManager> SearchPluginManager::m_instance = nullptr;
|
QPointer<SearchPluginManager> SearchPluginManager::m_instance = nullptr;
|
||||||
|
|
||||||
SearchPluginManager::SearchPluginManager()
|
SearchPluginManager::SearchPluginManager()
|
||||||
: m_updateUrl(QString("http://searchplugins.qbittorrent.org/%1/engines/").arg(Utils::Misc::pythonVersion() >= 3 ? "nova3" : "nova"))
|
: m_updateUrl(QString("http://searchplugins.qbittorrent.org/%1/engines/").arg(Utils::ForeignApps::pythonInfo().version.majorNumber() >= 3 ? "nova3" : "nova"))
|
||||||
{
|
{
|
||||||
Q_ASSERT(!m_instance); // only one instance is allowed
|
Q_ASSERT(!m_instance); // only one instance is allowed
|
||||||
m_instance = this;
|
m_instance = this;
|
||||||
@ -322,7 +323,7 @@ QString SearchPluginManager::pluginsLocation()
|
|||||||
QString SearchPluginManager::engineLocation()
|
QString SearchPluginManager::engineLocation()
|
||||||
{
|
{
|
||||||
QString folder = "nova";
|
QString folder = "nova";
|
||||||
if (Utils::Misc::pythonVersion() >= 3)
|
if (Utils::ForeignApps::pythonInfo().version.majorNumber() >= 3)
|
||||||
folder = "nova3";
|
folder = "nova3";
|
||||||
const QString location = Utils::Fs::expandPathAbs(specialFolderLocation(SpecialFolder::Data) + folder);
|
const QString location = Utils::Fs::expandPathAbs(specialFolderLocation(SpecialFolder::Data) + folder);
|
||||||
QDir locationDir(location);
|
QDir locationDir(location);
|
||||||
@ -370,7 +371,7 @@ void SearchPluginManager::updateNova()
|
|||||||
|
|
||||||
// create nova directory if necessary
|
// create nova directory if necessary
|
||||||
QDir searchDir(engineLocation());
|
QDir searchDir(engineLocation());
|
||||||
QString novaFolder = Utils::Misc::pythonVersion() >= 3 ? "searchengine/nova3" : "searchengine/nova";
|
QString novaFolder = Utils::ForeignApps::pythonInfo().version.majorNumber() >= 3 ? "searchengine/nova3" : "searchengine/nova";
|
||||||
QFile packageFile(searchDir.absoluteFilePath("__init__.py"));
|
QFile packageFile(searchDir.absoluteFilePath("__init__.py"));
|
||||||
packageFile.open(QIODevice::WriteOnly | QIODevice::Text);
|
packageFile.open(QIODevice::WriteOnly | QIODevice::Text);
|
||||||
packageFile.close();
|
packageFile.close();
|
||||||
@ -436,7 +437,7 @@ void SearchPluginManager::update()
|
|||||||
QStringList params;
|
QStringList params;
|
||||||
params << Utils::Fs::toNativePath(engineLocation() + "/nova2.py");
|
params << Utils::Fs::toNativePath(engineLocation() + "/nova2.py");
|
||||||
params << "--capabilities";
|
params << "--capabilities";
|
||||||
nova.start(Utils::Misc::pythonExecutable(), params, QIODevice::ReadOnly);
|
nova.start(Utils::ForeignApps::pythonInfo().executableName, params, QIODevice::ReadOnly);
|
||||||
nova.waitForStarted();
|
nova.waitForStarted();
|
||||||
nova.waitForFinished();
|
nova.waitForFinished();
|
||||||
|
|
||||||
|
100
src/base/utils/foreignapps.cpp
Normal file
100
src/base/utils/foreignapps.cpp
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
/*
|
||||||
|
* Bittorrent Client using Qt and libtorrent.
|
||||||
|
* Copyright (C) 2018 Mike Tzou
|
||||||
|
* Copyright (C) 2006 Christophe Dumez <chris@qbittorrent.org>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* In addition, as a special exception, the copyright holders give permission to
|
||||||
|
* link this program with the OpenSSL project's "OpenSSL" library (or with
|
||||||
|
* modified versions of it that use the same license as the "OpenSSL" library),
|
||||||
|
* and distribute the linked executables. You must obey the GNU General Public
|
||||||
|
* License in all respects for all of the code used other than "OpenSSL". If you
|
||||||
|
* modify file(s), you may extend this exception to your version of the file(s),
|
||||||
|
* but you are not obligated to do so. If you do not wish to do so, delete this
|
||||||
|
* exception statement from your version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "foreignapps.h"
|
||||||
|
|
||||||
|
#include <QCoreApplication>
|
||||||
|
#include <QProcess>
|
||||||
|
#include <QStringList>
|
||||||
|
|
||||||
|
#include "base/logger.h"
|
||||||
|
|
||||||
|
using namespace Utils::ForeignApps;
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
bool testPythonInstallation(const QString &exeName, PythonInfo &info)
|
||||||
|
{
|
||||||
|
QProcess proc;
|
||||||
|
proc.start(exeName, {"--version"}, QIODevice::ReadOnly);
|
||||||
|
if (proc.waitForFinished() && (proc.exitCode() == QProcess::NormalExit)) {
|
||||||
|
QByteArray procOutput = proc.readAllStandardOutput();
|
||||||
|
if (procOutput.isEmpty())
|
||||||
|
procOutput = proc.readAllStandardError();
|
||||||
|
procOutput = procOutput.simplified();
|
||||||
|
|
||||||
|
// Software 'Anaconda' installs its own python interpreter
|
||||||
|
// and `python --version` returns a string like this:
|
||||||
|
// "Python 3.4.3 :: Anaconda 2.3.0 (64-bit)"
|
||||||
|
const QList<QByteArray> outputSplit = procOutput.split(' ');
|
||||||
|
if (outputSplit.size() <= 1)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
try {
|
||||||
|
info = {exeName, outputSplit[1]};
|
||||||
|
}
|
||||||
|
catch (const std::runtime_error &err) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
LogMsg(QCoreApplication::translate("Utils::ForeignApps", "Python detected, version: %1").arg(info.version), Log::INFO);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Utils::ForeignApps::PythonInfo::isValid() const
|
||||||
|
{
|
||||||
|
return (!executableName.isEmpty() && version.isValid());
|
||||||
|
}
|
||||||
|
|
||||||
|
PythonInfo Utils::ForeignApps::pythonInfo()
|
||||||
|
{
|
||||||
|
static PythonInfo pyInfo;
|
||||||
|
if (!pyInfo.isValid()) {
|
||||||
|
#if defined(Q_OS_UNIX)
|
||||||
|
// On Unix-Like Systems python2 and python3 should always exist
|
||||||
|
// https://legacy.python.org/dev/peps/pep-0394/
|
||||||
|
if (testPythonInstallation("python3", pyInfo))
|
||||||
|
return pyInfo;
|
||||||
|
if (testPythonInstallation("python2", pyInfo))
|
||||||
|
return pyInfo;
|
||||||
|
#endif
|
||||||
|
// Look for "python" in Windows and in UNIX if "python2" and "python3" are
|
||||||
|
// not detected.
|
||||||
|
if (testPythonInstallation("python", pyInfo))
|
||||||
|
return pyInfo;
|
||||||
|
|
||||||
|
LogMsg(QCoreApplication::translate("Utils::ForeignApps", "Python not detected"), Log::INFO);
|
||||||
|
}
|
||||||
|
|
||||||
|
return pyInfo;
|
||||||
|
}
|
52
src/base/utils/foreignapps.h
Normal file
52
src/base/utils/foreignapps.h
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* Bittorrent Client using Qt and libtorrent.
|
||||||
|
* Copyright (C) 2018 Mike Tzou
|
||||||
|
* Copyright (C) 2006 Christophe Dumez <chris@qbittorrent.org>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* In addition, as a special exception, the copyright holders give permission to
|
||||||
|
* link this program with the OpenSSL project's "OpenSSL" library (or with
|
||||||
|
* modified versions of it that use the same license as the "OpenSSL" library),
|
||||||
|
* and distribute the linked executables. You must obey the GNU General Public
|
||||||
|
* License in all respects for all of the code used other than "OpenSSL". If you
|
||||||
|
* modify file(s), you may extend this exception to your version of the file(s),
|
||||||
|
* but you are not obligated to do so. If you do not wish to do so, delete this
|
||||||
|
* exception statement from your version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
#include "base/utils/version.h"
|
||||||
|
|
||||||
|
namespace Utils
|
||||||
|
{
|
||||||
|
namespace ForeignApps
|
||||||
|
{
|
||||||
|
struct PythonInfo
|
||||||
|
{
|
||||||
|
using Version = Utils::Version<quint8, 3, 1>;
|
||||||
|
|
||||||
|
bool isValid() const;
|
||||||
|
|
||||||
|
QString executableName;
|
||||||
|
Version version;
|
||||||
|
};
|
||||||
|
|
||||||
|
PythonInfo pythonInfo();
|
||||||
|
}
|
||||||
|
}
|
@ -237,106 +237,8 @@ QPoint Utils::Misc::screenCenter(const QWidget *w)
|
|||||||
QRect r = desktop->availableGeometry(scrn);
|
QRect r = desktop->availableGeometry(scrn);
|
||||||
return QPoint(r.x() + (r.width() - w->frameSize().width()) / 2, r.y() + (r.height() - w->frameSize().height()) / 2);
|
return QPoint(r.x() + (r.width() - w->frameSize().width()) / 2, r.y() + (r.height() - w->frameSize().height()) / 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
|
||||||
* Detects the python version.
|
|
||||||
*/
|
|
||||||
int Utils::Misc::pythonVersion()
|
|
||||||
{
|
|
||||||
static int version = -1;
|
|
||||||
if (version < 0) {
|
|
||||||
QString versionComplete = pythonVersionComplete().trimmed();
|
|
||||||
QStringList splitted = versionComplete.split('.');
|
|
||||||
if (splitted.size() > 1) {
|
|
||||||
int highVer = splitted.at(0).toInt();
|
|
||||||
if ((highVer == 2) || (highVer == 3))
|
|
||||||
version = highVer;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return version;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Detects the python executable by calling "python --version".
|
|
||||||
*/
|
|
||||||
QString Utils::Misc::pythonExecutable()
|
|
||||||
{
|
|
||||||
static QString executable;
|
|
||||||
if (executable.isEmpty()) {
|
|
||||||
QProcess pythonProc;
|
|
||||||
#if defined(Q_OS_UNIX)
|
|
||||||
/*
|
|
||||||
* On Unix-Like Systems python2 and python3 should always exist
|
|
||||||
* http://legacy.python.org/dev/peps/pep-0394/
|
|
||||||
*/
|
|
||||||
pythonProc.start("python3", {"--version"}, QIODevice::ReadOnly);
|
|
||||||
if (pythonProc.waitForFinished() && (pythonProc.exitCode() == 0)) {
|
|
||||||
executable = "python3";
|
|
||||||
return executable;
|
|
||||||
}
|
|
||||||
pythonProc.start("python2", {"--version"}, QIODevice::ReadOnly);
|
|
||||||
if (pythonProc.waitForFinished() && (pythonProc.exitCode() == 0)) {
|
|
||||||
executable = "python2";
|
|
||||||
return executable;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
// Look for "python" in Windows and in UNIX if "python2" and "python3" are
|
|
||||||
// not detected.
|
|
||||||
pythonProc.start("python", {"--version"}, QIODevice::ReadOnly);
|
|
||||||
if (pythonProc.waitForFinished() && (pythonProc.exitCode() == 0))
|
|
||||||
executable = "python";
|
|
||||||
else
|
|
||||||
Logger::instance()->addMessage(QCoreApplication::translate("misc", "Python not detected"), Log::INFO);
|
|
||||||
}
|
|
||||||
return executable;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the complete python version
|
|
||||||
* eg 2.7.9
|
|
||||||
* Make sure to have setup python first
|
|
||||||
*/
|
|
||||||
QString Utils::Misc::pythonVersionComplete()
|
|
||||||
{
|
|
||||||
static QString version;
|
|
||||||
if (version.isEmpty()) {
|
|
||||||
if (pythonExecutable().isEmpty())
|
|
||||||
return version;
|
|
||||||
QProcess pythonProc;
|
|
||||||
pythonProc.start(pythonExecutable(), {"--version"}, QIODevice::ReadOnly);
|
|
||||||
if (pythonProc.waitForFinished() && (pythonProc.exitCode() == 0)) {
|
|
||||||
QByteArray output = pythonProc.readAllStandardOutput();
|
|
||||||
if (output.isEmpty())
|
|
||||||
output = pythonProc.readAllStandardError();
|
|
||||||
|
|
||||||
// Software 'Anaconda' installs its own python interpreter
|
|
||||||
// and `python --version` returns a string like this:
|
|
||||||
// `Python 3.4.3 :: Anaconda 2.3.0 (64-bit)`
|
|
||||||
const QList<QByteArray> outSplit = output.split(' ');
|
|
||||||
if (outSplit.size() > 1) {
|
|
||||||
version = outSplit.at(1).trimmed();
|
|
||||||
Logger::instance()->addMessage(QCoreApplication::translate("misc", "Python version: %1").arg(version), Log::INFO);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If python doesn't report a 3-piece version e.g. 3.6.1
|
|
||||||
// then fill the missing pieces with zero
|
|
||||||
const QStringList verSplit = version.split('.', QString::SkipEmptyParts);
|
|
||||||
if (verSplit.size() < 3) {
|
|
||||||
for (int i = verSplit.size(); i < 3; ++i) {
|
|
||||||
if (version.endsWith('.'))
|
|
||||||
version.append('0');
|
|
||||||
else
|
|
||||||
version.append(".0");
|
|
||||||
}
|
|
||||||
Logger::instance()->addMessage(QCoreApplication::translate("misc", "Normalized Python version: %1").arg(version), Log::INFO);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return version;
|
|
||||||
}
|
|
||||||
|
|
||||||
QString Utils::Misc::unitString(Utils::Misc::SizeUnit unit)
|
QString Utils::Misc::unitString(Utils::Misc::SizeUnit unit)
|
||||||
{
|
{
|
||||||
return QCoreApplication::translate("misc",
|
return QCoreApplication::translate("misc",
|
||||||
|
@ -80,10 +80,6 @@ namespace Utils
|
|||||||
QString boostVersionString();
|
QString boostVersionString();
|
||||||
QString libtorrentVersionString();
|
QString libtorrentVersionString();
|
||||||
|
|
||||||
int pythonVersion();
|
|
||||||
QString pythonExecutable();
|
|
||||||
QString pythonVersionComplete();
|
|
||||||
|
|
||||||
QString unitString(SizeUnit unit);
|
QString unitString(SizeUnit unit);
|
||||||
|
|
||||||
// return the best user friendly storage unit (B, KiB, MiB, GiB, TiB)
|
// return the best user friendly storage unit (B, KiB, MiB, GiB, TiB)
|
||||||
|
@ -58,7 +58,7 @@ namespace Utils
|
|||||||
|
|
||||||
template <typename ... Other>
|
template <typename ... Other>
|
||||||
constexpr Version(Other ... components)
|
constexpr Version(Other ... components)
|
||||||
: m_components {{components ...}}
|
: m_components {{static_cast<T>(components) ...}}
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,6 +129,11 @@ namespace Utils
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
constexpr bool isValid() const
|
||||||
|
{
|
||||||
|
return (*this != ThisType {});
|
||||||
|
}
|
||||||
|
|
||||||
constexpr bool operator==(const ThisType &other) const
|
constexpr bool operator==(const ThisType &other) const
|
||||||
{
|
{
|
||||||
return (m_components == other.m_components);
|
return (m_components == other.m_components);
|
||||||
|
@ -66,6 +66,7 @@
|
|||||||
#include "base/rss/rss_folder.h"
|
#include "base/rss/rss_folder.h"
|
||||||
#include "base/rss/rss_session.h"
|
#include "base/rss/rss_session.h"
|
||||||
#include "base/settingsstorage.h"
|
#include "base/settingsstorage.h"
|
||||||
|
#include "base/utils/foreignapps.h"
|
||||||
#include "base/utils/fs.h"
|
#include "base/utils/fs.h"
|
||||||
#include "base/utils/misc.h"
|
#include "base/utils/misc.h"
|
||||||
#include "aboutdialog.h"
|
#include "aboutdialog.h"
|
||||||
@ -1742,45 +1743,42 @@ void MainWindow::on_actionRSSReader_triggered()
|
|||||||
void MainWindow::on_actionSearchWidget_triggered()
|
void MainWindow::on_actionSearchWidget_triggered()
|
||||||
{
|
{
|
||||||
if (!m_hasPython && m_ui->actionSearchWidget->isChecked()) {
|
if (!m_hasPython && m_ui->actionSearchWidget->isChecked()) {
|
||||||
int pythonVersion = Utils::Misc::pythonVersion();
|
int majorVersion = Utils::ForeignApps::pythonInfo().version.majorNumber();
|
||||||
|
|
||||||
// Check if python is already in PATH
|
// Check if python is already in PATH
|
||||||
if (pythonVersion > 0)
|
if (majorVersion > 0) {
|
||||||
// Prevent translators from messing with PATH
|
// Prevent translators from messing with PATH
|
||||||
Logger::instance()->addMessage(tr("Python found in %1: %2", "Python found in PATH: /usr/local/bin:/usr/bin:/etc/bin")
|
Logger::instance()->addMessage(tr("Python found in %1: %2", "Python found in PATH: /usr/local/bin:/usr/bin:/etc/bin")
|
||||||
.arg("PATH", qgetenv("PATH").constData()), Log::INFO);
|
.arg("PATH", qgetenv("PATH").constData()), Log::INFO);
|
||||||
|
}
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
else if (addPythonPathToEnv())
|
else if (addPythonPathToEnv()) {
|
||||||
pythonVersion = Utils::Misc::pythonVersion();
|
majorVersion = Utils::ForeignApps::pythonInfo().version.majorNumber();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
else {
|
||||||
|
QMessageBox::information(this, tr("Undetermined Python version"), tr("Couldn't determine your Python version. Search engine disabled."));
|
||||||
|
m_ui->actionSearchWidget->setChecked(false);
|
||||||
|
Preferences::instance()->setSearchEnabled(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
bool res = false;
|
bool res = false;
|
||||||
|
|
||||||
if ((pythonVersion == 2) || (pythonVersion == 3)) {
|
if ((majorVersion == 2) || (majorVersion == 3)) {
|
||||||
// Check Python minimum requirement: 2.7.9 / 3.3.0
|
// Check Python minimum requirement: 2.7.9 / 3.3.0
|
||||||
QString version = Utils::Misc::pythonVersionComplete();
|
using Version = Utils::ForeignApps::PythonInfo::Version;
|
||||||
QStringList splitted = version.split('.');
|
const Version pyVersion = Utils::ForeignApps::pythonInfo().version;
|
||||||
if (splitted.size() > 2) {
|
|
||||||
int middleVer = splitted.at(1).toInt();
|
if (((majorVersion == 2) && (pyVersion < Version {2, 7, 9}))
|
||||||
int lowerVer = splitted.at(2).toInt();
|
|| ((majorVersion == 3) && (pyVersion < Version {3, 3, 0}))) {
|
||||||
if (((pythonVersion == 2) && (middleVer < 7))
|
QMessageBox::information(this, tr("Old Python Interpreter"), tr("Your Python version (%1) is outdated. Please upgrade to latest version for search engines to work.\nMinimum requirement: 2.7.9 / 3.3.0.").arg(pyVersion));
|
||||||
|| ((pythonVersion == 2) && (middleVer == 7) && (lowerVer < 9))
|
|
||||||
|| ((pythonVersion == 3) && (middleVer < 3))) {
|
|
||||||
QMessageBox::information(this, tr("Old Python Interpreter"), tr("Your Python version (%1) is outdated. Please upgrade to latest version for search engines to work.\nMinimum requirement: 2.7.9 / 3.3.0.").arg(version));
|
|
||||||
m_ui->actionSearchWidget->setChecked(false);
|
|
||||||
Preferences::instance()->setSearchEnabled(false);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
res = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
QMessageBox::information(this, tr("Undetermined Python version"), tr("Couldn't determine your Python version (%1). Search engine disabled.").arg(version));
|
|
||||||
m_ui->actionSearchWidget->setChecked(false);
|
m_ui->actionSearchWidget->setChecked(false);
|
||||||
Preferences::instance()->setSearchEnabled(false);
|
Preferences::instance()->setSearchEnabled(false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
res = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (res) {
|
if (res) {
|
||||||
@ -2085,7 +2083,7 @@ void MainWindow::pythonDownloadSuccess(const QString &url, const QString &filePa
|
|||||||
m_hasPython = addPythonPathToEnv();
|
m_hasPython = addPythonPathToEnv();
|
||||||
if (m_hasPython) {
|
if (m_hasPython) {
|
||||||
// Make it print the version to Log
|
// Make it print the version to Log
|
||||||
Utils::Misc::pythonVersion();
|
Utils::ForeignApps::pythonInfo();
|
||||||
m_ui->actionSearchWidget->setChecked(true);
|
m_ui->actionSearchWidget->setChecked(true);
|
||||||
displaySearchTab(true);
|
displaySearchTab(true);
|
||||||
}
|
}
|
||||||
|
@ -56,8 +56,8 @@
|
|||||||
#include "base/preferences.h"
|
#include "base/preferences.h"
|
||||||
#include "base/search/searchpluginmanager.h"
|
#include "base/search/searchpluginmanager.h"
|
||||||
#include "base/search/searchhandler.h"
|
#include "base/search/searchhandler.h"
|
||||||
|
#include "base/utils/foreignapps.h"
|
||||||
#include "base/utils/fs.h"
|
#include "base/utils/fs.h"
|
||||||
#include "base/utils/misc.h"
|
|
||||||
#include "addnewtorrentdialog.h"
|
#include "addnewtorrentdialog.h"
|
||||||
#include "guiiconprovider.h"
|
#include "guiiconprovider.h"
|
||||||
#include "mainwindow.h"
|
#include "mainwindow.h"
|
||||||
@ -285,7 +285,7 @@ void SearchWidget::giveFocusToSearchInput()
|
|||||||
// Function called when we click on search button
|
// Function called when we click on search button
|
||||||
void SearchWidget::on_searchButton_clicked()
|
void SearchWidget::on_searchButton_clicked()
|
||||||
{
|
{
|
||||||
if (Utils::Misc::pythonVersion() < 0) {
|
if (Utils::ForeignApps::pythonInfo().version.majorNumber() <= 0) {
|
||||||
m_mainWindow->showNotificationBaloon(tr("Search Engine"), tr("Please install Python to use the Search Engine."));
|
m_mainWindow->showNotificationBaloon(tr("Search Engine"), tr("Please install Python to use the Search Engine."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user