some further cleanup, following some Clang-Tidy suggestions and CodeQL

Signed-off-by: Tayou <tayou@gmx.net>
This commit is contained in:
Tayou 2023-05-19 21:21:15 +02:00 committed by Tayou
parent 8a6c0e7314
commit e90706461c
No known key found for this signature in database
GPG Key ID: 02CA43C1CB6E9887
3 changed files with 32 additions and 38 deletions

View File

@ -41,11 +41,6 @@
#include "FileSystem.h" #include "FileSystem.h"
#include "GameOptions.h" #include "GameOptions.h"
static Qt::CheckState boolToState(bool b)
{
return b ? Qt::Checked : Qt::Unchecked;
};
namespace { namespace {
bool load(const QString& path, bool load(const QString& path,
std::vector<GameOptionItem>& contents, std::vector<GameOptionItem>& contents,
@ -91,32 +86,26 @@ bool load(const QString& path,
bool isFloat = false; bool isFloat = false;
item.intValue = item.value.toInt(&isInt); item.intValue = item.value.toInt(&isInt);
item.floatValue = item.value.toFloat(&isFloat); item.floatValue = item.value.toFloat(&isFloat);
if (isInt) { item.boolValue = item.value == "true";
item.type = OptionType::Int; item.type = isInt ? OptionType::Int : isFloat ? OptionType::Float : OptionType::Bool;
// qDebug() << "The value" << value << "is a int"; if (item.value.startsWith("[") && item.value.endsWith("]")) {
} else if (isFloat) {
item.type = OptionType::Float;
// qDebug() << "The value" << value << "is a float";
} else if (item.value == "true" || item.value == "false") {
item.boolValue = item.value == "true";
item.type = OptionType::Bool;
qDebug() << "The value" << item.value << "is a bool";
} else if (item.value.endsWith("]") && item.value.startsWith("[")) {
qDebug() << "The value" << item.value << "is an array"; qDebug() << "The value" << item.value << "is an array";
for (const QString& part : item.value.mid(1, item.value.size() - 2).split(",")) { for (const QString& part : item.value.mid(1, item.value.size() - 2).split(",")) {
GameOptionChildItem child{ part, static_cast<int>(contents.size()) }; GameOptionChildItem child{ part, static_cast<int>(contents.size()) };
qDebug() << "Array has entry" << part; qDebug() << "Array has entry" << part;
item.children.append(child); item.children.append(child);
} }
item.type = OptionType::Array;
} else if (item.key.startsWith("key_")) { } else if (item.key.startsWith("key_")) {
item.type = OptionType::KeyBind; item.type = OptionType::KeyBind;
} else { } else {
// this is really ugly, please suggest how to truncate the start and end // This removes the leading and ending " from the string to display it more cleanly.
item.value = item.value.remove(item.value.length()-1, 1).remove(0, 1); item.value = item.value.mid(1, item.value.length()-2);
item.type = OptionType::String;
} }
// adds reference to known option from gameOptionsSchema if avaiable to get display name and other metadata // adds reference to known option from gameOptionsSchema if available to get display name and other metadata
item.knownOption = knownOptions->find(item.key) != knownOptions->end() ? knownOptions->find(item.key).value() : nullptr; item.knownOption = knownOptions->value(item.key, nullptr);
contents.emplace_back(item); contents.emplace_back(item);
} }
qDebug() << "Loaded" << path << "with version:" << version; qDebug() << "Loaded" << path << "with version:" << version;
@ -171,6 +160,7 @@ bool GameOptions::setData(const QModelIndex& index, const QVariant& value, int r
auto column = (Column)index.column(); auto column = (Column)index.column();
if (column == Column::Value) { if (column == Column::Value) {
switch (contents[row].type) { switch (contents[row].type) {
case OptionType::Array:
case OptionType::String: { case OptionType::String: {
contents[row].value = value.toString(); contents[row].value = value.toString();
return true; return true;
@ -203,13 +193,13 @@ Qt::ItemFlags GameOptions::flags(const QModelIndex& index) const
QVariant GameOptions::data(const QModelIndex& index, int role) const QVariant GameOptions::data(const QModelIndex& index, int role) const
{ {
if (!index.isValid()) if (!index.isValid())
return QVariant(); return {};
int row = index.row(); int row = index.row();
Column column = (Column)index.column(); Column column = (Column)index.column();
if (row < 0 || row >= int(contents.size())) if (row < 0 || row >= int(contents.size()))
return QVariant(); return {};
if (index.parent().isValid()) { if (index.parent().isValid()) {
switch (role) { switch (role) {
@ -218,11 +208,11 @@ QVariant GameOptions::data(const QModelIndex& index, int role) const
GameOptionChildItem* item = static_cast<GameOptionChildItem*>(index.internalPointer()); GameOptionChildItem* item = static_cast<GameOptionChildItem*>(index.internalPointer());
return item->value; return item->value;
} else { } else {
return QVariant(); return {};
} }
} }
default: { default: {
return QVariant(); return {};
} }
} }
} }
@ -237,29 +227,29 @@ QVariant GameOptions::data(const QModelIndex& index, int role) const
if (contents[row].knownOption != nullptr) { if (contents[row].knownOption != nullptr) {
return contents[row].knownOption->description; return contents[row].knownOption->description;
} else { } else {
return QVariant(); return {};
} }
} }
default: { default: {
return QVariant(); return {};
} }
} }
} }
default: { default: {
return QVariant(); return {};
} }
} }
return QVariant(); return {};
} }
QModelIndex GameOptions::index(int row, int column, const QModelIndex& parent) const QModelIndex GameOptions::index(int row, int column, const QModelIndex& parent) const
{ {
if (!hasIndex(row, column, parent)) if (!hasIndex(row, column, parent))
return QModelIndex(); return {};
if (parent.isValid()) { if (parent.isValid()) {
if (parent.parent().isValid()) if (parent.parent().isValid())
return QModelIndex(); return {};
GameOptionItem* item = static_cast<GameOptionItem*>(parent.internalPointer()); GameOptionItem* item = static_cast<GameOptionItem*>(parent.internalPointer());
return createIndex(row, column, &item->children[row]); return createIndex(row, column, &item->children[row]);
@ -271,14 +261,14 @@ QModelIndex GameOptions::index(int row, int column, const QModelIndex& parent) c
QModelIndex GameOptions::parent(const QModelIndex& index) const QModelIndex GameOptions::parent(const QModelIndex& index) const
{ {
if (!index.isValid()) if (!index.isValid())
return QModelIndex(); return {};
const void* childItem = index.internalPointer(); const void* childItem = index.internalPointer();
// Determine where childItem points to // Determine where childItem points to
if (childItem >= &contents[0] && childItem <= &contents.back()) { if (childItem >= &contents[0] && childItem <= &contents.back()) {
// Parent is root/contents // Parent is root/contents
return QModelIndex(); return {};
} else { } else {
GameOptionChildItem* child = static_cast<GameOptionChildItem*>(index.internalPointer()); GameOptionChildItem* child = static_cast<GameOptionChildItem*>(index.internalPointer());
return createIndex(child->parentRow, 0, reinterpret_cast<quintptr>(&contents[child->parentRow])); return createIndex(child->parentRow, 0, reinterpret_cast<quintptr>(&contents[child->parentRow]));
@ -298,7 +288,7 @@ int GameOptions::rowCount(const QModelIndex& parent) const
if (parent.parent().isValid()) if (parent.parent().isValid())
return 0; return 0;
GameOptionItem* item = static_cast<GameOptionItem*>(parent.internalPointer()); auto* item = static_cast<GameOptionItem*>(parent.internalPointer());
return item->children.count(); return item->children.count();
} }
} }

View File

@ -23,7 +23,7 @@
#include <memory> #include <memory>
#include <utility> #include <utility>
enum class OptionType { String, Int, Float, Bool, KeyBind }; enum class OptionType { String, Int, Float, Bool, KeyBind, Array };
template <class T> struct Range { template <class T> struct Range {
T min, max; T min, max;
@ -38,7 +38,6 @@ union OptionValue {
float floatValue; float floatValue;
int intValue; int intValue;
bool boolValue; bool boolValue;
// QString stringValue;
}; };
class GameOption { class GameOption {
@ -91,13 +90,16 @@ class GameOption {
OptionType type; OptionType type;
bool readOnly = false; bool readOnly = false;
QList<QString> validValues; // if empty, treat as text input QList<QString> validValues; // if empty, treat as text input
//int introducedVersion;
//int removedVersion; // Not sure if versioning these makes sense, it would be a lot of effort to keep track of as new minecraft versions are made.
// not even considering the large bulk of old minecraft versions, of which some data may not even be documented yet.
// int introducedVersion; // format version number, where this options key got introduced
// int removedVersion; // format version number, where this options key got removed - -1 if it is still present in the latest version
int getDefaultInt() const { return defaultValue.intValue; }; int getDefaultInt() const { return defaultValue.intValue; };
bool getDefaultBool() const { return defaultValue.boolValue; }; bool getDefaultBool() const { return defaultValue.boolValue; };
float getDefaultFloat() const { return defaultValue.floatValue; }; float getDefaultFloat() const { return defaultValue.floatValue; };
QString getDefaultString();; QString getDefaultString();
Range<int> getIntRange() const { return range.intRange; }; Range<int> getIntRange() const { return range.intRange; };
Range<float> getFloatRange() const { return range.floatRange; }; Range<float> getFloatRange() const { return range.floatRange; };

View File

@ -38,6 +38,7 @@ GameOptionWidgetKeyBind::~GameOptionWidgetKeyBind()
} }
void GameOptionWidgetKeyBind::setEditorData(GameOptionItem optionItem) { void GameOptionWidgetKeyBind::setEditorData(GameOptionItem optionItem) {
// TODO implement this, *keybindingOptions is needed
/*for (auto& keyBinding : *keybindingOptions) { /*for (auto& keyBinding : *keybindingOptions) {
// this could become a std::find_if eventually, if someone wants to bother making it that. // this could become a std::find_if eventually, if someone wants to bother making it that.
if (keyBinding->minecraftKeyCode == contents[row].knownOption->getDefaultString()) { if (keyBinding->minecraftKeyCode == contents[row].knownOption->getDefaultString()) {
@ -50,6 +51,7 @@ void GameOptionWidgetKeyBind::setEditorData(GameOptionItem optionItem) {
} }
void GameOptionWidgetKeyBind::saveEditorData(GameOptionItem optionItem) { void GameOptionWidgetKeyBind::saveEditorData(GameOptionItem optionItem) {
QString minecraftKeyCode; QString minecraftKeyCode;
// TODO implement this, *keybindingOptions is needed
/*for (auto& keyBinding : *keybindingOptions) { /*for (auto& keyBinding : *keybindingOptions) {
// this could become a std::find_if eventually, if someone wants to bother making it that. // this could become a std::find_if eventually, if someone wants to bother making it that.
if (keyBinding->qtKeyCode.keyboardKey == ui->keySequenceEdit->keySequence()[0].key() || if (keyBinding->qtKeyCode.keyboardKey == ui->keySequenceEdit->keySequence()[0].key() ||