mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 11:56:42 +08:00 
			
		
		
		
	
						commit
						23bb870046
					
				| @ -75,7 +75,7 @@ GMainWindow::GMainWindow() : config(new Config()), emu_thread(nullptr) { | ||||
| 
 | ||||
|     QStringList args = QApplication::arguments(); | ||||
|     if (args.length() >= 2) { | ||||
|         BootGame(args[1].toStdString()); | ||||
|         BootGame(args[1]); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| @ -272,7 +272,7 @@ void GMainWindow::OnDisplayTitleBars(bool show) { | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool GMainWindow::LoadROM(const std::string& filename) { | ||||
| bool GMainWindow::LoadROM(const QString& filename) { | ||||
|     // Shutdown previous session if the emu thread is still active...
 | ||||
|     if (emu_thread != nullptr) | ||||
|         ShutdownGame(); | ||||
| @ -290,12 +290,13 @@ bool GMainWindow::LoadROM(const std::string& filename) { | ||||
| 
 | ||||
|     Core::System& system{Core::System::GetInstance()}; | ||||
| 
 | ||||
|     const Core::System::ResultStatus result{system.Load(render_window, filename)}; | ||||
|     const Core::System::ResultStatus result{system.Load(render_window, filename.toStdString())}; | ||||
| 
 | ||||
|     if (result != Core::System::ResultStatus::Success) { | ||||
|         switch (result) { | ||||
|         case Core::System::ResultStatus::ErrorGetLoader: | ||||
|             LOG_CRITICAL(Frontend, "Failed to obtain loader for %s!", filename.c_str()); | ||||
|             LOG_CRITICAL(Frontend, "Failed to obtain loader for %s!", | ||||
|                          filename.toStdString().c_str()); | ||||
|             QMessageBox::critical(this, tr("Error while loading ROM!"), | ||||
|                                   tr("The ROM format is not supported.")); | ||||
|             break; | ||||
| @ -335,7 +336,7 @@ bool GMainWindow::LoadROM(const std::string& filename) { | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::BootGame(const std::string& filename) { | ||||
| void GMainWindow::BootGame(const QString& filename) { | ||||
|     LOG_INFO(Frontend, "Citra starting..."); | ||||
|     StoreRecentFile(filename); // Put the filename on top of the list
 | ||||
| 
 | ||||
| @ -411,8 +412,8 @@ void GMainWindow::ShutdownGame() { | ||||
|     emulation_running = false; | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::StoreRecentFile(const std::string& filename) { | ||||
|     UISettings::values.recent_files.prepend(QString::fromStdString(filename)); | ||||
| void GMainWindow::StoreRecentFile(const QString& filename) { | ||||
|     UISettings::values.recent_files.prepend(filename); | ||||
|     UISettings::values.recent_files.removeDuplicates(); | ||||
|     while (UISettings::values.recent_files.size() > max_recent_files_item) { | ||||
|         UISettings::values.recent_files.removeLast(); | ||||
| @ -447,7 +448,7 @@ void GMainWindow::UpdateRecentFiles() { | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::OnGameListLoadFile(QString game_path) { | ||||
|     BootGame(game_path.toStdString()); | ||||
|     BootGame(game_path); | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::OnGameListOpenSaveFolder(u64 program_id) { | ||||
| @ -470,20 +471,21 @@ void GMainWindow::OnMenuLoadFile() { | ||||
|     for (const auto& piece : game_list->supported_file_extensions) | ||||
|         extensions += "*." + piece + " "; | ||||
| 
 | ||||
|     QString file_filter = tr("3DS executable") + " (" + extensions + ")"; | ||||
|     QString file_filter = tr("3DS Executable") + " (" + extensions + ")"; | ||||
|     file_filter += ";;" + tr("All Files (*.*)"); | ||||
| 
 | ||||
|     QString filename = QFileDialog::getOpenFileName(this, tr("Load File"), | ||||
|                                                     UISettings::values.roms_path, file_filter); | ||||
|     if (!filename.isEmpty()) { | ||||
|         UISettings::values.roms_path = QFileInfo(filename).path(); | ||||
| 
 | ||||
|         BootGame(filename.toStdString()); | ||||
|         BootGame(filename); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::OnMenuLoadSymbolMap() { | ||||
|     QString filename = QFileDialog::getOpenFileName( | ||||
|         this, tr("Load Symbol Map"), UISettings::values.symbols_path, tr("Symbol map (*)")); | ||||
|         this, tr("Load Symbol Map"), UISettings::values.symbols_path, tr("Symbol Map (*.*)")); | ||||
|     if (!filename.isEmpty()) { | ||||
|         UISettings::values.symbols_path = QFileInfo(filename).path(); | ||||
| 
 | ||||
| @ -506,7 +508,7 @@ void GMainWindow::OnMenuRecentFile() { | ||||
|     QString filename = action->data().toString(); | ||||
|     QFileInfo file_info(filename); | ||||
|     if (file_info.exists()) { | ||||
|         BootGame(filename.toStdString()); | ||||
|         BootGame(filename); | ||||
|     } else { | ||||
|         // Display an error message and remove the file from the list.
 | ||||
|         QMessageBox::information(this, tr("File not found"), | ||||
| @ -625,7 +627,7 @@ void GMainWindow::closeEvent(QCloseEvent* event) { | ||||
|     QWidget::closeEvent(event); | ||||
| } | ||||
| 
 | ||||
| bool IsSingleFileDropEvent(QDropEvent* event) { | ||||
| static bool IsSingleFileDropEvent(QDropEvent* event) { | ||||
|     const QMimeData* mimeData = event->mimeData(); | ||||
|     return mimeData->hasUrls() && mimeData->urls().length() == 1; | ||||
| } | ||||
| @ -634,7 +636,7 @@ void GMainWindow::dropEvent(QDropEvent* event) { | ||||
|     if (IsSingleFileDropEvent(event) && ConfirmChangeGame()) { | ||||
|         const QMimeData* mimeData = event->mimeData(); | ||||
|         QString filename = mimeData->urls().at(0).toLocalFile(); | ||||
|         BootGame(filename.toStdString()); | ||||
|         BootGame(filename); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -73,14 +73,8 @@ private: | ||||
| 
 | ||||
|     void ConnectWidgetEvents(); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Initializes the emulation system. | ||||
|      * @param system_mode The system mode with which to intialize the kernel. | ||||
|      * @returns Whether the system was properly initialized. | ||||
|      */ | ||||
|     bool InitializeSystem(u32 system_mode); | ||||
|     bool LoadROM(const std::string& filename); | ||||
|     void BootGame(const std::string& filename); | ||||
|     bool LoadROM(const QString& filename); | ||||
|     void BootGame(const QString& filename); | ||||
|     void ShutdownGame(); | ||||
| 
 | ||||
|     /**
 | ||||
| @ -94,7 +88,7 @@ private: | ||||
|      * | ||||
|      * @param filename the filename to store | ||||
|      */ | ||||
|     void StoreRecentFile(const std::string& filename); | ||||
|     void StoreRecentFile(const QString& filename); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Updates the recent files menu. | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user