configuration: Use IDs to sort holds
This commit is contained in:
parent
f7948b7b64
commit
9e3c94bb3d
|
@ -37,7 +37,7 @@ void ConfigureGeneral::SetConfiguration() {
|
||||||
const bool runtime_lock = !system.IsPoweredOn();
|
const bool runtime_lock = !system.IsPoweredOn();
|
||||||
QLayout& layout = *ui->general_widget->layout();
|
QLayout& layout = *ui->general_widget->layout();
|
||||||
|
|
||||||
std::map<std::string, QWidget*> hold{};
|
std::map<u32, QWidget*> hold{};
|
||||||
|
|
||||||
for (const auto setting :
|
for (const auto setting :
|
||||||
UISettings::values.linkage.by_category[Settings::Category::UiGeneral]) {
|
UISettings::values.linkage.by_category[Settings::Category::UiGeneral]) {
|
||||||
|
@ -49,10 +49,10 @@ void ConfigureGeneral::SetConfiguration() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
hold.insert({setting->GetLabel(), widget});
|
hold.emplace(setting->Id(), widget);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto& [label, widget] : hold) {
|
for (const auto& [id, widget] : hold) {
|
||||||
layout.addWidget(widget);
|
layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -226,12 +226,10 @@ void ConfigureGraphics::Setup() {
|
||||||
|
|
||||||
QLayout& graphics_layout = *ui->graphics_widget->layout();
|
QLayout& graphics_layout = *ui->graphics_widget->layout();
|
||||||
|
|
||||||
std::map<bool, std::map<std::string, QWidget*>> hold_graphics;
|
std::map<u32, QWidget*> hold_graphics;
|
||||||
std::forward_list<QWidget*> hold_api;
|
std::forward_list<QWidget*> hold_api;
|
||||||
|
|
||||||
for (const auto setting : Settings::values.linkage.by_category[Settings::Category::Renderer]) {
|
for (const auto setting : Settings::values.linkage.by_category[Settings::Category::Renderer]) {
|
||||||
const auto& setting_label = setting->GetLabel();
|
|
||||||
|
|
||||||
ConfigurationShared::Widget* widget = [&]() {
|
ConfigurationShared::Widget* widget = [&]() {
|
||||||
if (setting->Id() == Settings::values.vulkan_device.Id() ||
|
if (setting->Id() == Settings::values.vulkan_device.Id() ||
|
||||||
setting->Id() == Settings::values.shader_backend.Id() ||
|
setting->Id() == Settings::values.shader_backend.Id() ||
|
||||||
|
@ -284,17 +282,15 @@ void ConfigureGraphics::Setup() {
|
||||||
shader_backend_widget = widget;
|
shader_backend_widget = widget;
|
||||||
} else if (setting->Id() == Settings::values.vsync_mode.Id()) {
|
} else if (setting->Id() == Settings::values.vsync_mode.Id()) {
|
||||||
vsync_mode_combobox = widget->combobox;
|
vsync_mode_combobox = widget->combobox;
|
||||||
hold_graphics[setting->IsEnum()][setting_label] = widget;
|
hold_graphics.emplace(setting->Id(), widget);
|
||||||
} else {
|
} else {
|
||||||
hold_graphics[setting->IsEnum()][setting_label] = widget;
|
hold_graphics.emplace(setting->Id(), widget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto& [_, settings] : hold_graphics) {
|
for (const auto& [id, widget] : hold_graphics) {
|
||||||
for (const auto& [label, widget] : settings) {
|
|
||||||
graphics_layout.addWidget(widget);
|
graphics_layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
for (auto widget : hold_api) {
|
for (auto widget : hold_api) {
|
||||||
api_grid_layout->addWidget(widget);
|
api_grid_layout->addWidget(widget);
|
||||||
|
|
|
@ -31,7 +31,7 @@ ConfigureGraphicsAdvanced::~ConfigureGraphicsAdvanced() = default;
|
||||||
void ConfigureGraphicsAdvanced::SetConfiguration() {
|
void ConfigureGraphicsAdvanced::SetConfiguration() {
|
||||||
const bool runtime_lock = !system.IsPoweredOn();
|
const bool runtime_lock = !system.IsPoweredOn();
|
||||||
auto& layout = *ui->populate_target->layout();
|
auto& layout = *ui->populate_target->layout();
|
||||||
std::map<std::string, QWidget*> hold{}; // A map will sort the data for us
|
std::map<u32, QWidget*> hold{}; // A map will sort the data for us
|
||||||
|
|
||||||
for (auto setting :
|
for (auto setting :
|
||||||
Settings::values.linkage.by_category[Settings::Category::RendererAdvanced]) {
|
Settings::values.linkage.by_category[Settings::Category::RendererAdvanced]) {
|
||||||
|
@ -43,17 +43,13 @@ void ConfigureGraphicsAdvanced::SetConfiguration() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!setting->IsEnum()) {
|
hold.emplace(setting->Id(), widget);
|
||||||
hold.emplace(setting->GetLabel(), widget);
|
|
||||||
} else {
|
|
||||||
layout.addWidget(widget);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (setting->Id() == Settings::values.enable_compute_pipelines.Id()) {
|
if (setting->Id() == Settings::values.enable_compute_pipelines.Id()) {
|
||||||
checkbox_enable_compute_pipelines = widget;
|
checkbox_enable_compute_pipelines = widget;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (const auto& [label, widget] : hold) {
|
for (const auto& [id, widget] : hold) {
|
||||||
layout.addWidget(widget);
|
layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -109,8 +109,8 @@ void ConfigureSystem::Setup() {
|
||||||
auto& core_layout = *ui->core_widget->layout();
|
auto& core_layout = *ui->core_widget->layout();
|
||||||
auto& system_layout = *ui->system_widget->layout();
|
auto& system_layout = *ui->system_widget->layout();
|
||||||
|
|
||||||
std::map<std::string, QWidget*> core_hold{};
|
std::map<u32, QWidget*> core_hold{};
|
||||||
std::map<bool, std::map<std::string, QWidget*>> system_hold{};
|
std::map<u32, QWidget*> system_hold{};
|
||||||
|
|
||||||
std::forward_list<Settings::BasicSetting*> settings;
|
std::forward_list<Settings::BasicSetting*> settings;
|
||||||
auto push = [&settings](std::forward_list<Settings::BasicSetting*>& list) {
|
auto push = [&settings](std::forward_list<Settings::BasicSetting*>& list) {
|
||||||
|
@ -165,10 +165,10 @@ void ConfigureSystem::Setup() {
|
||||||
|
|
||||||
switch (setting->Category()) {
|
switch (setting->Category()) {
|
||||||
case Settings::Category::Core:
|
case Settings::Category::Core:
|
||||||
core_hold[setting->GetLabel()] = widget;
|
core_hold.emplace(setting->Id(), widget);
|
||||||
break;
|
break;
|
||||||
case Settings::Category::System:
|
case Settings::Category::System:
|
||||||
system_hold[setting->IsEnum()].insert(std::pair{setting->GetLabel(), widget});
|
system_hold.emplace(setting->Id(), widget);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
delete widget;
|
delete widget;
|
||||||
|
@ -177,10 +177,7 @@ void ConfigureSystem::Setup() {
|
||||||
for (const auto& [label, widget] : core_hold) {
|
for (const auto& [label, widget] : core_hold) {
|
||||||
core_layout.addWidget(widget);
|
core_layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
for (const auto& [label, widget] : system_hold[true]) {
|
for (const auto& [id, widget] : system_hold) {
|
||||||
system_layout.addWidget(widget);
|
|
||||||
}
|
|
||||||
for (const auto& [label, widget] : system_hold[false]) {
|
|
||||||
system_layout.addWidget(widget);
|
system_layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Reference in New Issue