Browse Source

Code style: formatting and refactoring of launcher code

Arseniy Shestakov 7 years ago
parent
commit
9da3f48274

+ 29 - 17
launcher/jsonutils.cpp

@@ -14,7 +14,7 @@
 static QVariantMap JsonToMap(const JsonMap & json)
 {
 	QVariantMap map;
-	for (auto & entry : json)
+	for(auto & entry : json)
 	{
 		map.insert(QString::fromUtf8(entry.first.c_str()), JsonUtils::toVariant(entry.second));
 	}
@@ -24,7 +24,7 @@ static QVariantMap JsonToMap(const JsonMap & json)
 static QVariantList JsonToList(const JsonVector & json)
 {
 	QVariantList list;
-	for (auto & entry : json)
+	for(auto & entry : json)
 	{
 		list.push_back(JsonUtils::toVariant(entry));
 	}
@@ -34,7 +34,7 @@ static QVariantList JsonToList(const JsonVector & json)
 static JsonVector VariantToList(QVariantList variant)
 {
 	JsonVector vector;
-	for (auto & entry : variant)
+	for(auto & entry : variant)
 	{
 		vector.push_back(JsonUtils::toJson(entry));
 	}
@@ -44,7 +44,7 @@ static JsonVector VariantToList(QVariantList variant)
 static JsonMap VariantToMap(QVariantMap variant)
 {
 	JsonMap map;
-	for (auto & entry : variant.toStdMap())
+	for(auto & entry : variant.toStdMap())
 	{
 		map[entry.first.toUtf8().data()] = JsonUtils::toJson(entry.second);
 	}
@@ -56,14 +56,26 @@ namespace JsonUtils
 
 QVariant toVariant(const JsonNode & node)
 {
-	switch (node.getType())
+	switch(node.getType())
 	{
-		break; case JsonNode::JsonType::DATA_NULL:   return QVariant();
-		break; case JsonNode::JsonType::DATA_BOOL:   return QVariant(node.Bool());
-		break; case JsonNode::JsonType::DATA_FLOAT:  return QVariant(node.Float());
-		break; case JsonNode::JsonType::DATA_STRING: return QVariant(QString::fromUtf8(node.String().c_str()));
-		break; case JsonNode::JsonType::DATA_VECTOR: return JsonToList(node.Vector());
-		break; case JsonNode::JsonType::DATA_STRUCT: return JsonToMap(node.Struct());
+		break;
+	case JsonNode::JsonType::DATA_NULL:
+		return QVariant();
+		break;
+	case JsonNode::JsonType::DATA_BOOL:
+		return QVariant(node.Bool());
+		break;
+	case JsonNode::JsonType::DATA_FLOAT:
+		return QVariant(node.Float());
+		break;
+	case JsonNode::JsonType::DATA_STRING:
+		return QVariant(QString::fromUtf8(node.String().c_str()));
+		break;
+	case JsonNode::JsonType::DATA_VECTOR:
+		return JsonToList(node.Vector());
+		break;
+	case JsonNode::JsonType::DATA_STRUCT:
+		return JsonToMap(node.Struct());
 	}
 	return QVariant();
 }
@@ -74,7 +86,7 @@ QVariant JsonFromFile(QString filename)
 	file.open(QFile::ReadOnly);
 	auto data = file.readAll();
 
-	if (data.size() == 0)
+	if(data.size() == 0)
 	{
 		logGlobal->error("Failed to open file %s", filename.toUtf8().data());
 		return QVariant();
@@ -90,15 +102,15 @@ JsonNode toJson(QVariant object)
 {
 	JsonNode ret;
 
-	if (object.canConvert<QVariantMap>())
+	if(object.canConvert<QVariantMap>())
 		ret.Struct() = VariantToMap(object.toMap());
-	else if (object.canConvert<QVariantList>())
+	else if(object.canConvert<QVariantList>())
 		ret.Vector() = VariantToList(object.toList());
-	else if (static_cast<QMetaType::Type>(object.type()) == QMetaType::QString)
+	else if(static_cast<QMetaType::Type>(object.type()) == QMetaType::QString)
 		ret.String() = object.toString().toUtf8().data();
-	else if (static_cast<QMetaType::Type>(object.type()) == QMetaType::Bool)
+	else if(static_cast<QMetaType::Type>(object.type()) == QMetaType::Bool)
 		ret.Bool() = object.toBool();
-	else if (object.canConvert<double>())
+	else if(object.canConvert<double>())
 		ret.Float() = object.toFloat();
 
 	return ret;

+ 4 - 4
launcher/jsonutils.h

@@ -14,9 +14,9 @@
 
 namespace JsonUtils
 {
-	QVariant toVariant(const JsonNode & node);
-	QVariant JsonFromFile(QString filename);
+QVariant toVariant(const JsonNode & node);
+QVariant JsonFromFile(QString filename);
 
-	JsonNode toJson(QVariant object);
-	void JsonToFile(QString filename, QVariant object);
+JsonNode toJson(QVariant object);
+void JsonToFile(QString filename, QVariant object);
 }

+ 8 - 11
launcher/mainwindow_moc.cpp

@@ -32,31 +32,28 @@ void MainWindow::load()
 	CResourceHandler::initialize();
 	CResourceHandler::load("config/filesystem.json");
 
-	for (auto & string : VCMIDirs::get().dataPaths())
+	for(auto & string : VCMIDirs::get().dataPaths())
 		QDir::addSearchPath("icons", pathToQString(string / "launcher" / "icons"));
 	QDir::addSearchPath("icons", pathToQString(VCMIDirs::get().userDataPath() / "launcher" / "icons"));
 
 	settings.init(true);
 }
 
-MainWindow::MainWindow(QWidget * parent) :
-    QMainWindow(parent),
-    ui(new Ui::MainWindow)
+MainWindow::MainWindow(QWidget * parent)
+	: QMainWindow(parent), ui(new Ui::MainWindow)
 {
 	load(); // load FS before UI
 
 	ui->setupUi(this);
 	auto width = ui->startGameTitle->fontMetrics().boundingRect(ui->startGameTitle->text()).width();
-	if (ui->startGameButton->iconSize().width() < width)
+	if(ui->startGameButton->iconSize().width() < width)
 	{
 		ui->startGameButton->setIconSize(QSize(width, width));
 	}
 	auto tab_icon_size = ui->tabSelectList->iconSize();
-	if (tab_icon_size.width() < width)
+	if(tab_icon_size.width() < width)
 	{
-		ui->tabSelectList->setIconSize(QSize(
-			width,
-			width + tab_icon_size.height() - tab_icon_size.width()));
+		ui->tabSelectList->setIconSize(QSize(width, width + tab_icon_size.height() - tab_icon_size.width()));
 		ui->tabSelectList->setGridSize(QSize(width, width));
 		// 4 is a dirty hack to make it look right
 		ui->tabSelectList->setMaximumWidth(width + 4);
@@ -65,7 +62,7 @@ MainWindow::MainWindow(QWidget * parent) :
 	ui->settingsView->setDisplayList();
 
 	connect(ui->tabSelectList, SIGNAL(currentRowChanged(int)),
-	        ui->tabListWidget, SLOT(setCurrentIndex(int)));
+		ui->tabListWidget, SLOT(setCurrentIndex(int)));
 }
 
 MainWindow::~MainWindow()
@@ -83,7 +80,7 @@ void MainWindow::startExecutable(QString name)
 	QProcess process;
 
 	// Start the executable
-	if (process.startDetached(name))
+	if(process.startDetached(name))
 	{
 		close(); // exit launcher
 	}

+ 6 - 3
launcher/mainwindow_moc.h

@@ -11,8 +11,9 @@
 #include <QMainWindow>
 #include <QStringList>
 
-namespace Ui {
-	class MainWindow;
+namespace Ui
+{
+class MainWindow;
 }
 
 class QTableWidgetItem;
@@ -20,10 +21,12 @@ class QTableWidgetItem;
 class MainWindow : public QMainWindow
 {
 	Q_OBJECT
+
 private:
-	Ui::MainWindow *ui;
+	Ui::MainWindow * ui;
 	void load();
 	void startExecutable(QString name);
+
 public:
 	explicit MainWindow(QWidget * parent = 0);
 	~MainWindow();

+ 21 - 21
launcher/modManager/cdownloadmanager_moc.cpp

@@ -14,11 +14,11 @@
 
 CDownloadManager::CDownloadManager()
 {
-	connect(&manager, SIGNAL(finished(QNetworkReply*)),
-			SLOT(downloadFinished(QNetworkReply*)));
+	connect(&manager, SIGNAL(finished(QNetworkReply *)),
+		SLOT(downloadFinished(QNetworkReply *)));
 }
 
-void CDownloadManager::downloadFile(const QUrl &url, const QString &file)
+void CDownloadManager::downloadFile(const QUrl & url, const QString & file)
 {
 	QNetworkRequest request(url);
 	FileEntry entry;
@@ -26,18 +26,18 @@ void CDownloadManager::downloadFile(const QUrl &url, const QString &file)
 	entry.bytesReceived = 0;
 	entry.totalSize = 0;
 
-	if (entry.file->open(QIODevice::WriteOnly | QIODevice::Truncate))
+	if(entry.file->open(QIODevice::WriteOnly | QIODevice::Truncate))
 	{
 		entry.status = FileEntry::IN_PROGRESS;
 		entry.reply = manager.get(request);
 
-		connect(entry.reply, SIGNAL(downloadProgress(qint64, qint64)),
-				SLOT(downloadProgressChanged(qint64, qint64)));
+		connect(entry.reply, SIGNAL(downloadProgress(qint64,qint64)),
+			SLOT(downloadProgressChanged(qint64,qint64)));
 	}
 	else
 	{
 		entry.status = FileEntry::FAILED;
-		entry.reply  = nullptr;
+		entry.reply = nullptr;
 		encounteredErrors += entry.file->errorString();
 	}
 
@@ -48,9 +48,9 @@ void CDownloadManager::downloadFile(const QUrl &url, const QString &file)
 CDownloadManager::FileEntry & CDownloadManager::getEntry(QNetworkReply * reply)
 {
 	assert(reply);
-	for (auto & entry : currentDownloads)
+	for(auto & entry : currentDownloads)
 	{
-		if (entry.reply == reply)
+		if(entry.reply == reply)
 			return entry;
 	}
 	assert(0);
@@ -58,11 +58,11 @@ CDownloadManager::FileEntry & CDownloadManager::getEntry(QNetworkReply * reply)
 	return errorValue;
 }
 
-void CDownloadManager::downloadFinished(QNetworkReply *reply)
+void CDownloadManager::downloadFinished(QNetworkReply * reply)
 {
 	FileEntry & file = getEntry(reply);
 
-	if (file.reply->error())
+	if(file.reply->error())
 	{
 		encounteredErrors += file.reply->errorString();
 		file.file->remove();
@@ -76,9 +76,9 @@ void CDownloadManager::downloadFinished(QNetworkReply *reply)
 	}
 
 	bool downloadComplete = true;
-	for (auto & entry : currentDownloads)
+	for(auto & entry : currentDownloads)
 	{
-		if (entry.status == FileEntry::IN_PROGRESS)
+		if(entry.status == FileEntry::IN_PROGRESS)
 		{
 			downloadComplete = false;
 			break;
@@ -88,15 +88,15 @@ void CDownloadManager::downloadFinished(QNetworkReply *reply)
 	QStringList successful;
 	QStringList failed;
 
-	for (auto & entry : currentDownloads)
+	for(auto & entry : currentDownloads)
 	{
-		if (entry.status == FileEntry::FINISHED)
+		if(entry.status == FileEntry::FINISHED)
 			successful += entry.file->fileName();
 		else
 			failed += entry.file->fileName();
 	}
 
-	if (downloadComplete)
+	if(downloadComplete)
 		emit finished(successful, failed, encounteredErrors);
 
 	file.reply->deleteLater();
@@ -113,21 +113,21 @@ void CDownloadManager::downloadProgressChanged(qint64 bytesReceived, qint64 byte
 	entry.totalSize = bytesTotal;
 
 	quint64 total = 0;
-	for (auto & entry : currentDownloads)
+	for(auto & entry : currentDownloads)
 		total += entry.totalSize > 0 ? entry.totalSize : 0;
 
 	quint64 received = 0;
-	for (auto & entry : currentDownloads)
+	for(auto & entry : currentDownloads)
 		received += entry.bytesReceived > 0 ? entry.bytesReceived : 0;
 
 	emit downloadProgress(received, total);
 }
 
-bool CDownloadManager::downloadInProgress(const QUrl &url)
+bool CDownloadManager::downloadInProgress(const QUrl & url)
 {
-	for (auto & entry : currentDownloads)
+	for(auto & entry : currentDownloads)
 	{
-		if (entry.reply->url() == url)
+		if(entry.reply->url() == url)
 			return true;
 	}
 	return false;

+ 5 - 4
launcher/modManager/cdownloadmanager_moc.h

@@ -14,7 +14,7 @@
 
 class QFile;
 
-class CDownloadManager: public QObject
+class CDownloadManager : public QObject
 {
 	Q_OBJECT
 
@@ -41,18 +41,19 @@ class CDownloadManager: public QObject
 	QList<FileEntry> currentDownloads;
 
 	FileEntry & getEntry(QNetworkReply * reply);
+
 public:
 	CDownloadManager();
 
 	// returns true if download with such URL is in progress/queued
 	// FIXME: not sure what's right place for "mod download in progress" check
-	bool downloadInProgress(const QUrl &url);
+	bool downloadInProgress(const QUrl & url);
 
 	// returns network reply so caller can connect to required signals
-	void downloadFile(const QUrl &url, const QString &file);
+	void downloadFile(const QUrl & url, const QString & file);
 
 public slots:
-	void downloadFinished(QNetworkReply *reply);
+	void downloadFinished(QNetworkReply * reply);
 	void downloadProgressChanged(qint64 bytesReceived, qint64 bytesTotal);
 
 signals:

+ 47 - 43
launcher/modManager/cmodlist.cpp

@@ -23,15 +23,15 @@ bool CModEntry::compareVersions(QString lesser, QString greater)
 	assert(lesserList.size() <= maxSections);
 	assert(greaterList.size() <= maxSections);
 
-	for (int i=0; i< maxSections; i++)
+	for(int i = 0; i < maxSections; i++)
 	{
-		if (greaterList.size() <= i) // 1.1.1 > 1.1
+		if(greaterList.size() <= i) // 1.1.1 > 1.1
 			return false;
 
-		if (lesserList.size() <= i) // 1.1 < 1.1.1
+		if(lesserList.size() <= i) // 1.1 < 1.1.1
 			return true;
 
-		if (lesserList[i].toInt() != greaterList[i].toInt())
+		if(lesserList[i].toInt() != greaterList[i].toInt())
 			return lesserList[i].toInt() < greaterList[i].toInt(); // 1.1 < 1.2
 	}
 	return false;
@@ -41,10 +41,10 @@ QString CModEntry::sizeToString(double size)
 {
 	static const QString sizes[] =
 	{
-		/*"%1 B", */"%1 KiB", "%1 MiB", "%1 GiB", "%1 TiB"
+		/*"%1 B", */ "%1 KiB", "%1 MiB", "%1 GiB", "%1 TiB"
 	};
 	size_t index = 0;
-	while (size > 1024 && index < 4)
+	while(size > 1024 && index < 4)
 	{
 		size /= 1024;
 		index++;
@@ -52,17 +52,14 @@ QString CModEntry::sizeToString(double size)
 	return sizes[index].arg(QString::number(size, 'f', 1));
 }
 
-CModEntry::CModEntry(QVariantMap repository, QVariantMap localData, QVariantMap modSettings, QString modname):
-    repository(repository),
-    localData(localData),
-    modSettings(modSettings),
-    modname(modname)
+CModEntry::CModEntry(QVariantMap repository, QVariantMap localData, QVariantMap modSettings, QString modname)
+	: repository(repository), localData(localData), modSettings(modSettings), modname(modname)
 {
 }
 
 bool CModEntry::isEnabled() const
 {
-	if (!isInstalled())
+	if(!isInstalled())
 		return false;
 
 	return modSettings["active"].toBool();
@@ -70,27 +67,27 @@ bool CModEntry::isEnabled() const
 
 bool CModEntry::isDisabled() const
 {
-	if (!isInstalled())
+	if(!isInstalled())
 		return false;
 	return !isEnabled();
 }
 
 bool CModEntry::isAvailable() const
 {
-	if (isInstalled())
+	if(isInstalled())
 		return false;
 	return !repository.isEmpty();
 }
 
 bool CModEntry::isUpdateable() const
 {
-	if (!isInstalled())
+	if(!isInstalled())
 		return false;
 
 	QString installedVer = localData["installedVersion"].toString();
 	QString availableVer = repository["latestVersion"].toString();
 
-	if (compareVersions(installedVer, availableVer))
+	if(compareVersions(installedVer, availableVer))
 		return true;
 	return false;
 }
@@ -102,10 +99,15 @@ bool CModEntry::isInstalled() const
 
 int CModEntry::getModStatus() const
 {
-	return
-	(isEnabled()   ? ModStatus::ENABLED    : 0) |
-	(isInstalled() ? ModStatus::INSTALLED  : 0) |
-	(isUpdateable()? ModStatus::UPDATEABLE : 0);
+	int status = 0;
+	if(isEnabled())
+		status |= ModStatus::ENABLED;
+	if(isInstalled())
+		status |= ModStatus::INSTALLED;
+	if(isUpdateable())
+		status |= ModStatus::UPDATEABLE;
+
+	return status;
 }
 
 QString CModEntry::getName() const
@@ -115,22 +117,22 @@ QString CModEntry::getName() const
 
 QVariant CModEntry::getValue(QString value) const
 {
-	if (repository.contains(value) && localData.contains(value))
+	if(repository.contains(value) && localData.contains(value))
 	{
 		// value is present in both repo and locally installed. Select one from latest version
 		QString installedVer = localData["installedVersion"].toString();
 		QString availableVer = repository["latestVersion"].toString();
 
-		if (compareVersions(installedVer, availableVer))
+		if(compareVersions(installedVer, availableVer))
 			return repository[value];
 		else
 			return localData[value];
 	}
 
-	if (repository.contains(value))
+	if(repository.contains(value))
 		return repository[value];
 
-	if (localData.contains(value))
+	if(localData.contains(value))
 		return localData[value];
 
 	return QVariant();
@@ -140,7 +142,7 @@ QVariantMap CModList::copyField(QVariantMap data, QString from, QString to)
 {
 	QVariantMap renamed;
 
-	for (auto it = data.begin(); it != data.end(); it++)
+	for(auto it = data.begin(); it != data.end(); it++)
 	{
 		QVariantMap modConf = it.value().toMap();
 
@@ -176,7 +178,7 @@ void CModList::modChanged(QString modID)
 
 static QVariant getValue(QVariantMap input, QString path)
 {
-	if (path.size() > 1)
+	if(path.size() > 1)
 	{
 		QString entryName = path.section('/', 0, 1);
 		QString remainder = "/" + path.section('/', 2, -1);
@@ -200,28 +202,30 @@ CModEntry CModList::getMod(QString modname) const
 	path = "/" + path.replace(".", "/mods/");
 	QVariant conf = getValue(modSettings, path);
 
-	if (conf.isNull())
+	if(conf.isNull())
 	{
 		settings["active"] = true; // default
 	}
 	else
 	{
-		if (conf.canConvert<QVariantMap>())
+		if(conf.canConvert<QVariantMap>())
 			settings = conf.toMap();
 		else
 			settings.insert("active", conf);
 	}
 
-	for (auto entry : repositories)
+	for(auto entry : repositories)
 	{
 		QVariant repoVal = getValue(entry, path);
-		if (repoVal.isValid())
+		if(repoVal.isValid())
 		{
-			if (repo.empty())
+			if(repo.empty())
+			{
 				repo = repoVal.toMap();
+			}
 			else
 			{
-				if (CModEntry::compareVersions(repo["version"].toString(), repoVal.toMap()["version"].toString()))
+				if(CModEntry::compareVersions(repo["version"].toString(), repoVal.toMap()["version"].toString()))
 					repo = repoVal.toMap();
 			}
 		}
@@ -232,11 +236,11 @@ CModEntry CModList::getMod(QString modname) const
 
 bool CModList::hasMod(QString modname) const
 {
-	if (localModList.contains(modname))
+	if(localModList.contains(modname))
 		return true;
 
-	for (auto entry : repositories)
-		if (entry.contains(modname))
+	for(auto entry : repositories)
+		if(entry.contains(modname))
 			return true;
 
 	return false;
@@ -246,11 +250,11 @@ QStringList CModList::getRequirements(QString modname)
 {
 	QStringList ret;
 
-	if (hasMod(modname))
+	if(hasMod(modname))
 	{
 		auto mod = getMod(modname);
 
-		for (auto entry : mod.getValue("depends").toStringList())
+		for(auto entry : mod.getValue("depends").toStringList())
 			ret += getRequirements(entry);
 	}
 	ret += modname;
@@ -262,19 +266,19 @@ QVector<QString> CModList::getModList() const
 {
 	QSet<QString> knownMods;
 	QVector<QString> modList;
-	for (auto repo : repositories)
+	for(auto repo : repositories)
 	{
-		for (auto it = repo.begin(); it != repo.end(); it++)
+		for(auto it = repo.begin(); it != repo.end(); it++)
 		{
 			knownMods.insert(it.key());
 		}
 	}
-	for (auto it = localModList.begin(); it != localModList.end(); it++)
+	for(auto it = localModList.begin(); it != localModList.end(); it++)
 	{
 		knownMods.insert(it.key());
 	}
 
-	for (auto entry : knownMods)
+	for(auto entry : knownMods)
 	{
 		modList.push_back(entry);
 	}
@@ -286,9 +290,9 @@ QVector<QString> CModList::getChildren(QString parent) const
 	QVector<QString> children;
 
 	int depth = parent.count('.') + 1;
-	for (const QString & mod : getModList())
+	for(const QString & mod : getModList())
 	{
-		if (mod.count('.') == depth && mod.startsWith(parent))
+		if(mod.count('.') == depth && mod.startsWith(parent))
 			children.push_back(mod);
 	}
 	return children;

+ 10 - 8
launcher/modManager/cmodlist.h

@@ -17,14 +17,14 @@ class JsonNode;
 
 namespace ModStatus
 {
-	enum EModStatus
-	{
-		MASK_NONE = 0,
-		ENABLED = 1,
-		INSTALLED = 2,
-		UPDATEABLE = 4,
-		MASK_ALL = 255
-	};
+enum EModStatus
+{
+	MASK_NONE = 0,
+	ENABLED = 1,
+	INSTALLED = 2,
+	UPDATEABLE = 4,
+	MASK_ALL = 255
+};
 }
 
 class CModEntry
@@ -35,6 +35,7 @@ class CModEntry
 	QVariantMap modSettings;
 
 	QString modname;
+
 public:
 	CModEntry(QVariantMap repository, QVariantMap localData, QVariantMap modSettings, QString modname);
 
@@ -70,6 +71,7 @@ class CModList
 	QVariantMap modSettings;
 
 	QVariantMap copyField(QVariantMap data, QString from, QString to);
+
 public:
 	virtual void resetRepositories();
 	virtual void addRepository(QVariantMap data);

+ 84 - 82
launcher/modManager/cmodlistmodel_moc.cpp

@@ -14,64 +14,64 @@
 
 namespace ModFields
 {
-	static const QString names [ModFields::COUNT] =
-	{
-		"name",
-		"",
-		"",
-		"modType",
-		"version",
-		"size",
-		"author"
-	};
-
-	static const QString header [ModFields::COUNT] =
-	{
-		"Name",
-		"", // status icon
-		"", // status icon
-		"Type",
-		"Version",
-		"Size",
-		"Author"
-	};
+static const QString names[ModFields::COUNT] =
+{
+	"name",
+	"",
+	"",
+	"modType",
+	"version",
+	"size",
+	"author"
+};
+
+static const QString header[ModFields::COUNT] =
+{
+	"Name",
+	"", // status icon
+	"", // status icon
+	"Type",
+	"Version",
+	"Size",
+	"Author"
+};
 }
 
 namespace ModStatus
 {
-	static const QString iconDelete   = "icons:mod-delete.png";
-	static const QString iconDisabled = "icons:mod-disabled.png";
-	static const QString iconDownload = "icons:mod-download.png";
-	static const QString iconEnabled  = "icons:mod-enabled.png";
-	static const QString iconUpdate   = "icons:mod-update.png";
+static const QString iconDelete = "icons:mod-delete.png";
+static const QString iconDisabled = "icons:mod-disabled.png";
+static const QString iconDownload = "icons:mod-download.png";
+static const QString iconEnabled = "icons:mod-enabled.png";
+static const QString iconUpdate = "icons:mod-update.png";
 }
 
-CModListModel::CModListModel(QObject *parent) :
-	QAbstractItemModel(parent)
+CModListModel::CModListModel(QObject * parent)
+	: QAbstractItemModel(parent)
 {
 }
 
 QString CModListModel::modIndexToName(const QModelIndex & index) const
 {
-	if (index.isValid())
+	if(index.isValid())
 	{
 		return modNameToID.at(index.internalId());
 	}
 	return "";
 }
 
-QVariant CModListModel::getValue(const CModEntry &mod, int field) const
+QVariant CModListModel::getValue(const CModEntry & mod, int field) const
 {
 	switch(field)
 	{
-		case ModFields::STATUS_ENABLED:
-			return mod.getModStatus() & (ModStatus::ENABLED | ModStatus::INSTALLED);
+	case ModFields::STATUS_ENABLED:
+		return mod.getModStatus() & (ModStatus::ENABLED | ModStatus::INSTALLED);
 
-		case ModFields::STATUS_UPDATE:
-			return mod.getModStatus() & (ModStatus::UPDATEABLE | ModStatus::INSTALLED);
+	case ModFields::STATUS_UPDATE:
+		return mod.getModStatus() & (ModStatus::UPDATEABLE | ModStatus::INSTALLED);
 
-		default:
-			return mod.getValue(ModFields::names[field]);
+	default:
+		return mod.getValue(ModFields::names[field]);
 	}
 }
 
@@ -79,26 +79,26 @@ QVariant CModListModel::getText(const CModEntry & mod, int field) const
 {
 	switch(field)
 	{
-		case ModFields::STATUS_ENABLED:
-		case ModFields::STATUS_UPDATE:
-			return "";
-		case ModFields::SIZE:
-			return CModEntry::sizeToString(getValue(mod, field).toDouble());
-		default:
-			return getValue(mod, field);
+	case ModFields::STATUS_ENABLED:
+	case ModFields::STATUS_UPDATE:
+		return "";
+	case ModFields::SIZE:
+		return CModEntry::sizeToString(getValue(mod, field).toDouble());
+	default:
+		return getValue(mod, field);
 	}
 }
 
 QVariant CModListModel::getIcon(const CModEntry & mod, int field) const
 {
-	if (field == ModFields::STATUS_ENABLED && mod.isEnabled())
+	if(field == ModFields::STATUS_ENABLED && mod.isEnabled())
 		return QIcon(ModStatus::iconEnabled);
-	if (field == ModFields::STATUS_ENABLED && mod.isDisabled())
+	if(field == ModFields::STATUS_ENABLED && mod.isDisabled())
 		return QIcon(ModStatus::iconDisabled);
 
-	if (field == ModFields::STATUS_UPDATE  && mod.isUpdateable())
+	if(field == ModFields::STATUS_UPDATE && mod.isUpdateable())
 		return QIcon(ModStatus::iconUpdate);
-	if (field == ModFields::STATUS_UPDATE  && !mod.isInstalled())
+	if(field == ModFields::STATUS_UPDATE && !mod.isInstalled())
 		return QIcon(ModStatus::iconDownload);
 
 	return QVariant();
@@ -106,26 +106,31 @@ QVariant CModListModel::getIcon(const CModEntry & mod, int field) const
 
 QVariant CModListModel::getTextAlign(int field) const
 {
-	if (field == ModFields::SIZE)
+	if(field == ModFields::SIZE)
 		return QVariant(Qt::AlignRight | Qt::AlignVCenter);
 	//if (field == ModFields::NAME)
 	//	return QVariant(Qt::AlignHCenter | Qt::AlignVCenter);
-	return QVariant(Qt::AlignLeft  | Qt::AlignVCenter);
+	return QVariant(Qt::AlignLeft | Qt::AlignVCenter);
 }
 
-QVariant CModListModel::data(const QModelIndex &index, int role) const
+QVariant CModListModel::data(const QModelIndex & index, int role) const
 {
-	if (index.isValid())
+	if(index.isValid())
 	{
 		auto mod = getMod(modIndexToName(index));
 
-		switch (role)
+		switch(role)
 		{
-			case Qt::DecorationRole:    return getIcon(mod, index.column());
-			case Qt::DisplayRole:       return getText(mod, index.column());
-			case Qt::TextAlignmentRole: return getTextAlign(index.column());
-			case ModRoles::ValueRole:   return getValue(mod, index.column());
-			case ModRoles::ModNameRole: return mod.getName();
+		case Qt::DecorationRole:
+			return getIcon(mod, index.column());
+		case Qt::DisplayRole:
+			return getText(mod, index.column());
+		case Qt::TextAlignmentRole:
+			return getTextAlign(index.column());
+		case ModRoles::ValueRole:
+			return getValue(mod, index.column());
+		case ModRoles::ModNameRole:
+			return mod.getName();
 		}
 	}
 	return QVariant();
@@ -133,7 +138,7 @@ QVariant CModListModel::data(const QModelIndex &index, int role) const
 
 int CModListModel::rowCount(const QModelIndex & index) const
 {
-	if (index.isValid())
+	if(index.isValid())
 		return modIndex[modIndexToName(index)].size();
 	return modIndex[""].size();
 }
@@ -150,7 +155,7 @@ Qt::ItemFlags CModListModel::flags(const QModelIndex &) const
 
 QVariant CModListModel::headerData(int section, Qt::Orientation orientation, int role) const
 {
-	if (role == Qt::DisplayRole && orientation == Qt::Horizontal)
+	if(role == Qt::DisplayRole && orientation == Qt::Horizontal)
 		return ModFields::header[section];
 	return QVariant();
 }
@@ -172,7 +177,7 @@ void CModListModel::addRepository(QVariantMap data)
 void CModListModel::modChanged(QString modID)
 {
 	int index = modNameToID.indexOf(modID);
-	QModelIndex parent  = this->parent(createIndex(0, 0, index));
+	QModelIndex parent = this->parent(createIndex(0, 0, index));
 	int row = modIndex[modIndexToName(parent)].indexOf(modID);
 	emit dataChanged(createIndex(row, 0, index), createIndex(row, 4, index));
 }
@@ -181,9 +186,9 @@ void CModListModel::endResetModel()
 {
 	modNameToID = getModList();
 	modIndex.clear();
-	for (const QString & str : modNameToID)
+	for(const QString & str : modNameToID)
 	{
-		if (str.contains('.'))
+		if(str.contains('.'))
 		{
 			modIndex[str.section('.', 0, -2)].append(str);
 		}
@@ -195,27 +200,27 @@ void CModListModel::endResetModel()
 	QAbstractItemModel::endResetModel();
 }
 
-QModelIndex CModListModel::index(int row, int column, const QModelIndex &parent) const
+QModelIndex CModListModel::index(int row, int column, const QModelIndex & parent) const
 {
-	if (parent.isValid())
+	if(parent.isValid())
 	{
-		if (modIndex[modIndexToName(parent)].size() > row)
+		if(modIndex[modIndexToName(parent)].size() > row)
 			return createIndex(row, column, modNameToID.indexOf(modIndex[modIndexToName(parent)][row]));
 	}
 	else
 	{
-		if (modIndex[""].size() > row)
+		if(modIndex[""].size() > row)
 			return createIndex(row, column, modNameToID.indexOf(modIndex[""][row]));
 	}
 	return QModelIndex();
 }
 
-QModelIndex CModListModel::parent(const QModelIndex &child) const
+QModelIndex CModListModel::parent(const QModelIndex & child) const
 {
 	QString modID = modNameToID[child.internalId()];
-	for (auto entry = modIndex.begin(); entry != modIndex.end(); entry++) // because using range-for entry type is QMap::value_type oO
+	for(auto entry = modIndex.begin(); entry != modIndex.end(); entry++) // because using range-for entry type is QMap::value_type oO
 	{
-		if (entry.key() != "" && entry.value().indexOf(modID) != -1)
+		if(entry.key() != "" && entry.value().indexOf(modID) != -1)
 		{
 			return createIndex(entry.value().indexOf(modID), child.column(), modNameToID.indexOf(entry.key()));
 		}
@@ -230,43 +235,40 @@ void CModFilterModel::setTypeFilter(int filteredType, int filterMask)
 	invalidateFilter();
 }
 
-bool CModFilterModel::filterMatchesThis(const QModelIndex &source) const
+bool CModFilterModel::filterMatchesThis(const QModelIndex & source) const
 {
 	CModEntry mod = base->getMod(source.data(ModRoles::ModNameRole).toString());
 	return (mod.getModStatus() & filterMask) == filteredType &&
-			QSortFilterProxyModel::filterAcceptsRow(source.row(), source.parent());
+	       QSortFilterProxyModel::filterAcceptsRow(source.row(), source.parent());
 }
 
-bool CModFilterModel::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const
+bool CModFilterModel::filterAcceptsRow(int source_row, const QModelIndex & source_parent) const
 {
 	QModelIndex index = base->index(source_row, 0, source_parent);
 
-	if (filterMatchesThis(index))
+	if(filterMatchesThis(index))
 	{
 		return true;
 	}
 
-	for (size_t i=0; i<base->rowCount(index); i++)
+	for(size_t i = 0; i < base->rowCount(index); i++)
 	{
-		if (filterMatchesThis(index.child(i, 0)))
+		if(filterMatchesThis(index.child(i, 0)))
 			return true;
 	}
 
 	QModelIndex parent = source_parent;
-	while (parent.isValid())
+	while(parent.isValid())
 	{
-		if (filterMatchesThis(parent))
+		if(filterMatchesThis(parent))
 			return true;
 		parent = parent.parent();
 	}
 	return false;
 }
 
-CModFilterModel::CModFilterModel(CModListModel * model, QObject * parent):
-    QSortFilterProxyModel(parent),
-    base(model),
-    filteredType(ModStatus::MASK_NONE),
-    filterMask(ModStatus::MASK_NONE)
+CModFilterModel::CModFilterModel(CModListModel * model, QObject * parent)
+	: QSortFilterProxyModel(parent), base(model), filteredType(ModStatus::MASK_NONE), filterMask(ModStatus::MASK_NONE)
 {
 	setSourceModel(model);
 	setSortRole(ModRoles::ValueRole);

+ 30 - 27
launcher/modManager/cmodlistmodel_moc.h

@@ -16,26 +16,26 @@
 
 namespace ModFields
 {
-	enum EModFields
-	{
-		NAME,
-		STATUS_ENABLED,
-		STATUS_UPDATE,
-		TYPE,
-		VERSION,
-		SIZE,
-		AUTHOR,
-		COUNT
-	};
+enum EModFields
+{
+	NAME,
+	STATUS_ENABLED,
+	STATUS_UPDATE,
+	TYPE,
+	VERSION,
+	SIZE,
+	AUTHOR,
+	COUNT
+};
 }
 
 namespace ModRoles
 {
-	enum EModRoles
-	{
-		ValueRole = Qt::UserRole,
-		ModNameRole
-	};
+enum EModRoles
+{
+	ValueRole = Qt::UserRole,
+	ModNameRole
+};
 }
 
 class CModListModel : public QAbstractItemModel, public CModList
@@ -55,28 +55,30 @@ class CModListModel : public QAbstractItemModel, public CModList
 	QVariant getValue(const CModEntry & mod, int field) const;
 	QVariant getText(const CModEntry & mod, int field) const;
 	QVariant getIcon(const CModEntry & mod, int field) const;
+
 public:
-	explicit CModListModel(QObject *parent = 0);
+	explicit CModListModel(QObject * parent = 0);
 
 	/// CModListContainer overrides
 	void resetRepositories() override;
 	void addRepository(QVariantMap data) override;
 	void modChanged(QString modID) override;
 
-	QVariant data(const QModelIndex &index, int role) const override;
+	QVariant data(const QModelIndex & index, int role) const override;
 	QVariant headerData(int section, Qt::Orientation orientation, int role) const override;
 
-	int rowCount(const QModelIndex &parent) const override;
-	int columnCount(const QModelIndex &parent) const override;
+	int rowCount(const QModelIndex & parent) const override;
+	int columnCount(const QModelIndex & parent) const override;
 
-	QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const override;
-	QModelIndex parent(const QModelIndex &child) const override;
+	QModelIndex index(int row, int column, const QModelIndex & parent = QModelIndex()) const override;
+	QModelIndex parent(const QModelIndex & child) const override;
+
+	Qt::ItemFlags flags(const QModelIndex & index) const override;
 
-	Qt::ItemFlags flags(const QModelIndex &index) const override;
 signals:
-	
+
 public slots:
-	
+
 };
 
 class CModFilterModel : public QSortFilterProxyModel
@@ -87,9 +89,10 @@ class CModFilterModel : public QSortFilterProxyModel
 
 	bool filterMatchesThis(const QModelIndex & source) const;
 
-	bool filterAcceptsRow(int source_row, const QModelIndex &source_parent) const override;
+	bool filterAcceptsRow(int source_row, const QModelIndex & source_parent) const override;
+
 public:
 	void setTypeFilter(int filteredType, int filterMask);
 
-	CModFilterModel(CModListModel * model, QObject *parent = 0);
+	CModFilterModel(CModListModel * model, QObject * parent = 0);
 };

+ 120 - 106
launcher/modManager/cmodlistview_moc.cpp

@@ -50,24 +50,22 @@ void CModListView::setupModsView()
 	ui->allModsView->setColumnWidth(ModFields::VERSION, 60);
 
 	ui->allModsView->header()->setSectionResizeMode(ModFields::STATUS_ENABLED, QHeaderView::Fixed);
-	ui->allModsView->header()->setSectionResizeMode(ModFields::STATUS_UPDATE,  QHeaderView::Fixed);
+	ui->allModsView->header()->setSectionResizeMode(ModFields::STATUS_UPDATE, QHeaderView::Fixed);
 
 	ui->allModsView->setUniformRowHeights(true);
 
-	connect( ui->allModsView->selectionModel(), SIGNAL( currentRowChanged( const QModelIndex &, const QModelIndex & )),
-	         this, SLOT( modSelected( const QModelIndex &, const QModelIndex & )));
+	connect(ui->allModsView->selectionModel(), SIGNAL(currentRowChanged(const QModelIndex&,const QModelIndex&)),
+		this, SLOT(modSelected(const QModelIndex&,const QModelIndex&)));
 
-	connect( filterModel, SIGNAL( modelReset()),
-	         this, SLOT( modelReset()));
+	connect(filterModel, SIGNAL(modelReset()),
+		this, SLOT(modelReset()));
 
-	connect( modModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)),
-			 this, SLOT(dataChanged(QModelIndex,QModelIndex)));
+	connect(modModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)),
+		this, SLOT(dataChanged(QModelIndex,QModelIndex)));
 }
 
-CModListView::CModListView(QWidget *parent) :
-	QWidget(parent),
-    settingsListener(settings.listen["launcher"]["repositoryURL"]),
-	ui(new Ui::CModListView)
+CModListView::CModListView(QWidget * parent)
+	: QWidget(parent), settingsListener(settings.listen["launcher"]["repositoryURL"]), ui(new Ui::CModListView)
 {
 	settingsListener([&](const JsonNode &){ repositoriesChanged = true; });
 	ui->setupUi(this);
@@ -79,7 +77,7 @@ CModListView::CModListView(QWidget *parent) :
 	ui->progressWidget->setVisible(false);
 	dlManager = nullptr;
 	disableModInfo();
-	if (settings["launcher"]["autoCheckRepositories"].Bool())
+	if(settings["launcher"]["autoCheckRepositories"].Bool())
 	{
 		loadRepositories();
 	}
@@ -92,7 +90,7 @@ CModListView::CModListView(QWidget *parent) :
 void CModListView::loadRepositories()
 {
 	manager->resetRepositories();
-	for (auto entry : settings["launcher"]["repositoryURL"].Vector())
+	for(auto entry : settings["launcher"]["repositoryURL"].Vector())
 	{
 		QString str = QString::fromUtf8(entry.String().c_str());
 
@@ -112,10 +110,10 @@ CModListView::~CModListView()
 void CModListView::showEvent(QShowEvent * event)
 {
 	QWidget::showEvent(event);
-	if (repositoriesChanged)
+	if(repositoriesChanged)
 	{
 		repositoriesChanged = false;
-		if (settings["launcher"]["autoCheckRepositories"].Bool())
+		if(settings["launcher"]["autoCheckRepositories"].Bool())
 		{
 			loadRepositories();
 		}
@@ -141,10 +139,10 @@ void CModListView::hideModInfo()
 
 static QString replaceIfNotEmpty(QVariant value, QString pattern)
 {
-	if (value.canConvert<QStringList>())
+	if(value.canConvert<QStringList>())
 		return pattern.arg(value.toStringList().join(", "));
 
-	if (value.canConvert<QString>())
+	if(value.canConvert<QString>())
 		return pattern.arg(value.toString());
 
 	// all valid types of data should have been filtered by code above
@@ -155,12 +153,12 @@ static QString replaceIfNotEmpty(QVariant value, QString pattern)
 
 static QString replaceIfNotEmpty(QStringList value, QString pattern)
 {
-	if (!value.empty())
+	if(!value.empty())
 		return pattern.arg(value.join(", "));
 	return "";
 }
 
-QString CModListView::genChangelogText(CModEntry &mod)
+QString CModListView::genChangelogText(CModEntry & mod)
 {
 	QString headerTemplate = "<p><span style=\" font-weight:600;\">%1: </span></p>";
 	QString entryBegin = "<p align=\"justify\"><ul>";
@@ -178,22 +176,22 @@ QString CModListView::genChangelogText(CModEntry &mod)
 		return !CModEntry::compareVersions(lesser, greater);
 	});
 
-	for (auto & version : versions)
+	for(auto & version : versions)
 	{
 		result += headerTemplate.arg(version);
 		result += entryBegin;
-		for (auto & line : changelog.value(version).toStringList())
+		for(auto & line : changelog.value(version).toStringList())
 			result += entryLine.arg(line);
 		result += entryEnd;
 	}
 	return result;
 }
 
-QString CModListView::genModInfoText(CModEntry &mod)
+QString CModListView::genModInfoText(CModEntry & mod)
 {
 	QString prefix = "<p><span style=\" font-weight:600;\">%1: </span>"; // shared prefix
 	QString lineTemplate = prefix + "%2</p>";
-	QString urlTemplate  = prefix + "<a href=\"%2\">%3</a></p>";
+	QString urlTemplate = prefix + "<a href=\"%2\">%3</a></p>";
 	QString textTemplate = prefix + "</p><p align=\"justify\">%2</p>";
 	QString listTemplate = "<p align=\"justify\">%1: %2</p>";
 	QString noteTemplate = "<p align=\"justify\">%1</p>";
@@ -204,14 +202,14 @@ QString CModListView::genModInfoText(CModEntry &mod)
 	result += replaceIfNotEmpty(mod.getValue("installedVersion"), lineTemplate.arg(tr("Installed version")));
 	result += replaceIfNotEmpty(mod.getValue("latestVersion"), lineTemplate.arg(tr("Latest version")));
 
-	if (mod.getValue("size").isValid())
+	if(mod.getValue("size").isValid())
 		result += replaceIfNotEmpty(CModEntry::sizeToString(mod.getValue("size").toDouble()), lineTemplate.arg(tr("Download size")));
 	result += replaceIfNotEmpty(mod.getValue("author"), lineTemplate.arg(tr("Authors")));
 
-	if (mod.getValue("licenseURL").isValid())
+	if(mod.getValue("licenseURL").isValid())
 		result += urlTemplate.arg(tr("License")).arg(mod.getValue("licenseURL").toString()).arg(mod.getValue("licenseName").toString());
 
-	if (mod.getValue("contact").isValid())
+	if(mod.getValue("contact").isValid())
 		result += urlTemplate.arg(tr("Home")).arg(mod.getValue("contact").toString()).arg(mod.getValue("contact").toString());
 
 	result += replaceIfNotEmpty(mod.getValue("depends"), lineTemplate.arg(tr("Required mods")));
@@ -220,7 +218,7 @@ QString CModListView::genModInfoText(CModEntry &mod)
 
 	result += "<p></p>"; // to get some empty space
 
-	QString unknownDeps  = tr("This mod can not be installed or enabled because following dependencies are not present");
+	QString unknownDeps = tr("This mod can not be installed or enabled because following dependencies are not present");
 	QString blockingMods = tr("This mod can not be enabled because following mods are incompatible with this mod");
 	QString hasActiveDependentMods = tr("This mod can not be disabled because it is required to run following mods");
 	QString hasDependentMods = tr("This mod can not be uninstalled or updated because it is required to run following mods");
@@ -230,15 +228,15 @@ QString CModListView::genModInfoText(CModEntry &mod)
 
 	notes += replaceIfNotEmpty(findInvalidDependencies(mod.getName()), listTemplate.arg(unknownDeps));
 	notes += replaceIfNotEmpty(findBlockingMods(mod.getName()), listTemplate.arg(blockingMods));
-	if (mod.isEnabled())
+	if(mod.isEnabled())
 		notes += replaceIfNotEmpty(findDependentMods(mod.getName(), true), listTemplate.arg(hasActiveDependentMods));
-	if (mod.isInstalled())
+	if(mod.isInstalled())
 		notes += replaceIfNotEmpty(findDependentMods(mod.getName(), false), listTemplate.arg(hasDependentMods));
 
-	if (mod.getName().contains('.'))
+	if(mod.getName().contains('.'))
 		notes += noteTemplate.arg(thisIsSubmod);
 
-	if (notes.size())
+	if(notes.size())
 		result += textTemplate.arg(tr("Notes")).arg(notes);
 
 	return result;
@@ -270,7 +268,7 @@ void CModListView::dataChanged(const QModelIndex & topleft, const QModelIndex &
 
 void CModListView::selectMod(const QModelIndex & index)
 {
-	if (!index.isValid())
+	if(!index.isValid())
 	{
 		disableModInfo();
 	}
@@ -308,7 +306,7 @@ void CModListView::selectMod(const QModelIndex & index)
 
 void CModListView::keyPressEvent(QKeyEvent * event)
 {
-	if (event->key() == Qt::Key_Escape && ui->modInfoWidget->isVisible() )
+	if(event->key() == Qt::Key_Escape && ui->modInfoWidget->isVisible())
 	{
 		hideModInfo();
 	}
@@ -318,26 +316,26 @@ void CModListView::keyPressEvent(QKeyEvent * event)
 	}
 }
 
-void CModListView::modSelected(const QModelIndex & current, const QModelIndex & )
+void CModListView::modSelected(const QModelIndex & current, const QModelIndex &)
 {
 	selectMod(current);
 }
 
 void CModListView::on_hideModInfoButton_clicked()
 {
-	if (ui->modInfoWidget->isVisible())
+	if(ui->modInfoWidget->isVisible())
 		hideModInfo();
 	else
 		showModInfo();
 }
 
-void CModListView::on_allModsView_activated(const QModelIndex &index)
+void CModListView::on_allModsView_activated(const QModelIndex & index)
 {
 	showModInfo();
 	selectMod(index);
 }
 
-void CModListView::on_lineEdit_textChanged(const QString &arg1)
+void CModListView::on_lineEdit_textChanged(const QString & arg1)
 {
 	QRegExp regExp(arg1, Qt::CaseInsensitive, QRegExp::Wildcard);
 	filterModel->setFilterRegExp(regExp);
@@ -345,23 +343,35 @@ void CModListView::on_lineEdit_textChanged(const QString &arg1)
 
 void CModListView::on_comboBox_currentIndexChanged(int index)
 {
-	switch (index)
+	switch(index)
 	{
-	break; case 0: filterModel->setTypeFilter(ModStatus::MASK_NONE, ModStatus::MASK_NONE);
-	break; case 1: filterModel->setTypeFilter(ModStatus::MASK_NONE, ModStatus::INSTALLED);
-	break; case 2: filterModel->setTypeFilter(ModStatus::INSTALLED, ModStatus::INSTALLED);
-	break; case 3: filterModel->setTypeFilter(ModStatus::UPDATEABLE, ModStatus::UPDATEABLE);
-	break; case 4: filterModel->setTypeFilter(ModStatus::ENABLED | ModStatus::INSTALLED, ModStatus::ENABLED | ModStatus::INSTALLED);
-	break; case 5: filterModel->setTypeFilter(ModStatus::INSTALLED, ModStatus::ENABLED | ModStatus::INSTALLED);
+	case 0:
+		filterModel->setTypeFilter(ModStatus::MASK_NONE, ModStatus::MASK_NONE);
+		break;
+	case 1:
+		filterModel->setTypeFilter(ModStatus::MASK_NONE, ModStatus::INSTALLED);
+		break;
+	case 2:
+		filterModel->setTypeFilter(ModStatus::INSTALLED, ModStatus::INSTALLED);
+		break;
+	case 3:
+		filterModel->setTypeFilter(ModStatus::UPDATEABLE, ModStatus::UPDATEABLE);
+		break;
+	case 4:
+		filterModel->setTypeFilter(ModStatus::ENABLED | ModStatus::INSTALLED, ModStatus::ENABLED | ModStatus::INSTALLED);
+		break;
+	case 5:
+		filterModel->setTypeFilter(ModStatus::INSTALLED, ModStatus::ENABLED | ModStatus::INSTALLED);
+		break;
 	}
 }
 
 QStringList CModListView::findInvalidDependencies(QString mod)
 {
 	QStringList ret;
-	for (QString requrement : modModel->getRequirements(mod))
+	for(QString requrement : modModel->getRequirements(mod))
 	{
-		if (!modModel->hasMod(requrement))
+		if(!modModel->hasMod(requrement))
 			ret += requrement;
 	}
 	return ret;
@@ -372,16 +382,18 @@ QStringList CModListView::findBlockingMods(QString mod)
 	QStringList ret;
 	auto required = modModel->getRequirements(mod);
 
-	for (QString name : modModel->getModList())
+	for(QString name : modModel->getModList())
 	{
 		auto mod = modModel->getMod(name);
 
-		if (mod.isEnabled())
+		if(mod.isEnabled())
 		{
 			// one of enabled mods have requirement (or this mod) marked as conflict
-			for (auto conflict : mod.getValue("conflicts").toStringList())
-				if (required.contains(conflict))
+			for(auto conflict : mod.getValue("conflicts").toStringList())
+			{
+				if(required.contains(conflict))
 					ret.push_back(name);
+			}
 		}
 	}
 
@@ -391,16 +403,18 @@ QStringList CModListView::findBlockingMods(QString mod)
 QStringList CModListView::findDependentMods(QString mod, bool excludeDisabled)
 {
 	QStringList ret;
-	for (QString modName : modModel->getModList())
+	for(QString modName : modModel->getModList())
 	{
 		auto current = modModel->getMod(modName);
 
-		if (!current.isInstalled())
+		if(!current.isInstalled())
 			continue;
 
-		if (current.getValue("depends").toStringList().contains(mod) &&
-		    !(current.isDisabled() && excludeDisabled))
-			ret += modName;
+		if(current.getValue("depends").toStringList().contains(mod))
+		{
+			if(!(current.isDisabled() && excludeDisabled))
+				ret += modName;
+		}
 	}
 	return ret;
 }
@@ -412,9 +426,11 @@ void CModListView::on_enableButton_clicked()
 	assert(findBlockingMods(modName).empty());
 	assert(findInvalidDependencies(modName).empty());
 
-	for (auto & name : modModel->getRequirements(modName))
-		if (modModel->getMod(name).isDisabled())
+	for(auto & name : modModel->getRequirements(modName))
+	{
+		if(modModel->getMod(name).isDisabled())
 			manager->enableMod(name);
+	}
 	checkManagerErrors();
 }
 
@@ -422,9 +438,8 @@ void CModListView::on_disableButton_clicked()
 {
 	QString modName = ui->allModsView->currentIndex().data(ModRoles::ModNameRole).toString();
 
-	if (modModel->hasMod(modName) &&
-	    modModel->getMod(modName).isEnabled())
-			manager->disableMod(modName);
+	if(modModel->hasMod(modName) && modModel->getMod(modName).isEnabled())
+		manager->disableMod(modName);
 
 	checkManagerErrors();
 }
@@ -435,11 +450,11 @@ void CModListView::on_updateButton_clicked()
 
 	assert(findInvalidDependencies(modName).empty());
 
-	for (auto & name : modModel->getRequirements(modName))
+	for(auto & name : modModel->getRequirements(modName))
 	{
 		auto mod = modModel->getMod(name);
 		// update required mod, install missing (can be new dependency)
-		if (mod.isUpdateable() || !mod.isInstalled())
+		if(mod.isUpdateable() || !mod.isInstalled())
 			downloadFile(name + ".zip", mod.getValue("download").toString(), "mods");
 	}
 }
@@ -449,10 +464,9 @@ void CModListView::on_uninstallButton_clicked()
 	QString modName = ui->allModsView->currentIndex().data(ModRoles::ModNameRole).toString();
 	// NOTE: perhaps add "manually installed" flag and uninstall those dependencies that don't have it?
 
-	if (modModel->hasMod(modName) &&
-	    modModel->getMod(modName).isInstalled())
+	if(modModel->hasMod(modName) && modModel->getMod(modName).isInstalled())
 	{
-		if (modModel->getMod(modName).isEnabled())
+		if(modModel->getMod(modName).isEnabled())
 			manager->disableMod(modName);
 		manager->uninstallMod(modName);
 	}
@@ -465,25 +479,25 @@ void CModListView::on_installButton_clicked()
 
 	assert(findInvalidDependencies(modName).empty());
 
-	for (auto & name : modModel->getRequirements(modName))
+	for(auto & name : modModel->getRequirements(modName))
 	{
 		auto mod = modModel->getMod(name);
-		if (!mod.isInstalled())
+		if(!mod.isInstalled())
 			downloadFile(name + ".zip", mod.getValue("download").toString(), "mods");
 	}
 }
 
 void CModListView::downloadFile(QString file, QString url, QString description)
 {
-	if (!dlManager)
+	if(!dlManager)
 	{
 		dlManager = new CDownloadManager();
 		ui->progressWidget->setVisible(true);
 		connect(dlManager, SIGNAL(downloadProgress(qint64,qint64)),
-				this, SLOT(downloadProgress(qint64,qint64)));
+			this, SLOT(downloadProgress(qint64,qint64)));
 
 		connect(dlManager, SIGNAL(finished(QStringList,QStringList,QStringList)),
-				this, SLOT(downloadFinished(QStringList,QStringList,QStringList)));
+			this, SLOT(downloadFinished(QStringList,QStringList,QStringList)));
 
 
 		QString progressBarFormat = "Downloading %s%. %p% (%v KB out of %m KB) finished";
@@ -498,8 +512,8 @@ void CModListView::downloadFile(QString file, QString url, QString description)
 void CModListView::downloadProgress(qint64 current, qint64 max)
 {
 	// display progress, in kilobytes
-	ui->progressBar->setValue(current/1024);
-	ui->progressBar->setMaximum(max/1024);
+	ui->progressBar->setValue(current / 1024);
+	ui->progressBar->setMaximum(max / 1024);
 }
 
 void CModListView::downloadFinished(QStringList savedFiles, QStringList failedFiles, QStringList errors)
@@ -511,18 +525,18 @@ void CModListView::downloadFinished(QStringList savedFiles, QStringList failedFi
 	// if all files were d/loaded there should be no errors. And on failure there must be an error
 	assert(failedFiles.empty() == errors.empty());
 
-	if (savedFiles.empty())
+	if(savedFiles.empty())
 	{
 		// no successfully downloaded mods
-		QMessageBox::warning(this, title, firstLine + errors.join("\n"), QMessageBox::Ok, QMessageBox::Ok );
+		QMessageBox::warning(this, title, firstLine + errors.join("\n"), QMessageBox::Ok, QMessageBox::Ok);
 	}
-	else if (!failedFiles.empty())
+	else if(!failedFiles.empty())
 	{
 		// some mods were not downloaded
 		int result = QMessageBox::warning (this, title, firstLine + errors.join("\n") + lastLine,
 		                                   QMessageBox::Yes | QMessageBox::No, QMessageBox::No );
 
-		if (result == QMessageBox::Yes)
+		if(result == QMessageBox::Yes)
 			installFiles(savedFiles);
 	}
 	else
@@ -532,7 +546,7 @@ void CModListView::downloadFinished(QStringList savedFiles, QStringList failedFi
 	}
 
 	// remove progress bar after some delay so user can see that download was complete and not interrupted.
-	QTimer::singleShot(1000, this,  SLOT(hideProgressBar()));
+	QTimer::singleShot(1000, this, SLOT(hideProgressBar()));
 
 	dlManager->deleteLater();
 	dlManager = nullptr;
@@ -540,7 +554,7 @@ void CModListView::downloadFinished(QStringList savedFiles, QStringList failedFi
 
 void CModListView::hideProgressBar()
 {
-	if (dlManager == nullptr) // it was not recreated meanwhile
+	if(dlManager == nullptr) // it was not recreated meanwhile
 	{
 		ui->progressWidget->setVisible(false);
 		ui->progressBar->setMaximum(0);
@@ -554,19 +568,19 @@ void CModListView::installFiles(QStringList files)
 	QStringList images;
 
 	// TODO: some better way to separate zip's with mods and downloaded repository files
-	for (QString filename : files)
+	for(QString filename : files)
 	{
-		if (filename.endsWith(".zip"))
+		if(filename.endsWith(".zip"))
 			mods.push_back(filename);
-		if (filename.endsWith(".json"))
+		if(filename.endsWith(".json"))
 			manager->loadRepository(filename);
-		if (filename.endsWith(".png"))
+		if(filename.endsWith(".png"))
 			images.push_back(filename);
 	}
-	if (!mods.empty())
+	if(!mods.empty())
 		installMods(mods);
 
-	if (!images.empty())
+	if(!images.empty())
 		loadScreenshots();
 }
 
@@ -574,7 +588,7 @@ void CModListView::installMods(QStringList archives)
 {
 	QStringList modNames;
 
-	for (QString archive : archives)
+	for(QString archive : archives)
 	{
 		// get basename out of full file name
 		//                remove path                  remove extension
@@ -586,31 +600,31 @@ void CModListView::installMods(QStringList archives)
 	QStringList modsToEnable;
 
 	// disable mod(s), to properly recalculate dependencies, if changed
-	for (QString mod : boost::adaptors::reverse(modNames))
+	for(QString mod : boost::adaptors::reverse(modNames))
 	{
 		CModEntry entry = modModel->getMod(mod);
-		if (entry.isInstalled())
+		if(entry.isInstalled())
 		{
 			// enable mod if installed and enabled
-			if (entry.isEnabled())
+			if(entry.isEnabled())
 				modsToEnable.push_back(mod);
 		}
 		else
 		{
 			// enable mod if m
-			if (settings["launcher"]["enableInstalledMods"].Bool())
+			if(settings["launcher"]["enableInstalledMods"].Bool())
 				modsToEnable.push_back(mod);
 		}
 	}
 
 	// uninstall old version of mod, if installed
-	for (QString mod : boost::adaptors::reverse(modNames))
+	for(QString mod : boost::adaptors::reverse(modNames))
 	{
-		if (modModel->getMod(mod).isInstalled())
+		if(modModel->getMod(mod).isInstalled())
 			manager->uninstallMod(mod);
 	}
 
-	for (int i=0; i<modNames.size(); i++)
+	for(int i = 0; i < modNames.size(); i++)
 		manager->installMod(modNames[i], archives[i]);
 
 	std::function<void(QString)> enableMod;
@@ -618,22 +632,22 @@ void CModListView::installMods(QStringList archives)
 	enableMod = [&](QString modName)
 	{
 		auto mod = modModel->getMod(modName);
-		if (mod.isInstalled() && !mod.getValue("keepDisabled").toBool())
+		if(mod.isInstalled() && !mod.getValue("keepDisabled").toBool())
 		{
-			if (manager->enableMod(modName))
+			if(manager->enableMod(modName))
 			{
-				for (QString child : modModel->getChildren(modName))
+				for(QString child : modModel->getChildren(modName))
 					enableMod(child);
 			}
 		}
 	};
 
-	for (QString mod : modsToEnable)
+	for(QString mod : modsToEnable)
 	{
 		enableMod(mod);
 	}
 
-	for (QString archive : archives)
+	for(QString archive : archives)
 		QFile::remove(archive);
 
 	checkManagerErrors();
@@ -653,18 +667,18 @@ void CModListView::on_pushButton_clicked()
 
 void CModListView::modelReset()
 {
-	if (ui->modInfoWidget->isVisible())
-		selectMod(filterModel->rowCount() > 0 ? filterModel->index(0,0) : QModelIndex());
+	if(ui->modInfoWidget->isVisible())
+		selectMod(filterModel->rowCount() > 0 ? filterModel->index(0, 0) : QModelIndex());
 }
 
 void CModListView::checkManagerErrors()
 {
 	QString errors = manager->getErrors().join('\n');
-	if (errors.size() != 0)
+	if(errors.size() != 0)
 	{
 		QString title = "Operation failed";
 		QString description = "Encountered errors:\n" + errors;
-		QMessageBox::warning(this, title, description, QMessageBox::Ok, QMessageBox::Ok );
+		QMessageBox::warning(this, title, description, QMessageBox::Ok, QMessageBox::Ok);
 	}
 }
 
@@ -675,13 +689,13 @@ void CModListView::on_tabWidget_currentChanged(int index)
 
 void CModListView::loadScreenshots()
 {
-	if (ui->tabWidget->currentIndex() == 2 && ui->modInfoWidget->isVisible())
+	if(ui->tabWidget->currentIndex() == 2 && ui->modInfoWidget->isVisible())
 	{
 		ui->screenshotsList->clear();
 		QString modName = ui->allModsView->currentIndex().data(ModRoles::ModNameRole).toString();
 		assert(modModel->hasMod(modName)); //should be filtered out by check above
 
-		for (QString & url : modModel->getMod(modName).getValue("screenshots").toStringList())
+		for(QString & url : modModel->getMod(modName).getValue("screenshots").toStringList())
 		{
 			// URL must be encoded to something else to get rid of symbols illegal in file names
 			auto hashed = QCryptographicHash::hash(url.toUtf8(), QCryptographicHash::Md5);
@@ -689,7 +703,7 @@ void CModListView::loadScreenshots()
 
 			QString fullPath = CLauncherDirs::get().downloadsPath() + '/' + hashedStr + ".png";
 			QPixmap pixmap(fullPath);
-			if (pixmap.isNull())
+			if(pixmap.isNull())
 			{
 				// image file not exists or corrupted - try to redownload
 				downloadFile(hashedStr + ".png", url, "screenshots");
@@ -705,9 +719,9 @@ void CModListView::loadScreenshots()
 	}
 }
 
-void CModListView::on_screenshotsList_clicked(const QModelIndex &index)
+void CModListView::on_screenshotsList_clicked(const QModelIndex & index)
 {
-	if (index.isValid())
+	if(index.isValid())
 	{
 		QIcon icon = ui->screenshotsList->item(index.row())->icon();
 		auto pixmap = icon.pixmap(icon.availableSizes()[0]);

+ 10 - 8
launcher/modManager/cmodlistview_moc.h

@@ -12,8 +12,9 @@
 #include "../StdInc.h"
 #include "../../lib/CConfigHandler.h"
 
-namespace Ui {
-	class CModListView;
+namespace Ui
+{
+class CModListView;
 }
 
 class CModManager;
@@ -61,8 +62,9 @@ class CModListView : public QWidget
 
 	QString genChangelogText(CModEntry & mod);
 	QString genModInfoText(CModEntry & mod);
+
 public:
-	explicit CModListView(QWidget *parent = 0);
+	explicit CModListView(QWidget * parent = 0);
 	~CModListView();
 
 	void showModInfo();
@@ -79,12 +81,12 @@ private slots:
 	void modSelected(const QModelIndex & current, const QModelIndex & previous);
 	void downloadProgress(qint64 current, qint64 max);
 	void downloadFinished(QStringList savedFiles, QStringList failedFiles, QStringList errors);
-	void modelReset ();
+	void modelReset();
 	void hideProgressBar();
 
 	void on_hideModInfoButton_clicked();
 
-	void on_lineEdit_textChanged(const QString &arg1);
+	void on_lineEdit_textChanged(const QString & arg1);
 
 	void on_comboBox_currentIndexChanged(int index);
 
@@ -102,14 +104,14 @@ private slots:
 
 	void on_refreshButton_clicked();
 
-	void on_allModsView_activated(const QModelIndex &index);
+	void on_allModsView_activated(const QModelIndex & index);
 
 	void on_tabWidget_currentChanged(int index);
 
-	void on_screenshotsList_clicked(const QModelIndex &index);
+	void on_screenshotsList_clicked(const QModelIndex & index);
 
 	void on_showInfoButton_clicked();
 
 private:
-	Ui::CModListView *ui;
+	Ui::CModListView * ui;
 };

+ 37 - 36
launcher/modManager/cmodmanager.cpp

@@ -24,23 +24,25 @@ static QString detectModArchive(QString path, QString modName)
 
 	QString modDirName;
 
-	for (auto file : files)
+	for(auto file : files)
 	{
 		QString filename = QString::fromUtf8(file.c_str());
-		if (filename.toLower().startsWith(modName))
+		if(filename.toLower().startsWith(modName))
 		{
 			// archive must contain mod.json file
-			if (filename.toLower() == modName + "/mod.json")
+			if(filename.toLower() == modName + "/mod.json")
 				modDirName = filename.section('/', 0, 0);
 		}
 		else // all files must be in <modname> directory
+		{
 			return "";
+		}
 	}
 	return modDirName;
 }
 
-CModManager::CModManager(CModList * modList):
-    modList(modList)
+CModManager::CModManager(CModList * modList)
+	: modList(modList)
 {
 	loadMods();
 	loadModSettings();
@@ -73,10 +75,10 @@ void CModManager::loadMods()
 	handler.loadMods();
 	auto installedMods = handler.getAllMods();
 
-	for (auto modname : installedMods)
+	for(auto modname : installedMods)
 	{
 		ResourceID resID(CModInfo::getModFile(modname));
-		if (CResourceHandler::get()->existsResource(resID))
+		if(CResourceHandler::get()->existsResource(resID))
 		{
 			boost::filesystem::path name = *CResourceHandler::get()->getResourceName(resID);
 			auto mod = JsonUtils::JsonFromFile(pathToQString(name));
@@ -123,13 +125,13 @@ bool CModManager::canInstallMod(QString modname)
 {
 	auto mod = modList->getMod(modname);
 
-	if (mod.getName().contains('.'))
+	if(mod.getName().contains('.'))
 		return addError(modname, "Can not install submod");
 
-	if (mod.isInstalled())
+	if(mod.isInstalled())
 		return addError(modname, "Mod is already installed");
 
-	if (!mod.isAvailable())
+	if(!mod.isAvailable())
 		return addError(modname, "Mod is not available");
 	return true;
 }
@@ -138,13 +140,13 @@ bool CModManager::canUninstallMod(QString modname)
 {
 	auto mod = modList->getMod(modname);
 
-	if (mod.getName().contains('.'))
+	if(mod.getName().contains('.'))
 		return addError(modname, "Can not uninstall submod");
 
-	if (!mod.isInstalled())
+	if(!mod.isInstalled())
 		return addError(modname, "Mod is not installed");
 
-	if (mod.isEnabled())
+	if(mod.isEnabled())
 		return addError(modname, "Mod must be disabled first");
 	return true;
 }
@@ -153,33 +155,33 @@ bool CModManager::canEnableMod(QString modname)
 {
 	auto mod = modList->getMod(modname);
 
-	if (mod.isEnabled())
+	if(mod.isEnabled())
 		return addError(modname, "Mod is already enabled");
 
-	if (!mod.isInstalled())
+	if(!mod.isInstalled())
 		return addError(modname, "Mod must be installed first");
 
-	for (auto modEntry : mod.getValue("depends").toStringList())
+	for(auto modEntry : mod.getValue("depends").toStringList())
 	{
-		if (!modList->hasMod(modEntry)) // required mod is not available
+		if(!modList->hasMod(modEntry)) // required mod is not available
 			return addError(modname, QString("Required mod %1 is missing").arg(modEntry));
-		if (!modList->getMod(modEntry).isEnabled())
+		if(!modList->getMod(modEntry).isEnabled())
 			return addError(modname, QString("Required mod %1 is not enabled").arg(modEntry));
 	}
 
-	for (QString modEntry : modList->getModList())
+	for(QString modEntry : modList->getModList())
 	{
 		auto mod = modList->getMod(modEntry);
 
 		// "reverse conflict" - enabled mod has this one as conflict
-		if (mod.isEnabled() && mod.getValue("conflicts").toStringList().contains(modname))
+		if(mod.isEnabled() && mod.getValue("conflicts").toStringList().contains(modname))
 			return addError(modname, QString("This mod conflicts with %1").arg(modEntry));
 	}
 
-	for (auto modEntry : mod.getValue("conflicts").toStringList())
+	for(auto modEntry : mod.getValue("conflicts").toStringList())
 	{
-		if (modList->hasMod(modEntry) &&
-		    modList->getMod(modEntry).isEnabled()) // conflicting mod installed and enabled
+		// check if conflicting mod installed and enabled
+		if(modList->hasMod(modEntry) && modList->getMod(modEntry).isEnabled())
 			return addError(modname, QString("This mod conflicts with %1").arg(modEntry));
 	}
 	return true;
@@ -189,18 +191,17 @@ bool CModManager::canDisableMod(QString modname)
 {
 	auto mod = modList->getMod(modname);
 
-	if (mod.isDisabled())
+	if(mod.isDisabled())
 		return addError(modname, "Mod is already disabled");
 
-	if (!mod.isInstalled())
+	if(!mod.isInstalled())
 		return addError(modname, "Mod must be installed first");
 
-	for (QString modEntry : modList->getModList())
+	for(QString modEntry : modList->getModList())
 	{
 		auto current = modList->getMod(modEntry);
 
-		if (current.getValue("depends").toStringList().contains(modname) &&
-		    current.isEnabled())
+		if(current.getValue("depends").toStringList().contains(modname) && current.isEnabled())
 			return addError(modname, QString("This mod is needed to run %1").arg(modEntry));
 	}
 	return true;
@@ -208,7 +209,7 @@ bool CModManager::canDisableMod(QString modname)
 
 static QVariant writeValue(QString path, QVariantMap input, QVariant value)
 {
-	if (path.size() > 1)
+	if(path.size() > 1)
 	{
 
 		QString entryName = path.section('/', 0, 1);
@@ -242,17 +243,17 @@ bool CModManager::doInstallMod(QString modname, QString archivePath)
 {
 	QString destDir = CLauncherDirs::get().modsPath() + "/";
 
-	if (!QFile(archivePath).exists())
+	if(!QFile(archivePath).exists())
 		return addError(modname, "Mod archive is missing");
 
-	if (localMods.contains(modname))
+	if(localMods.contains(modname))
 		return addError(modname, "Mod with such name is already installed");
 
 	QString modDirName = detectModArchive(archivePath, modname);
-	if (!modDirName.size())
+	if(!modDirName.size())
 		return addError(modname, "Mod archive is invalid or corrupted");
 
-	if (!ZipArchive::extract(qstringToPath(archivePath), qstringToPath(destDir)))
+	if(!ZipArchive::extract(qstringToPath(archivePath), qstringToPath(destDir)))
 	{
 		removeModDir(destDir + modDirName);
 		return addError(modname, "Failed to extract mod data");
@@ -273,13 +274,13 @@ bool CModManager::doUninstallMod(QString modname)
 	// Get location of the mod, in case-insensitive way
 	QString modDir = pathToQString(*CResourceHandler::get()->getResourceName(resID));
 
-	if (!QDir(modDir).exists())
+	if(!QDir(modDir).exists())
 		return addError(modname, "Data with this mod was not found");
 
-	if (!localMods.contains(modname))
+	if(!localMods.contains(modname))
 		return addError(modname, "Data with this mod was not found");
 
-	if (!removeModDir(modDir))
+	if(!removeModDir(modDir))
 		return addError(modname, "Failed to delete mod data");
 
 	localMods.remove(modname);

+ 1 - 0
launcher/modManager/cmodmanager.h

@@ -28,6 +28,7 @@ class CModManager
 	QStringList recentErrors;
 	bool addError(QString modname, QString message);
 	bool removeModDir(QString mod);
+
 public:
 	CModManager(CModList * modList);
 

+ 3 - 4
launcher/modManager/imageviewer_moc.cpp

@@ -14,9 +14,8 @@
 #include "imageviewer_moc.h"
 #include "ui_imageviewer_moc.h"
 
-ImageViewer::ImageViewer(QWidget *parent) :
-    QDialog(parent),
-    ui(new Ui::ImageViewer)
+ImageViewer::ImageViewer(QWidget * parent)
+	: QDialog(parent), ui(new Ui::ImageViewer)
 {
 	ui->setupUi(this);
 }
@@ -32,7 +31,7 @@ QSize ImageViewer::calculateWindowSize()
 	return desktop.availableGeometry(desktop.primaryScreen()).size() * 0.8;
 }
 
-void ImageViewer::showPixmap(QPixmap & pixmap, QWidget *parent)
+void ImageViewer::showPixmap(QPixmap & pixmap, QWidget * parent)
 {
 	assert(!pixmap.isNull());
 

+ 8 - 7
launcher/modManager/imageviewer_moc.h

@@ -12,29 +12,30 @@
 
 #include <QDialog>
 
-namespace Ui {
-	class ImageViewer;
+namespace Ui
+{
+class ImageViewer;
 }
 
 class ImageViewer : public QDialog
 {
 	Q_OBJECT
-	
+
 public:
-	explicit ImageViewer(QWidget *parent = 0);
+	explicit ImageViewer(QWidget * parent = 0);
 	~ImageViewer();
 
 	void setPixmap(QPixmap & pixmap);
 
-	static void showPixmap(QPixmap & pixmap, QWidget *parent = 0);
+	static void showPixmap(QPixmap & pixmap, QWidget * parent = 0);
+
 protected:
 	void mousePressEvent(QMouseEvent * event) override;
 	void keyPressEvent(QKeyEvent * event) override;
 	QSize calculateWindowSize();
 
-
 private:
-	Ui::ImageViewer *ui;
+	Ui::ImageViewer * ui;
 };
 
 #endif // IMAGEVIEWER_H

+ 16 - 17
launcher/settingsView/csettingsview_moc.cpp

@@ -20,13 +20,13 @@
 /// Note that it is possible to specify enconding manually in settings.json
 static const std::string knownEncodingsList[] = //TODO: remove hardcode
 {
-    // European Windows-125X encodings
-    "CP1250", // West European, covers mostly Slavic languages that use latin script
-    "CP1251", // Covers languages that use cyrillic scrypt
-    "CP1252", // Latin/East European, covers most of latin languages
-    // Chinese encodings
-    "GBK",    // extension of GB2312, also known as CP936
-    "GB2312"  // basic set for Simplified Chinese. Separate from GBK to allow proper detection of H3 fonts
+	// European Windows-125X encodings
+	"CP1250", // West European, covers mostly Slavic languages that use latin script
+	"CP1251", // Covers languages that use cyrillic scrypt
+	"CP1252", // Latin/East European, covers most of latin languages
+	// Chinese encodings
+	"GBK", // extension of GB2312, also known as CP936
+	"GB2312" // basic set for Simplified Chinese. Separate from GBK to allow proper detection of H3 fonts
 };
 
 void CSettingsView::setDisplayList()
@@ -83,7 +83,7 @@ void CSettingsView::loadSettings()
 	JsonNode urls = settings["launcher"]["repositoryURL"];
 
 	ui->plainTextEditRepos->clear();
-	for (auto entry : urls.Vector())
+	for(auto entry : urls.Vector())
 		ui->plainTextEditRepos->appendPlainText(QString::fromUtf8(entry.String().c_str()));
 
 	ui->lineEditUserDataDir->setText(pathToQString(VCMIDirs::get().userDataPath()));
@@ -92,14 +92,13 @@ void CSettingsView::loadSettings()
 
 	std::string encoding = settings["general"]["encoding"].String();
 	size_t encodingIndex = boost::range::find(knownEncodingsList, encoding) - knownEncodingsList;
-	if (encodingIndex < ui->comboBoxEncoding->count())
+	if(encodingIndex < ui->comboBoxEncoding->count())
 		ui->comboBoxEncoding->setCurrentIndex(encodingIndex);
 	ui->comboBoxAutoSave->setCurrentIndex(settings["general"]["saveFrequency"].Integer() > 0 ? 1 : 0);
 }
 
-CSettingsView::CSettingsView(QWidget *parent) :
-    QWidget(parent),
-    ui(new Ui::CSettingsView)
+CSettingsView::CSettingsView(QWidget * parent)
+	: QWidget(parent), ui(new Ui::CSettingsView)
 {
 	ui->setupUi(this);
 
@@ -112,7 +111,7 @@ CSettingsView::~CSettingsView()
 }
 
 
-void CSettingsView::on_comboBoxResolution_currentIndexChanged(const QString &arg1)
+void CSettingsView::on_comboBoxResolution_currentIndexChanged(const QString & arg1)
 {
 	QStringList list = arg1.split("x");
 
@@ -145,7 +144,7 @@ void CSettingsView::on_comboBoxDisplayIndex_currentIndexChanged(int index)
 	node["displayIndex"].Float() = index;
 }
 
-void CSettingsView::on_comboBoxPlayerAI_currentIndexChanged(const QString &arg1)
+void CSettingsView::on_comboBoxPlayerAI_currentIndexChanged(const QString & arg1)
 {
 	Settings node = settings.write["server"]["playerAI"];
 	node->String() = arg1.toUtf8().data();
@@ -157,7 +156,7 @@ void CSettingsView::on_comboBoxFriendlyAI_currentIndexChanged(const QString & ar
 	node->String() = arg1.toUtf8().data();
 }
 
-void CSettingsView::on_comboBoxNeutralAI_currentIndexChanged(const QString &arg1)
+void CSettingsView::on_comboBoxNeutralAI_currentIndexChanged(const QString & arg1)
 {
 	Settings node = settings.write["server"]["neutralAI"];
 	node->String() = arg1.toUtf8().data();
@@ -182,9 +181,9 @@ void CSettingsView::on_plainTextEditRepos_textChanged()
 	QStringList list = ui->plainTextEditRepos->toPlainText().split('\n');
 
 	node->Vector().clear();
-	for (QString line : list)
+	for(QString line : list)
 	{
-		if (line.trimmed().size() > 0)
+		if(line.trimmed().size() > 0)
 		{
 			JsonNode entry;
 			entry.String() = line.trimmed().toUtf8().data();

+ 11 - 9
launcher/settingsView/csettingsview_moc.h

@@ -10,15 +10,17 @@
 #pragma once
 #include "../StdInc.h"
 
-namespace Ui {
-	class CSettingsView;
+namespace Ui
+{
+class CSettingsView;
 }
 
 class CSettingsView : public QWidget
 {
 	Q_OBJECT
+
 public:
-	explicit CSettingsView(QWidget *parent = 0);
+	explicit CSettingsView(QWidget * parent = 0);
 	~CSettingsView();
 
 	void loadSettings();
@@ -27,17 +29,17 @@ public:
 private slots:
 	void on_checkBoxFullScreen_stateChanged(int state);
 
-	void on_comboBoxResolution_currentIndexChanged(const QString &arg1);
+	void on_comboBoxResolution_currentIndexChanged(const QString & arg1);
 
 	void on_comboBoxFullScreen_currentIndexChanged(int index);
 
-	void on_comboBoxPlayerAI_currentIndexChanged(const QString &arg1);
+	void on_comboBoxPlayerAI_currentIndexChanged(const QString & arg1);
 
-	void on_comboBoxFriendlyAI_currentIndexChanged(const QString &arg1);
+	void on_comboBoxFriendlyAI_currentIndexChanged(const QString & arg1);
 
-	void on_comboBoxNeutralAI_currentIndexChanged(const QString &arg1);
+	void on_comboBoxNeutralAI_currentIndexChanged(const QString & arg1);
 
-	void on_comboBoxEnemyAI_currentIndexChanged(const QString &arg1);
+	void on_comboBoxEnemyAI_currentIndexChanged(const QString & arg1);
 
 	void on_spinBoxNetworkPort_valueChanged(int arg1);
 
@@ -62,5 +64,5 @@ private slots:
 	void on_comboBoxAutoSave_currentIndexChanged(int index);
 
 private:
-	Ui::CSettingsView *ui;
+	Ui::CSettingsView * ui;
 };