aboutsummaryrefslogtreecommitdiff
path: root/src/frontend/qt_sdl/main.cpp
diff options
context:
space:
mode:
authorArisotura <thetotalworm@gmail.com>2020-04-28 22:45:11 +0200
committerArisotura <thetotalworm@gmail.com>2020-04-28 22:45:11 +0200
commit63efc2e02aa51c44c9cb5abc621624aa1d7bf1e5 (patch)
tree8dedbbf4a9bc86439b9de0988491c34defbbb136 /src/frontend/qt_sdl/main.cpp
parent0913576ef598bee4d2ea3c4268a6a6f163cd90ef (diff)
add menu items for running the firmware and for quitting.
Diffstat (limited to 'src/frontend/qt_sdl/main.cpp')
-rw-r--r--src/frontend/qt_sdl/main.cpp44
1 files changed, 41 insertions, 3 deletions
diff --git a/src/frontend/qt_sdl/main.cpp b/src/frontend/qt_sdl/main.cpp
index e9b9122..cadcec9 100644
--- a/src/frontend/qt_sdl/main.cpp
+++ b/src/frontend/qt_sdl/main.cpp
@@ -394,10 +394,17 @@ MainWindow::MainWindow(QWidget* parent) : QMainWindow(parent)
QMenuBar* menubar = new QMenuBar();
{
QMenu* menu = menubar->addMenu("File");
- QAction* act;
- act = menu->addAction("Open file...");
- connect(act, &QAction::triggered, this, &MainWindow::onOpenFile);
+ actOpenROM = menu->addAction("Open file...");
+ connect(actOpenROM, &QAction::triggered, this, &MainWindow::onOpenFile);
+
+ actBootFirmware = menu->addAction("Launch DS menu");
+ connect(actBootFirmware, &QAction::triggered, this, &MainWindow::onBootFirmware);
+
+ menu->addSeparator();
+
+ actQuit = menu->addAction("Quit");
+ connect(actQuit, &QAction::triggered, this, &MainWindow::onQuit);
}
setMenuBar(menubar);
@@ -411,6 +418,12 @@ MainWindow::~MainWindow()
}
+void MainWindow::keyPressEvent(QKeyEvent* event)
+{
+ printf("key press. %d %d %08X %08X\n", event->key(), event->nativeScanCode(), event->modifiers(), event->nativeModifiers());
+}
+
+
void MainWindow::onOpenFile()
{
emuThread->emuPause(true);
@@ -465,6 +478,31 @@ void MainWindow::onOpenFile()
}
}
+void MainWindow::onBootFirmware()
+{
+ // TODO: ensure the firmware is actually bootable!!
+ // TODO: check the whole GBA cart shito
+
+ emuThread->emuPause(true);
+
+ bool res = Frontend::LoadBIOS();
+ if (!res)
+ {
+ // TODO!
+
+ emuThread->emuUnpause();
+ }
+ else
+ {
+ emuThread->emuRun();
+ }
+}
+
+void MainWindow::onQuit()
+{
+ QApplication::quit();
+}
+
void MainWindow::onTitleUpdate(QString title)
{