same shit with Import Savefile
Some checks are pending
macOS / ${{ matrix.arch }} (arm64) (push) Waiting to run
macOS / ${{ matrix.arch }} (x86_64) (push) Waiting to run
macOS / Universal binary (push) Blocked by required conditions
Ubuntu / x86_64 (push) Waiting to run
Ubuntu / aarch64 (push) Waiting to run
Windows / build (push) Waiting to run

This commit is contained in:
Arisotura 2024-10-25 10:52:47 +02:00
parent 8b6628b070
commit 979f1ed615
3 changed files with 38 additions and 21 deletions

View File

@ -618,6 +618,26 @@ void EmuThread::handleMessages()
emuInstance->undoStateLoad();
msgResult = 1;
break;
case msg_ImportSavefile:
{
msgResult = 0;
auto f = Platform::OpenFile(msg.param.value<QString>().toStdString(), Platform::FileMode::Read);
if (!f) break;
u32 len = FileLength(f);
std::unique_ptr<u8[]> data = std::make_unique<u8[]>(len);
Platform::FileRewind(f);
Platform::FileRead(data.get(), len, 1, f);
assert(emuInstance->nds != nullptr);
emuInstance->nds->SetNDSSave(data.get(), len);
CloseFile(f);
msgResult = 1;
}
break;
}
msgSemaphore.release();
@ -771,6 +791,14 @@ int EmuThread::undoStateLoad()
return msgResult;
}
int EmuThread::importSavefile(const QString& filename)
{
sendMessage(msg_EmuReset);
sendMessage({.type = msg_ImportSavefile, .param = filename});
waitMessage(2);
return msgResult;
}
void EmuThread::updateRenderer()
{
if (videoRenderer != lastVideoRenderer)

View File

@ -80,6 +80,8 @@ public:
msg_LoadState,
msg_SaveState,
msg_UndoStateLoad,
msg_ImportSavefile,
};
struct Message
@ -119,6 +121,8 @@ public:
int loadState(const QString& filename);
int undoStateLoad();
int importSavefile(const QString& filename);
bool emuIsRunning();
bool emuIsActive();

View File

@ -1483,23 +1483,17 @@ void MainWindow::onUndoStateLoad()
void MainWindow::onImportSavefile()
{
emuThread->emuPause();
QString path = QFileDialog::getOpenFileName(this,
"Select savefile",
globalCfg.GetQString("LastROMFolder"),
"Savefiles (*.sav *.bin *.dsv);;Any file (*.*)");
if (path.isEmpty())
{
emuThread->emuUnpause();
return;
}
Platform::FileHandle* f = Platform::OpenFile(path.toStdString(), Platform::FileMode::Read);
if (!f)
if (!Platform::FileExists(path.toStdString()))
{
QMessageBox::critical(this, "melonDS", "Could not open the given savefile.");
emuThread->emuUnpause();
return;
}
@ -1510,24 +1504,15 @@ void MainWindow::onImportSavefile()
"The emulation will be reset and the current savefile overwritten.",
QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok)
{
emuThread->emuUnpause();
return;
}
emuInstance->reset();
}
u32 len = FileLength(f);
std::unique_ptr<u8[]> data = std::make_unique<u8[]>(len);
Platform::FileRewind(f);
Platform::FileRead(data.get(), len, 1, f);
assert(emuInstance->nds != nullptr);
emuInstance->nds->SetNDSSave(data.get(), len);
CloseFile(f);
emuThread->emuUnpause();
if (!emuThread->importSavefile(path))
{
QMessageBox::critical(this, "melonDS", "Could not import the given savefile.");
return;
}
}
void MainWindow::onQuit()