Merge remote-tracking branch 'upstream/develop' into upstream_update
This commit is contained in:
commit
fa98ed3ccd
10
BUILD.md
10
BUILD.md
@ -193,11 +193,19 @@ zlib1.dll
|
|||||||
# macOS
|
# macOS
|
||||||
|
|
||||||
### Install prerequisites:
|
### Install prerequisites:
|
||||||
- Install XCode and set it up to the point where you can build things from a terminal
|
- Install XCode Command Line tools
|
||||||
- Install the official build of CMake (https://cmake.org/download/)
|
- Install the official build of CMake (https://cmake.org/download/)
|
||||||
- Install JDK 8 (https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html)
|
- Install JDK 8 (https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html)
|
||||||
- Get Qt 5.6 and install it (https://download.qt.io/new_archive/qt/5.6/5.6.3/)
|
- Get Qt 5.6 and install it (https://download.qt.io/new_archive/qt/5.6/5.6.3/)
|
||||||
|
|
||||||
|
### XCode Command Line tools
|
||||||
|
|
||||||
|
If you don't have XCode CommandLine tools installed, you can install them by using this command in the Terminal App
|
||||||
|
|
||||||
|
```bash
|
||||||
|
xcode-select --install
|
||||||
|
```
|
||||||
|
|
||||||
### Build
|
### Build
|
||||||
|
|
||||||
Pick an installation path - this is where the final `.app` will be constructed when you run `make install`. Supply it as the `CMAKE_INSTALL_PREFIX` argument during CMake configuration.
|
Pick an installation path - this is where the final `.app` will be constructed when you run `make install`. Supply it as the `CMAKE_INSTALL_PREFIX` argument during CMake configuration.
|
||||||
|
@ -47,6 +47,9 @@ if(UNIX AND APPLE)
|
|||||||
endif()
|
endif()
|
||||||
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Werror=return-type")
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Werror=return-type")
|
||||||
|
|
||||||
|
# Fix build with Qt 5.13
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DQT_NO_DEPRECATED_WARNINGS=Y")
|
||||||
|
|
||||||
##################################### Set Application options #####################################
|
##################################### Set Application options #####################################
|
||||||
|
|
||||||
######## Set URLs ########
|
######## Set URLs ########
|
||||||
|
@ -523,7 +523,7 @@ Application::Application(int &argc, char **argv) : QApplication(argc, argv)
|
|||||||
// Set up paths
|
// Set up paths
|
||||||
{
|
{
|
||||||
// Root path is used for updates.
|
// Root path is used for updates.
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
QDir foo(FS::PathCombine(binPath, ".."));
|
QDir foo(FS::PathCombine(binPath, ".."));
|
||||||
m_rootPath = foo.absolutePath();
|
m_rootPath = foo.absolutePath();
|
||||||
#elif defined(Q_OS_WIN32)
|
#elif defined(Q_OS_WIN32)
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
/**
|
/**
|
||||||
* This shouldn't exist, but until QTBUG-9328 and other unreported bugs are fixed, it needs to be a thing.
|
* This shouldn't exist, but until QTBUG-9328 and other unreported bugs are fixed, it needs to be a thing.
|
||||||
*/
|
*/
|
||||||
#if defined(Q_OS_LINUX)
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
@ -83,7 +83,7 @@ bool openDirectory(const QString &path, bool ensureExists)
|
|||||||
{
|
{
|
||||||
return QDesktopServices::openUrl(QUrl::fromLocalFile(dir.absolutePath()));
|
return QDesktopServices::openUrl(QUrl::fromLocalFile(dir.absolutePath()));
|
||||||
};
|
};
|
||||||
#if defined(Q_OS_LINUX)
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
return IndirectOpen(f);
|
return IndirectOpen(f);
|
||||||
#else
|
#else
|
||||||
return f();
|
return f();
|
||||||
@ -97,7 +97,7 @@ bool openFile(const QString &path)
|
|||||||
{
|
{
|
||||||
return QDesktopServices::openUrl(QUrl::fromLocalFile(path));
|
return QDesktopServices::openUrl(QUrl::fromLocalFile(path));
|
||||||
};
|
};
|
||||||
#if defined(Q_OS_LINUX)
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
return IndirectOpen(f);
|
return IndirectOpen(f);
|
||||||
#else
|
#else
|
||||||
return f();
|
return f();
|
||||||
@ -107,7 +107,7 @@ bool openFile(const QString &path)
|
|||||||
bool openFile(const QString &application, const QString &path, const QString &workingDirectory, qint64 *pid)
|
bool openFile(const QString &application, const QString &path, const QString &workingDirectory, qint64 *pid)
|
||||||
{
|
{
|
||||||
qDebug() << "Opening file" << path << "using" << application;
|
qDebug() << "Opening file" << path << "using" << application;
|
||||||
#if defined(Q_OS_LINUX)
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
// FIXME: the pid here is fake. So if something depends on it, it will likely misbehave
|
// FIXME: the pid here is fake. So if something depends on it, it will likely misbehave
|
||||||
return IndirectOpen([&]()
|
return IndirectOpen([&]()
|
||||||
{
|
{
|
||||||
@ -121,7 +121,7 @@ bool openFile(const QString &application, const QString &path, const QString &wo
|
|||||||
bool run(const QString &application, const QStringList &args, const QString &workingDirectory, qint64 *pid)
|
bool run(const QString &application, const QStringList &args, const QString &workingDirectory, qint64 *pid)
|
||||||
{
|
{
|
||||||
qDebug() << "Running" << application << "with args" << args.join(' ');
|
qDebug() << "Running" << application << "with args" << args.join(' ');
|
||||||
#if defined(Q_OS_LINUX)
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
// FIXME: the pid here is fake. So if something depends on it, it will likely misbehave
|
// FIXME: the pid here is fake. So if something depends on it, it will likely misbehave
|
||||||
return IndirectOpen([&]()
|
return IndirectOpen([&]()
|
||||||
{
|
{
|
||||||
@ -139,7 +139,7 @@ bool openUrl(const QUrl &url)
|
|||||||
{
|
{
|
||||||
return QDesktopServices::openUrl(url);
|
return QDesktopServices::openUrl(url);
|
||||||
};
|
};
|
||||||
#if defined(Q_OS_LINUX)
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
return IndirectOpen(f);
|
return IndirectOpen(f);
|
||||||
#else
|
#else
|
||||||
return f();
|
return f();
|
||||||
|
@ -403,7 +403,7 @@ QString getDesktopDir()
|
|||||||
bool createShortCut(QString location, QString dest, QStringList args, QString name,
|
bool createShortCut(QString location, QString dest, QStringList args, QString name,
|
||||||
QString icon)
|
QString icon)
|
||||||
{
|
{
|
||||||
#if defined Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
location = PathCombine(location, name + ".desktop");
|
location = PathCombine(location, name + ".desktop");
|
||||||
|
|
||||||
QFile f(location);
|
QFile f(location);
|
||||||
|
@ -55,14 +55,14 @@ void InstanceImportTask::executeTask()
|
|||||||
const QString path = m_sourceUrl.host() + '/' + m_sourceUrl.path();
|
const QString path = m_sourceUrl.host() + '/' + m_sourceUrl.path();
|
||||||
auto entry = APPLICATION->metacache()->resolveEntry("general", path);
|
auto entry = APPLICATION->metacache()->resolveEntry("general", path);
|
||||||
entry->setStale(true);
|
entry->setStale(true);
|
||||||
m_filesNetJob.reset(new NetJob(tr("Modpack download")));
|
m_filesNetJob = new NetJob(tr("Modpack download"), APPLICATION->network());
|
||||||
m_filesNetJob->addNetAction(Net::Download::makeCached(m_sourceUrl, entry));
|
m_filesNetJob->addNetAction(Net::Download::makeCached(m_sourceUrl, entry));
|
||||||
m_archivePath = entry->getFullPath();
|
m_archivePath = entry->getFullPath();
|
||||||
auto job = m_filesNetJob.get();
|
auto job = m_filesNetJob.get();
|
||||||
connect(job, &NetJob::succeeded, this, &InstanceImportTask::downloadSucceeded);
|
connect(job, &NetJob::succeeded, this, &InstanceImportTask::downloadSucceeded);
|
||||||
connect(job, &NetJob::progress, this, &InstanceImportTask::downloadProgressChanged);
|
connect(job, &NetJob::progress, this, &InstanceImportTask::downloadProgressChanged);
|
||||||
connect(job, &NetJob::failed, this, &InstanceImportTask::downloadFailed);
|
connect(job, &NetJob::failed, this, &InstanceImportTask::downloadFailed);
|
||||||
m_filesNetJob->start(APPLICATION->network());
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -337,7 +337,7 @@ void InstanceImportTask::processFlame()
|
|||||||
connect(m_modIdResolver.get(), &Flame::FileResolvingTask::succeeded, [&]()
|
connect(m_modIdResolver.get(), &Flame::FileResolvingTask::succeeded, [&]()
|
||||||
{
|
{
|
||||||
auto results = m_modIdResolver->getResults();
|
auto results = m_modIdResolver->getResults();
|
||||||
m_filesNetJob.reset(new NetJob(tr("Mod download")));
|
m_filesNetJob = new NetJob(tr("Mod download"), APPLICATION->network());
|
||||||
for(auto result: results.files)
|
for(auto result: results.files)
|
||||||
{
|
{
|
||||||
QString filename = result.fileName;
|
QString filename = result.fileName;
|
||||||
@ -391,7 +391,7 @@ void InstanceImportTask::processFlame()
|
|||||||
setProgress(current, total);
|
setProgress(current, total);
|
||||||
});
|
});
|
||||||
setStatus(tr("Downloading mods..."));
|
setStatus(tr("Downloading mods..."));
|
||||||
m_filesNetJob->start(APPLICATION->network());
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(m_modIdResolver.get(), &Flame::FileResolvingTask::failed, [&](QString reason)
|
connect(m_modIdResolver.get(), &Flame::FileResolvingTask::failed, [&](QString reason)
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
#include <QHostInfo>
|
#include <QHostInfo>
|
||||||
#include <QList>
|
#include <QList>
|
||||||
#include <QHostAddress>
|
#include <QHostAddress>
|
||||||
|
#include <QPushButton>
|
||||||
|
|
||||||
#include "BuildConfig.h"
|
#include "BuildConfig.h"
|
||||||
#include "JavaCommon.h"
|
#include "JavaCommon.h"
|
||||||
@ -145,21 +146,8 @@ void LaunchController::login() {
|
|||||||
m_session->MakeOffline(usedname);
|
m_session->MakeOffline(usedname);
|
||||||
// offline flavored game from here :3
|
// offline flavored game from here :3
|
||||||
}
|
}
|
||||||
if(m_accountToUse->ownsMinecraft() && !m_accountToUse->hasProfile()) {
|
if(m_accountToUse->ownsMinecraft()) {
|
||||||
auto entitlement = m_accountToUse->accountData()->minecraftEntitlement;
|
if(!m_accountToUse->hasProfile()) {
|
||||||
QString errorString;
|
|
||||||
if(!entitlement.canPlayMinecraft) {
|
|
||||||
errorString = tr("The account does not own Minecraft. You need to purchase the game first to play it.");
|
|
||||||
QMessageBox::warning(
|
|
||||||
nullptr,
|
|
||||||
tr("Missing Minecraft profile"),
|
|
||||||
errorString,
|
|
||||||
QMessageBox::StandardButton::Ok,
|
|
||||||
QMessageBox::StandardButton::Ok
|
|
||||||
);
|
|
||||||
emitFailed(errorString);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// Now handle setting up a profile name here...
|
// Now handle setting up a profile name here...
|
||||||
ProfileSetupDialog dialog(m_accountToUse, m_parentWidget);
|
ProfileSetupDialog dialog(m_accountToUse, m_parentWidget);
|
||||||
if (dialog.exec() == QDialog::Accepted)
|
if (dialog.exec() == QDialog::Accepted)
|
||||||
@ -173,8 +161,29 @@ void LaunchController::login() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
// we own Minecraft, there is a profile, it's all ready to go!
|
||||||
launchInstance();
|
launchInstance();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// play demo ?
|
||||||
|
QMessageBox box(m_parentWidget);
|
||||||
|
box.setWindowTitle(tr("Play demo?"));
|
||||||
|
box.setText(tr("This account does not own Minecraft.\nYou need to purchase the game first to play it.\n\nDo you want to play the demo?"));
|
||||||
|
box.setIcon(QMessageBox::Warning);
|
||||||
|
auto demoButton = box.addButton(tr("Play Demo"), QMessageBox::ButtonRole::YesRole);
|
||||||
|
auto cancelButton = box.addButton(tr("Cancel"), QMessageBox::ButtonRole::NoRole);
|
||||||
|
box.setDefaultButton(cancelButton);
|
||||||
|
|
||||||
|
box.exec();
|
||||||
|
if(box.clickedButton() == demoButton) {
|
||||||
|
// play demo here
|
||||||
|
m_session->MakeDemo();
|
||||||
|
launchInstance();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
emitFailed(tr("Launch cancelled - account does not own Minecraft."));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -93,7 +93,7 @@ void UpdateController::installUpdates()
|
|||||||
qDebug() << "Installing updates.";
|
qDebug() << "Installing updates.";
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
QString finishCmd = QApplication::applicationFilePath();
|
QString finishCmd = QApplication::applicationFilePath();
|
||||||
#elif defined Q_OS_LINUX
|
#elif defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
QString finishCmd = FS::PathCombine(m_root, BuildConfig.LAUNCHER_NAME);
|
QString finishCmd = FS::PathCombine(m_root, BuildConfig.LAUNCHER_NAME);
|
||||||
#elif defined Q_OS_MAC
|
#elif defined Q_OS_MAC
|
||||||
QString finishCmd = QApplication::applicationFilePath();
|
QString finishCmd = QApplication::applicationFilePath();
|
||||||
|
@ -31,7 +31,7 @@ JavaUtils::JavaUtils()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
static QString processLD_LIBRARY_PATH(const QString & LD_LIBRARY_PATH)
|
static QString processLD_LIBRARY_PATH(const QString & LD_LIBRARY_PATH)
|
||||||
{
|
{
|
||||||
QDir mmcBin(QCoreApplication::applicationDirPath());
|
QDir mmcBin(QCoreApplication::applicationDirPath());
|
||||||
@ -83,7 +83,7 @@ QProcessEnvironment CleanEnviroment()
|
|||||||
qDebug() << "Env: ignoring" << key << value;
|
qDebug() << "Env: ignoring" << key << value;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
// Do not pass LD_* variables to java. They were intended for MultiMC
|
// Do not pass LD_* variables to java. They were intended for MultiMC
|
||||||
if(key.startsWith("LD_"))
|
if(key.startsWith("LD_"))
|
||||||
{
|
{
|
||||||
|
@ -117,7 +117,7 @@ void Meta::BaseEntity::load(Net::Mode loadType)
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_updateTask = new NetJob(QObject::tr("Download of meta file %1").arg(localFilename()));
|
m_updateTask = new NetJob(QObject::tr("Download of meta file %1").arg(localFilename()), APPLICATION->network());
|
||||||
auto url = this->url();
|
auto url = this->url();
|
||||||
auto entry = APPLICATION->metacache()->resolveEntry("meta", localFilename());
|
auto entry = APPLICATION->metacache()->resolveEntry("meta", localFilename());
|
||||||
entry->setStale(true);
|
entry->setStale(true);
|
||||||
@ -140,7 +140,7 @@ void Meta::BaseEntity::load(Net::Mode loadType)
|
|||||||
m_updateStatus = UpdateStatus::Failed;
|
m_updateStatus = UpdateStatus::Failed;
|
||||||
m_updateTask.reset();
|
m_updateTask.reset();
|
||||||
});
|
});
|
||||||
m_updateTask->start(APPLICATION->network());
|
m_updateTask->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Meta::BaseEntity::isLoaded() const
|
bool Meta::BaseEntity::isLoaded() const
|
||||||
|
@ -29,6 +29,8 @@
|
|||||||
#include "net/ChecksumValidator.h"
|
#include "net/ChecksumValidator.h"
|
||||||
#include "BuildConfig.h"
|
#include "BuildConfig.h"
|
||||||
|
|
||||||
|
#include "Application.h"
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
QSet<QString> collectPathsFromDir(QString dirPath)
|
QSet<QString> collectPathsFromDir(QString dirPath)
|
||||||
{
|
{
|
||||||
@ -318,7 +320,7 @@ QString AssetObject::getRelPath()
|
|||||||
|
|
||||||
NetJob::Ptr AssetsIndex::getDownloadJob()
|
NetJob::Ptr AssetsIndex::getDownloadJob()
|
||||||
{
|
{
|
||||||
auto job = new NetJob(QObject::tr("Assets for %1").arg(id));
|
auto job = new NetJob(QObject::tr("Assets for %1").arg(id), APPLICATION->network());
|
||||||
for (auto &object : objects.values())
|
for (auto &object : objects.values())
|
||||||
{
|
{
|
||||||
auto dl = object.getDownloadAction();
|
auto dl = object.getDownloadAction();
|
||||||
|
@ -431,8 +431,7 @@ QStringList MinecraftInstance::processMinecraftArgs(
|
|||||||
|
|
||||||
QMap<QString, QString> token_mapping;
|
QMap<QString, QString> token_mapping;
|
||||||
// yggdrasil!
|
// yggdrasil!
|
||||||
if(session)
|
if(session) {
|
||||||
{
|
|
||||||
// token_mapping["auth_username"] = session->username;
|
// token_mapping["auth_username"] = session->username;
|
||||||
token_mapping["auth_session"] = session->session;
|
token_mapping["auth_session"] = session->session;
|
||||||
token_mapping["auth_access_token"] = session->access_token;
|
token_mapping["auth_access_token"] = session->access_token;
|
||||||
@ -440,6 +439,9 @@ QStringList MinecraftInstance::processMinecraftArgs(
|
|||||||
token_mapping["auth_uuid"] = session->uuid;
|
token_mapping["auth_uuid"] = session->uuid;
|
||||||
token_mapping["user_properties"] = session->serializeUserProperties();
|
token_mapping["user_properties"] = session->serializeUserProperties();
|
||||||
token_mapping["user_type"] = session->user_type;
|
token_mapping["user_type"] = session->user_type;
|
||||||
|
if(session->demo) {
|
||||||
|
args_pattern += " --demo";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// blatant self-promotion.
|
// blatant self-promotion.
|
||||||
@ -872,7 +874,9 @@ shared_qobject_ptr<LaunchTask> MinecraftInstance::createLaunchTask(AuthSessionPt
|
|||||||
// if we aren't in offline mode,.
|
// if we aren't in offline mode,.
|
||||||
if(session->status != AuthSession::PlayableOffline)
|
if(session->status != AuthSession::PlayableOffline)
|
||||||
{
|
{
|
||||||
|
if(!session->demo) {
|
||||||
process->appendStep(new ClaimAccount(pptr, session));
|
process->appendStep(new ClaimAccount(pptr, session));
|
||||||
|
}
|
||||||
process->appendStep(new Update(pptr, Net::Mode::Online));
|
process->appendStep(new Update(pptr, Net::Mode::Online));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
|
|
||||||
OpSys OpSys_fromString(QString name)
|
OpSys OpSys_fromString(QString name)
|
||||||
{
|
{
|
||||||
|
if (name == "freebsd")
|
||||||
|
return Os_FreeBSD;
|
||||||
if (name == "linux")
|
if (name == "linux")
|
||||||
return Os_Linux;
|
return Os_Linux;
|
||||||
if (name == "windows")
|
if (name == "windows")
|
||||||
@ -30,6 +32,8 @@ QString OpSys_toString(OpSys name)
|
|||||||
{
|
{
|
||||||
switch (name)
|
switch (name)
|
||||||
{
|
{
|
||||||
|
case Os_FreeBSD:
|
||||||
|
return "freebsd";
|
||||||
case Os_Linux:
|
case Os_Linux:
|
||||||
return "linux";
|
return "linux";
|
||||||
case Os_OSX:
|
case Os_OSX:
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
enum OpSys
|
enum OpSys
|
||||||
{
|
{
|
||||||
Os_Windows,
|
Os_Windows,
|
||||||
|
Os_FreeBSD,
|
||||||
Os_Linux,
|
Os_Linux,
|
||||||
Os_OSX,
|
Os_OSX,
|
||||||
Os_Other
|
Os_Other
|
||||||
@ -28,10 +29,10 @@ QString OpSys_toString(OpSys);
|
|||||||
|
|
||||||
#ifdef Q_OS_WIN32
|
#ifdef Q_OS_WIN32
|
||||||
#define currentSystem Os_Windows
|
#define currentSystem Os_Windows
|
||||||
#else
|
#elif defined Q_OS_MAC
|
||||||
#ifdef Q_OS_MAC
|
|
||||||
#define currentSystem Os_OSX
|
#define currentSystem Os_OSX
|
||||||
|
#elif defined Q_OS_FREEBSD
|
||||||
|
#define currentSystem Os_FreeBSD
|
||||||
#else
|
#else
|
||||||
#define currentSystem Os_Linux
|
#define currentSystem Os_Linux
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
@ -30,3 +30,8 @@ bool AuthSession::MakeOffline(QString offline_playername)
|
|||||||
status = PlayableOffline;
|
status = PlayableOffline;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AuthSession::MakeDemo() {
|
||||||
|
player_name = "Player";
|
||||||
|
demo = true;
|
||||||
|
}
|
||||||
|
@ -11,6 +11,7 @@ class QNetworkAccessManager;
|
|||||||
struct AuthSession
|
struct AuthSession
|
||||||
{
|
{
|
||||||
bool MakeOffline(QString offline_playername);
|
bool MakeOffline(QString offline_playername);
|
||||||
|
void MakeDemo();
|
||||||
|
|
||||||
QString serializeUserProperties();
|
QString serializeUserProperties();
|
||||||
|
|
||||||
@ -43,6 +44,9 @@ struct AuthSession
|
|||||||
bool auth_server_online = false;
|
bool auth_server_online = false;
|
||||||
// Did the user request online mode?
|
// Did the user request online mode?
|
||||||
bool wants_online = true;
|
bool wants_online = true;
|
||||||
|
|
||||||
|
//Is this a demo session?
|
||||||
|
bool demo = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::shared_ptr<AuthSession> AuthSessionPtr;
|
typedef std::shared_ptr<AuthSession> AuthSessionPtr;
|
||||||
|
@ -226,6 +226,8 @@ bool parseMinecraftEntitlements(QByteArray & data, MinecraftEntitlement &output)
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto obj = doc.object();
|
auto obj = doc.object();
|
||||||
|
output.canPlayMinecraft = false;
|
||||||
|
output.ownsMinecraft = false;
|
||||||
|
|
||||||
auto itemsArray = obj.value("items").toArray();
|
auto itemsArray = obj.value("items").toArray();
|
||||||
for(auto item: itemsArray) {
|
for(auto item: itemsArray) {
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
ClaimAccount::ClaimAccount(LaunchTask* parent, AuthSessionPtr session): LaunchStep(parent)
|
ClaimAccount::ClaimAccount(LaunchTask* parent, AuthSessionPtr session): LaunchStep(parent)
|
||||||
{
|
{
|
||||||
if(session->status == AuthSession::Status::PlayableOnline)
|
if(session->status == AuthSession::Status::PlayableOnline && !session->demo)
|
||||||
{
|
{
|
||||||
auto accounts = APPLICATION->accounts();
|
auto accounts = APPLICATION->accounts();
|
||||||
m_account = accounts->getAccountByProfileName(session->player_name);
|
m_account = accounts->getAccountByProfileName(session->player_name);
|
||||||
|
@ -23,6 +23,13 @@
|
|||||||
#include "FileSystem.h"
|
#include "FileSystem.h"
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
|
|
||||||
|
#ifdef major
|
||||||
|
#undef major
|
||||||
|
#endif
|
||||||
|
#ifdef minor
|
||||||
|
#undef minor
|
||||||
|
#endif
|
||||||
|
|
||||||
static QString replaceSuffix (QString target, const QString &suffix, const QString &replacement)
|
static QString replaceSuffix (QString target, const QString &suffix, const QString &replacement)
|
||||||
{
|
{
|
||||||
if (!target.endsWith(suffix))
|
if (!target.endsWith(suffix))
|
||||||
|
@ -19,8 +19,9 @@
|
|||||||
#include "PrintInstanceInfo.h"
|
#include "PrintInstanceInfo.h"
|
||||||
#include <launch/LaunchTask.h>
|
#include <launch/LaunchTask.h>
|
||||||
|
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
namespace {
|
namespace {
|
||||||
|
#if defined(Q_OS_LINUX)
|
||||||
void probeProcCpuinfo(QStringList &log)
|
void probeProcCpuinfo(QStringList &log)
|
||||||
{
|
{
|
||||||
std::ifstream cpuin("/proc/cpuinfo");
|
std::ifstream cpuin("/proc/cpuinfo");
|
||||||
@ -66,7 +67,43 @@ void runLspci(QStringList &log)
|
|||||||
}
|
}
|
||||||
pclose(lspci);
|
pclose(lspci);
|
||||||
}
|
}
|
||||||
|
#elif defined(Q_OS_FREEBSD)
|
||||||
|
void runSysctlHwModel(QStringList &log)
|
||||||
|
{
|
||||||
|
char buff[512];
|
||||||
|
FILE *hwmodel = popen("sysctl hw.model", "r");
|
||||||
|
while (fgets(buff, 512, hwmodel) != NULL)
|
||||||
|
{
|
||||||
|
log << QString::fromUtf8(buff);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pclose(hwmodel);
|
||||||
|
}
|
||||||
|
|
||||||
|
void runPciconf(QStringList &log)
|
||||||
|
{
|
||||||
|
char buff[512];
|
||||||
|
std::string strcard;
|
||||||
|
FILE *pciconf = popen("pciconf -lv -a vgapci0", "r");
|
||||||
|
while (fgets(buff, 512, pciconf) != NULL)
|
||||||
|
{
|
||||||
|
if (strncmp(buff, " vendor", 10) == 0)
|
||||||
|
{
|
||||||
|
std::string str(buff);
|
||||||
|
strcard.append(str.substr(str.find_first_of("'") + 1, str.find_last_not_of("'") - (str.find_first_of("'") + 2)));
|
||||||
|
strcard.append(" ");
|
||||||
|
}
|
||||||
|
else if (strncmp(buff, " device", 10) == 0)
|
||||||
|
{
|
||||||
|
std::string str2(buff);
|
||||||
|
strcard.append(str2.substr(str2.find_first_of("'") + 1, str2.find_last_not_of("'") - (str2.find_first_of("'") + 2)));
|
||||||
|
}
|
||||||
|
log << QString::fromStdString(strcard);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pclose(pciconf);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
void runGlxinfo(QStringList & log)
|
void runGlxinfo(QStringList & log)
|
||||||
{
|
{
|
||||||
// FIXME: fixed size buffers...
|
// FIXME: fixed size buffers...
|
||||||
@ -94,10 +131,14 @@ void PrintInstanceInfo::executeTask()
|
|||||||
auto instance = m_parent->instance();
|
auto instance = m_parent->instance();
|
||||||
QStringList log;
|
QStringList log;
|
||||||
|
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX)
|
||||||
::probeProcCpuinfo(log);
|
::probeProcCpuinfo(log);
|
||||||
::runLspci(log);
|
::runLspci(log);
|
||||||
::runGlxinfo(log);
|
::runGlxinfo(log);
|
||||||
|
#elif defined(Q_OS_FREEBSD)
|
||||||
|
::runSysctlHwModel(log);
|
||||||
|
::runPciconf(log);
|
||||||
|
::runGlxinfo(log);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
logLines(log, MessageLevel::Launcher);
|
logLines(log, MessageLevel::Launcher);
|
||||||
|
@ -5,6 +5,13 @@
|
|||||||
#include <minecraft/PackProfile.h>
|
#include <minecraft/PackProfile.h>
|
||||||
#include <minecraft/VersionFilterData.h>
|
#include <minecraft/VersionFilterData.h>
|
||||||
|
|
||||||
|
#ifdef major
|
||||||
|
#undef major
|
||||||
|
#endif
|
||||||
|
#ifdef minor
|
||||||
|
#undef minor
|
||||||
|
#endif
|
||||||
|
|
||||||
void VerifyJavaInstall::executeTask() {
|
void VerifyJavaInstall::executeTask() {
|
||||||
auto m_inst = std::dynamic_pointer_cast<MinecraftInstance>(m_parent->instance());
|
auto m_inst = std::dynamic_pointer_cast<MinecraftInstance>(m_parent->instance());
|
||||||
|
|
||||||
|
@ -24,7 +24,10 @@ void AssetUpdateTask::executeTask()
|
|||||||
auto assets = profile->getMinecraftAssets();
|
auto assets = profile->getMinecraftAssets();
|
||||||
QUrl indexUrl = assets->url;
|
QUrl indexUrl = assets->url;
|
||||||
QString localPath = assets->id + ".json";
|
QString localPath = assets->id + ".json";
|
||||||
auto job = new NetJob(tr("Asset index for %1").arg(m_inst->name()));
|
auto job = new NetJob(
|
||||||
|
tr("Asset index for %1").arg(m_inst->name()),
|
||||||
|
APPLICATION->network()
|
||||||
|
);
|
||||||
|
|
||||||
auto metacache = APPLICATION->metacache();
|
auto metacache = APPLICATION->metacache();
|
||||||
auto entry = metacache->resolveEntry("asset_indexes", localPath);
|
auto entry = metacache->resolveEntry("asset_indexes", localPath);
|
||||||
@ -43,7 +46,7 @@ void AssetUpdateTask::executeTask()
|
|||||||
connect(downloadJob.get(), &NetJob::progress, this, &AssetUpdateTask::progress);
|
connect(downloadJob.get(), &NetJob::progress, this, &AssetUpdateTask::progress);
|
||||||
|
|
||||||
qDebug() << m_inst->name() << ": Starting asset index download";
|
qDebug() << m_inst->name() << ": Starting asset index download";
|
||||||
downloadJob->start(APPLICATION->network());
|
downloadJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AssetUpdateTask::canAbort() const
|
bool AssetUpdateTask::canAbort() const
|
||||||
@ -78,7 +81,7 @@ void AssetUpdateTask::assetIndexFinished()
|
|||||||
connect(downloadJob.get(), &NetJob::succeeded, this, &AssetUpdateTask::emitSucceeded);
|
connect(downloadJob.get(), &NetJob::succeeded, this, &AssetUpdateTask::emitSucceeded);
|
||||||
connect(downloadJob.get(), &NetJob::failed, this, &AssetUpdateTask::assetsFailed);
|
connect(downloadJob.get(), &NetJob::failed, this, &AssetUpdateTask::assetsFailed);
|
||||||
connect(downloadJob.get(), &NetJob::progress, this, &AssetUpdateTask::progress);
|
connect(downloadJob.get(), &NetJob::progress, this, &AssetUpdateTask::progress);
|
||||||
downloadJob->start(APPLICATION->network());
|
downloadJob->start();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
emitSucceeded();
|
emitSucceeded();
|
||||||
|
@ -61,7 +61,7 @@ void FMLLibrariesTask::executeTask()
|
|||||||
|
|
||||||
// download missing libs to our place
|
// download missing libs to our place
|
||||||
setStatus(tr("Downloading FML libraries..."));
|
setStatus(tr("Downloading FML libraries..."));
|
||||||
auto dljob = new NetJob("FML libraries");
|
auto dljob = new NetJob("FML libraries", APPLICATION->network());
|
||||||
auto metacache = APPLICATION->metacache();
|
auto metacache = APPLICATION->metacache();
|
||||||
for (auto &lib : fmlLibsToProcess)
|
for (auto &lib : fmlLibsToProcess)
|
||||||
{
|
{
|
||||||
@ -74,7 +74,7 @@ void FMLLibrariesTask::executeTask()
|
|||||||
connect(dljob, &NetJob::failed, this, &FMLLibrariesTask::fmllibsFailed);
|
connect(dljob, &NetJob::failed, this, &FMLLibrariesTask::fmllibsFailed);
|
||||||
connect(dljob, &NetJob::progress, this, &FMLLibrariesTask::progress);
|
connect(dljob, &NetJob::progress, this, &FMLLibrariesTask::progress);
|
||||||
downloadJob.reset(dljob);
|
downloadJob.reset(dljob);
|
||||||
downloadJob->start(APPLICATION->network());
|
downloadJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FMLLibrariesTask::canAbort() const
|
bool FMLLibrariesTask::canAbort() const
|
||||||
|
@ -20,7 +20,7 @@ void LibrariesTask::executeTask()
|
|||||||
auto components = inst->getPackProfile();
|
auto components = inst->getPackProfile();
|
||||||
auto profile = components->getProfile();
|
auto profile = components->getProfile();
|
||||||
|
|
||||||
auto job = new NetJob(tr("Libraries for instance %1").arg(inst->name()));
|
auto job = new NetJob(tr("Libraries for instance %1").arg(inst->name()), APPLICATION->network());
|
||||||
downloadJob.reset(job);
|
downloadJob.reset(job);
|
||||||
|
|
||||||
auto metacache = APPLICATION->metacache();
|
auto metacache = APPLICATION->metacache();
|
||||||
@ -65,7 +65,7 @@ void LibrariesTask::executeTask()
|
|||||||
connect(downloadJob.get(), &NetJob::succeeded, this, &LibrariesTask::emitSucceeded);
|
connect(downloadJob.get(), &NetJob::succeeded, this, &LibrariesTask::emitSucceeded);
|
||||||
connect(downloadJob.get(), &NetJob::failed, this, &LibrariesTask::jarlibFailed);
|
connect(downloadJob.get(), &NetJob::failed, this, &LibrariesTask::jarlibFailed);
|
||||||
connect(downloadJob.get(), &NetJob::progress, this, &LibrariesTask::progress);
|
connect(downloadJob.get(), &NetJob::progress, this, &LibrariesTask::progress);
|
||||||
downloadJob->start(APPLICATION->network());
|
downloadJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LibrariesTask::canAbort() const
|
bool LibrariesTask::canAbort() const
|
||||||
|
@ -58,12 +58,12 @@ bool PackInstallTask::abort()
|
|||||||
void PackInstallTask::executeTask()
|
void PackInstallTask::executeTask()
|
||||||
{
|
{
|
||||||
qDebug() << "PackInstallTask::executeTask: " << QThread::currentThreadId();
|
qDebug() << "PackInstallTask::executeTask: " << QThread::currentThreadId();
|
||||||
auto *netJob = new NetJob("ATLauncher::VersionFetch");
|
auto *netJob = new NetJob("ATLauncher::VersionFetch", APPLICATION->network());
|
||||||
auto searchUrl = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "packs/%1/versions/%2/Configs.json")
|
auto searchUrl = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "packs/%1/versions/%2/Configs.json")
|
||||||
.arg(m_pack).arg(m_version_name);
|
.arg(m_pack).arg(m_version_name);
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
|
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
|
QObject::connect(netJob, &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
|
||||||
@ -424,7 +424,7 @@ void PackInstallTask::installConfigs()
|
|||||||
{
|
{
|
||||||
qDebug() << "PackInstallTask::installConfigs: " << QThread::currentThreadId();
|
qDebug() << "PackInstallTask::installConfigs: " << QThread::currentThreadId();
|
||||||
setStatus(tr("Downloading configs..."));
|
setStatus(tr("Downloading configs..."));
|
||||||
jobPtr.reset(new NetJob(tr("Config download")));
|
jobPtr = new NetJob(tr("Config download"), APPLICATION->network());
|
||||||
|
|
||||||
auto path = QString("Configs/%1/%2.zip").arg(m_pack).arg(m_version_name);
|
auto path = QString("Configs/%1/%2.zip").arg(m_pack).arg(m_version_name);
|
||||||
auto url = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "packs/%1/versions/%2/Configs.zip")
|
auto url = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "packs/%1/versions/%2/Configs.zip")
|
||||||
@ -458,7 +458,7 @@ void PackInstallTask::installConfigs()
|
|||||||
setProgress(current, total);
|
setProgress(current, total);
|
||||||
});
|
});
|
||||||
|
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PackInstallTask::extractConfigs()
|
void PackInstallTask::extractConfigs()
|
||||||
@ -508,7 +508,7 @@ void PackInstallTask::downloadMods()
|
|||||||
setStatus(tr("Downloading mods..."));
|
setStatus(tr("Downloading mods..."));
|
||||||
|
|
||||||
jarmods.clear();
|
jarmods.clear();
|
||||||
jobPtr.reset(new NetJob(tr("Mod download")));
|
jobPtr = new NetJob(tr("Mod download"), APPLICATION->network());
|
||||||
for(const auto& mod : m_version.mods) {
|
for(const auto& mod : m_version.mods) {
|
||||||
// skip non-client mods
|
// skip non-client mods
|
||||||
if(!mod.client) continue;
|
if(!mod.client) continue;
|
||||||
@ -613,7 +613,7 @@ void PackInstallTask::downloadMods()
|
|||||||
setProgress(current, total);
|
setProgress(current, total);
|
||||||
});
|
});
|
||||||
|
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PackInstallTask::onModsDownloaded() {
|
void PackInstallTask::onModsDownloaded() {
|
||||||
|
@ -14,7 +14,7 @@ void Flame::FileResolvingTask::executeTask()
|
|||||||
{
|
{
|
||||||
setStatus(tr("Resolving mod IDs..."));
|
setStatus(tr("Resolving mod IDs..."));
|
||||||
setProgress(0, m_toProcess.files.size());
|
setProgress(0, m_toProcess.files.size());
|
||||||
m_dljob = new NetJob("Mod id resolver");
|
m_dljob = new NetJob("Mod id resolver", m_network);
|
||||||
results.resize(m_toProcess.files.size());
|
results.resize(m_toProcess.files.size());
|
||||||
int index = 0;
|
int index = 0;
|
||||||
for(auto & file: m_toProcess.files)
|
for(auto & file: m_toProcess.files)
|
||||||
@ -27,7 +27,7 @@ void Flame::FileResolvingTask::executeTask()
|
|||||||
index ++;
|
index ++;
|
||||||
}
|
}
|
||||||
connect(m_dljob.get(), &NetJob::finished, this, &Flame::FileResolvingTask::netJobFinished);
|
connect(m_dljob.get(), &NetJob::finished, this, &Flame::FileResolvingTask::netJobFinished);
|
||||||
m_dljob->start(m_network);
|
m_dljob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Flame::FileResolvingTask::netJobFinished()
|
void Flame::FileResolvingTask::netJobFinished()
|
||||||
|
@ -12,7 +12,7 @@ void PackFetchTask::fetch()
|
|||||||
publicPacks.clear();
|
publicPacks.clear();
|
||||||
thirdPartyPacks.clear();
|
thirdPartyPacks.clear();
|
||||||
|
|
||||||
jobPtr = new NetJob("LegacyFTB::ModpackFetch");
|
jobPtr = new NetJob("LegacyFTB::ModpackFetch", m_network);
|
||||||
|
|
||||||
QUrl publicPacksUrl = QUrl(BuildConfig.LEGACY_FTB_CDN_BASE_URL + "static/modpacks.xml");
|
QUrl publicPacksUrl = QUrl(BuildConfig.LEGACY_FTB_CDN_BASE_URL + "static/modpacks.xml");
|
||||||
qDebug() << "Downloading public version info from" << publicPacksUrl.toString();
|
qDebug() << "Downloading public version info from" << publicPacksUrl.toString();
|
||||||
@ -25,7 +25,7 @@ void PackFetchTask::fetch()
|
|||||||
QObject::connect(jobPtr.get(), &NetJob::succeeded, this, &PackFetchTask::fileDownloadFinished);
|
QObject::connect(jobPtr.get(), &NetJob::succeeded, this, &PackFetchTask::fileDownloadFinished);
|
||||||
QObject::connect(jobPtr.get(), &NetJob::failed, this, &PackFetchTask::fileDownloadFailed);
|
QObject::connect(jobPtr.get(), &NetJob::failed, this, &PackFetchTask::fileDownloadFailed);
|
||||||
|
|
||||||
jobPtr->start(m_network);
|
jobPtr->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PackFetchTask::fetchPrivate(const QStringList & toFetch)
|
void PackFetchTask::fetchPrivate(const QStringList & toFetch)
|
||||||
@ -35,7 +35,7 @@ void PackFetchTask::fetchPrivate(const QStringList & toFetch)
|
|||||||
for (auto &packCode: toFetch)
|
for (auto &packCode: toFetch)
|
||||||
{
|
{
|
||||||
QByteArray *data = new QByteArray();
|
QByteArray *data = new QByteArray();
|
||||||
NetJob *job = new NetJob("Fetching private pack");
|
NetJob *job = new NetJob("Fetching private pack", m_network);
|
||||||
job->addNetAction(Net::Download::makeByteArray(privatePackBaseUrl.arg(packCode), data));
|
job->addNetAction(Net::Download::makeByteArray(privatePackBaseUrl.arg(packCode), data));
|
||||||
|
|
||||||
QObject::connect(job, &NetJob::succeeded, this, [this, job, data, packCode]
|
QObject::connect(job, &NetJob::succeeded, this, [this, job, data, packCode]
|
||||||
@ -63,7 +63,7 @@ void PackFetchTask::fetchPrivate(const QStringList & toFetch)
|
|||||||
delete data;
|
delete data;
|
||||||
});
|
});
|
||||||
|
|
||||||
job->start(m_network);
|
job->start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ void PackInstallTask::downloadPack()
|
|||||||
|
|
||||||
auto packoffset = QString("%1/%2/%3").arg(m_pack.dir, m_version.replace(".", "_"), m_pack.file);
|
auto packoffset = QString("%1/%2/%3").arg(m_pack.dir, m_version.replace(".", "_"), m_pack.file);
|
||||||
auto entry = APPLICATION->metacache()->resolveEntry("FTBPacks", packoffset);
|
auto entry = APPLICATION->metacache()->resolveEntry("FTBPacks", packoffset);
|
||||||
netJobContainer = new NetJob("Download FTB Pack");
|
netJobContainer = new NetJob("Download FTB Pack", m_network);
|
||||||
|
|
||||||
entry->setStale(true);
|
entry->setStale(true);
|
||||||
QString url;
|
QString url;
|
||||||
@ -51,7 +51,7 @@ void PackInstallTask::downloadPack()
|
|||||||
connect(netJobContainer.get(), &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
|
connect(netJobContainer.get(), &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
|
||||||
connect(netJobContainer.get(), &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
|
connect(netJobContainer.get(), &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
|
||||||
connect(netJobContainer.get(), &NetJob::progress, this, &PackInstallTask::onDownloadProgress);
|
connect(netJobContainer.get(), &NetJob::progress, this, &PackInstallTask::onDownloadProgress);
|
||||||
netJobContainer->start(m_network);
|
netJobContainer->start();
|
||||||
|
|
||||||
progress(1, 4);
|
progress(1, 4);
|
||||||
}
|
}
|
||||||
|
@ -63,12 +63,11 @@ void PackInstallTask::executeTask()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto *netJob = new NetJob("ModpacksCH::VersionFetch");
|
auto *netJob = new NetJob("ModpacksCH::VersionFetch", APPLICATION->network());
|
||||||
auto searchUrl = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/%1/%2")
|
auto searchUrl = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/%1/%2").arg(m_pack.id).arg(version.id);
|
||||||
.arg(m_pack.id).arg(version.id);
|
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
|
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
|
QObject::connect(netJob, &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
|
||||||
@ -113,7 +112,7 @@ void PackInstallTask::downloadPack()
|
|||||||
{
|
{
|
||||||
setStatus(tr("Downloading mods..."));
|
setStatus(tr("Downloading mods..."));
|
||||||
|
|
||||||
jobPtr = new NetJob(tr("Mod download"));
|
jobPtr = new NetJob(tr("Mod download"), APPLICATION->network());
|
||||||
for(auto file : m_version.files) {
|
for(auto file : m_version.files) {
|
||||||
if(file.serverOnly) continue;
|
if(file.serverOnly) continue;
|
||||||
|
|
||||||
@ -159,7 +158,7 @@ void PackInstallTask::downloadPack()
|
|||||||
setProgress(current, total);
|
setProgress(current, total);
|
||||||
});
|
});
|
||||||
|
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PackInstallTask::install()
|
void PackInstallTask::install()
|
||||||
|
@ -44,14 +44,14 @@ void Technic::SingleZipPackInstallTask::executeTask()
|
|||||||
const QString path = m_sourceUrl.host() + '/' + m_sourceUrl.path();
|
const QString path = m_sourceUrl.host() + '/' + m_sourceUrl.path();
|
||||||
auto entry = APPLICATION->metacache()->resolveEntry("general", path);
|
auto entry = APPLICATION->metacache()->resolveEntry("general", path);
|
||||||
entry->setStale(true);
|
entry->setStale(true);
|
||||||
m_filesNetJob.reset(new NetJob(tr("Modpack download")));
|
m_filesNetJob = new NetJob(tr("Modpack download"), APPLICATION->network());
|
||||||
m_filesNetJob->addNetAction(Net::Download::makeCached(m_sourceUrl, entry));
|
m_filesNetJob->addNetAction(Net::Download::makeCached(m_sourceUrl, entry));
|
||||||
m_archivePath = entry->getFullPath();
|
m_archivePath = entry->getFullPath();
|
||||||
auto job = m_filesNetJob.get();
|
auto job = m_filesNetJob.get();
|
||||||
connect(job, &NetJob::succeeded, this, &Technic::SingleZipPackInstallTask::downloadSucceeded);
|
connect(job, &NetJob::succeeded, this, &Technic::SingleZipPackInstallTask::downloadSucceeded);
|
||||||
connect(job, &NetJob::progress, this, &Technic::SingleZipPackInstallTask::downloadProgressChanged);
|
connect(job, &NetJob::progress, this, &Technic::SingleZipPackInstallTask::downloadProgressChanged);
|
||||||
connect(job, &NetJob::failed, this, &Technic::SingleZipPackInstallTask::downloadFailed);
|
connect(job, &NetJob::failed, this, &Technic::SingleZipPackInstallTask::downloadFailed);
|
||||||
m_filesNetJob->start(APPLICATION->network());
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Technic::SingleZipPackInstallTask::downloadSucceeded()
|
void Technic::SingleZipPackInstallTask::downloadSucceeded()
|
||||||
|
@ -42,12 +42,12 @@ bool Technic::SolderPackInstallTask::abort() {
|
|||||||
void Technic::SolderPackInstallTask::executeTask()
|
void Technic::SolderPackInstallTask::executeTask()
|
||||||
{
|
{
|
||||||
setStatus(tr("Finding recommended version:\n%1").arg(m_sourceUrl.toString()));
|
setStatus(tr("Finding recommended version:\n%1").arg(m_sourceUrl.toString()));
|
||||||
m_filesNetJob.reset(new NetJob(tr("Finding recommended version")));
|
m_filesNetJob = new NetJob(tr("Finding recommended version"), m_network);
|
||||||
m_filesNetJob->addNetAction(Net::Download::makeByteArray(m_sourceUrl, &m_response));
|
m_filesNetJob->addNetAction(Net::Download::makeByteArray(m_sourceUrl, &m_response));
|
||||||
auto job = m_filesNetJob.get();
|
auto job = m_filesNetJob.get();
|
||||||
connect(job, &NetJob::succeeded, this, &Technic::SolderPackInstallTask::versionSucceeded);
|
connect(job, &NetJob::succeeded, this, &Technic::SolderPackInstallTask::versionSucceeded);
|
||||||
connect(job, &NetJob::failed, this, &Technic::SolderPackInstallTask::downloadFailed);
|
connect(job, &NetJob::failed, this, &Technic::SolderPackInstallTask::downloadFailed);
|
||||||
m_filesNetJob->start(m_network);
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Technic::SolderPackInstallTask::versionSucceeded()
|
void Technic::SolderPackInstallTask::versionSucceeded()
|
||||||
@ -67,12 +67,12 @@ void Technic::SolderPackInstallTask::versionSucceeded()
|
|||||||
}
|
}
|
||||||
|
|
||||||
setStatus(tr("Resolving modpack files:\n%1").arg(m_sourceUrl.toString()));
|
setStatus(tr("Resolving modpack files:\n%1").arg(m_sourceUrl.toString()));
|
||||||
m_filesNetJob.reset(new NetJob(tr("Resolving modpack files")));
|
m_filesNetJob = new NetJob(tr("Resolving modpack files"), m_network);
|
||||||
m_filesNetJob->addNetAction(Net::Download::makeByteArray(m_sourceUrl, &m_response));
|
m_filesNetJob->addNetAction(Net::Download::makeByteArray(m_sourceUrl, &m_response));
|
||||||
auto job = m_filesNetJob.get();
|
auto job = m_filesNetJob.get();
|
||||||
connect(job, &NetJob::succeeded, this, &Technic::SolderPackInstallTask::fileListSucceeded);
|
connect(job, &NetJob::succeeded, this, &Technic::SolderPackInstallTask::fileListSucceeded);
|
||||||
connect(job, &NetJob::failed, this, &Technic::SolderPackInstallTask::downloadFailed);
|
connect(job, &NetJob::failed, this, &Technic::SolderPackInstallTask::downloadFailed);
|
||||||
m_filesNetJob->start(m_network);
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Technic::SolderPackInstallTask::fileListSucceeded()
|
void Technic::SolderPackInstallTask::fileListSucceeded()
|
||||||
@ -99,7 +99,7 @@ void Technic::SolderPackInstallTask::fileListSucceeded()
|
|||||||
m_filesNetJob.reset();
|
m_filesNetJob.reset();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_filesNetJob.reset(new NetJob(tr("Downloading modpack")));
|
m_filesNetJob = new NetJob(tr("Downloading modpack"), m_network);
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (auto &modUrl: modUrls)
|
for (auto &modUrl: modUrls)
|
||||||
{
|
{
|
||||||
@ -113,7 +113,7 @@ void Technic::SolderPackInstallTask::fileListSucceeded()
|
|||||||
connect(m_filesNetJob.get(), &NetJob::succeeded, this, &Technic::SolderPackInstallTask::downloadSucceeded);
|
connect(m_filesNetJob.get(), &NetJob::succeeded, this, &Technic::SolderPackInstallTask::downloadSucceeded);
|
||||||
connect(m_filesNetJob.get(), &NetJob::progress, this, &Technic::SolderPackInstallTask::downloadProgressChanged);
|
connect(m_filesNetJob.get(), &NetJob::progress, this, &Technic::SolderPackInstallTask::downloadProgressChanged);
|
||||||
connect(m_filesNetJob.get(), &NetJob::failed, this, &Technic::SolderPackInstallTask::downloadFailed);
|
connect(m_filesNetJob.get(), &NetJob::failed, this, &Technic::SolderPackInstallTask::downloadFailed);
|
||||||
m_filesNetJob->start(m_network);
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Technic::SolderPackInstallTask::downloadSucceeded()
|
void Technic::SolderPackInstallTask::downloadSucceeded()
|
||||||
|
@ -29,7 +29,7 @@ class NetJob : public Task
|
|||||||
public:
|
public:
|
||||||
using Ptr = shared_qobject_ptr<NetJob>;
|
using Ptr = shared_qobject_ptr<NetJob>;
|
||||||
|
|
||||||
explicit NetJob(QString job_name) : Task()
|
explicit NetJob(QString job_name, shared_qobject_ptr<QNetworkAccessManager> network) : Task(), m_network(network)
|
||||||
{
|
{
|
||||||
setObjectName(job_name);
|
setObjectName(job_name);
|
||||||
}
|
}
|
||||||
@ -65,19 +65,6 @@ private slots:
|
|||||||
public slots:
|
public slots:
|
||||||
virtual void executeTask() override;
|
virtual void executeTask() override;
|
||||||
virtual bool abort() override;
|
virtual bool abort() override;
|
||||||
virtual void start(shared_qobject_ptr<QNetworkAccessManager> network) {
|
|
||||||
m_network = network;
|
|
||||||
start();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected slots:
|
|
||||||
void start() override {
|
|
||||||
if(!m_network) {
|
|
||||||
throw "Missing network while trying to start " + objectName();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Task::start();
|
|
||||||
}
|
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void partProgress(int index, qint64 bytesReceived, qint64 bytesTotal);
|
void partProgress(int index, qint64 bytesReceived, qint64 bytesTotal);
|
||||||
|
@ -37,12 +37,12 @@ void NewsChecker::reloadNews()
|
|||||||
|
|
||||||
qDebug() << "Reloading news.";
|
qDebug() << "Reloading news.";
|
||||||
|
|
||||||
NetJob* job = new NetJob("News RSS Feed");
|
NetJob* job = new NetJob("News RSS Feed", m_network);
|
||||||
job->addNetAction(Net::Download::makeByteArray(m_feedUrl, &newsData));
|
job->addNetAction(Net::Download::makeByteArray(m_feedUrl, &newsData));
|
||||||
QObject::connect(job, &NetJob::succeeded, this, &NewsChecker::rssDownloadFinished);
|
QObject::connect(job, &NetJob::succeeded, this, &NewsChecker::rssDownloadFinished);
|
||||||
QObject::connect(job, &NetJob::failed, this, &NewsChecker::rssDownloadFailed);
|
QObject::connect(job, &NetJob::failed, this, &NewsChecker::rssDownloadFailed);
|
||||||
m_newsNetJob.reset(job);
|
m_newsNetJob.reset(job);
|
||||||
job->start(m_network);
|
job->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NewsChecker::rssDownloadFinished()
|
void NewsChecker::rssDownloadFinished()
|
||||||
|
@ -52,12 +52,12 @@ void NotificationChecker::checkForNotifications()
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_checkJob.reset(new NetJob("Checking for notifications"));
|
m_checkJob = new NetJob("Checking for notifications", APPLICATION->network());
|
||||||
auto entry = APPLICATION->metacache()->resolveEntry("root", "notifications.json");
|
auto entry = APPLICATION->metacache()->resolveEntry("root", "notifications.json");
|
||||||
entry->setStale(true);
|
entry->setStale(true);
|
||||||
m_checkJob->addNetAction(m_download = Net::Download::makeCached(m_notificationsUrl, entry));
|
m_checkJob->addNetAction(m_download = Net::Download::makeCached(m_notificationsUrl, entry));
|
||||||
connect(m_download.get(), &Net::Download::succeeded, this, &NotificationChecker::downloadSucceeded);
|
connect(m_download.get(), &Net::Download::succeeded, this, &NotificationChecker::downloadSucceeded);
|
||||||
m_checkJob->start(APPLICATION->network());
|
m_checkJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationChecker::downloadSucceeded(int)
|
void NotificationChecker::downloadSucceeded(int)
|
||||||
|
@ -52,7 +52,7 @@ QString MCEditTool::getProgramPath()
|
|||||||
#else
|
#else
|
||||||
const QString mceditPath = path();
|
const QString mceditPath = path();
|
||||||
QDir mceditDir(mceditPath);
|
QDir mceditDir(mceditPath);
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
if (mceditDir.exists("mcedit.sh"))
|
if (mceditDir.exists("mcedit.sh"))
|
||||||
{
|
{
|
||||||
return mceditDir.absoluteFilePath("mcedit.sh");
|
return mceditDir.absoluteFilePath("mcedit.sh");
|
||||||
|
@ -573,14 +573,14 @@ void TranslationsModel::downloadIndex()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
qDebug() << "Downloading Translations Index...";
|
qDebug() << "Downloading Translations Index...";
|
||||||
d->m_index_job.reset(new NetJob("Translations Index"));
|
d->m_index_job = new NetJob("Translations Index", APPLICATION->network());
|
||||||
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("translations", "index_v2.json");
|
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("translations", "index_v2.json");
|
||||||
entry->setStale(true);
|
entry->setStale(true);
|
||||||
d->m_index_task = Net::Download::makeCached(QUrl("https://files.multimc.org/translations/index_v2.json"), entry);
|
d->m_index_task = Net::Download::makeCached(QUrl("https://files.multimc.org/translations/index_v2.json"), entry);
|
||||||
d->m_index_job->addNetAction(d->m_index_task);
|
d->m_index_job->addNetAction(d->m_index_task);
|
||||||
connect(d->m_index_job.get(), &NetJob::failed, this, &TranslationsModel::indexFailed);
|
connect(d->m_index_job.get(), &NetJob::failed, this, &TranslationsModel::indexFailed);
|
||||||
connect(d->m_index_job.get(), &NetJob::succeeded, this, &TranslationsModel::indexReceived);
|
connect(d->m_index_job.get(), &NetJob::succeeded, this, &TranslationsModel::indexReceived);
|
||||||
d->m_index_job->start(APPLICATION->network());
|
d->m_index_job->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TranslationsModel::updateLanguage(QString key)
|
void TranslationsModel::updateLanguage(QString key)
|
||||||
@ -625,13 +625,13 @@ void TranslationsModel::downloadTranslation(QString key)
|
|||||||
dl->addValidator(new Net::ChecksumValidator(QCryptographicHash::Sha1, rawHash));
|
dl->addValidator(new Net::ChecksumValidator(QCryptographicHash::Sha1, rawHash));
|
||||||
dl->m_total_progress = lang->file_size;
|
dl->m_total_progress = lang->file_size;
|
||||||
|
|
||||||
d->m_dl_job.reset(new NetJob("Translation for " + key));
|
d->m_dl_job = new NetJob("Translation for " + key, APPLICATION->network());
|
||||||
d->m_dl_job->addNetAction(dl);
|
d->m_dl_job->addNetAction(dl);
|
||||||
|
|
||||||
connect(d->m_dl_job.get(), &NetJob::succeeded, this, &TranslationsModel::dlGood);
|
connect(d->m_dl_job.get(), &NetJob::succeeded, this, &TranslationsModel::dlGood);
|
||||||
connect(d->m_dl_job.get(), &NetJob::failed, this, &TranslationsModel::dlFailed);
|
connect(d->m_dl_job.get(), &NetJob::failed, this, &TranslationsModel::dlFailed);
|
||||||
|
|
||||||
d->m_dl_job->start(APPLICATION->network());
|
d->m_dl_job->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TranslationsModel::downloadNext()
|
void TranslationsModel::downloadNext()
|
||||||
|
@ -133,10 +133,10 @@ AboutDialog::~AboutDialog()
|
|||||||
|
|
||||||
void AboutDialog::loadPatronList()
|
void AboutDialog::loadPatronList()
|
||||||
{
|
{
|
||||||
netJob = new NetJob("Patreon Patron List");
|
netJob = new NetJob("Patreon Patron List", APPLICATION->network());
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl("https://files.multimc.org/patrons.txt"), &dataSink));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl("https://files.multimc.org/patrons.txt"), &dataSink));
|
||||||
connect(netJob.get(), &NetJob::succeeded, this, &AboutDialog::patronListLoaded);
|
connect(netJob.get(), &NetJob::succeeded, this, &AboutDialog::patronListLoaded);
|
||||||
netJob->start(APPLICATION->network());
|
netJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AboutDialog::patronListLoaded()
|
void AboutDialog::patronListLoaded()
|
||||||
|
@ -34,7 +34,7 @@ UpdateDialog::~UpdateDialog()
|
|||||||
void UpdateDialog::loadChangelog()
|
void UpdateDialog::loadChangelog()
|
||||||
{
|
{
|
||||||
auto channel = APPLICATION->settings()->get("UpdateChannel").toString();
|
auto channel = APPLICATION->settings()->get("UpdateChannel").toString();
|
||||||
dljob.reset(new NetJob("Changelog"));
|
dljob = new NetJob("Changelog", APPLICATION->network());
|
||||||
QString url;
|
QString url;
|
||||||
if(channel == "stable")
|
if(channel == "stable")
|
||||||
{
|
{
|
||||||
@ -49,7 +49,7 @@ void UpdateDialog::loadChangelog()
|
|||||||
dljob->addNetAction(Net::Download::makeByteArray(QUrl(url), &changelogData));
|
dljob->addNetAction(Net::Download::makeByteArray(QUrl(url), &changelogData));
|
||||||
connect(dljob.get(), &NetJob::succeeded, this, &UpdateDialog::changelogLoaded);
|
connect(dljob.get(), &NetJob::succeeded, this, &UpdateDialog::changelogLoaded);
|
||||||
connect(dljob.get(), &NetJob::failed, this, &UpdateDialog::changelogFailed);
|
connect(dljob.get(), &NetJob::failed, this, &UpdateDialog::changelogFailed);
|
||||||
dljob->start(APPLICATION->network());
|
dljob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString reprocessMarkdown(QByteArray markdown)
|
QString reprocessMarkdown(QByteArray markdown)
|
||||||
|
@ -304,7 +304,7 @@ void ScreenshotsPage::on_actionUpload_triggered()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
QList<ScreenShot::Ptr> uploaded;
|
QList<ScreenShot::Ptr> uploaded;
|
||||||
auto job = NetJob::Ptr(new NetJob("Screenshot Upload"));
|
auto job = NetJob::Ptr(new NetJob("Screenshot Upload", APPLICATION->network()));
|
||||||
if(selection.size() < 2)
|
if(selection.size() < 2)
|
||||||
{
|
{
|
||||||
auto item = selection.at(0);
|
auto item = selection.at(0);
|
||||||
@ -314,6 +314,7 @@ void ScreenshotsPage::on_actionUpload_triggered()
|
|||||||
|
|
||||||
m_uploadActive = true;
|
m_uploadActive = true;
|
||||||
ProgressDialog dialog(this);
|
ProgressDialog dialog(this);
|
||||||
|
|
||||||
if(dialog.execWithTask(job.get()) != QDialog::Accepted)
|
if(dialog.execWithTask(job.get()) != QDialog::Accepted)
|
||||||
{
|
{
|
||||||
CustomMessageBox::selectable(this, tr("Failed to upload screenshots!"),
|
CustomMessageBox::selectable(this, tr("Failed to upload screenshots!"),
|
||||||
@ -345,7 +346,7 @@ void ScreenshotsPage::on_actionUpload_triggered()
|
|||||||
job->addNetAction(ImgurUpload::make(screenshot));
|
job->addNetAction(ImgurUpload::make(screenshot));
|
||||||
}
|
}
|
||||||
SequentialTask task;
|
SequentialTask task;
|
||||||
auto albumTask = NetJob::Ptr(new NetJob("Imgur Album Creation"));
|
auto albumTask = NetJob::Ptr(new NetJob("Imgur Album Creation", APPLICATION->network()));
|
||||||
auto imgurAlbum = ImgurAlbumCreation::make(uploaded);
|
auto imgurAlbum = ImgurAlbumCreation::make(uploaded);
|
||||||
albumTask->addNetAction(imgurAlbum);
|
albumTask->addNetAction(imgurAlbum);
|
||||||
task.addTask(job);
|
task.addTask(job);
|
||||||
@ -354,8 +355,12 @@ void ScreenshotsPage::on_actionUpload_triggered()
|
|||||||
ProgressDialog prog(this);
|
ProgressDialog prog(this);
|
||||||
if (prog.execWithTask(&task) != QDialog::Accepted)
|
if (prog.execWithTask(&task) != QDialog::Accepted)
|
||||||
{
|
{
|
||||||
CustomMessageBox::selectable(this, tr("Failed to upload screenshots!"),
|
CustomMessageBox::selectable(
|
||||||
tr("Unknown error"), QMessageBox::Warning)->exec();
|
this,
|
||||||
|
tr("Failed to upload screenshots!"),
|
||||||
|
tr("Unknown error"),
|
||||||
|
QMessageBox::Warning
|
||||||
|
)->exec();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -86,11 +86,11 @@ void ListModel::request()
|
|||||||
modpacks.clear();
|
modpacks.clear();
|
||||||
endResetModel();
|
endResetModel();
|
||||||
|
|
||||||
auto *netJob = new NetJob("Atl::Request");
|
auto *netJob = new NetJob("Atl::Request", APPLICATION->network());
|
||||||
auto url = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "launcher/json/packsnew.json");
|
auto url = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "launcher/json/packsnew.json");
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(url), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(url), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
|
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::requestFinished);
|
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::requestFinished);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &ListModel::requestFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &ListModel::requestFailed);
|
||||||
@ -183,7 +183,7 @@ void ListModel::requestLogo(QString file, QString url)
|
|||||||
}
|
}
|
||||||
|
|
||||||
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("ATLauncherPacks", QString("logos/%1").arg(file.section(".", 0, 0)));
|
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("ATLauncherPacks", QString("logos/%1").arg(file.section(".", 0, 0)));
|
||||||
NetJob *job = new NetJob(QString("ATLauncher Icon Download %1").arg(file));
|
NetJob *job = new NetJob(QString("ATLauncher Icon Download %1").arg(file), APPLICATION->network());
|
||||||
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
||||||
|
|
||||||
auto fullPath = entry->getFullPath();
|
auto fullPath = entry->getFullPath();
|
||||||
@ -201,7 +201,7 @@ void ListModel::requestLogo(QString file, QString url)
|
|||||||
emit logoFailed(file);
|
emit logoFailed(file);
|
||||||
});
|
});
|
||||||
|
|
||||||
job->start(APPLICATION->network());
|
job->start();
|
||||||
|
|
||||||
m_loadingLogos.append(file);
|
m_loadingLogos.append(file);
|
||||||
}
|
}
|
||||||
|
@ -100,7 +100,7 @@ void ListModel::requestLogo(QString logo, QString url)
|
|||||||
}
|
}
|
||||||
|
|
||||||
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("FlamePacks", QString("logos/%1").arg(logo.section(".", 0, 0)));
|
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("FlamePacks", QString("logos/%1").arg(logo.section(".", 0, 0)));
|
||||||
NetJob *job = new NetJob(QString("Flame Icon Download %1").arg(logo));
|
NetJob *job = new NetJob(QString("Flame Icon Download %1").arg(logo), APPLICATION->network());
|
||||||
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
||||||
|
|
||||||
auto fullPath = entry->getFullPath();
|
auto fullPath = entry->getFullPath();
|
||||||
@ -118,7 +118,7 @@ void ListModel::requestLogo(QString logo, QString url)
|
|||||||
emit logoFailed(logo);
|
emit logoFailed(logo);
|
||||||
});
|
});
|
||||||
|
|
||||||
job->start(APPLICATION->network());
|
job->start();
|
||||||
|
|
||||||
m_loadingLogos.append(logo);
|
m_loadingLogos.append(logo);
|
||||||
}
|
}
|
||||||
@ -158,7 +158,7 @@ void ListModel::fetchMore(const QModelIndex& parent)
|
|||||||
|
|
||||||
void ListModel::performPaginatedSearch()
|
void ListModel::performPaginatedSearch()
|
||||||
{
|
{
|
||||||
NetJob *netJob = new NetJob("Flame::Search");
|
NetJob *netJob = new NetJob("Flame::Search", APPLICATION->network());
|
||||||
auto searchUrl = QString(
|
auto searchUrl = QString(
|
||||||
"https://addons-ecs.forgesvc.net/api/v2/addon/search?"
|
"https://addons-ecs.forgesvc.net/api/v2/addon/search?"
|
||||||
"categoryId=0&"
|
"categoryId=0&"
|
||||||
@ -171,7 +171,7 @@ void ListModel::performPaginatedSearch()
|
|||||||
).arg(nextSearchOffset).arg(currentSearchTerm).arg(currentSort);
|
).arg(nextSearchOffset).arg(currentSearchTerm).arg(currentSort);
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::searchRequestFinished);
|
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::searchRequestFinished);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &ListModel::searchRequestFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &ListModel::searchRequestFailed);
|
||||||
}
|
}
|
||||||
|
@ -109,7 +109,7 @@ void FlamePage::onSelectionChanged(QModelIndex first, QModelIndex second)
|
|||||||
if (current.versionsLoaded == false)
|
if (current.versionsLoaded == false)
|
||||||
{
|
{
|
||||||
qDebug() << "Loading flame modpack versions";
|
qDebug() << "Loading flame modpack versions";
|
||||||
NetJob *netJob = new NetJob(QString("Flame::PackVersions(%1)").arg(current.name));
|
NetJob *netJob = new NetJob(QString("Flame::PackVersions(%1)").arg(current.name), APPLICATION->network());
|
||||||
std::shared_ptr<QByteArray> response = std::make_shared<QByteArray>();
|
std::shared_ptr<QByteArray> response = std::make_shared<QByteArray>();
|
||||||
int addonId = current.addonId;
|
int addonId = current.addonId;
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QString("https://addons-ecs.forgesvc.net/api/v2/addon/%1/files").arg(addonId), response.get()));
|
netJob->addNetAction(Net::Download::makeByteArray(QString("https://addons-ecs.forgesvc.net/api/v2/addon/%1/files").arg(addonId), response.get()));
|
||||||
@ -140,7 +140,7 @@ void FlamePage::onSelectionChanged(QModelIndex first, QModelIndex second)
|
|||||||
|
|
||||||
suggestCurrent();
|
suggestCurrent();
|
||||||
});
|
});
|
||||||
netJob->start(APPLICATION->network());
|
netJob->start();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -107,11 +107,11 @@ void ListModel::request()
|
|||||||
modpacks.clear();
|
modpacks.clear();
|
||||||
endResetModel();
|
endResetModel();
|
||||||
|
|
||||||
auto *netJob = new NetJob("Ftb::Request");
|
auto *netJob = new NetJob("Ftb::Request", APPLICATION->network());
|
||||||
auto url = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/all");
|
auto url = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/all");
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(url), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(url), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
|
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::requestFinished);
|
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::requestFinished);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &ListModel::requestFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &ListModel::requestFailed);
|
||||||
@ -150,12 +150,11 @@ void ListModel::requestFailed(QString reason)
|
|||||||
|
|
||||||
void ListModel::requestPack()
|
void ListModel::requestPack()
|
||||||
{
|
{
|
||||||
auto *netJob = new NetJob("Ftb::Search");
|
auto *netJob = new NetJob("Ftb::Search", APPLICATION->network());
|
||||||
auto searchUrl = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/%1")
|
auto searchUrl = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/%1").arg(currentPack);
|
||||||
.arg(currentPack);
|
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
|
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::packRequestFinished);
|
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::packRequestFinished);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &ListModel::packRequestFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &ListModel::packRequestFailed);
|
||||||
@ -271,7 +270,7 @@ void ListModel::requestLogo(QString logo, QString url)
|
|||||||
|
|
||||||
bool stale = entry->isStale();
|
bool stale = entry->isStale();
|
||||||
|
|
||||||
NetJob *job = new NetJob(QString("FTB Icon Download %1").arg(logo));
|
NetJob *job = new NetJob(QString("FTB Icon Download %1").arg(logo), APPLICATION->network());
|
||||||
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
||||||
|
|
||||||
auto fullPath = entry->getFullPath();
|
auto fullPath = entry->getFullPath();
|
||||||
@ -288,7 +287,7 @@ void ListModel::requestLogo(QString logo, QString url)
|
|||||||
auto &newLogoEntry = m_logoMap[logo];
|
auto &newLogoEntry = m_logoMap[logo];
|
||||||
newLogoEntry.downloadJob = job;
|
newLogoEntry.downloadJob = job;
|
||||||
newLogoEntry.fullpath = fullPath;
|
newLogoEntry.fullpath = fullPath;
|
||||||
job->start(APPLICATION->network());
|
job->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -216,7 +216,7 @@ void ListModel::requestLogo(QString file)
|
|||||||
}
|
}
|
||||||
|
|
||||||
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("FTBPacks", QString("logos/%1").arg(file.section(".", 0, 0)));
|
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("FTBPacks", QString("logos/%1").arg(file.section(".", 0, 0)));
|
||||||
NetJob *job = new NetJob(QString("FTB Icon Download for %1").arg(file));
|
NetJob *job = new NetJob(QString("FTB Icon Download for %1").arg(file), APPLICATION->network());
|
||||||
job->addNetAction(Net::Download::makeCached(QUrl(QString(BuildConfig.LEGACY_FTB_CDN_BASE_URL + "static/%1").arg(file)), entry));
|
job->addNetAction(Net::Download::makeCached(QUrl(QString(BuildConfig.LEGACY_FTB_CDN_BASE_URL + "static/%1").arg(file)), entry));
|
||||||
|
|
||||||
auto fullPath = entry->getFullPath();
|
auto fullPath = entry->getFullPath();
|
||||||
@ -234,7 +234,7 @@ void ListModel::requestLogo(QString file)
|
|||||||
emit logoFailed(file);
|
emit logoFailed(file);
|
||||||
});
|
});
|
||||||
|
|
||||||
job->start(APPLICATION->network());
|
job->start();
|
||||||
|
|
||||||
m_loadingLogos.append(file);
|
m_loadingLogos.append(file);
|
||||||
}
|
}
|
||||||
|
@ -91,7 +91,7 @@ void Technic::ListModel::searchWithTerm(const QString& term)
|
|||||||
|
|
||||||
void Technic::ListModel::performSearch()
|
void Technic::ListModel::performSearch()
|
||||||
{
|
{
|
||||||
NetJob *netJob = new NetJob("Technic::Search");
|
NetJob *netJob = new NetJob("Technic::Search", APPLICATION->network());
|
||||||
QString searchUrl = "";
|
QString searchUrl = "";
|
||||||
if (currentSearchTerm.isEmpty()) {
|
if (currentSearchTerm.isEmpty()) {
|
||||||
searchUrl = "https://api.technicpack.net/trending?build=multimc";
|
searchUrl = "https://api.technicpack.net/trending?build=multimc";
|
||||||
@ -104,7 +104,7 @@ void Technic::ListModel::performSearch()
|
|||||||
}
|
}
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
|
||||||
jobPtr = netJob;
|
jobPtr = netJob;
|
||||||
jobPtr->start(APPLICATION->network());
|
jobPtr->start();
|
||||||
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::searchRequestFinished);
|
QObject::connect(netJob, &NetJob::succeeded, this, &ListModel::searchRequestFinished);
|
||||||
QObject::connect(netJob, &NetJob::failed, this, &ListModel::searchRequestFailed);
|
QObject::connect(netJob, &NetJob::failed, this, &ListModel::searchRequestFailed);
|
||||||
}
|
}
|
||||||
@ -216,7 +216,7 @@ void Technic::ListModel::requestLogo(QString logo, QString url)
|
|||||||
}
|
}
|
||||||
|
|
||||||
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("TechnicPacks", QString("logos/%1").arg(logo));
|
MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("TechnicPacks", QString("logos/%1").arg(logo));
|
||||||
NetJob *job = new NetJob(QString("Technic Icon Download %1").arg(logo));
|
NetJob *job = new NetJob(QString("Technic Icon Download %1").arg(logo), APPLICATION->network());
|
||||||
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
job->addNetAction(Net::Download::makeCached(QUrl(url), entry));
|
||||||
|
|
||||||
auto fullPath = entry->getFullPath();
|
auto fullPath = entry->getFullPath();
|
||||||
@ -231,7 +231,7 @@ void Technic::ListModel::requestLogo(QString logo, QString url)
|
|||||||
logoFailed(logo);
|
logoFailed(logo);
|
||||||
});
|
});
|
||||||
|
|
||||||
job->start(APPLICATION->network());
|
job->start();
|
||||||
|
|
||||||
m_loadingLogos.append(logo);
|
m_loadingLogos.append(logo);
|
||||||
}
|
}
|
||||||
|
@ -111,7 +111,7 @@ void TechnicPage::suggestCurrent()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetJob *netJob = new NetJob(QString("Technic::PackMeta(%1)").arg(current.name));
|
NetJob *netJob = new NetJob(QString("Technic::PackMeta(%1)").arg(current.name), APPLICATION->network());
|
||||||
std::shared_ptr<QByteArray> response = std::make_shared<QByteArray>();
|
std::shared_ptr<QByteArray> response = std::make_shared<QByteArray>();
|
||||||
QString slug = current.slug;
|
QString slug = current.slug;
|
||||||
netJob->addNetAction(Net::Download::makeByteArray(QString("https://api.technicpack.net/modpack/%1?build=multimc").arg(slug), response.get()));
|
netJob->addNetAction(Net::Download::makeByteArray(QString("https://api.technicpack.net/modpack/%1?build=multimc").arg(slug), response.get()));
|
||||||
@ -167,7 +167,7 @@ void TechnicPage::suggestCurrent()
|
|||||||
current.metadataLoaded = true;
|
current.metadataLoaded = true;
|
||||||
metadataLoaded();
|
metadataLoaded();
|
||||||
});
|
});
|
||||||
netJob->start(APPLICATION->network());
|
netJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
// expects current.metadataLoaded to be true
|
// expects current.metadataLoaded to be true
|
||||||
|
@ -319,7 +319,7 @@ void JavaSettingsWidget::on_javaStatusBtn_clicked()
|
|||||||
}
|
}
|
||||||
CustomMessageBox::selectable(
|
CustomMessageBox::selectable(
|
||||||
this,
|
this,
|
||||||
failed ? QObject::tr("Java test success") : QObject::tr("Java test failure"),
|
failed ? QObject::tr("Java test failure") : QObject::tr("Java test success"),
|
||||||
text,
|
text,
|
||||||
failed ? QMessageBox::Critical : QMessageBox::Information
|
failed ? QMessageBox::Critical : QMessageBox::Information
|
||||||
)->show();
|
)->show();
|
||||||
|
@ -47,7 +47,7 @@ void DownloadTask::loadVersionInfo()
|
|||||||
{
|
{
|
||||||
setStatus(tr("Loading version information..."));
|
setStatus(tr("Loading version information..."));
|
||||||
|
|
||||||
NetJob *netJob = new NetJob("Version Info");
|
NetJob *netJob = new NetJob("Version Info", m_network);
|
||||||
|
|
||||||
// Find the index URL.
|
// Find the index URL.
|
||||||
QUrl newIndexUrl = QUrl(m_status.newRepoUrl).resolved(QString::number(m_status.newVersionId) + ".json");
|
QUrl newIndexUrl = QUrl(m_status.newRepoUrl).resolved(QString::number(m_status.newVersionId) + ".json");
|
||||||
@ -67,7 +67,7 @@ void DownloadTask::loadVersionInfo()
|
|||||||
connect(netJob, &NetJob::succeeded, this, &DownloadTask::processDownloadedVersionInfo);
|
connect(netJob, &NetJob::succeeded, this, &DownloadTask::processDownloadedVersionInfo);
|
||||||
connect(netJob, &NetJob::failed, this, &DownloadTask::vinfoDownloadFailed);
|
connect(netJob, &NetJob::failed, this, &DownloadTask::vinfoDownloadFailed);
|
||||||
m_vinfoNetJob.reset(netJob);
|
m_vinfoNetJob.reset(netJob);
|
||||||
netJob->start(m_network);
|
netJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DownloadTask::vinfoDownloadFailed()
|
void DownloadTask::vinfoDownloadFailed()
|
||||||
@ -121,7 +121,7 @@ void DownloadTask::processDownloadedVersionInfo()
|
|||||||
setStatus(tr("Processing file lists - figuring out how to install the update..."));
|
setStatus(tr("Processing file lists - figuring out how to install the update..."));
|
||||||
|
|
||||||
// make a new netjob for the actual update files
|
// make a new netjob for the actual update files
|
||||||
NetJob::Ptr netJob (new NetJob("Update Files"));
|
NetJob::Ptr netJob = new NetJob("Update Files", m_network);
|
||||||
|
|
||||||
// fill netJob and operationList
|
// fill netJob and operationList
|
||||||
if (!processFileLists(m_currentVersionFileList, m_newVersionFileList, m_status.rootPath, m_updateFilesDir.path(), netJob, m_operations))
|
if (!processFileLists(m_currentVersionFileList, m_newVersionFileList, m_status.rootPath, m_updateFilesDir.path(), netJob, m_operations))
|
||||||
@ -145,7 +145,7 @@ void DownloadTask::processDownloadedVersionInfo()
|
|||||||
}
|
}
|
||||||
qDebug() << "Begin downloading update files to" << m_updateFilesDir.path();
|
qDebug() << "Begin downloading update files to" << m_updateFilesDir.path();
|
||||||
m_filesNetJob = netJob;
|
m_filesNetJob = netJob;
|
||||||
m_filesNetJob->start(m_network);
|
m_filesNetJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DownloadTask::fileDownloadFinished()
|
void DownloadTask::fileDownloadFinished()
|
||||||
|
@ -179,7 +179,8 @@ slots:
|
|||||||
|
|
||||||
OperationList operations;
|
OperationList operations;
|
||||||
|
|
||||||
processFileLists(currentVersion, newVersion, QDir::currentPath(), tempFolder, new NetJob("Dummy"), operations);
|
shared_qobject_ptr<QNetworkAccessManager> network = new QNetworkAccessManager();
|
||||||
|
processFileLists(currentVersion, newVersion, QDir::currentPath(), tempFolder, new NetJob("Dummy", network), operations);
|
||||||
qDebug() << (operations == expectedOperations);
|
qDebug() << (operations == expectedOperations);
|
||||||
qDebug() << operations;
|
qDebug() << operations;
|
||||||
qDebug() << expectedOperations;
|
qDebug() << expectedOperations;
|
||||||
|
@ -104,11 +104,11 @@ void UpdateChecker::checkForUpdate(QString updateChannel, bool notifyNoUpdate)
|
|||||||
|
|
||||||
QUrl indexUrl = QUrl(m_newRepoUrl).resolved(QUrl("index.json"));
|
QUrl indexUrl = QUrl(m_newRepoUrl).resolved(QUrl("index.json"));
|
||||||
|
|
||||||
indexJob = new NetJob("GoUpdate Repository Index");
|
indexJob = new NetJob("GoUpdate Repository Index", m_network);
|
||||||
indexJob->addNetAction(Net::Download::makeByteArray(indexUrl, &indexData));
|
indexJob->addNetAction(Net::Download::makeByteArray(indexUrl, &indexData));
|
||||||
connect(indexJob.get(), &NetJob::succeeded, [this, notifyNoUpdate](){ updateCheckFinished(notifyNoUpdate); });
|
connect(indexJob.get(), &NetJob::succeeded, [this, notifyNoUpdate](){ updateCheckFinished(notifyNoUpdate); });
|
||||||
connect(indexJob.get(), &NetJob::failed, this, &UpdateChecker::updateCheckFailed);
|
connect(indexJob.get(), &NetJob::failed, this, &UpdateChecker::updateCheckFailed);
|
||||||
indexJob->start(m_network);
|
indexJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void UpdateChecker::updateCheckFinished(bool notifyNoUpdate)
|
void UpdateChecker::updateCheckFinished(bool notifyNoUpdate)
|
||||||
@ -191,11 +191,11 @@ void UpdateChecker::updateChanList(bool notifyNoUpdate)
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_chanListLoading = true;
|
m_chanListLoading = true;
|
||||||
chanListJob = new NetJob("Update System Channel List");
|
chanListJob = new NetJob("Update System Channel List", m_network);
|
||||||
chanListJob->addNetAction(Net::Download::makeByteArray(QUrl(m_channelUrl), &chanlistData));
|
chanListJob->addNetAction(Net::Download::makeByteArray(QUrl(m_channelUrl), &chanlistData));
|
||||||
connect(chanListJob.get(), &NetJob::succeeded, [this, notifyNoUpdate]() { chanListDownloadFinished(notifyNoUpdate); });
|
connect(chanListJob.get(), &NetJob::succeeded, [this, notifyNoUpdate]() { chanListDownloadFinished(notifyNoUpdate); });
|
||||||
connect(chanListJob.get(), &NetJob::failed, this, &UpdateChecker::chanListDownloadFailed);
|
connect(chanListJob.get(), &NetJob::failed, this, &UpdateChecker::chanListDownloadFailed);
|
||||||
chanListJob->start(m_network);
|
chanListJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void UpdateChecker::chanListDownloadFinished(bool notifyNoUpdate)
|
void UpdateChecker::chanListDownloadFinished(bool notifyNoUpdate)
|
||||||
|
@ -320,7 +320,7 @@ Description: Make it so that the QIcon loader honors /usr/share/pixmaps
|
|||||||
icon theme specification.
|
icon theme specification.
|
||||||
Bug: https://bugreports.qt.nokia.com/browse/QTBUG-12874
|
Bug: https://bugreports.qt.nokia.com/browse/QTBUG-12874
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
#ifdef Q_OS_LINUX
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
||||||
/* Freedesktop standard says to look in /usr/share/pixmaps last */
|
/* Freedesktop standard says to look in /usr/share/pixmaps last */
|
||||||
if (entries.isEmpty())
|
if (entries.isEmpty())
|
||||||
{
|
{
|
||||||
|
@ -47,6 +47,7 @@ Sys::KernelInfo Sys::getKernelInfo()
|
|||||||
uint64_t Sys::getSystemRam()
|
uint64_t Sys::getSystemRam()
|
||||||
{
|
{
|
||||||
std::string token;
|
std::string token;
|
||||||
|
#ifdef Q_OS_LINUX
|
||||||
std::ifstream file("/proc/meminfo");
|
std::ifstream file("/proc/meminfo");
|
||||||
while(file >> token)
|
while(file >> token)
|
||||||
{
|
{
|
||||||
@ -65,6 +66,19 @@ uint64_t Sys::getSystemRam()
|
|||||||
// ignore rest of the line
|
// ignore rest of the line
|
||||||
file.ignore(std::numeric_limits<std::streamsize>::max(), '\n');
|
file.ignore(std::numeric_limits<std::streamsize>::max(), '\n');
|
||||||
}
|
}
|
||||||
|
#elif defined(Q_OS_FREEBSD)
|
||||||
|
char buff[512];
|
||||||
|
FILE *fp = popen("sysctl hw.physmem", "r");
|
||||||
|
if (fp != NULL)
|
||||||
|
{
|
||||||
|
while(fgets(buff, 512, fp) != NULL)
|
||||||
|
{
|
||||||
|
std::string str(buff);
|
||||||
|
uint64_t mem = std::stoull(str.substr(12, std::string::npos));
|
||||||
|
return mem * 1024ull;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return 0; // nothing found
|
return 0; // nothing found
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user