as a test, convert EmuSettingsDialog to the new config shito

This commit is contained in:
Arisotura 2024-04-18 16:52:18 +02:00
parent 92d1614b45
commit f93937e88b
2 changed files with 104 additions and 141 deletions

View File

@ -1113,7 +1113,7 @@ printf("save\n");
//toml::serializer<std::string> vorp(RootTable); //toml::serializer<std::string> vorp(RootTable);
//toml::serializer<toml::string> zarp; //toml::serializer<toml::string> zarp;
std::cout << RootTable; //std::cout << RootTable;
printf("blarg\n"); printf("blarg\n");
std::ofstream file; std::ofstream file;
file.open(cfgpath, std::ofstream::out | std::ofstream::trunc); file.open(cfgpath, std::ofstream::out | std::ofstream::trunc);

View File

@ -57,31 +57,34 @@ EmuSettingsDialog::EmuSettingsDialog(QWidget* parent) : QDialog(parent), ui(new
ui->setupUi(this); ui->setupUi(this);
setAttribute(Qt::WA_DeleteOnClose); setAttribute(Qt::WA_DeleteOnClose);
ui->chkExternalBIOS->setChecked(Config::ExternalBIOSEnable); Config::Table cfg = Config::GetGlobalTable();
ui->txtBIOS9Path->setText(QString::fromStdString(Config::BIOS9Path)); Config::Table instcfg = Config::GetLocalTable(Platform::InstanceID());
ui->txtBIOS7Path->setText(QString::fromStdString(Config::BIOS7Path));
ui->txtFirmwarePath->setText(QString::fromStdString(Config::FirmwarePath));
ui->txtDSiBIOS9Path->setText(QString::fromStdString(Config::DSiBIOS9Path)); ui->chkExternalBIOS->setChecked(cfg.GetBool("Emu.ExternalBIOSEnable"));
ui->txtDSiBIOS7Path->setText(QString::fromStdString(Config::DSiBIOS7Path)); ui->txtBIOS9Path->setText(cfg.GetQString("DS.BIOS9Path"));
ui->txtDSiFirmwarePath->setText(QString::fromStdString(Config::DSiFirmwarePath)); ui->txtBIOS7Path->setText(cfg.GetQString("DS.BIOS7Path"));
ui->txtDSiNANDPath->setText(QString::fromStdString(Config::DSiNANDPath)); ui->txtFirmwarePath->setText(cfg.GetQString("DS.FirmwarePath"));
ui->txtDSiBIOS9Path->setText(cfg.GetQString("DSi.BIOS9Path"));
ui->txtDSiBIOS7Path->setText(cfg.GetQString("DSi.BIOS7Path"));
ui->txtDSiFirmwarePath->setText(cfg.GetQString("DSi.FirmwarePath"));
ui->txtDSiNANDPath->setText(cfg.GetQString("DSi.NANDPath"));
ui->cbxConsoleType->addItem("DS"); ui->cbxConsoleType->addItem("DS");
ui->cbxConsoleType->addItem("DSi (experimental)"); ui->cbxConsoleType->addItem("DSi (experimental)");
ui->cbxConsoleType->setCurrentIndex(Config::ConsoleType); ui->cbxConsoleType->setCurrentIndex(cfg.GetInt("Emu.ConsoleType"));
ui->chkDirectBoot->setChecked(Config::DirectBoot); ui->chkDirectBoot->setChecked(cfg.GetBool("Emu.DirectBoot"));
#ifdef JIT_ENABLED #ifdef JIT_ENABLED
ui->chkEnableJIT->setChecked(Config::JIT_Enable); ui->chkEnableJIT->setChecked(cfg.GetBool("JIT.Enable"));
ui->chkJITBranchOptimisations->setChecked(Config::JIT_BranchOptimisations); ui->chkJITBranchOptimisations->setChecked(cfg.GetBool("JIT.BranchOptimisations"));
ui->chkJITLiteralOptimisations->setChecked(Config::JIT_LiteralOptimisations); ui->chkJITLiteralOptimisations->setChecked(cfg.GetBool("JIT.LiteralOptimisations"));
ui->chkJITFastMemory->setChecked(Config::JIT_FastMemory); ui->chkJITFastMemory->setChecked(cfg.GetBool("JIT.FastMemory"));
#ifdef __APPLE__ #ifdef __APPLE__
ui->chkJITFastMemory->setDisabled(true); ui->chkJITFastMemory->setDisabled(true);
#endif #endif
ui->spnJITMaximumBlockSize->setValue(Config::JIT_MaxBlockSize); ui->spnJITMaximumBlockSize->setValue(cfg.GetInt("JIT.MaxBlockSize"));
#else #else
ui->chkEnableJIT->setDisabled(true); ui->chkEnableJIT->setDisabled(true);
ui->chkJITBranchOptimisations->setDisabled(true); ui->chkJITBranchOptimisations->setDisabled(true);
@ -91,11 +94,11 @@ EmuSettingsDialog::EmuSettingsDialog(QWidget* parent) : QDialog(parent), ui(new
#endif #endif
#ifdef GDBSTUB_ENABLED #ifdef GDBSTUB_ENABLED
ui->cbGdbEnabled->setChecked(Config::GdbEnabled); ui->cbGdbEnabled->setChecked(cfg.GetBool("Gdb.Enabled"));
ui->intGdbPortA7->setValue(Config::GdbPortARM7); ui->intGdbPortA7->setValue(instcfg.GetInt("Gdb.ARM7.Port"));
ui->intGdbPortA9->setValue(Config::GdbPortARM9); ui->intGdbPortA9->setValue(instcfg.GetInt("Gdb.ARM9.Port"));
ui->cbGdbBOSA7->setChecked(Config::GdbARM7BreakOnStartup); ui->cbGdbBOSA7->setChecked(instcfg.GetBool("Gdb.ARM7.BreakOnStartup"));
ui->cbGdbBOSA9->setChecked(Config::GdbARM9BreakOnStartup); ui->cbGdbBOSA9->setChecked(instcfg.GetBool("Gdb.ARM9.BreakOnStartup"));
#else #else
ui->cbGdbEnabled->setDisabled(true); ui->cbGdbEnabled->setDisabled(true);
ui->intGdbPortA7->setDisabled(true); ui->intGdbPortA7->setDisabled(true);
@ -131,23 +134,34 @@ EmuSettingsDialog::EmuSettingsDialog(QWidget* parent) : QDialog(parent), ui(new
ui->cbxDSiSDSize->addItem(sizelbl); ui->cbxDSiSDSize->addItem(sizelbl);
} }
ui->cbDLDIEnable->setChecked(Config::DLDIEnable); ui->cbDLDIEnable->setChecked(cfg.GetBool("DLDI.Enable"));
ui->txtDLDISDPath->setText(QString::fromStdString(Config::DLDISDPath)); ui->txtDLDISDPath->setText(cfg.GetQString("DLDI.ImagePath"));
ui->cbxDLDISize->setCurrentIndex(Config::DLDISize); ui->cbxDLDISize->setCurrentIndex(cfg.GetInt("DLDI.ImageSize"));
ui->cbDLDIReadOnly->setChecked(Config::DLDIReadOnly); ui->cbDLDIReadOnly->setChecked(cfg.GetBool("DLDI.ReadOnly"));
ui->cbDLDIFolder->setChecked(Config::DLDIFolderSync); ui->cbDLDIFolder->setChecked(cfg.GetBool("DLDI.FolderSync"));
ui->txtDLDIFolder->setText(QString::fromStdString(Config::DLDIFolderPath)); ui->txtDLDIFolder->setText(cfg.GetQString("DLDI.FolderPath"));
on_cbDLDIEnable_toggled(); on_cbDLDIEnable_toggled();
ui->cbDSiFullBIOSBoot->setChecked(Config::DSiFullBIOSBoot); ui->cbDSiFullBIOSBoot->setChecked(cfg.GetBool("DSi.FullBIOSBoot"));
ui->cbDSiSDEnable->setChecked(Config::DSiSDEnable); ui->cbDSiSDEnable->setChecked(cfg.GetBool("DSi.SD.Enable"));
ui->txtDSiSDPath->setText(QString::fromStdString(Config::DSiSDPath)); ui->txtDSiSDPath->setText(cfg.GetQString("DSi.SD.ImagePath"));
ui->cbxDSiSDSize->setCurrentIndex(Config::DSiSDSize); ui->cbxDSiSDSize->setCurrentIndex(cfg.GetInt("DSi.SD.ImageSize"));
ui->cbDSiSDReadOnly->setChecked(Config::DSiSDReadOnly); ui->cbDSiSDReadOnly->setChecked(cfg.GetBool("DSi.SD.ReadOnly"));
ui->cbDSiSDFolder->setChecked(Config::DSiSDFolderSync); ui->cbDSiSDFolder->setChecked(cfg.GetBool("DSi.SD.FolderSync"));
ui->txtDSiSDFolder->setText(QString::fromStdString(Config::DSiSDFolderPath)); ui->txtDSiSDFolder->setText(cfg.GetQString("DSi.SD.FolderPath"));
on_cbDSiSDEnable_toggled(); on_cbDSiSDEnable_toggled();
#define SET_ORIGVAL(type, val) \
for (type* w : findChildren<type*>(nullptr)) \
w->setProperty("user_originalValue", w->val());
SET_ORIGVAL(QLineEdit, text);
SET_ORIGVAL(QSpinBox, value);
SET_ORIGVAL(QComboBox, currentIndex);
SET_ORIGVAL(QCheckBox, isChecked);
#undef SET_ORIGVAL
} }
EmuSettingsDialog::~EmuSettingsDialog() EmuSettingsDialog::~EmuSettingsDialog()
@ -155,6 +169,7 @@ EmuSettingsDialog::~EmuSettingsDialog()
delete ui; delete ui;
} }
void EmuSettingsDialog::verifyFirmware() void EmuSettingsDialog::verifyFirmware()
{ {
// verify the firmware // verify the firmware
@ -203,85 +218,30 @@ void EmuSettingsDialog::done(int r)
if (r == QDialog::Accepted) if (r == QDialog::Accepted)
{ {
verifyFirmware(); bool modified = false;
int consoleType = ui->cbxConsoleType->currentIndex(); #define CHECK_ORIGVAL(type, val) \
bool directBoot = ui->chkDirectBoot->isChecked(); if (!modified) for (type* w : findChildren<type*>(nullptr)) \
{ \
QVariant v = w->val(); \
if (v != w->property("user_originalValue")) \
{ \
modified = true; \
break; \
}\
}
bool jitEnable = ui->chkEnableJIT->isChecked(); CHECK_ORIGVAL(QLineEdit, text);
int jitMaxBlockSize = ui->spnJITMaximumBlockSize->value(); CHECK_ORIGVAL(QSpinBox, value);
bool jitBranchOptimisations = ui->chkJITBranchOptimisations->isChecked(); CHECK_ORIGVAL(QComboBox, currentIndex);
bool jitLiteralOptimisations = ui->chkJITLiteralOptimisations->isChecked(); CHECK_ORIGVAL(QCheckBox, isChecked);
bool jitFastMemory = ui->chkJITFastMemory->isChecked();
bool externalBiosEnable = ui->chkExternalBIOS->isChecked(); #undef CHECK_ORIGVAL
std::string bios9Path = ui->txtBIOS9Path->text().toStdString();
std::string bios7Path = ui->txtBIOS7Path->text().toStdString();
std::string firmwarePath = ui->txtFirmwarePath->text().toStdString();
bool dldiEnable = ui->cbDLDIEnable->isChecked(); if (QVariant(ui->txtFirmwarePath->text()) != ui->txtFirmwarePath->property("user_originalValue"))
std::string dldiSDPath = ui->txtDLDISDPath->text().toStdString(); verifyFirmware();
int dldiSize = ui->cbxDLDISize->currentIndex();
bool dldiReadOnly = ui->cbDLDIReadOnly->isChecked();
bool dldiFolderSync = ui->cbDLDIFolder->isChecked();
std::string dldiFolderPath = ui->txtDLDIFolder->text().toStdString();
std::string dsiBios9Path = ui->txtDSiBIOS9Path->text().toStdString(); if (modified)
std::string dsiBios7Path = ui->txtDSiBIOS7Path->text().toStdString();
std::string dsiFirmwarePath = ui->txtDSiFirmwarePath->text().toStdString();
std::string dsiNANDPath = ui->txtDSiNANDPath->text().toStdString();
bool dsiFullBiosBoot = ui->cbDSiFullBIOSBoot->isChecked();
bool dsiSDEnable = ui->cbDSiSDEnable->isChecked();
std::string dsiSDPath = ui->txtDSiSDPath->text().toStdString();
int dsiSDSize = ui->cbxDSiSDSize->currentIndex();
bool dsiSDReadOnly = ui->cbDSiSDReadOnly->isChecked();
bool dsiSDFolderSync = ui->cbDSiSDFolder->isChecked();
std::string dsiSDFolderPath = ui->txtDSiSDFolder->text().toStdString();
bool gdbEnabled = ui->cbGdbEnabled->isChecked();
int gdbPortA7 = ui->intGdbPortA7->value();
int gdbPortA9 = ui->intGdbPortA9->value();
bool gdbBOSA7 = ui->cbGdbBOSA7->isChecked();
bool gdbBOSA9 = ui->cbGdbBOSA9->isChecked();
if (consoleType != Config::ConsoleType
|| directBoot != Config::DirectBoot
#ifdef JIT_ENABLED
|| jitEnable != Config::JIT_Enable
|| jitMaxBlockSize != Config::JIT_MaxBlockSize
|| jitBranchOptimisations != Config::JIT_BranchOptimisations
|| jitLiteralOptimisations != Config::JIT_LiteralOptimisations
|| jitFastMemory != Config::JIT_FastMemory
#endif
#ifdef GDBSTUB_ENABLED
|| gdbEnabled != Config::GdbEnabled
|| gdbPortA7 != Config::GdbPortARM7
|| gdbPortA9 != Config::GdbPortARM9
|| gdbBOSA7 != Config::GdbARM7BreakOnStartup
|| gdbBOSA9 != Config::GdbARM9BreakOnStartup
#endif
|| externalBiosEnable != Config::ExternalBIOSEnable
|| bios9Path != Config::BIOS9Path
|| bios7Path != Config::BIOS7Path
|| firmwarePath != Config::FirmwarePath
|| dldiEnable != Config::DLDIEnable
|| dldiSDPath != Config::DLDISDPath
|| dldiSize != Config::DLDISize
|| dldiReadOnly != Config::DLDIReadOnly
|| dldiFolderSync != Config::DLDIFolderSync
|| dldiFolderPath != Config::DLDIFolderPath
|| dsiBios9Path != Config::DSiBIOS9Path
|| dsiBios7Path != Config::DSiBIOS7Path
|| dsiFirmwarePath != Config::DSiFirmwarePath
|| dsiNANDPath != Config::DSiNANDPath
|| dsiFullBiosBoot != Config::DSiFullBIOSBoot
|| dsiSDEnable != Config::DSiSDEnable
|| dsiSDPath != Config::DSiSDPath
|| dsiSDSize != Config::DSiSDSize
|| dsiSDReadOnly != Config::DSiSDReadOnly
|| dsiSDFolderSync != Config::DSiSDFolderSync
|| dsiSDFolderPath != Config::DSiSDFolderPath)
{ {
if (RunningSomething if (RunningSomething
&& QMessageBox::warning(this, "Reset necessary to apply changes", && QMessageBox::warning(this, "Reset necessary to apply changes",
@ -289,48 +249,51 @@ void EmuSettingsDialog::done(int r)
QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok) QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok)
return; return;
Config::ExternalBIOSEnable = externalBiosEnable; Config::Table cfg = Config::GetGlobalTable();
Config::BIOS9Path = bios9Path; Config::Table instcfg = Config::GetLocalTable(Platform::InstanceID());
Config::BIOS7Path = bios7Path;
Config::FirmwarePath = firmwarePath;
Config::DLDIEnable = dldiEnable; cfg.SetBool("Emu.ExternalBIOSEnable", ui->chkExternalBIOS->isChecked());
Config::DLDISDPath = dldiSDPath; cfg.SetQString("DS.BIOS9Path", ui->txtBIOS9Path->text());
Config::DLDISize = dldiSize; cfg.SetQString("DS.BIOS7Path", ui->txtBIOS7Path->text());
Config::DLDIReadOnly = dldiReadOnly; cfg.SetQString("DS.FirmwarePath", ui->txtFirmwarePath->text());
Config::DLDIFolderSync = dldiFolderSync;
Config::DLDIFolderPath = dldiFolderPath;
Config::DSiBIOS9Path = dsiBios9Path; cfg.SetBool("DLDI.Enable", ui->cbDLDIEnable->isChecked());
Config::DSiBIOS7Path = dsiBios7Path; cfg.SetQString("DLDI.ImagePath", ui->txtDLDISDPath->text());
Config::DSiFirmwarePath = dsiFirmwarePath; cfg.SetInt("DLDI.ImageSize", ui->cbxDLDISize->currentIndex());
Config::DSiNANDPath = dsiNANDPath; cfg.SetBool("DLDI.ReadOnly", ui->cbDLDIReadOnly->isChecked());
Config::DSiFullBIOSBoot = dsiFullBiosBoot; cfg.SetBool("DLDI.FolderSync", ui->cbDLDIFolder->isChecked());
cfg.SetQString("DLDI.FolderPath", ui->txtDLDIFolder->text());
Config::DSiSDEnable = dsiSDEnable; cfg.SetQString("DSi.BIOS9Path", ui->txtDSiBIOS9Path->text());
Config::DSiSDPath = dsiSDPath; cfg.SetQString("DSi.BIOS7Path", ui->txtDSiBIOS7Path->text());
Config::DSiSDSize = dsiSDSize; cfg.SetQString("DSi.FirmwarePath", ui->txtDSiFirmwarePath->text());
Config::DSiSDReadOnly = dsiSDReadOnly; cfg.SetQString("DSi.NANDPath", ui->txtDSiNANDPath->text());
Config::DSiSDFolderSync = dsiSDFolderSync; cfg.SetBool("DSi.FullBIOSBoot", ui->cbDSiFullBIOSBoot->isChecked());
Config::DSiSDFolderPath = dsiSDFolderPath;
cfg.SetBool("DSi.SD.Enable", ui->cbDSiSDEnable->isChecked());
cfg.SetQString("DSi.SD.ImagePath", ui->txtDSiSDPath->text());
cfg.SetInt("DSi.SD.ImageSize", ui->cbxDSiSDSize->currentIndex());
cfg.SetBool("DSi.SD.ReadOnly", ui->cbDSiSDReadOnly->isChecked());
cfg.SetBool("DSi.SD.FolderSync", ui->cbDSiSDFolder->isChecked());
cfg.SetQString("DSi.SD.FolderPath", ui->txtDSiSDFolder->text());
#ifdef JIT_ENABLED #ifdef JIT_ENABLED
Config::JIT_Enable = jitEnable; cfg.SetBool("JIT.Enable", ui->chkEnableJIT->isChecked());
Config::JIT_MaxBlockSize = jitMaxBlockSize; cfg.SetInt("JIT.MaxBlockSize", ui->spnJITMaximumBlockSize->value());
Config::JIT_BranchOptimisations = jitBranchOptimisations; cfg.SetBool("JIT.BranchOptimisations", ui->chkJITBranchOptimisations->isChecked());
Config::JIT_LiteralOptimisations = jitLiteralOptimisations; cfg.SetBool("JIT.LiteralOptimisations", ui->chkJITLiteralOptimisations->isChecked());
Config::JIT_FastMemory = jitFastMemory; cfg.SetBool("JIT.FastMemory", ui->chkJITFastMemory->isChecked());
#endif #endif
#ifdef GDBSTUB_ENABLED #ifdef GDBSTUB_ENABLED
Config::GdbEnabled = gdbEnabled; cfg.SetBool("Gdb.Enabled", ui->cbGdbEnabled->isChecked());
Config::GdbPortARM7 = gdbPortA7; instcfg.SetInt("Gdb.ARM7.Port", ui->intGdbPortA7->value());
Config::GdbPortARM9 = gdbPortA9; instcfg.SetInt("Gdb.ARM9.Port", ui->intGdbPortA9->value());
Config::GdbARM7BreakOnStartup = gdbBOSA7; instcfg.SetBool("Gdb.ARM7.BreakOnStartup", ui->cbGdbBOSA7->isChecked());
Config::GdbARM9BreakOnStartup = gdbBOSA9; instcfg.SetBool("Gdb.ARM9.BreakOnStartup", ui->cbGdbBOSA9->isChecked());
#endif #endif
Config::ConsoleType = consoleType; cfg.SetInt("Emu.ConsoleType", ui->cbxConsoleType->currentIndex());
Config::DirectBoot = directBoot; cfg.SetBool("Emu.DirectBoot", ui->chkDirectBoot->isChecked());
Config::Save(); Config::Save();