Rewrote the settings system. It may still need some work.
This commit is contained in:
parent
a7111b1328
commit
498225debd
@ -166,6 +166,7 @@ gui/taskdialog.h
|
|||||||
data/version.h
|
data/version.h
|
||||||
data/userinfo.h
|
data/userinfo.h
|
||||||
data/loginresponse.h
|
data/loginresponse.h
|
||||||
|
data/appsettings.h
|
||||||
|
|
||||||
data/plugin/pluginmanager.h
|
data/plugin/pluginmanager.h
|
||||||
|
|
||||||
@ -192,6 +193,7 @@ main.cpp
|
|||||||
data/version.cpp
|
data/version.cpp
|
||||||
data/userinfo.cpp
|
data/userinfo.cpp
|
||||||
data/loginresponse.cpp
|
data/loginresponse.cpp
|
||||||
|
data/appsettings.cpp
|
||||||
|
|
||||||
data/plugin/pluginmanager.cpp
|
data/plugin/pluginmanager.cpp
|
||||||
|
|
||||||
|
70
data/appsettings.cpp
Normal file
70
data/appsettings.cpp
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "appsettings.h"
|
||||||
|
|
||||||
|
#include <setting.h>
|
||||||
|
|
||||||
|
#include <QPoint>
|
||||||
|
#include <QColor>
|
||||||
|
|
||||||
|
AppSettings *settings;
|
||||||
|
|
||||||
|
AppSettings::AppSettings(QObject *parent) :
|
||||||
|
BasicSettingsObject(parent)
|
||||||
|
{
|
||||||
|
// Updates
|
||||||
|
registerSetting(new Setting("UseDevBuilds", false));
|
||||||
|
registerSetting(new Setting("AutoUpdate", true));
|
||||||
|
|
||||||
|
// Folders
|
||||||
|
registerSetting(new Setting("InstanceDir", "instances"));
|
||||||
|
registerSetting(new Setting("CentralModsDir", "mods"));
|
||||||
|
registerSetting(new Setting("LWJGLDir", "lwjgl"));
|
||||||
|
|
||||||
|
// Console
|
||||||
|
registerSetting(new Setting("ShowConsole", true));
|
||||||
|
registerSetting(new Setting("AutoCloseConsole", true));
|
||||||
|
|
||||||
|
// Toolbar settings
|
||||||
|
registerSetting(new Setting("InstanceToolbarVisible", true));
|
||||||
|
registerSetting(new Setting("InstanceToolbarPosition", QPoint()));
|
||||||
|
|
||||||
|
// Console Colors
|
||||||
|
registerSetting(new Setting("SysMessageColor", QColor(Qt::blue)));
|
||||||
|
registerSetting(new Setting("StdOutColor", QColor(Qt::black)));
|
||||||
|
registerSetting(new Setting("StdErrColor", QColor(Qt::red)));
|
||||||
|
|
||||||
|
// Window Size
|
||||||
|
registerSetting(new Setting("LaunchCompatMode", false));
|
||||||
|
registerSetting(new Setting("LaunchMaximized", false));
|
||||||
|
registerSetting(new Setting("MinecraftWinWidth", 854));
|
||||||
|
registerSetting(new Setting("MinecraftWinHeight", 480));
|
||||||
|
|
||||||
|
// Auto login
|
||||||
|
registerSetting(new Setting("AutoLogin", false));
|
||||||
|
|
||||||
|
// Memory
|
||||||
|
registerSetting(new Setting("MinMemAlloc", 512));
|
||||||
|
registerSetting(new Setting("MaxMemAlloc", 1024));
|
||||||
|
|
||||||
|
// Java Settings
|
||||||
|
registerSetting(new Setting("JavaPath", "java"));
|
||||||
|
registerSetting(new Setting("JvmArgs", ""));
|
||||||
|
|
||||||
|
// Custom Commands
|
||||||
|
registerSetting(new Setting("PreLaunchCommand", ""));
|
||||||
|
registerSetting(new Setting("PostExitCommand", ""));
|
||||||
|
}
|
@ -13,28 +13,20 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "include/appsettings.h"
|
#ifndef APPSETTINGS_H
|
||||||
|
#define APPSETTINGS_H
|
||||||
|
|
||||||
AppSettings* settings;
|
#include <QObject>
|
||||||
|
|
||||||
SettingsBase::SettingsBase(QObject *parent) :
|
#include <basicsettingsobject.h>
|
||||||
QObject(parent)
|
|
||||||
|
class AppSettings : public BasicSettingsObject
|
||||||
{
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit AppSettings(QObject *parent = 0);
|
||||||
|
};
|
||||||
|
|
||||||
}
|
extern AppSettings *settings;
|
||||||
|
|
||||||
AppSettings::AppSettings(QObject *parent) :
|
#endif // APPSETTINGS_H
|
||||||
SettingsBase(parent)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
QVariant AppSettings::getValue(const QString& name, QVariant defVal) const
|
|
||||||
{
|
|
||||||
return config.value(name, defVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
void AppSettings::setValue(const QString& name, QVariant val)
|
|
||||||
{
|
|
||||||
config.setValue(name, val);
|
|
||||||
}
|
|
@ -19,51 +19,51 @@ LoginResponse::LoginResponse(const QString& username, const QString& sessionID,
|
|||||||
qint64 latestVersion, QObject *parent) :
|
qint64 latestVersion, QObject *parent) :
|
||||||
QObject(parent)
|
QObject(parent)
|
||||||
{
|
{
|
||||||
this->username = username;
|
this->m_username = username;
|
||||||
this->sessionID = sessionID;
|
this->m_sessionID = sessionID;
|
||||||
this->latestVersion = latestVersion;
|
this->m_latestVersion = latestVersion;
|
||||||
}
|
}
|
||||||
|
|
||||||
LoginResponse::LoginResponse()
|
LoginResponse::LoginResponse()
|
||||||
{
|
{
|
||||||
this->username = "";
|
this->m_username = "";
|
||||||
this->sessionID = "";
|
this->m_sessionID = "";
|
||||||
this->latestVersion = 0;
|
this->m_latestVersion = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
LoginResponse::LoginResponse(const LoginResponse &other)
|
LoginResponse::LoginResponse(const LoginResponse &other)
|
||||||
{
|
{
|
||||||
this->username = other.getUsername();
|
this->m_username = other.username();
|
||||||
this->sessionID = other.getSessionID();
|
this->m_sessionID = other.sessionID();
|
||||||
this->latestVersion = other.getLatestVersion();
|
this->m_latestVersion = other.latestVersion();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString LoginResponse::getUsername() const
|
QString LoginResponse::username() const
|
||||||
{
|
{
|
||||||
return username;
|
return m_username;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoginResponse::setUsername(const QString& username)
|
void LoginResponse::setUsername(const QString& username)
|
||||||
{
|
{
|
||||||
this->username = username;
|
this->m_username = username;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString LoginResponse::getSessionID() const
|
QString LoginResponse::sessionID() const
|
||||||
{
|
{
|
||||||
return sessionID;
|
return m_sessionID;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoginResponse::setSessionID(const QString& sessionID)
|
void LoginResponse::setSessionID(const QString& sessionID)
|
||||||
{
|
{
|
||||||
this->sessionID = sessionID;
|
this->m_sessionID = sessionID;
|
||||||
}
|
}
|
||||||
|
|
||||||
qint64 LoginResponse::getLatestVersion() const
|
qint64 LoginResponse::latestVersion() const
|
||||||
{
|
{
|
||||||
return latestVersion;
|
return m_latestVersion;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoginResponse::setLatestVersion(qint64 v)
|
void LoginResponse::setLatestVersion(qint64 v)
|
||||||
{
|
{
|
||||||
this->latestVersion = v;
|
this->m_latestVersion = v;
|
||||||
}
|
}
|
||||||
|
@ -18,28 +18,75 @@
|
|||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The LoginResponse class represents a response received from Minecraft's login servers.
|
||||||
|
*/
|
||||||
class LoginResponse : public QObject
|
class LoginResponse : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
/*!
|
||||||
|
* \brief Creates a new instance of the LoginResponse class.
|
||||||
|
* \param username The user's username.
|
||||||
|
* \param sessionID The user's session ID.
|
||||||
|
* \param latestVersion The latest version of Minecraft.
|
||||||
|
* \param parent The parent object.
|
||||||
|
*/
|
||||||
explicit LoginResponse(const QString &username, const QString &sessionID,
|
explicit LoginResponse(const QString &username, const QString &sessionID,
|
||||||
qint64 latestVersion, QObject *parent = 0);
|
qint64 latestVersion, QObject *parent = 0);
|
||||||
LoginResponse();
|
LoginResponse();
|
||||||
LoginResponse(const LoginResponse& other);
|
LoginResponse(const LoginResponse& other);
|
||||||
|
|
||||||
QString getUsername() const;
|
/*!
|
||||||
|
* \brief Gets the username.
|
||||||
|
* This one should go without saying.
|
||||||
|
* \return The username.
|
||||||
|
* \sa setUsername()
|
||||||
|
*/
|
||||||
|
QString username() const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief setUsername Sets the username.
|
||||||
|
* \param username The new username.
|
||||||
|
* \sa username()
|
||||||
|
*/
|
||||||
void setUsername(const QString& username);
|
void setUsername(const QString& username);
|
||||||
|
|
||||||
QString getSessionID() const;
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets the session ID.
|
||||||
|
* \return The session ID.
|
||||||
|
* \sa setSessionID()
|
||||||
|
*/
|
||||||
|
QString sessionID() const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Sets the session ID.
|
||||||
|
* \param sessionID The new session ID.
|
||||||
|
* \sa sessionID()
|
||||||
|
*/
|
||||||
void setSessionID(const QString& sessionID);
|
void setSessionID(const QString& sessionID);
|
||||||
|
|
||||||
qint64 getLatestVersion() const;
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets the latest version.
|
||||||
|
* This is a value returned by the login servers when a user logs in.
|
||||||
|
* \return The latest version.
|
||||||
|
* \sa setLatestVersion()
|
||||||
|
*/
|
||||||
|
qint64 latestVersion() const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Sets the latest version.
|
||||||
|
* \param v The new latest version.
|
||||||
|
* \sa latestVersion()
|
||||||
|
*/
|
||||||
void setLatestVersion(qint64 v);
|
void setLatestVersion(qint64 v);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString username;
|
QString m_username;
|
||||||
QString sessionID;
|
QString m_sessionID;
|
||||||
qint64 latestVersion;
|
qint64 m_latestVersion;
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_DECLARE_METATYPE(LoginResponse)
|
Q_DECLARE_METATYPE(LoginResponse)
|
||||||
|
@ -18,32 +18,32 @@
|
|||||||
UserInfo::UserInfo(const QString &username, const QString &password, QObject *parent) :
|
UserInfo::UserInfo(const QString &username, const QString &password, QObject *parent) :
|
||||||
QObject(parent)
|
QObject(parent)
|
||||||
{
|
{
|
||||||
this->username = username;
|
this->m_username = username;
|
||||||
this->password = password;
|
this->m_password = password;
|
||||||
}
|
}
|
||||||
|
|
||||||
UserInfo::UserInfo(const UserInfo &other)
|
UserInfo::UserInfo(const UserInfo &other)
|
||||||
{
|
{
|
||||||
this->username = other.username;
|
this->m_username = other.m_username;
|
||||||
this->password = other.password;
|
this->m_password = other.m_password;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString UserInfo::getUsername() const
|
QString UserInfo::username() const
|
||||||
{
|
{
|
||||||
return username;
|
return m_username;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserInfo::setUsername(const QString &username)
|
void UserInfo::setUsername(const QString &username)
|
||||||
{
|
{
|
||||||
this->username = username;
|
this->m_username = username;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString UserInfo::getPassword() const
|
QString UserInfo::password() const
|
||||||
{
|
{
|
||||||
return password;
|
return m_password;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserInfo::setPassword(const QString &password)
|
void UserInfo::setPassword(const QString &password)
|
||||||
{
|
{
|
||||||
this->password = password;
|
this->m_password = password;
|
||||||
}
|
}
|
||||||
|
@ -25,15 +25,15 @@ public:
|
|||||||
explicit UserInfo(const QString& username, const QString& password, QObject *parent = 0);
|
explicit UserInfo(const QString& username, const QString& password, QObject *parent = 0);
|
||||||
explicit UserInfo(const UserInfo& other);
|
explicit UserInfo(const UserInfo& other);
|
||||||
|
|
||||||
QString getUsername() const;
|
QString username() const;
|
||||||
void setUsername(const QString& username);
|
void setUsername(const QString& username);
|
||||||
|
|
||||||
QString getPassword() const;
|
QString password() const;
|
||||||
void setPassword(const QString& password);
|
void setPassword(const QString& password);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
QString username;
|
QString m_username;
|
||||||
QString password;
|
QString m_password;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // USERINFO_H
|
#endif // USERINFO_H
|
||||||
|
@ -18,6 +18,9 @@
|
|||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The Version class represents a MultiMC version number.
|
||||||
|
*/
|
||||||
class Version : public QObject
|
class Version : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -27,11 +30,35 @@ public:
|
|||||||
|
|
||||||
Version(const Version& ver);
|
Version(const Version& ver);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Converts the Version to a string.
|
||||||
|
* \return The version number in string format (major.minor.revision.build).
|
||||||
|
*/
|
||||||
QString toString() const;
|
QString toString() const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The major version number.
|
||||||
|
* For MultiMC 5, this will always be 5.
|
||||||
|
*/
|
||||||
int major;
|
int major;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The minor version number.
|
||||||
|
* This number is incremented when major features are added.
|
||||||
|
*/
|
||||||
int minor;
|
int minor;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The revision number.
|
||||||
|
* This number is incremented for bugfixes and small features.
|
||||||
|
*/
|
||||||
int revision;
|
int revision;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The build number.
|
||||||
|
* This number is automatically set by Jenkins. It is incremented every time
|
||||||
|
* a new build is run.
|
||||||
|
*/
|
||||||
int build;
|
int build;
|
||||||
|
|
||||||
static Version current;
|
static Version current;
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
#include "gui/taskdialog.h"
|
#include "gui/taskdialog.h"
|
||||||
|
|
||||||
#include "instancelist.h"
|
#include "instancelist.h"
|
||||||
#include "appsettings.h"
|
#include "data/appsettings.h"
|
||||||
#include "data/version.h"
|
#include "data/version.h"
|
||||||
|
|
||||||
#include "tasks/logintask.h"
|
#include "tasks/logintask.h"
|
||||||
@ -43,14 +43,14 @@ void openInDefaultProgram(QString filename);
|
|||||||
MainWindow::MainWindow(QWidget *parent) :
|
MainWindow::MainWindow(QWidget *parent) :
|
||||||
QMainWindow(parent),
|
QMainWindow(parent),
|
||||||
ui(new Ui::MainWindow),
|
ui(new Ui::MainWindow),
|
||||||
instList(settings->getInstanceDir())
|
instList(settings->get("InstanceDir").toString())
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
setWindowTitle(QString("MultiMC %1").arg(Version::current.toString()));
|
setWindowTitle(QString("MultiMC %1").arg(Version::current.toString()));
|
||||||
|
// TODO: Make this work with the new settings system.
|
||||||
restoreGeometry(settings->getConfig().value("MainWindowGeometry", saveGeometry()).toByteArray());
|
// restoreGeometry(settings->getConfig().value("MainWindowGeometry", saveGeometry()).toByteArray());
|
||||||
restoreState(settings->getConfig().value("MainWindowState", saveState()).toByteArray());
|
// restoreState(settings->getConfig().value("MainWindowState", saveState()).toByteArray());
|
||||||
|
|
||||||
instList.loadList();
|
instList.loadList();
|
||||||
}
|
}
|
||||||
@ -68,7 +68,7 @@ void MainWindow::on_actionAddInstance_triggered()
|
|||||||
|
|
||||||
void MainWindow::on_actionViewInstanceFolder_triggered()
|
void MainWindow::on_actionViewInstanceFolder_triggered()
|
||||||
{
|
{
|
||||||
openInDefaultProgram(settings->getInstanceDir());
|
openInDefaultProgram(settings->get("InstanceDir").toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionRefresh_triggered()
|
void MainWindow::on_actionRefresh_triggered()
|
||||||
@ -78,7 +78,7 @@ void MainWindow::on_actionRefresh_triggered()
|
|||||||
|
|
||||||
void MainWindow::on_actionViewCentralModsFolder_triggered()
|
void MainWindow::on_actionViewCentralModsFolder_triggered()
|
||||||
{
|
{
|
||||||
openInDefaultProgram(settings->getCentralModsDir());
|
openInDefaultProgram(settings->get("CentralModsDir").toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionCheckUpdate_triggered()
|
void MainWindow::on_actionCheckUpdate_triggered()
|
||||||
@ -117,8 +117,9 @@ void MainWindow::on_mainToolBar_visibilityChanged(bool)
|
|||||||
void MainWindow::closeEvent(QCloseEvent *event)
|
void MainWindow::closeEvent(QCloseEvent *event)
|
||||||
{
|
{
|
||||||
// Save the window state and geometry.
|
// Save the window state and geometry.
|
||||||
settings->getConfig().setValue("MainWindowGeometry", saveGeometry());
|
// TODO: Make this work with the new settings system.
|
||||||
settings->getConfig().setValue("MainWindowState", saveState());
|
// settings->getConfig().setValue("MainWindowGeometry", saveGeometry());
|
||||||
|
// settings->getConfig().setValue("MainWindowState", saveState());
|
||||||
QMainWindow::closeEvent(event);
|
QMainWindow::closeEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,7 +160,7 @@ void MainWindow::onLoginComplete(LoginResponse response)
|
|||||||
{
|
{
|
||||||
QMessageBox::information(this, "Login Successful",
|
QMessageBox::information(this, "Login Successful",
|
||||||
QString("Logged in as %1 with session ID %2.").
|
QString("Logged in as %1 with session ID %2.").
|
||||||
arg(response.getUsername(), response.getSessionID()));
|
arg(response.username(), response.sessionID()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void openInDefaultProgram(QString filename)
|
void openInDefaultProgram(QString filename)
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
#include "settingsdialog.h"
|
#include "settingsdialog.h"
|
||||||
#include "ui_settingsdialog.h"
|
#include "ui_settingsdialog.h"
|
||||||
|
|
||||||
#include "appsettings.h"
|
#include "data/appsettings.h"
|
||||||
|
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
@ -87,95 +87,95 @@ void SettingsDialog::on_buttonBox_accepted()
|
|||||||
applySettings(settings);
|
applySettings(settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingsDialog::applySettings(SettingsBase *s)
|
void SettingsDialog::applySettings(SettingsObject *s)
|
||||||
{
|
{
|
||||||
// Special cases
|
// Special cases
|
||||||
|
|
||||||
// Warn about dev builds.
|
// Warn about dev builds.
|
||||||
if (!ui->devBuildsCheckBox->isChecked())
|
if (!ui->devBuildsCheckBox->isChecked())
|
||||||
{
|
{
|
||||||
s->setUseDevBuilds(false);
|
s->set("UseDevBuilds", false);
|
||||||
}
|
}
|
||||||
else if (!s->getUseDevBuilds())
|
else if (!s->get("UseDevBuilds").toBool())
|
||||||
{
|
{
|
||||||
int response = QMessageBox::question(this, "Development builds",
|
int response = QMessageBox::question(this, "Development builds",
|
||||||
"Development builds contain experimental features "
|
"Development builds contain experimental features "
|
||||||
"and may be unstable. Are you sure you want to enable them?");
|
"and may be unstable. Are you sure you want to enable them?");
|
||||||
if (response == QMessageBox::Yes)
|
if (response == QMessageBox::Yes)
|
||||||
{
|
{
|
||||||
s->setUseDevBuilds(true);
|
s->set("UseDevBuilds", true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Updates
|
// Updates
|
||||||
s->setAutoUpdate(ui->autoUpdateCheckBox->isChecked());
|
s->set("AutoUpdate", ui->autoUpdateCheckBox->isChecked());
|
||||||
|
|
||||||
// Folders
|
// Folders
|
||||||
// TODO: Offer to move instances to new instance folder.
|
// TODO: Offer to move instances to new instance folder.
|
||||||
s->setInstanceDir(ui->instDirTextBox->text());
|
s->set("InstanceDir", ui->instDirTextBox->text());
|
||||||
s->setCentralModsDir(ui->modsDirTextBox->text());
|
s->set("CentralModsDir", ui->modsDirTextBox->text());
|
||||||
s->setLWJGLDir(ui->lwjglDirTextBox->text());
|
s->set("LWJGLDir", ui->lwjglDirTextBox->text());
|
||||||
|
|
||||||
// Console
|
// Console
|
||||||
s->setShowConsole(ui->showConsoleCheck->isChecked());
|
s->set("ShowConsole", ui->showConsoleCheck->isChecked());
|
||||||
s->setAutoCloseConsole(ui->autoCloseConsoleCheck->isChecked());
|
s->set("AutoCloseConsole", ui->autoCloseConsoleCheck->isChecked());
|
||||||
|
|
||||||
// Window Size
|
// Window Size
|
||||||
s->setLaunchCompatMode(ui->compatModeCheckBox->isChecked());
|
s->set("LaunchCompatMode", ui->compatModeCheckBox->isChecked());
|
||||||
s->setLaunchMaximized(ui->maximizedCheckBox->isChecked());
|
s->set("LaunchMaximized", ui->maximizedCheckBox->isChecked());
|
||||||
s->setMinecraftWinWidth(ui->windowWidthSpinBox->value());
|
s->set("MinecraftWinWidth", ui->windowWidthSpinBox->value());
|
||||||
s->setMinecraftWinHeight(ui->windowHeightSpinBox->value());
|
s->set("MinecraftWinHeight", ui->windowHeightSpinBox->value());
|
||||||
|
|
||||||
// Auto Login
|
// Auto Login
|
||||||
s->setAutoLogin(ui->autoLoginCheckBox->isChecked());
|
s->set("AutoLogin", ui->autoLoginCheckBox->isChecked());
|
||||||
|
|
||||||
// Memory
|
// Memory
|
||||||
s->setMinMemAlloc(ui->minMemSpinBox->value());
|
s->set("MinMemAlloc", ui->minMemSpinBox->value());
|
||||||
s->setMaxMemAlloc(ui->maxMemSpinBox->value());
|
s->set("MaxMemAlloc", ui->maxMemSpinBox->value());
|
||||||
|
|
||||||
// Java Settings
|
// Java Settings
|
||||||
s->setJavaPath(ui->javaPathTextBox->text());
|
s->set("JavaPath", ui->javaPathTextBox->text());
|
||||||
s->setJvmArgs(ui->jvmArgsTextBox->text());
|
s->set("JvmArgs", ui->jvmArgsTextBox->text());
|
||||||
|
|
||||||
// Custom Commands
|
// Custom Commands
|
||||||
s->setPreLaunchCommand(ui->preLaunchCmdTextBox->text());
|
s->set("PreLaunchCommand", ui->preLaunchCmdTextBox->text());
|
||||||
s->setPostExitCommand(ui->postExitCmdTextBox->text());
|
s->set("PostExitCommand", ui->postExitCmdTextBox->text());
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingsDialog::loadSettings(SettingsBase *s)
|
void SettingsDialog::loadSettings(SettingsObject *s)
|
||||||
{
|
{
|
||||||
// Updates
|
// Updates
|
||||||
ui->autoUpdateCheckBox->setChecked(s->getAutoUpdate());
|
ui->autoUpdateCheckBox->setChecked(s->get("AutoUpdate").toBool());
|
||||||
ui->devBuildsCheckBox->setChecked(s->getUseDevBuilds());
|
ui->devBuildsCheckBox->setChecked(s->get("UseDevBuilds").toBool());
|
||||||
|
|
||||||
// Folders
|
// Folders
|
||||||
ui->instDirTextBox->setText(s->getInstanceDir());
|
ui->instDirTextBox->setText(s->get("InstanceDir").toString());
|
||||||
ui->modsDirTextBox->setText(s->getCentralModsDir());
|
ui->modsDirTextBox->setText(s->get("CentralModsDir").toString());
|
||||||
ui->lwjglDirTextBox->setText(s->getLWJGLDir());
|
ui->lwjglDirTextBox->setText(s->get("LWJGLDir").toString());
|
||||||
|
|
||||||
// Console
|
// Console
|
||||||
ui->showConsoleCheck->setChecked(s->getShowConsole());
|
ui->showConsoleCheck->setChecked(s->get("ShowConsole").toBool());
|
||||||
ui->autoCloseConsoleCheck->setChecked(s->getAutoCloseConsole());
|
ui->autoCloseConsoleCheck->setChecked(s->get("AutoCloseConsole").toBool());
|
||||||
|
|
||||||
// Window Size
|
// Window Size
|
||||||
ui->compatModeCheckBox->setChecked(s->getLaunchCompatMode());
|
ui->compatModeCheckBox->setChecked(s->get("LaunchCompatMode").toBool());
|
||||||
ui->maximizedCheckBox->setChecked(s->getLaunchMaximized());
|
ui->maximizedCheckBox->setChecked(s->get("LaunchMaximized").toBool());
|
||||||
ui->windowWidthSpinBox->setValue(s->getMinecraftWinWidth());
|
ui->windowWidthSpinBox->setValue(s->get("MinecraftWinWidth").toInt());
|
||||||
ui->windowHeightSpinBox->setValue(s->getMinecraftWinHeight());
|
ui->windowHeightSpinBox->setValue(s->get("MinecraftWinHeight").toInt());
|
||||||
|
|
||||||
// Auto Login
|
// Auto Login
|
||||||
ui->autoLoginCheckBox->setChecked(s->getAutoLogin());
|
ui->autoLoginCheckBox->setChecked(s->get("AutoLogin").toBool());
|
||||||
|
|
||||||
// Memory
|
// Memory
|
||||||
ui->minMemSpinBox->setValue(s->getMinMemAlloc());
|
ui->minMemSpinBox->setValue(s->get("MinMemAlloc").toInt());
|
||||||
ui->maxMemSpinBox->setValue(s->getMaxMemAlloc());
|
ui->maxMemSpinBox->setValue(s->get("MaxMemAlloc").toInt());
|
||||||
|
|
||||||
// Java Settings
|
// Java Settings
|
||||||
ui->javaPathTextBox->setText(s->getJavaPath());
|
ui->javaPathTextBox->setText(s->get("JavaPath").toString());
|
||||||
ui->jvmArgsTextBox->setText(s->getJvmArgs());
|
ui->jvmArgsTextBox->setText(s->get("JvmArgs").toString());
|
||||||
|
|
||||||
// Custom Commands
|
// Custom Commands
|
||||||
ui->preLaunchCmdTextBox->setText(s->getPreLaunchCommand());
|
ui->preLaunchCmdTextBox->setText(s->get("PreLaunchCommand").toString());
|
||||||
ui->postExitCmdTextBox->setText(s->getPostExitCommand());
|
ui->postExitCmdTextBox->setText(s->get("PostExitCommand").toString());
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
|
|
||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
|
|
||||||
class SettingsBase;
|
class SettingsObject;
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class SettingsDialog;
|
class SettingsDialog;
|
||||||
@ -34,8 +34,8 @@ public:
|
|||||||
|
|
||||||
void updateCheckboxStuff();
|
void updateCheckboxStuff();
|
||||||
|
|
||||||
void applySettings(SettingsBase* s);
|
void applySettings(SettingsObject *s);
|
||||||
void loadSettings(SettingsBase* s);
|
void loadSettings(SettingsObject* s);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void on_instDirBrowseBtn_clicked();
|
void on_instDirBrowseBtn_clicked();
|
||||||
|
@ -19,17 +19,10 @@
|
|||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QDateTime>
|
#include <QDateTime>
|
||||||
|
|
||||||
#include "appsettings.h"
|
|
||||||
#include "inifile.h"
|
#include "inifile.h"
|
||||||
|
|
||||||
#include "libinstance_config.h"
|
#include "libinstance_config.h"
|
||||||
|
|
||||||
#define DEFINE_OVERRIDDEN_SETTING_ADVANCED(funcName, cfgEntryName, typeName) \
|
|
||||||
typeName get ## funcName() const { return getField(cfgEntryName, settings->get ## funcName()).value<typeName>(); }
|
|
||||||
|
|
||||||
#define DEFINE_OVERRIDDEN_SETTING(funcName, typeName) \
|
|
||||||
DEFINE_OVERRIDDEN_SETTING_ADVANCED(funcName, STR_VAL(funcName), typeName)
|
|
||||||
|
|
||||||
class InstanceList;
|
class InstanceList;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -40,7 +33,7 @@ class InstanceList;
|
|||||||
* To create a new instance type, create a new class inheriting from this class
|
* To create a new instance type, create a new class inheriting from this class
|
||||||
* and implement the pure virtual functions.
|
* and implement the pure virtual functions.
|
||||||
*/
|
*/
|
||||||
class LIBMMCINST_EXPORT Instance : public SettingsBase
|
class LIBMMCINST_EXPORT Instance : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
@ -261,27 +254,6 @@ public:
|
|||||||
//! Gets the path to the instance's modlist file.
|
//! Gets the path to the instance's modlist file.
|
||||||
QString modListFile() const;
|
QString modListFile() const;
|
||||||
|
|
||||||
////// Settings //////
|
|
||||||
|
|
||||||
//// Java Settings ////
|
|
||||||
DEFINE_OVERRIDDEN_SETTING_ADVANCED(JavaPath, JPATHKEY, QString)
|
|
||||||
DEFINE_OVERRIDDEN_SETTING(JvmArgs, QString)
|
|
||||||
|
|
||||||
//// Custom Commands ////
|
|
||||||
DEFINE_OVERRIDDEN_SETTING(PreLaunchCommand, QString)
|
|
||||||
DEFINE_OVERRIDDEN_SETTING(PostExitCommand, QString)
|
|
||||||
|
|
||||||
//// Memory ////
|
|
||||||
DEFINE_OVERRIDDEN_SETTING(MinMemAlloc, int)
|
|
||||||
DEFINE_OVERRIDDEN_SETTING(MaxMemAlloc, int)
|
|
||||||
|
|
||||||
//// Auto login ////
|
|
||||||
DEFINE_OVERRIDDEN_SETTING(AutoLogin, bool)
|
|
||||||
|
|
||||||
// This little guy here is to keep Qt Creator from being a dumbass and
|
|
||||||
// auto-indenting the lines below the macros. Seriously, it's really annoying.
|
|
||||||
;
|
|
||||||
|
|
||||||
|
|
||||||
//////// OTHER FUNCTIONS ////////
|
//////// OTHER FUNCTIONS ////////
|
||||||
|
|
||||||
@ -327,12 +299,6 @@ protected:
|
|||||||
*/
|
*/
|
||||||
virtual void setField(const QString &name, QVariant val);
|
virtual void setField(const QString &name, QVariant val);
|
||||||
|
|
||||||
// Overrides for SettingBase stuff.
|
|
||||||
virtual QVariant getValue(const QString &name, QVariant defVal = QVariant()) const
|
|
||||||
{ return settings->getValue(name, defVal); }
|
|
||||||
virtual void setValue(const QString &name, QVariant val)
|
|
||||||
{ setField(name, val); }
|
|
||||||
|
|
||||||
INIFile config;
|
INIFile config;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
#include "pathutils.h"
|
#include "pathutils.h"
|
||||||
|
|
||||||
Instance::Instance(const QString &rootDir, QObject *parent) :
|
Instance::Instance(const QString &rootDir, QObject *parent) :
|
||||||
SettingsBase(parent)
|
QObject(parent)
|
||||||
{
|
{
|
||||||
m_rootDir = rootDir;
|
m_rootDir = rootDir;
|
||||||
config.loadFile(PathCombine(rootDir, "instance.cfg"));
|
config.loadFile(PathCombine(rootDir, "instance.cfg"));
|
||||||
|
@ -13,11 +13,17 @@ include_directories(${CMAKE_SOURCE_DIR}/libutil/include)
|
|||||||
SET(LIBSETTINGS_HEADERS
|
SET(LIBSETTINGS_HEADERS
|
||||||
include/libsettings_config.h
|
include/libsettings_config.h
|
||||||
|
|
||||||
include/appsettings.h
|
include/settingsobject.h
|
||||||
|
include/setting.h
|
||||||
|
|
||||||
|
include/basicsettingsobject.h
|
||||||
)
|
)
|
||||||
|
|
||||||
SET(LIBSETTINGS_SOURCES
|
SET(LIBSETTINGS_SOURCES
|
||||||
src/appsettings.cpp
|
src/settingsobject.cpp
|
||||||
|
src/setting.cpp
|
||||||
|
|
||||||
|
src/basicsettingsobject.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
# Set the include dir path.
|
# Set the include dir path.
|
||||||
|
@ -1,119 +0,0 @@
|
|||||||
/* Copyright 2013 MultiMC Contributors
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef APPSETTINGS_H
|
|
||||||
#define APPSETTINGS_H
|
|
||||||
|
|
||||||
#include <QObject>
|
|
||||||
#include <QSettings>
|
|
||||||
//#include <QColor>
|
|
||||||
#include <QPoint>
|
|
||||||
|
|
||||||
#include <apputils.h>
|
|
||||||
#include <osutils.h>
|
|
||||||
|
|
||||||
#include "libsettings_config.h"
|
|
||||||
|
|
||||||
#if WINDOWS
|
|
||||||
#define JPATHKEY "JavaPathWindows"
|
|
||||||
#elif OSX
|
|
||||||
#define JPATHKEY "JavaPathOSX"
|
|
||||||
#else
|
|
||||||
#define JPATHKEY "JavaPathLinux"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define DEFINE_SETTING_ADVANCED(funcName, name, valType, defVal) \
|
|
||||||
virtual valType get ## funcName() const { return getValue(name, defVal).value<valType>(); } \
|
|
||||||
virtual void set ## funcName(valType value) { setValue(name, value); }
|
|
||||||
|
|
||||||
#define DEFINE_SETTING(name, valType, defVal) \
|
|
||||||
DEFINE_SETTING_ADVANCED(name, STR_VAL(name), valType, defVal)
|
|
||||||
|
|
||||||
|
|
||||||
class LIBMMCSETTINGS_EXPORT SettingsBase : public QObject
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
public:
|
|
||||||
explicit SettingsBase(QObject *parent = 0);
|
|
||||||
|
|
||||||
// Updates
|
|
||||||
DEFINE_SETTING(UseDevBuilds, bool, false)
|
|
||||||
DEFINE_SETTING(AutoUpdate, bool, true)
|
|
||||||
|
|
||||||
// Folders
|
|
||||||
DEFINE_SETTING(InstanceDir, QString, "instances")
|
|
||||||
DEFINE_SETTING(CentralModsDir, QString, "mods")
|
|
||||||
DEFINE_SETTING(LWJGLDir, QString, "lwjgl")
|
|
||||||
|
|
||||||
// Console
|
|
||||||
DEFINE_SETTING(ShowConsole, bool, true)
|
|
||||||
DEFINE_SETTING(AutoCloseConsole, bool, true)
|
|
||||||
|
|
||||||
// Toolbar settings
|
|
||||||
DEFINE_SETTING(InstanceToolbarVisible, bool, true)
|
|
||||||
DEFINE_SETTING(InstanceToolbarPosition, QPoint, QPoint())
|
|
||||||
|
|
||||||
// Console Colors
|
|
||||||
// Currently commented out because QColor is a part of QtGUI
|
|
||||||
// DEFINE_SETTING(SysMessageColor, QColor, QColor(Qt::blue))
|
|
||||||
// DEFINE_SETTING(StdOutColor, QColor, QColor(Qt::black))
|
|
||||||
// DEFINE_SETTING(StdErrColor, QColor, QColor(Qt::red))
|
|
||||||
|
|
||||||
// Window Size
|
|
||||||
DEFINE_SETTING(LaunchCompatMode, bool, false)
|
|
||||||
DEFINE_SETTING(LaunchMaximized, bool, false)
|
|
||||||
DEFINE_SETTING(MinecraftWinWidth, int, 854)
|
|
||||||
DEFINE_SETTING(MinecraftWinHeight, int, 480)
|
|
||||||
|
|
||||||
// Auto login
|
|
||||||
DEFINE_SETTING(AutoLogin, bool, false)
|
|
||||||
|
|
||||||
// Memory
|
|
||||||
DEFINE_SETTING(MinMemAlloc, int, 512)
|
|
||||||
DEFINE_SETTING(MaxMemAlloc, int, 1024)
|
|
||||||
|
|
||||||
// Java Settings
|
|
||||||
DEFINE_SETTING_ADVANCED(JavaPath, JPATHKEY, QString, "java")
|
|
||||||
DEFINE_SETTING(JvmArgs, QString, "")
|
|
||||||
|
|
||||||
// Custom Commands
|
|
||||||
DEFINE_SETTING(PreLaunchCommand, QString, "")
|
|
||||||
DEFINE_SETTING(PostExitCommand, QString, "")
|
|
||||||
|
|
||||||
virtual QVariant getValue(const QString& name, QVariant defVal = QVariant()) const = 0;
|
|
||||||
virtual void setValue(const QString& name, QVariant val) = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
class LIBMMCSETTINGS_EXPORT AppSettings : public SettingsBase
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
public:
|
|
||||||
explicit AppSettings(QObject *parent = 0);
|
|
||||||
|
|
||||||
QSettings& getConfig() { return config; }
|
|
||||||
|
|
||||||
virtual QVariant getValue(const QString &name, QVariant defVal = QVariant()) const;
|
|
||||||
virtual void setValue(const QString& name, QVariant val);
|
|
||||||
|
|
||||||
protected:
|
|
||||||
QSettings config;
|
|
||||||
};
|
|
||||||
|
|
||||||
#undef DEFINE_SETTING_ADVANCED
|
|
||||||
#undef DEFINE_SETTING
|
|
||||||
|
|
||||||
LIBMMCSETTINGS_EXPORT extern AppSettings* settings;
|
|
||||||
|
|
||||||
#endif // APPSETTINGS_H
|
|
44
libsettings/include/basicsettingsobject.h
Normal file
44
libsettings/include/basicsettingsobject.h
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef BASICSETTINGSOBJECT_H
|
||||||
|
#define BASICSETTINGSOBJECT_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QSettings>
|
||||||
|
|
||||||
|
#include "settingsobject.h"
|
||||||
|
|
||||||
|
#include "libsettings_config.h"
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief A settings object that stores its settings in a QSettings object.
|
||||||
|
*/
|
||||||
|
class LIBMMCSETTINGS_EXPORT BasicSettingsObject : public SettingsObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit BasicSettingsObject(QObject *parent = 0);
|
||||||
|
|
||||||
|
protected slots:
|
||||||
|
virtual void changeSetting(const Setting &setting, QVariant value);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual QVariant retrieveValue(const Setting &setting);
|
||||||
|
|
||||||
|
QSettings config;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // BASICSETTINGSOBJECT_H
|
101
libsettings/include/setting.h
Normal file
101
libsettings/include/setting.h
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef SETTING_H
|
||||||
|
#define SETTING_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QVariant>
|
||||||
|
|
||||||
|
#include "libsettings_config.h"
|
||||||
|
|
||||||
|
class SettingsObject;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class LIBMMCSETTINGS_EXPORT Setting : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
/*!
|
||||||
|
* \brief Constructs a new Setting object with the given parent.
|
||||||
|
* \param parent The Setting's parent object.
|
||||||
|
*/
|
||||||
|
explicit Setting(QString id, QVariant defVal = QVariant(), QObject *parent = 0);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets this setting's ID.
|
||||||
|
* This is used to refer to the setting within the application.
|
||||||
|
* \warning Changing the ID while the setting is registered with a SettingsObject results in undefined behavior.
|
||||||
|
* \return The ID of the setting.
|
||||||
|
*/
|
||||||
|
virtual QString id() const { return m_id; }
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets this setting's config file key.
|
||||||
|
* This is used to store the setting's value in the config file. It is usually
|
||||||
|
* the same as the setting's ID, but it can be different.
|
||||||
|
* \return The setting's config file key.
|
||||||
|
*/
|
||||||
|
virtual QString configKey() const { return id(); }
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets this setting's value as a QVariant.
|
||||||
|
* This is done by calling the SettingsObject's retrieveValue() function.
|
||||||
|
* If this Setting doesn't have a SettingsObject, this returns an invalid QVariant.
|
||||||
|
* \return QVariant containing this setting's value.
|
||||||
|
* \sa value()
|
||||||
|
*/
|
||||||
|
virtual QVariant get() const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets this setting's actual value (I.E. not as a QVariant).
|
||||||
|
* This function is just shorthand for get().value<T>()
|
||||||
|
* \return The setting's actual value.
|
||||||
|
*/
|
||||||
|
template<typename T>
|
||||||
|
inline T value() const { return get().value<T>(); }
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets this setting's default value.
|
||||||
|
* \return The default value of this setting.
|
||||||
|
*/
|
||||||
|
virtual QVariant defValue() const;
|
||||||
|
|
||||||
|
signals:
|
||||||
|
/*!
|
||||||
|
* \brief Signal emitted when this Setting object's value changes.
|
||||||
|
* \param setting A reference to the Setting that changed.
|
||||||
|
* \param value This Setting object's new value.
|
||||||
|
*/
|
||||||
|
void settingChanged(const Setting &setting, QVariant value);
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
/*!
|
||||||
|
* \brief Changes the setting's value.
|
||||||
|
* This is done by emitting the settingChanged() signal which will then be
|
||||||
|
* handled by the SettingsObject object and cause the setting to change.
|
||||||
|
* \param value The new value.
|
||||||
|
*/
|
||||||
|
virtual void set(QVariant value);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
QString m_id;
|
||||||
|
QVariant m_defVal;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SETTING_H
|
165
libsettings/include/settingsobject.h
Normal file
165
libsettings/include/settingsobject.h
Normal file
@ -0,0 +1,165 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef SETTINGSOBJECT_H
|
||||||
|
#define SETTINGSOBJECT_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QMap>
|
||||||
|
|
||||||
|
#include "libsettings_config.h"
|
||||||
|
|
||||||
|
class Setting;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The SettingsObject handles communicating settings between the application and a settings file.
|
||||||
|
* The class keeps a list of Setting objects. Each Setting object represents one
|
||||||
|
* of the application's settings. These Setting objects are registered with
|
||||||
|
* a SettingsObject and can be managed similarly to the way a list works.
|
||||||
|
*
|
||||||
|
* \author Andrew Okin
|
||||||
|
* \date 2/22/2013
|
||||||
|
*
|
||||||
|
* \sa Setting
|
||||||
|
*/
|
||||||
|
class LIBMMCSETTINGS_EXPORT SettingsObject : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit SettingsObject(QObject *parent = 0);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Registers the given setting with this SettingsObject and connects the necessary signals.
|
||||||
|
* This will fail if there is already a setting with the same ID as
|
||||||
|
* the one that is being registered.
|
||||||
|
* \note Registering a setting object causes the SettingsObject to take ownership
|
||||||
|
* of the object. This means that setting's parent will be set to the object
|
||||||
|
* it was registered with. Because the object it was registered with has taken
|
||||||
|
* ownership, it becomes responsible for managing that setting object's memory.
|
||||||
|
* \warning Do \b not delete the setting after registering it.
|
||||||
|
* \param setting A pointer to the setting that will be registered.
|
||||||
|
* \return True if successful. False if registry failed.
|
||||||
|
*/
|
||||||
|
virtual bool registerSetting(Setting *setting);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Unregisters the given setting from this SettingsObject and disconnects its signals.
|
||||||
|
* \note This does not delete the setting. Furthermore, when the setting is
|
||||||
|
* unregistered, the SettingsObject drops ownership of the setting. This means
|
||||||
|
* that if you unregister a setting, its parent is set to null and you become
|
||||||
|
* responsible for freeing its memory.
|
||||||
|
* \param setting The setting to unregister.
|
||||||
|
*/
|
||||||
|
virtual void unregisterSetting(Setting *setting);
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets the setting with the given ID.
|
||||||
|
* \param id The ID of the setting to get.
|
||||||
|
* \return A pointer to the setting with the given ID.
|
||||||
|
* Returns null if there is no setting with the given ID.
|
||||||
|
* \sa operator []()
|
||||||
|
*/
|
||||||
|
virtual Setting *getSetting(const QString &id) const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Same as getSetting()
|
||||||
|
* \param id The ID of the setting to get.
|
||||||
|
* \return A pointer to the setting with the given ID.
|
||||||
|
* \sa getSetting()
|
||||||
|
*/
|
||||||
|
inline Setting *operator [](const QString &id) { return getSetting(id); }
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets the value of the setting with the given ID.
|
||||||
|
* \param id The ID of the setting to get.
|
||||||
|
* \return The setting's value as a QVariant.
|
||||||
|
* If no setting with the given ID exists, returns an invalid QVariant.
|
||||||
|
*/
|
||||||
|
virtual QVariant get(const QString &id) const;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Sets the value of the setting with the given ID.
|
||||||
|
* If no setting with the given ID exists, returns false and logs to qDebug
|
||||||
|
* \param id The ID of the setting to change.
|
||||||
|
* \param value The new value of the setting.
|
||||||
|
* \return True if successful, false if it failed.
|
||||||
|
*/
|
||||||
|
virtual bool set(const QString &id, QVariant value);
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets a QList with pointers to all of the registered settings.
|
||||||
|
* The order of the entries in the list is undefined.
|
||||||
|
* \return A QList with pointers to all registered settings.
|
||||||
|
*/
|
||||||
|
virtual QList<Setting *> getSettings();
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Checks if this SettingsObject contains a setting with the given ID.
|
||||||
|
* \param id The ID to check for.
|
||||||
|
* \return True if the SettingsObject has a setting with the given ID.
|
||||||
|
*/
|
||||||
|
virtual bool contains(const QString &id);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
/*!
|
||||||
|
* \brief Signal emitted when one of this SettingsObject object's settings changes.
|
||||||
|
* This is usually just connected directly to each Setting object's
|
||||||
|
* settingChanged() signals.
|
||||||
|
* \param setting A reference to the Setting object that changed.
|
||||||
|
* \param value The Setting object's new value.
|
||||||
|
*/
|
||||||
|
void settingChanged(const Setting &setting, QVariant value);
|
||||||
|
|
||||||
|
protected slots:
|
||||||
|
/*!
|
||||||
|
* \brief Changes a setting.
|
||||||
|
* This slot is usually connected to each Setting object's
|
||||||
|
* settingChanged() signal. The signal is emitted, causing this slot
|
||||||
|
* to update the setting's value in the config file.
|
||||||
|
* \param setting A reference to the Setting object that changed.
|
||||||
|
* \param value The setting's new value.
|
||||||
|
*/
|
||||||
|
virtual void changeSetting(const Setting &setting, QVariant value) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
/*!
|
||||||
|
* \brief Connects the necessary signals to the given Setting.
|
||||||
|
* \param setting The setting to connect.
|
||||||
|
*/
|
||||||
|
virtual void connectSignals(const Setting &setting);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Disconnects signals from the given Setting.
|
||||||
|
* \param setting The setting to disconnect.
|
||||||
|
*/
|
||||||
|
virtual void disconnectSignals(const Setting &setting);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Function used by Setting objects to get their values from the SettingsObject.
|
||||||
|
* \param setting The
|
||||||
|
* \return
|
||||||
|
*/
|
||||||
|
virtual QVariant retrieveValue(const Setting &setting) = 0;
|
||||||
|
|
||||||
|
friend class Setting;
|
||||||
|
|
||||||
|
private:
|
||||||
|
QMap<QString, Setting *> m_settings;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SETTINGSOBJECT_H
|
43
libsettings/src/basicsettingsobject.cpp
Normal file
43
libsettings/src/basicsettingsobject.cpp
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "include/basicsettingsobject.h"
|
||||||
|
#include "include/setting.h"
|
||||||
|
|
||||||
|
BasicSettingsObject::BasicSettingsObject(QObject *parent) :
|
||||||
|
SettingsObject(parent)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void BasicSettingsObject::changeSetting(const Setting &setting, QVariant value)
|
||||||
|
{
|
||||||
|
if (contains(setting.id()))
|
||||||
|
{
|
||||||
|
config.setValue(setting.configKey(), value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant BasicSettingsObject::retrieveValue(const Setting &setting)
|
||||||
|
{
|
||||||
|
if (contains(setting.id()))
|
||||||
|
{
|
||||||
|
return config.value(setting.configKey());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
}
|
42
libsettings/src/setting.cpp
Normal file
42
libsettings/src/setting.cpp
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "include/setting.h"
|
||||||
|
#include "include/settingsobject.h"
|
||||||
|
|
||||||
|
Setting::Setting(QString id, QVariant defVal, QObject *parent) :
|
||||||
|
QObject(parent), m_id(id), m_defVal(defVal)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant Setting::get() const
|
||||||
|
{
|
||||||
|
SettingsObject *sbase = qobject_cast<SettingsObject *>(parent());
|
||||||
|
if (!sbase)
|
||||||
|
return defValue();
|
||||||
|
else
|
||||||
|
return sbase->retrieveValue(*this);
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant Setting::defValue() const
|
||||||
|
{
|
||||||
|
return m_defVal;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Setting::set(QVariant value)
|
||||||
|
{
|
||||||
|
emit settingChanged(*this, value);
|
||||||
|
}
|
124
libsettings/src/settingsobject.cpp
Normal file
124
libsettings/src/settingsobject.cpp
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "include/settingsobject.h"
|
||||||
|
#include "include/setting.h"
|
||||||
|
|
||||||
|
#include <QVariant>
|
||||||
|
|
||||||
|
SettingsObject::SettingsObject(QObject *parent) :
|
||||||
|
QObject(parent)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SettingsObject::registerSetting(Setting *setting)
|
||||||
|
{
|
||||||
|
// Check if setting is null or we already have a setting with the same ID.
|
||||||
|
if (!setting)
|
||||||
|
{
|
||||||
|
qDebug(QString("Failed to register setting. Setting is null.").
|
||||||
|
arg(setting->id()).toUtf8());
|
||||||
|
return false; // Fail
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contains(setting->id()))
|
||||||
|
{
|
||||||
|
qDebug(QString("Failed to register setting %1. ID already exists.").
|
||||||
|
arg(setting->id()).toUtf8());
|
||||||
|
return false; // Fail
|
||||||
|
}
|
||||||
|
|
||||||
|
m_settings.insert(setting->id(), setting);
|
||||||
|
setting->setParent(this); // Take ownership.
|
||||||
|
|
||||||
|
// Connect signals.
|
||||||
|
connectSignals(*setting);
|
||||||
|
|
||||||
|
qDebug(QString("Registered setting %1.").arg(setting->id()).toUtf8());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SettingsObject::unregisterSetting(Setting *setting)
|
||||||
|
{
|
||||||
|
if (!setting || !m_settings.contains(setting->id()))
|
||||||
|
return; // We can't unregister something that's not registered.
|
||||||
|
|
||||||
|
m_settings.remove(setting->id());
|
||||||
|
|
||||||
|
// Disconnect signals.
|
||||||
|
disconnectSignals(*setting);
|
||||||
|
|
||||||
|
setting->setParent(NULL); // Drop ownership.
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Setting *SettingsObject::getSetting(const QString &id) const
|
||||||
|
{
|
||||||
|
// Make sure there is a setting with the given ID.
|
||||||
|
if (!m_settings.contains(id))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return m_settings[id];
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant SettingsObject::get(const QString &id) const
|
||||||
|
{
|
||||||
|
Setting *setting = getSetting(id);
|
||||||
|
return (setting ? setting->get() : QVariant());
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SettingsObject::set(const QString &id, QVariant value)
|
||||||
|
{
|
||||||
|
Setting *setting = getSetting(id);
|
||||||
|
if (!setting)
|
||||||
|
{
|
||||||
|
qDebug(QString("Error changing setting %1. Setting doesn't exist.").
|
||||||
|
arg(id).toUtf8());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
setting->set(value);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<Setting *> SettingsObject::getSettings()
|
||||||
|
{
|
||||||
|
return m_settings.values();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SettingsObject::contains(const QString &id)
|
||||||
|
{
|
||||||
|
return m_settings.contains(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void SettingsObject::connectSignals(const Setting &setting)
|
||||||
|
{
|
||||||
|
connect(&setting, SIGNAL(settingChanged(const Setting &, QVariant)),
|
||||||
|
SLOT(changeSetting(const Setting &, QVariant)));
|
||||||
|
connect(&setting, SIGNAL(settingChanged(const Setting &, QVariant)),
|
||||||
|
SIGNAL(settingChanged(const Setting &, QVariant)));
|
||||||
|
}
|
||||||
|
|
||||||
|
void SettingsObject::disconnectSignals(const Setting &setting)
|
||||||
|
{
|
||||||
|
setting.disconnect(SIGNAL(settingChanged(const Setting &, QVariant)),
|
||||||
|
this, SLOT(changeSetting(const Setting &, QVariant)));
|
||||||
|
setting.disconnect(SIGNAL(settingChanged(const Setting &, QVariant)),
|
||||||
|
this, SIGNAL(settingChanged(const Setting &, QVariant)));
|
||||||
|
}
|
2
main.cpp
2
main.cpp
@ -17,7 +17,7 @@
|
|||||||
#include "gui/mainwindow.h"
|
#include "gui/mainwindow.h"
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
|
|
||||||
#include "appsettings.h"
|
#include "data/appsettings.h"
|
||||||
#include "data/loginresponse.h"
|
#include "data/loginresponse.h"
|
||||||
|
|
||||||
#include "data/plugin/pluginmanager.h"
|
#include "data/plugin/pluginmanager.h"
|
||||||
|
@ -44,8 +44,8 @@ void LoginTask::executeTask()
|
|||||||
"application/x-www-form-urlencoded");
|
"application/x-www-form-urlencoded");
|
||||||
|
|
||||||
QUrlQuery params;
|
QUrlQuery params;
|
||||||
params.addQueryItem("user", uInfo.getUsername());
|
params.addQueryItem("user", uInfo.username());
|
||||||
params.addQueryItem("password", uInfo.getPassword());
|
params.addQueryItem("password", uInfo.password());
|
||||||
params.addQueryItem("version", "13");
|
params.addQueryItem("version", "13");
|
||||||
|
|
||||||
netReply = netMgr.post(netRequest, params.query(QUrl::EncodeSpaces).toUtf8());
|
netReply = netMgr.post(netRequest, params.query(QUrl::EncodeSpaces).toUtf8());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user