diff options
Diffstat (limited to 'src/yuzu')
| -rw-r--r-- | src/yuzu/about_dialog.cpp | 2 | ||||
| -rw-r--r-- | src/yuzu/about_dialog.h | 2 | ||||
| -rw-r--r-- | src/yuzu/bootmanager.h | 2 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_debug.cpp | 2 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_debug.ui | 7 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_dialog.cpp | 7 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_dialog.h | 4 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_general.cpp | 6 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_general.h | 4 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_graphics.cpp | 2 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_system.cpp | 2 | ||||
| -rw-r--r-- | src/yuzu/debugger/graphics/graphics_surface.cpp | 3 | ||||
| -rw-r--r-- | src/yuzu/debugger/graphics/graphics_surface.h | 6 | ||||
| -rw-r--r-- | src/yuzu/debugger/wait_tree.cpp | 4 | ||||
| -rw-r--r-- | src/yuzu/debugger/wait_tree.h | 4 | ||||
| -rw-r--r-- | src/yuzu/game_list.cpp | 44 | ||||
| -rw-r--r-- | src/yuzu/game_list_p.h | 17 | ||||
| -rw-r--r-- | src/yuzu/hotkeys.cpp | 67 | ||||
| -rw-r--r-- | src/yuzu/hotkeys.h | 107 | ||||
| -rw-r--r-- | src/yuzu/main.cpp | 130 | ||||
| -rw-r--r-- | src/yuzu/main.h | 5 | 
21 files changed, 234 insertions, 193 deletions
| diff --git a/src/yuzu/about_dialog.cpp b/src/yuzu/about_dialog.cpp index 39ed3bccf..a81ad2888 100644 --- a/src/yuzu/about_dialog.cpp +++ b/src/yuzu/about_dialog.cpp @@ -15,4 +15,4 @@ AboutDialog::AboutDialog(QWidget* parent) : QDialog(parent), ui(new Ui::AboutDia                                         Common::g_scm_desc, QString(Common::g_build_date).left(10)));  } -AboutDialog::~AboutDialog() {} +AboutDialog::~AboutDialog() = default; diff --git a/src/yuzu/about_dialog.h b/src/yuzu/about_dialog.h index 2eb6e28f5..18e8c11a7 100644 --- a/src/yuzu/about_dialog.h +++ b/src/yuzu/about_dialog.h @@ -16,7 +16,7 @@ class AboutDialog : public QDialog {  public:      explicit AboutDialog(QWidget* parent); -    ~AboutDialog(); +    ~AboutDialog() override;  private:      std::unique_ptr<Ui::AboutDialog> ui; diff --git a/src/yuzu/bootmanager.h b/src/yuzu/bootmanager.h index 130bc613b..d0f990c64 100644 --- a/src/yuzu/bootmanager.h +++ b/src/yuzu/bootmanager.h @@ -106,7 +106,7 @@ class GRenderWindow : public QWidget, public EmuWindow {  public:      GRenderWindow(QWidget* parent, EmuThread* emu_thread); -    ~GRenderWindow(); +    ~GRenderWindow() override;      // EmuWindow implementation      void SwapBuffers() override; diff --git a/src/yuzu/configuration/configure_debug.cpp b/src/yuzu/configuration/configure_debug.cpp index 7fd07539a..45d84f19a 100644 --- a/src/yuzu/configuration/configure_debug.cpp +++ b/src/yuzu/configuration/configure_debug.cpp @@ -24,7 +24,7 @@ ConfigureDebug::ConfigureDebug(QWidget* parent) : QWidget(parent), ui(new Ui::Co      });  } -ConfigureDebug::~ConfigureDebug() {} +ConfigureDebug::~ConfigureDebug() = default;  void ConfigureDebug::setConfiguration() {      ui->toggle_gdbstub->setChecked(Settings::values.use_gdbstub); diff --git a/src/yuzu/configuration/configure_debug.ui b/src/yuzu/configuration/configure_debug.ui index 118e91cf1..5ae7276bd 100644 --- a/src/yuzu/configuration/configure_debug.ui +++ b/src/yuzu/configuration/configure_debug.ui @@ -23,13 +23,6 @@         </property>         <layout class="QVBoxLayout" name="verticalLayout_3">          <item> -         <widget class="QLabel" name="label_1"> -          <property name="text"> -           <string>The GDB Stub only works correctly when the CPU JIT is off.</string> -          </property> -         </widget> -        </item> -        <item>           <layout class="QHBoxLayout" name="horizontalLayout_1">            <item>             <widget class="QCheckBox" name="toggle_gdbstub"> diff --git a/src/yuzu/configuration/configure_dialog.cpp b/src/yuzu/configuration/configure_dialog.cpp index f66abf870..cc4b326ae 100644 --- a/src/yuzu/configuration/configure_dialog.cpp +++ b/src/yuzu/configuration/configure_dialog.cpp @@ -6,13 +6,16 @@  #include "ui_configure.h"  #include "yuzu/configuration/config.h"  #include "yuzu/configuration/configure_dialog.h" +#include "yuzu/hotkeys.h" -ConfigureDialog::ConfigureDialog(QWidget* parent) : QDialog(parent), ui(new Ui::ConfigureDialog) { +ConfigureDialog::ConfigureDialog(QWidget* parent, const HotkeyRegistry& registry) +    : QDialog(parent), ui(new Ui::ConfigureDialog) {      ui->setupUi(this); +    ui->generalTab->PopulateHotkeyList(registry);      this->setConfiguration();  } -ConfigureDialog::~ConfigureDialog() {} +ConfigureDialog::~ConfigureDialog() = default;  void ConfigureDialog::setConfiguration() {} diff --git a/src/yuzu/configuration/configure_dialog.h b/src/yuzu/configuration/configure_dialog.h index 21fa1f501..bbbdacc29 100644 --- a/src/yuzu/configuration/configure_dialog.h +++ b/src/yuzu/configuration/configure_dialog.h @@ -7,6 +7,8 @@  #include <memory>  #include <QDialog> +class HotkeyRegistry; +  namespace Ui {  class ConfigureDialog;  } @@ -15,7 +17,7 @@ class ConfigureDialog : public QDialog {      Q_OBJECT  public: -    explicit ConfigureDialog(QWidget* parent); +    explicit ConfigureDialog(QWidget* parent, const HotkeyRegistry& registry);      ~ConfigureDialog();      void applyConfiguration(); diff --git a/src/yuzu/configuration/configure_general.cpp b/src/yuzu/configuration/configure_general.cpp index cb7d3f8bf..d8caee1e8 100644 --- a/src/yuzu/configuration/configure_general.cpp +++ b/src/yuzu/configuration/configure_general.cpp @@ -24,7 +24,7 @@ ConfigureGeneral::ConfigureGeneral(QWidget* parent)      ui->use_docked_mode->setEnabled(!Core::System::GetInstance().IsPoweredOn());  } -ConfigureGeneral::~ConfigureGeneral() {} +ConfigureGeneral::~ConfigureGeneral() = default;  void ConfigureGeneral::setConfiguration() {      ui->toggle_deepscan->setChecked(UISettings::values.gamedir_deepscan); @@ -35,6 +35,10 @@ void ConfigureGeneral::setConfiguration() {      ui->use_docked_mode->setChecked(Settings::values.use_docked_mode);  } +void ConfigureGeneral::PopulateHotkeyList(const HotkeyRegistry& registry) { +    ui->widget->Populate(registry); +} +  void ConfigureGeneral::applyConfiguration() {      UISettings::values.gamedir_deepscan = ui->toggle_deepscan->isChecked();      UISettings::values.confirm_before_closing = ui->toggle_check_exit->isChecked(); diff --git a/src/yuzu/configuration/configure_general.h b/src/yuzu/configuration/configure_general.h index 447552d8c..4770034cc 100644 --- a/src/yuzu/configuration/configure_general.h +++ b/src/yuzu/configuration/configure_general.h @@ -7,6 +7,8 @@  #include <memory>  #include <QWidget> +class HotkeyRegistry; +  namespace Ui {  class ConfigureGeneral;  } @@ -18,11 +20,11 @@ public:      explicit ConfigureGeneral(QWidget* parent = nullptr);      ~ConfigureGeneral(); +    void PopulateHotkeyList(const HotkeyRegistry& registry);      void applyConfiguration();  private:      void setConfiguration(); -private:      std::unique_ptr<Ui::ConfigureGeneral> ui;  }; diff --git a/src/yuzu/configuration/configure_graphics.cpp b/src/yuzu/configuration/configure_graphics.cpp index 3379b7963..4afe0f81b 100644 --- a/src/yuzu/configuration/configure_graphics.cpp +++ b/src/yuzu/configuration/configure_graphics.cpp @@ -14,7 +14,7 @@ ConfigureGraphics::ConfigureGraphics(QWidget* parent)      this->setConfiguration();  } -ConfigureGraphics::~ConfigureGraphics() {} +ConfigureGraphics::~ConfigureGraphics() = default;  enum class Resolution : int {      Auto, diff --git a/src/yuzu/configuration/configure_system.cpp b/src/yuzu/configuration/configure_system.cpp index 9be2c939c..e9ed9c38f 100644 --- a/src/yuzu/configuration/configure_system.cpp +++ b/src/yuzu/configuration/configure_system.cpp @@ -35,7 +35,7 @@ ConfigureSystem::ConfigureSystem(QWidget* parent) : QWidget(parent), ui(new Ui::      this->setConfiguration();  } -ConfigureSystem::~ConfigureSystem() {} +ConfigureSystem::~ConfigureSystem() = default;  void ConfigureSystem::setConfiguration() {      enabled = !Core::System::GetInstance().IsPoweredOn(); diff --git a/src/yuzu/debugger/graphics/graphics_surface.cpp b/src/yuzu/debugger/graphics/graphics_surface.cpp index ff3efcdaa..3f7103ab9 100644 --- a/src/yuzu/debugger/graphics/graphics_surface.cpp +++ b/src/yuzu/debugger/graphics/graphics_surface.cpp @@ -34,7 +34,8 @@ static Tegra::Texture::TextureFormat ConvertToTextureFormat(  SurfacePicture::SurfacePicture(QWidget* parent, GraphicsSurfaceWidget* surface_widget_)      : QLabel(parent), surface_widget(surface_widget_) {} -SurfacePicture::~SurfacePicture() {} + +SurfacePicture::~SurfacePicture() = default;  void SurfacePicture::mousePressEvent(QMouseEvent* event) {      // Only do something while the left mouse button is held down diff --git a/src/yuzu/debugger/graphics/graphics_surface.h b/src/yuzu/debugger/graphics/graphics_surface.h index 58f9db465..323e39d94 100644 --- a/src/yuzu/debugger/graphics/graphics_surface.h +++ b/src/yuzu/debugger/graphics/graphics_surface.h @@ -22,11 +22,11 @@ class SurfacePicture : public QLabel {  public:      explicit SurfacePicture(QWidget* parent = nullptr,                              GraphicsSurfaceWidget* surface_widget = nullptr); -    ~SurfacePicture(); +    ~SurfacePicture() override;  protected slots: -    virtual void mouseMoveEvent(QMouseEvent* event); -    virtual void mousePressEvent(QMouseEvent* event); +    void mouseMoveEvent(QMouseEvent* event) override; +    void mousePressEvent(QMouseEvent* event) override;  private:      GraphicsSurfaceWidget* surface_widget; diff --git a/src/yuzu/debugger/wait_tree.cpp b/src/yuzu/debugger/wait_tree.cpp index f5a5697a0..d0926d723 100644 --- a/src/yuzu/debugger/wait_tree.cpp +++ b/src/yuzu/debugger/wait_tree.cpp @@ -14,7 +14,7 @@  #include "core/hle/kernel/timer.h"  #include "core/hle/kernel/wait_object.h" -WaitTreeItem::~WaitTreeItem() {} +WaitTreeItem::~WaitTreeItem() = default;  QColor WaitTreeItem::GetColor() const {      return QColor(Qt::GlobalColor::black); @@ -316,7 +316,7 @@ std::vector<std::unique_ptr<WaitTreeItem>> WaitTreeEvent::GetChildren() const {      list.push_back(std::make_unique<WaitTreeText>(          tr("reset type = %1") -            .arg(GetResetTypeQString(static_cast<const Kernel::Event&>(object).reset_type)))); +            .arg(GetResetTypeQString(static_cast<const Kernel::Event&>(object).GetResetType()))));      return list;  } diff --git a/src/yuzu/debugger/wait_tree.h b/src/yuzu/debugger/wait_tree.h index 6cbce6856..513b3c45d 100644 --- a/src/yuzu/debugger/wait_tree.h +++ b/src/yuzu/debugger/wait_tree.h @@ -25,11 +25,13 @@ class WaitTreeThread;  class WaitTreeItem : public QObject {      Q_OBJECT  public: +    ~WaitTreeItem() override; +      virtual bool IsExpandable() const;      virtual std::vector<std::unique_ptr<WaitTreeItem>> GetChildren() const;      virtual QString GetText() const = 0;      virtual QColor GetColor() const; -    virtual ~WaitTreeItem(); +      void Expand();      WaitTreeItem* Parent() const;      const std::vector<std::unique_ptr<WaitTreeItem>>& Children() const; diff --git a/src/yuzu/game_list.cpp b/src/yuzu/game_list.cpp index 71e24a9e2..24f38a3c7 100644 --- a/src/yuzu/game_list.cpp +++ b/src/yuzu/game_list.cpp @@ -162,15 +162,15 @@ void GameList::onTextChanged(const QString& newText) {          }          search_field->setFilterResult(rowCount, rowCount);      } else { -        QStandardItem* child_file; -        QString file_path, file_name, file_title, file_programmid;          int result_count = 0;          for (int i = 0; i < rowCount; ++i) { -            child_file = item_model->item(i, 0); -            file_path = child_file->data(GameListItemPath::FullPathRole).toString().toLower(); -            file_name = file_path.mid(file_path.lastIndexOf("/") + 1); -            file_title = child_file->data(GameListItemPath::TitleRole).toString().toLower(); -            file_programmid = +            const QStandardItem* child_file = item_model->item(i, 0); +            const QString file_path = +                child_file->data(GameListItemPath::FullPathRole).toString().toLower(); +            QString file_name = file_path.mid(file_path.lastIndexOf('/') + 1); +            const QString file_title = +                child_file->data(GameListItemPath::TitleRole).toString().toLower(); +            const QString file_programmid =                  child_file->data(GameListItemPath::ProgramIdRole).toString().toLower();              // Only items which filename in combination with its title contains all words @@ -258,18 +258,20 @@ void GameList::AddEntry(const QList<QStandardItem*>& entry_items) {  void GameList::ValidateEntry(const QModelIndex& item) {      // We don't care about the individual QStandardItem that was selected, but its row. -    int row = item_model->itemFromIndex(item)->row(); -    QStandardItem* child_file = item_model->invisibleRootItem()->child(row, COLUMN_NAME); -    QString file_path = child_file->data(GameListItemPath::FullPathRole).toString(); +    const int row = item_model->itemFromIndex(item)->row(); +    const QStandardItem* child_file = item_model->invisibleRootItem()->child(row, COLUMN_NAME); +    const QString file_path = child_file->data(GameListItemPath::FullPathRole).toString();      if (file_path.isEmpty())          return; -    std::string std_file_path(file_path.toStdString()); -    if (!FileUtil::Exists(std_file_path)) + +    if (!QFileInfo::exists(file_path))          return; -    if (FileUtil::IsDirectory(std_file_path)) { -        QDir dir(std_file_path.c_str()); -        QStringList matching_main = dir.entryList(QStringList("main"), QDir::Files); + +    const QFileInfo file_info{file_path}; +    if (file_info.isDir()) { +        const QDir dir{file_path}; +        const QStringList matching_main = dir.entryList(QStringList("main"), QDir::Files);          if (matching_main.size() == 1) {              emit GameChosen(dir.path() + DIR_SEP + matching_main[0]);          } @@ -368,21 +370,23 @@ void GameList::LoadInterfaceLayout() {  const QStringList GameList::supported_file_extensions = {"nso", "nro", "nca", "xci"};  static bool HasSupportedFileExtension(const std::string& file_name) { -    QFileInfo file = QFileInfo(file_name.c_str()); +    const QFileInfo file = QFileInfo(QString::fromStdString(file_name));      return GameList::supported_file_extensions.contains(file.suffix(), Qt::CaseInsensitive);  }  static bool IsExtractedNCAMain(const std::string& file_name) { -    return QFileInfo(file_name.c_str()).fileName() == "main"; +    return QFileInfo(QString::fromStdString(file_name)).fileName() == "main";  }  static QString FormatGameName(const std::string& physical_name) { -    QFileInfo file_info(physical_name.c_str()); +    const QString physical_name_as_qstring = QString::fromStdString(physical_name); +    const QFileInfo file_info(physical_name_as_qstring); +      if (IsExtractedNCAMain(physical_name)) {          return file_info.dir().path(); -    } else { -        return QString::fromStdString(physical_name);      } + +    return physical_name_as_qstring;  }  void GameList::RefreshGameDirectory() { diff --git a/src/yuzu/game_list_p.h b/src/yuzu/game_list_p.h index a758b77aa..aa69a098f 100644 --- a/src/yuzu/game_list_p.h +++ b/src/yuzu/game_list_p.h @@ -5,6 +5,7 @@  #pragma once  #include <atomic> +#include <utility>  #include <QImage>  #include <QRunnable>  #include <QStandardItem> @@ -27,9 +28,8 @@ static QPixmap GetDefaultIcon(bool large) {  class GameListItem : public QStandardItem {  public: -    GameListItem() : QStandardItem() {} -    GameListItem(const QString& string) : QStandardItem(string) {} -    virtual ~GameListItem() override {} +    GameListItem() = default; +    explicit GameListItem(const QString& string) : QStandardItem(string) {}  };  /** @@ -45,9 +45,8 @@ public:      static const int TitleRole = Qt::UserRole + 2;      static const int ProgramIdRole = Qt::UserRole + 3; -    GameListItemPath() : GameListItem() {} -    GameListItemPath(const QString& game_path, const std::vector<u8>& smdh_data, u64 program_id) -        : GameListItem() { +    GameListItemPath() = default; +    GameListItemPath(const QString& game_path, const std::vector<u8>& smdh_data, u64 program_id) {          setData(game_path, FullPathRole);          setData(qulonglong(program_id), ProgramIdRole);      } @@ -75,8 +74,8 @@ class GameListItemSize : public GameListItem {  public:      static const int SizeRole = Qt::UserRole + 1; -    GameListItemSize() : GameListItem() {} -    GameListItemSize(const qulonglong size_bytes) : GameListItem() { +    GameListItemSize() = default; +    explicit GameListItemSize(const qulonglong size_bytes) {          setData(size_bytes, SizeRole);      } @@ -111,7 +110,7 @@ class GameListWorker : public QObject, public QRunnable {  public:      GameListWorker(QString dir_path, bool deep_scan) -        : QObject(), QRunnable(), dir_path(dir_path), deep_scan(deep_scan) {} +        : dir_path(std::move(dir_path)), deep_scan(deep_scan) {}  public slots:      /// Starts the processing of directory tree information. diff --git a/src/yuzu/hotkeys.cpp b/src/yuzu/hotkeys.cpp index 61acb38ee..dce399774 100644 --- a/src/yuzu/hotkeys.cpp +++ b/src/yuzu/hotkeys.cpp @@ -10,58 +10,53 @@  #include "yuzu/hotkeys.h"  #include "yuzu/ui_settings.h" -struct Hotkey { -    Hotkey() : shortcut(nullptr), context(Qt::WindowShortcut) {} +HotkeyRegistry::HotkeyRegistry() = default; +HotkeyRegistry::~HotkeyRegistry() = default; -    QKeySequence keyseq; -    QShortcut* shortcut; -    Qt::ShortcutContext context; -}; - -typedef std::map<QString, Hotkey> HotkeyMap; -typedef std::map<QString, HotkeyMap> HotkeyGroupMap; - -HotkeyGroupMap hotkey_groups; - -void SaveHotkeys() { -    UISettings::values.shortcuts.clear(); -    for (auto group : hotkey_groups) { -        for (auto hotkey : group.second) { -            UISettings::values.shortcuts.emplace_back( -                UISettings::Shortcut(group.first + "/" + hotkey.first, -                                     UISettings::ContextualShortcut(hotkey.second.keyseq.toString(), -                                                                    hotkey.second.context))); -        } -    } -} - -void LoadHotkeys() { +void HotkeyRegistry::LoadHotkeys() {      // Make sure NOT to use a reference here because it would become invalid once we call      // beginGroup()      for (auto shortcut : UISettings::values.shortcuts) { -        QStringList cat = shortcut.first.split("/"); +        const QStringList cat = shortcut.first.split('/');          Q_ASSERT(cat.size() >= 2);          // RegisterHotkey assigns default keybindings, so use old values as default parameters          Hotkey& hk = hotkey_groups[cat[0]][cat[1]];          if (!shortcut.second.first.isEmpty()) {              hk.keyseq = QKeySequence::fromString(shortcut.second.first); -            hk.context = (Qt::ShortcutContext)shortcut.second.second; +            hk.context = static_cast<Qt::ShortcutContext>(shortcut.second.second);          }          if (hk.shortcut)              hk.shortcut->setKey(hk.keyseq);      }  } -void RegisterHotkey(const QString& group, const QString& action, const QKeySequence& default_keyseq, -                    Qt::ShortcutContext default_context) { -    if (hotkey_groups[group].find(action) == hotkey_groups[group].end()) { -        hotkey_groups[group][action].keyseq = default_keyseq; -        hotkey_groups[group][action].context = default_context; +void HotkeyRegistry::SaveHotkeys() { +    UISettings::values.shortcuts.clear(); +    for (const auto& group : hotkey_groups) { +        for (const auto& hotkey : group.second) { +            UISettings::values.shortcuts.emplace_back( +                UISettings::Shortcut(group.first + '/' + hotkey.first, +                                     UISettings::ContextualShortcut(hotkey.second.keyseq.toString(), +                                                                    hotkey.second.context))); +        }      }  } -QShortcut* GetHotkey(const QString& group, const QString& action, QWidget* widget) { +void HotkeyRegistry::RegisterHotkey(const QString& group, const QString& action, +                                    const QKeySequence& default_keyseq, +                                    Qt::ShortcutContext default_context) { +    auto& hotkey_group = hotkey_groups[group]; +    if (hotkey_group.find(action) != hotkey_group.end()) { +        return; +    } + +    auto& hotkey_action = hotkey_groups[group][action]; +    hotkey_action.keyseq = default_keyseq; +    hotkey_action.context = default_context; +} + +QShortcut* HotkeyRegistry::GetHotkey(const QString& group, const QString& action, QWidget* widget) {      Hotkey& hk = hotkey_groups[group][action];      if (!hk.shortcut) @@ -72,10 +67,12 @@ QShortcut* GetHotkey(const QString& group, const QString& action, QWidget* widge  GHotkeysDialog::GHotkeysDialog(QWidget* parent) : QWidget(parent) {      ui.setupUi(this); +} -    for (auto group : hotkey_groups) { +void GHotkeysDialog::Populate(const HotkeyRegistry& registry) { +    for (const auto& group : registry.hotkey_groups) {          QTreeWidgetItem* toplevel_item = new QTreeWidgetItem(QStringList(group.first)); -        for (auto hotkey : group.second) { +        for (const auto& hotkey : group.second) {              QStringList columns;              columns << hotkey.first << hotkey.second.keyseq.toString();              QTreeWidgetItem* item = new QTreeWidgetItem(columns); diff --git a/src/yuzu/hotkeys.h b/src/yuzu/hotkeys.h index a4ccc193b..f38e6c002 100644 --- a/src/yuzu/hotkeys.h +++ b/src/yuzu/hotkeys.h @@ -4,6 +4,7 @@  #pragma once +#include <map>  #include "ui_hotkeys.h"  class QDialog; @@ -11,47 +12,69 @@ class QKeySequence;  class QSettings;  class QShortcut; -/** - * Register a hotkey. - * - * @param group General group this hotkey belongs to (e.g. "Main Window", "Debugger") - * @param action Name of the action (e.g. "Start Emulation", "Load Image") - * @param default_keyseq Default key sequence to assign if the hotkey wasn't present in the settings - * file before - * @param default_context Default context to assign if the hotkey wasn't present in the settings - * file before - * @warning Both the group and action strings will be displayed in the hotkey settings dialog - */ -void RegisterHotkey(const QString& group, const QString& action, -                    const QKeySequence& default_keyseq = QKeySequence(), -                    Qt::ShortcutContext default_context = Qt::WindowShortcut); - -/** - * Returns a QShortcut object whose activated() signal can be connected to other QObjects' slots. - * - * @param group  General group this hotkey belongs to (e.g. "Main Window", "Debugger"). - * @param action Name of the action (e.g. "Start Emulation", "Load Image"). - * @param widget Parent widget of the returned QShortcut. - * @warning If multiple QWidgets' call this function for the same action, the returned QShortcut - * will be the same. Thus, you shouldn't rely on the caller really being the QShortcut's parent. - */ -QShortcut* GetHotkey(const QString& group, const QString& action, QWidget* widget); - -/** - * Saves all registered hotkeys to the settings file. - * - * @note Each hotkey group will be stored a settings group; For each hotkey inside that group, a - * settings group will be created to store the key sequence and the hotkey context. - */ -void SaveHotkeys(); - -/** - * Loads hotkeys from the settings file. - * - * @note Yet unregistered hotkeys which are present in the settings will automatically be - * registered. - */ -void LoadHotkeys(); +class HotkeyRegistry final { +public: +    friend class GHotkeysDialog; + +    explicit HotkeyRegistry(); +    ~HotkeyRegistry(); + +    /** +     * Loads hotkeys from the settings file. +     * +     * @note Yet unregistered hotkeys which are present in the settings will automatically be +     *       registered. +     */ +    void LoadHotkeys(); + +    /** +     * Saves all registered hotkeys to the settings file. +     * +     * @note Each hotkey group will be stored a settings group; For each hotkey inside that group, a +     *       settings group will be created to store the key sequence and the hotkey context. +     */ +    void SaveHotkeys(); + +    /** +     * Returns a QShortcut object whose activated() signal can be connected to other QObjects' +     * slots. +     * +     * @param group  General group this hotkey belongs to (e.g. "Main Window", "Debugger"). +     * @param action Name of the action (e.g. "Start Emulation", "Load Image"). +     * @param widget Parent widget of the returned QShortcut. +     * @warning If multiple QWidgets' call this function for the same action, the returned QShortcut +     *          will be the same. Thus, you shouldn't rely on the caller really being the +     *          QShortcut's parent. +     */ +    QShortcut* GetHotkey(const QString& group, const QString& action, QWidget* widget); + +    /** +     * Register a hotkey. +     * +     * @param group General group this hotkey belongs to (e.g. "Main Window", "Debugger") +     * @param action Name of the action (e.g. "Start Emulation", "Load Image") +     * @param default_keyseq Default key sequence to assign if the hotkey wasn't present in the +     *                       settings file before +     * @param default_context Default context to assign if the hotkey wasn't present in the settings +     *                        file before +     * @warning Both the group and action strings will be displayed in the hotkey settings dialog +     */ +    void RegisterHotkey(const QString& group, const QString& action, +                        const QKeySequence& default_keyseq = {}, +                        Qt::ShortcutContext default_context = Qt::WindowShortcut); + +private: +    struct Hotkey { +        QKeySequence keyseq; +        QShortcut* shortcut = nullptr; +        Qt::ShortcutContext context = Qt::WindowShortcut; +    }; + +    using HotkeyMap = std::map<QString, Hotkey>; +    using HotkeyGroupMap = std::map<QString, HotkeyMap>; + +    HotkeyGroupMap hotkey_groups; +};  class GHotkeysDialog : public QWidget {      Q_OBJECT @@ -59,6 +82,8 @@ class GHotkeysDialog : public QWidget {  public:      explicit GHotkeysDialog(QWidget* parent = nullptr); +    void Populate(const HotkeyRegistry& registry); +  private:      Ui::hotkeys ui;  }; diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp index eac41553a..17ed62c72 100644 --- a/src/yuzu/main.cpp +++ b/src/yuzu/main.cpp @@ -81,6 +81,8 @@ static void ShowCalloutMessage(const QString& message, CalloutFlag flag) {  void GMainWindow::ShowCallouts() {} +const int GMainWindow::max_recent_files_item; +  GMainWindow::GMainWindow() : config(new Config()), emu_thread(nullptr) {      debug_context = Tegra::DebugContext::Construct(); @@ -206,43 +208,46 @@ void GMainWindow::InitializeRecentFileMenuActions() {  }  void GMainWindow::InitializeHotkeys() { -    RegisterHotkey("Main Window", "Load File", QKeySequence::Open); -    RegisterHotkey("Main Window", "Start Emulation"); -    RegisterHotkey("Main Window", "Continue/Pause", QKeySequence(Qt::Key_F4)); -    RegisterHotkey("Main Window", "Fullscreen", QKeySequence::FullScreen); -    RegisterHotkey("Main Window", "Exit Fullscreen", QKeySequence(Qt::Key_Escape), -                   Qt::ApplicationShortcut); -    RegisterHotkey("Main Window", "Toggle Speed Limit", QKeySequence("CTRL+Z"), -                   Qt::ApplicationShortcut); -    LoadHotkeys(); - -    connect(GetHotkey("Main Window", "Load File", this), &QShortcut::activated, this, -            &GMainWindow::OnMenuLoadFile); -    connect(GetHotkey("Main Window", "Start Emulation", this), &QShortcut::activated, this, -            &GMainWindow::OnStartGame); -    connect(GetHotkey("Main Window", "Continue/Pause", this), &QShortcut::activated, this, [&] { -        if (emulation_running) { -            if (emu_thread->IsRunning()) { -                OnPauseGame(); -            } else { -                OnStartGame(); -            } -        } -    }); -    connect(GetHotkey("Main Window", "Fullscreen", render_window), &QShortcut::activated, -            ui.action_Fullscreen, &QAction::trigger); -    connect(GetHotkey("Main Window", "Fullscreen", render_window), &QShortcut::activatedAmbiguously, -            ui.action_Fullscreen, &QAction::trigger); -    connect(GetHotkey("Main Window", "Exit Fullscreen", this), &QShortcut::activated, this, [&] { -        if (emulation_running) { -            ui.action_Fullscreen->setChecked(false); -            ToggleFullscreen(); -        } -    }); -    connect(GetHotkey("Main Window", "Toggle Speed Limit", this), &QShortcut::activated, this, [&] { -        Settings::values.toggle_framelimit = !Settings::values.toggle_framelimit; -        UpdateStatusBar(); -    }); +    hotkey_registry.RegisterHotkey("Main Window", "Load File", QKeySequence::Open); +    hotkey_registry.RegisterHotkey("Main Window", "Start Emulation"); +    hotkey_registry.RegisterHotkey("Main Window", "Continue/Pause", QKeySequence(Qt::Key_F4)); +    hotkey_registry.RegisterHotkey("Main Window", "Fullscreen", QKeySequence::FullScreen); +    hotkey_registry.RegisterHotkey("Main Window", "Exit Fullscreen", QKeySequence(Qt::Key_Escape), +                                   Qt::ApplicationShortcut); +    hotkey_registry.RegisterHotkey("Main Window", "Toggle Speed Limit", QKeySequence("CTRL+Z"), +                                   Qt::ApplicationShortcut); +    hotkey_registry.LoadHotkeys(); + +    connect(hotkey_registry.GetHotkey("Main Window", "Load File", this), &QShortcut::activated, +            this, &GMainWindow::OnMenuLoadFile); +    connect(hotkey_registry.GetHotkey("Main Window", "Start Emulation", this), +            &QShortcut::activated, this, &GMainWindow::OnStartGame); +    connect(hotkey_registry.GetHotkey("Main Window", "Continue/Pause", this), &QShortcut::activated, +            this, [&] { +                if (emulation_running) { +                    if (emu_thread->IsRunning()) { +                        OnPauseGame(); +                    } else { +                        OnStartGame(); +                    } +                } +            }); +    connect(hotkey_registry.GetHotkey("Main Window", "Fullscreen", render_window), +            &QShortcut::activated, ui.action_Fullscreen, &QAction::trigger); +    connect(hotkey_registry.GetHotkey("Main Window", "Fullscreen", render_window), +            &QShortcut::activatedAmbiguously, ui.action_Fullscreen, &QAction::trigger); +    connect(hotkey_registry.GetHotkey("Main Window", "Exit Fullscreen", this), +            &QShortcut::activated, this, [&] { +                if (emulation_running) { +                    ui.action_Fullscreen->setChecked(false); +                    ToggleFullscreen(); +                } +            }); +    connect(hotkey_registry.GetHotkey("Main Window", "Toggle Speed Limit", this), +            &QShortcut::activated, this, [&] { +                Settings::values.toggle_framelimit = !Settings::values.toggle_framelimit; +                UpdateStatusBar(); +            });  }  void GMainWindow::SetDefaultUIGeometry() { @@ -321,7 +326,8 @@ void GMainWindow::ConnectMenuEvents() {      connect(ui.action_Show_Status_Bar, &QAction::triggered, statusBar(), &QStatusBar::setVisible);      // Fullscreen -    ui.action_Fullscreen->setShortcut(GetHotkey("Main Window", "Fullscreen", this)->key()); +    ui.action_Fullscreen->setShortcut( +        hotkey_registry.GetHotkey("Main Window", "Fullscreen", this)->key());      connect(ui.action_Fullscreen, &QAction::triggered, this, &GMainWindow::ToggleFullscreen);      // Help @@ -477,7 +483,7 @@ bool GMainWindow::LoadROM(const QString& filename) {          case Core::System::ResultStatus::ErrorVideoCore:              QMessageBox::critical( -                this, tr("An error occured in the video core."), +                this, tr("An error occurred initializing the video core."),                  tr("yuzu has encountered an error while running the video core, please see the "                     "log for more details."                     "For more information on accessing the log, please see the following page: " @@ -491,7 +497,7 @@ bool GMainWindow::LoadROM(const QString& filename) {          default:              QMessageBox::critical(                  this, tr("Error while loading ROM!"), -                tr("An unknown error occured. Please see the log for more details.")); +                tr("An unknown error occurred. Please see the log for more details."));              break;          }          return false; @@ -579,11 +585,11 @@ void GMainWindow::StoreRecentFile(const QString& filename) {  }  void GMainWindow::UpdateRecentFiles() { -    unsigned int num_recent_files = -        std::min(UISettings::values.recent_files.size(), static_cast<int>(max_recent_files_item)); +    const int num_recent_files = +        std::min(UISettings::values.recent_files.size(), max_recent_files_item); -    for (unsigned int i = 0; i < num_recent_files; i++) { -        QString text = QString("&%1. %2").arg(i + 1).arg( +    for (int i = 0; i < num_recent_files; i++) { +        const QString text = QString("&%1. %2").arg(i + 1).arg(              QFileInfo(UISettings::values.recent_files[i]).fileName());          actions_recent_files[i]->setText(text);          actions_recent_files[i]->setData(UISettings::values.recent_files[i]); @@ -595,12 +601,8 @@ void GMainWindow::UpdateRecentFiles() {          actions_recent_files[j]->setVisible(false);      } -    // Grey out the recent files menu if the list is empty -    if (num_recent_files == 0) { -        ui.menu_recent_files->setEnabled(false); -    } else { -        ui.menu_recent_files->setEnabled(true); -    } +    // Enable the recent files menu if the list isn't empty +    ui.menu_recent_files->setEnabled(num_recent_files != 0);  }  void GMainWindow::OnGameListLoadFile(QString game_path) { @@ -631,9 +633,15 @@ void GMainWindow::OnMenuLoadFile() {  }  void GMainWindow::OnMenuLoadFolder() { -    QDir dir = QFileDialog::getExistingDirectory(this, tr("Open Extracted ROM Directory")); +    const QString dir_path = +        QFileDialog::getExistingDirectory(this, tr("Open Extracted ROM Directory")); + +    if (dir_path.isNull()) { +        return; +    } -    QStringList matching_main = dir.entryList(QStringList("main"), QDir::Files); +    const QDir dir{dir_path}; +    const QStringList matching_main = dir.entryList(QStringList("main"), QDir::Files);      if (matching_main.size() == 1) {          BootGame(dir.path() + DIR_SEP + matching_main[0]);      } else { @@ -654,9 +662,8 @@ void GMainWindow::OnMenuRecentFile() {      QAction* action = qobject_cast<QAction*>(sender());      assert(action); -    QString filename = action->data().toString(); -    QFileInfo file_info(filename); -    if (file_info.exists()) { +    const QString filename = action->data().toString(); +    if (QFileInfo::exists(filename)) {          BootGame(filename);      } else {          // Display an error message and remove the file from the list. @@ -754,7 +761,7 @@ void GMainWindow::ToggleWindowMode() {  }  void GMainWindow::OnConfigure() { -    ConfigureDialog configureDialog(this); +    ConfigureDialog configureDialog(this, hotkey_registry);      auto old_theme = UISettings::values.theme;      auto result = configureDialog.exec();      if (result == QDialog::Accepted) { @@ -893,7 +900,7 @@ void GMainWindow::closeEvent(QCloseEvent* event) {      UISettings::values.first_start = false;      game_list->SaveInterfaceLayout(); -    SaveHotkeys(); +    hotkey_registry.SaveHotkeys();      // Shutdown session if the emu thread is active...      if (emu_thread != nullptr) @@ -947,15 +954,14 @@ void GMainWindow::UpdateUITheme() {      QStringList theme_paths(default_theme_paths);      if (UISettings::values.theme != UISettings::themes[0].second &&          !UISettings::values.theme.isEmpty()) { -        QString theme_uri(":" + UISettings::values.theme + "/style.qss"); +        const QString theme_uri(":" + UISettings::values.theme + "/style.qss");          QFile f(theme_uri); -        if (!f.exists()) { -            LOG_ERROR(Frontend, "Unable to set style, stylesheet file not found"); -        } else { -            f.open(QFile::ReadOnly | QFile::Text); +        if (f.open(QFile::ReadOnly | QFile::Text)) {              QTextStream ts(&f);              qApp->setStyleSheet(ts.readAll());              GMainWindow::setStyleSheet(ts.readAll()); +        } else { +            LOG_ERROR(Frontend, "Unable to set style, stylesheet file not found");          }          theme_paths.append(QStringList{":/icons/default", ":/icons/" + UISettings::values.theme});          QIcon::setThemeName(":/icons/" + UISettings::values.theme); diff --git a/src/yuzu/main.h b/src/yuzu/main.h index 074bba3f9..6e335b8f8 100644 --- a/src/yuzu/main.h +++ b/src/yuzu/main.h @@ -9,6 +9,7 @@  #include <QTimer>  #include "core/core.h"  #include "ui_main.h" +#include "yuzu/hotkeys.h"  class Config;  class EmuThread; @@ -43,7 +44,7 @@ public:      void filterBarSetChecked(bool state);      void UpdateUITheme();      GMainWindow(); -    ~GMainWindow(); +    ~GMainWindow() override;  signals: @@ -172,6 +173,8 @@ private:      // stores default icon theme search paths for the platform      QStringList default_theme_paths; +    HotkeyRegistry hotkey_registry; +  protected:      void dropEvent(QDropEvent* event) override;      void dragEnterEvent(QDragEnterEvent* event) override; | 
