Qt/MenuBar: Make failures to load map and signature files more obvious
Previously we wouldn't indicate if saving or loading these files happened to fail. In some cases we'd only print out to the logger, but this is a pretty poor way to tell a user of the interface that something went wrong in a direct way (the logging messages aren't able to be localized either).
This commit is contained in:
parent
b9960777a7
commit
74899e417b
|
@ -1180,10 +1180,13 @@ void MenuBar::LoadSymbolMap()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
g_symbolDB.LoadMap(existing_map_file);
|
const QString existing_map_file_path = QString::fromStdString(existing_map_file);
|
||||||
QMessageBox::information(
|
|
||||||
this, tr("Information"),
|
if (!TryLoadMapFile(existing_map_file_path))
|
||||||
tr("Loaded symbols from '%1'").arg(QString::fromStdString(existing_map_file)));
|
return;
|
||||||
|
|
||||||
|
QMessageBox::information(this, tr("Information"),
|
||||||
|
tr("Loaded symbols from '%1'").arg(existing_map_file_path));
|
||||||
}
|
}
|
||||||
|
|
||||||
HLE::PatchFunctions();
|
HLE::PatchFunctions();
|
||||||
|
@ -1195,19 +1198,21 @@ void MenuBar::SaveSymbolMap()
|
||||||
std::string existing_map_file, writable_map_file;
|
std::string existing_map_file, writable_map_file;
|
||||||
CBoot::FindMapFile(&existing_map_file, &writable_map_file);
|
CBoot::FindMapFile(&existing_map_file, &writable_map_file);
|
||||||
|
|
||||||
g_symbolDB.SaveSymbolMap(writable_map_file);
|
TrySaveSymbolMap(QString::fromStdString(writable_map_file));
|
||||||
}
|
}
|
||||||
|
|
||||||
void MenuBar::LoadOtherSymbolMap()
|
void MenuBar::LoadOtherSymbolMap()
|
||||||
{
|
{
|
||||||
QString file = QFileDialog::getOpenFileName(this, tr("Load map file"),
|
const QString file = QFileDialog::getOpenFileName(
|
||||||
QString::fromStdString(File::GetUserPath(D_MAPS_IDX)),
|
this, tr("Load map file"), QString::fromStdString(File::GetUserPath(D_MAPS_IDX)),
|
||||||
tr("Dolphin Map File (*.map)"));
|
tr("Dolphin Map File (*.map)"));
|
||||||
|
|
||||||
if (file.isEmpty())
|
if (file.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
g_symbolDB.LoadMap(file.toStdString());
|
if (!TryLoadMapFile(file))
|
||||||
|
return;
|
||||||
|
|
||||||
HLE::PatchFunctions();
|
HLE::PatchFunctions();
|
||||||
emit NotifySymbolsUpdated();
|
emit NotifySymbolsUpdated();
|
||||||
}
|
}
|
||||||
|
@ -1215,7 +1220,7 @@ void MenuBar::LoadOtherSymbolMap()
|
||||||
void MenuBar::SaveSymbolMapAs()
|
void MenuBar::SaveSymbolMapAs()
|
||||||
{
|
{
|
||||||
const std::string& title_id_str = SConfig::GetInstance().m_debugger_game_id;
|
const std::string& title_id_str = SConfig::GetInstance().m_debugger_game_id;
|
||||||
QString file = QFileDialog::getSaveFileName(
|
const QString file = QFileDialog::getSaveFileName(
|
||||||
this, tr("Save map file"),
|
this, tr("Save map file"),
|
||||||
QString::fromStdString(File::GetUserPath(D_MAPS_IDX) + "/" + title_id_str + ".map"),
|
QString::fromStdString(File::GetUserPath(D_MAPS_IDX) + "/" + title_id_str + ".map"),
|
||||||
tr("Dolphin Map File (*.map)"));
|
tr("Dolphin Map File (*.map)"));
|
||||||
|
@ -1223,7 +1228,7 @@ void MenuBar::SaveSymbolMapAs()
|
||||||
if (file.isEmpty())
|
if (file.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
g_symbolDB.SaveSymbolMap(file.toStdString());
|
TrySaveSymbolMap(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MenuBar::SaveCode()
|
void MenuBar::SaveCode()
|
||||||
|
@ -1234,28 +1239,55 @@ void MenuBar::SaveCode()
|
||||||
const std::string path =
|
const std::string path =
|
||||||
writable_map_file.substr(0, writable_map_file.find_last_of('.')) + "_code.map";
|
writable_map_file.substr(0, writable_map_file.find_last_of('.')) + "_code.map";
|
||||||
|
|
||||||
g_symbolDB.SaveCodeMap(path);
|
if (!g_symbolDB.SaveCodeMap(path))
|
||||||
|
{
|
||||||
|
QMessageBox::warning(
|
||||||
|
this, tr("Error"),
|
||||||
|
tr("Failed to save code map to path '%1'").arg(QString::fromStdString(path)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool MenuBar::TryLoadMapFile(const QString& path)
|
||||||
|
{
|
||||||
|
if (!g_symbolDB.LoadMap(path.toStdString()))
|
||||||
|
{
|
||||||
|
QMessageBox::warning(this, tr("Error"), tr("Failed to load map file '%1'").arg(path));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MenuBar::TrySaveSymbolMap(const QString& path)
|
||||||
|
{
|
||||||
|
if (g_symbolDB.SaveSymbolMap(path.toStdString()))
|
||||||
|
return;
|
||||||
|
|
||||||
|
QMessageBox::warning(this, tr("Error"), tr("Failed to save symbol map to path '%1'").arg(path));
|
||||||
}
|
}
|
||||||
|
|
||||||
void MenuBar::CreateSignatureFile()
|
void MenuBar::CreateSignatureFile()
|
||||||
{
|
{
|
||||||
QString text = QInputDialog::getText(
|
const QString text = QInputDialog::getText(
|
||||||
this, tr("Input"), tr("Only export symbols with prefix:\n(Blank for all symbols)"));
|
this, tr("Input"), tr("Only export symbols with prefix:\n(Blank for all symbols)"));
|
||||||
|
|
||||||
if (text.isEmpty())
|
if (text.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
std::string prefix = text.toStdString();
|
const QString file = QFileDialog::getSaveFileName(this, tr("Save signature file"));
|
||||||
|
|
||||||
QString file = QFileDialog::getSaveFileName(this, tr("Save signature file"));
|
|
||||||
|
|
||||||
if (file.isEmpty())
|
if (file.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
std::string save_path = file.toStdString();
|
const std::string prefix = text.toStdString();
|
||||||
|
const std::string save_path = file.toStdString();
|
||||||
SignatureDB db(save_path);
|
SignatureDB db(save_path);
|
||||||
db.Populate(&g_symbolDB, prefix);
|
db.Populate(&g_symbolDB, prefix);
|
||||||
db.Save(save_path);
|
|
||||||
|
if (!db.Save(save_path))
|
||||||
|
{
|
||||||
|
QMessageBox::warning(this, tr("Error"), tr("Failed to save signature file '%1'").arg(file));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
db.List();
|
db.List();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -150,6 +150,8 @@ private:
|
||||||
void SaveSymbolMap();
|
void SaveSymbolMap();
|
||||||
void SaveSymbolMapAs();
|
void SaveSymbolMapAs();
|
||||||
void SaveCode();
|
void SaveCode();
|
||||||
|
bool TryLoadMapFile(const QString& path);
|
||||||
|
void TrySaveSymbolMap(const QString& path);
|
||||||
void CreateSignatureFile();
|
void CreateSignatureFile();
|
||||||
void PatchHLEFunctions();
|
void PatchHLEFunctions();
|
||||||
void ClearCache();
|
void ClearCache();
|
||||||
|
|
Loading…
Reference in New Issue