diff options
Diffstat (limited to 'src/yuzu')
47 files changed, 491 insertions, 498 deletions
| diff --git a/src/yuzu/applets/profile_select.cpp b/src/yuzu/applets/profile_select.cpp index 7fbc9deeb..6b5c7ba61 100644 --- a/src/yuzu/applets/profile_select.cpp +++ b/src/yuzu/applets/profile_select.cpp @@ -27,20 +27,20 @@ constexpr std::array<u8, 107> backup_jpeg{      0x01, 0x01, 0x00, 0x00, 0x3f, 0x00, 0xd2, 0xcf, 0x20, 0xff, 0xd9,  }; -QString FormatUserEntryText(const QString& username, Service::Account::UUID uuid) { +QString FormatUserEntryText(const QString& username, Common::UUID uuid) {      return QtProfileSelectionDialog::tr(                 "%1\n%2", "%1 is the profile username, %2 is the formatted UUID (e.g. "                           "00112233-4455-6677-8899-AABBCCDDEEFF))")          .arg(username, QString::fromStdString(uuid.FormatSwitch()));  } -QString GetImagePath(Service::Account::UUID uuid) { +QString GetImagePath(Common::UUID uuid) {      const auto path = FileUtil::GetUserPath(FileUtil::UserPath::NANDDir) +                        "/system/save/8000000000000010/su/avators/" + uuid.FormatSwitch() + ".jpg";      return QString::fromStdString(path);  } -QPixmap GetIcon(Service::Account::UUID uuid) { +QPixmap GetIcon(Common::UUID uuid) {      QPixmap icon{GetImagePath(uuid)};      if (!icon) { @@ -122,21 +122,15 @@ QtProfileSelectionDialog::QtProfileSelectionDialog(QWidget* parent)  QtProfileSelectionDialog::~QtProfileSelectionDialog() = default;  void QtProfileSelectionDialog::accept() { -    ok = true;      QDialog::accept();  }  void QtProfileSelectionDialog::reject() { -    ok = false;      user_index = 0;      QDialog::reject();  } -bool QtProfileSelectionDialog::GetStatus() const { -    return ok; -} - -u32 QtProfileSelectionDialog::GetIndex() const { +int QtProfileSelectionDialog::GetIndex() const {      return user_index;  } @@ -154,12 +148,12 @@ QtProfileSelector::QtProfileSelector(GMainWindow& parent) {  QtProfileSelector::~QtProfileSelector() = default;  void QtProfileSelector::SelectProfile( -    std::function<void(std::optional<Service::Account::UUID>)> callback) const { +    std::function<void(std::optional<Common::UUID>)> callback) const {      this->callback = std::move(callback);      emit MainWindowSelectProfile();  } -void QtProfileSelector::MainWindowFinishedSelection(std::optional<Service::Account::UUID> uuid) { +void QtProfileSelector::MainWindowFinishedSelection(std::optional<Common::UUID> uuid) {      // Acquire the HLE mutex      std::lock_guard lock{HLE::g_hle_lock};      callback(uuid); diff --git a/src/yuzu/applets/profile_select.h b/src/yuzu/applets/profile_select.h index 1c2922e54..cee886a77 100644 --- a/src/yuzu/applets/profile_select.h +++ b/src/yuzu/applets/profile_select.h @@ -9,6 +9,7 @@  #include <QList>  #include <QTreeView>  #include "core/frontend/applets/profile_select.h" +#include "core/hle/service/acc/profile_manager.h"  class GMainWindow;  class QDialogButtonBox; @@ -29,15 +30,13 @@ public:      void accept() override;      void reject() override; -    bool GetStatus() const; -    u32 GetIndex() const; +    int GetIndex() const;  private: -    bool ok = false; -    u32 user_index = 0; -      void SelectUser(const QModelIndex& index); +    int user_index = 0; +      QVBoxLayout* layout;      QTreeView* tree_view;      QStandardItemModel* item_model; @@ -60,14 +59,13 @@ public:      explicit QtProfileSelector(GMainWindow& parent);      ~QtProfileSelector() override; -    void SelectProfile( -        std::function<void(std::optional<Service::Account::UUID>)> callback) const override; +    void SelectProfile(std::function<void(std::optional<Common::UUID>)> callback) const override;  signals:      void MainWindowSelectProfile() const;  private: -    void MainWindowFinishedSelection(std::optional<Service::Account::UUID> uuid); +    void MainWindowFinishedSelection(std::optional<Common::UUID> uuid); -    mutable std::function<void(std::optional<Service::Account::UUID>)> callback; +    mutable std::function<void(std::optional<Common::UUID>)> callback;  }; diff --git a/src/yuzu/applets/software_keyboard.cpp b/src/yuzu/applets/software_keyboard.cpp index 5223ec977..af36f07c6 100644 --- a/src/yuzu/applets/software_keyboard.cpp +++ b/src/yuzu/applets/software_keyboard.cpp @@ -104,13 +104,11 @@ QtSoftwareKeyboardDialog::QtSoftwareKeyboardDialog(  QtSoftwareKeyboardDialog::~QtSoftwareKeyboardDialog() = default;  void QtSoftwareKeyboardDialog::accept() { -    ok = true;      text = line_edit->text().toStdU16String();      QDialog::accept();  }  void QtSoftwareKeyboardDialog::reject() { -    ok = false;      text.clear();      QDialog::reject();  } @@ -119,10 +117,6 @@ std::u16string QtSoftwareKeyboardDialog::GetText() const {      return text;  } -bool QtSoftwareKeyboardDialog::GetStatus() const { -    return ok; -} -  QtSoftwareKeyboard::QtSoftwareKeyboard(GMainWindow& main_window) {      connect(this, &QtSoftwareKeyboard::MainWindowGetText, &main_window,              &GMainWindow::SoftwareKeyboardGetText, Qt::QueuedConnection); diff --git a/src/yuzu/applets/software_keyboard.h b/src/yuzu/applets/software_keyboard.h index 78c5a042b..44bcece75 100644 --- a/src/yuzu/applets/software_keyboard.h +++ b/src/yuzu/applets/software_keyboard.h @@ -36,10 +36,8 @@ public:      void reject() override;      std::u16string GetText() const; -    bool GetStatus() const;  private: -    bool ok = false;      std::u16string text;      QDialogButtonBox* buttons; diff --git a/src/yuzu/bootmanager.cpp b/src/yuzu/bootmanager.cpp index eeee603d1..afec33b61 100644 --- a/src/yuzu/bootmanager.cpp +++ b/src/yuzu/bootmanager.cpp @@ -26,6 +26,8 @@  EmuThread::EmuThread(GRenderWindow* render_window) : render_window(render_window) {} +EmuThread::~EmuThread() = default; +  void EmuThread::run() {      render_window->MakeCurrent(); @@ -185,7 +187,7 @@ private:      bool do_painting;  }; -GRenderWindow::GRenderWindow(QWidget* parent, EmuThread* emu_thread) +GRenderWindow::GRenderWindow(GMainWindow* parent, EmuThread* emu_thread)      : QWidget(parent), emu_thread(emu_thread) {      setWindowTitle(QStringLiteral("yuzu %1 | %2-%3")                         .arg(QString::fromUtf8(Common::g_build_name), @@ -194,8 +196,7 @@ GRenderWindow::GRenderWindow(QWidget* parent, EmuThread* emu_thread)      setAttribute(Qt::WA_AcceptTouchEvents);      InputCommon::Init(); -    connect(this, &GRenderWindow::FirstFrameDisplayed, static_cast<GMainWindow*>(parent), -            &GMainWindow::OnLoadComplete); +    connect(this, &GRenderWindow::FirstFrameDisplayed, parent, &GMainWindow::OnLoadComplete);  }  GRenderWindow::~GRenderWindow() { @@ -247,9 +248,9 @@ void GRenderWindow::PollEvents() {}  void GRenderWindow::OnFramebufferSizeChanged() {      // Screen changes potentially incur a change in screen DPI, hence we should update the      // framebuffer size -    qreal pixelRatio = GetWindowPixelRatio(); -    unsigned width = child->QPaintDevice::width() * pixelRatio; -    unsigned height = child->QPaintDevice::height() * pixelRatio; +    const qreal pixel_ratio = GetWindowPixelRatio(); +    const u32 width = child->QPaintDevice::width() * pixel_ratio; +    const u32 height = child->QPaintDevice::height() * pixel_ratio;      UpdateCurrentFramebufferLayout(width, height);  } @@ -266,7 +267,7 @@ void GRenderWindow::ForwardKeyReleaseEvent(QKeyEvent* event) {  }  void GRenderWindow::BackupGeometry() { -    geometry = ((QWidget*)this)->saveGeometry(); +    geometry = QWidget::saveGeometry();  }  void GRenderWindow::RestoreGeometry() { @@ -283,10 +284,11 @@ void GRenderWindow::restoreGeometry(const QByteArray& geometry) {  QByteArray GRenderWindow::saveGeometry() {      // If we are a top-level widget, store the current geometry      // otherwise, store the last backup -    if (parent() == nullptr) -        return ((QWidget*)this)->saveGeometry(); -    else -        return geometry; +    if (parent() == nullptr) { +        return QWidget::saveGeometry(); +    } + +    return geometry;  }  qreal GRenderWindow::GetWindowPixelRatio() const { @@ -294,10 +296,10 @@ qreal GRenderWindow::GetWindowPixelRatio() const {      return windowHandle() ? windowHandle()->screen()->devicePixelRatio() : 1.0f;  } -std::pair<unsigned, unsigned> GRenderWindow::ScaleTouch(const QPointF pos) const { +std::pair<u32, u32> GRenderWindow::ScaleTouch(const QPointF pos) const {      const qreal pixel_ratio = GetWindowPixelRatio(); -    return {static_cast<unsigned>(std::max(std::round(pos.x() * pixel_ratio), qreal{0.0})), -            static_cast<unsigned>(std::max(std::round(pos.y() * pixel_ratio), qreal{0.0}))}; +    return {static_cast<u32>(std::max(std::round(pos.x() * pixel_ratio), qreal{0.0})), +            static_cast<u32>(std::max(std::round(pos.y() * pixel_ratio), qreal{0.0}))};  }  void GRenderWindow::closeEvent(QCloseEvent* event) { @@ -353,7 +355,7 @@ void GRenderWindow::focusOutEvent(QFocusEvent* event) {      InputCommon::GetKeyboard()->ReleaseAllKeys();  } -void GRenderWindow::OnClientAreaResized(unsigned width, unsigned height) { +void GRenderWindow::OnClientAreaResized(u32 width, u32 height) {      NotifyClientAreaSizeChanged(std::make_pair(width, height));  } @@ -394,7 +396,7 @@ void GRenderWindow::InitRenderTarget() {      context->setShareContext(shared_context.get());      context->setFormat(fmt);      context->create(); -    fmt.setSwapInterval(false); +    fmt.setSwapInterval(0);      child = new GGLWidgetInternal(this, shared_context.get());      container = QWidget::createWindowContainer(child, this); @@ -424,24 +426,29 @@ void GRenderWindow::InitRenderTarget() {      BackupGeometry();  } -void GRenderWindow::CaptureScreenshot(u16 res_scale, const QString& screenshot_path) { +void GRenderWindow::CaptureScreenshot(u32 res_scale, const QString& screenshot_path) {      auto& renderer = Core::System::GetInstance().Renderer(); -    if (!res_scale) +    if (res_scale == 0) {          res_scale = VideoCore::GetResolutionScaleFactor(renderer); +    }      const Layout::FramebufferLayout layout{Layout::FrameLayoutFromResolutionScale(res_scale)};      screenshot_image = QImage(QSize(layout.width, layout.height), QImage::Format_RGB32); -    renderer.RequestScreenshot(screenshot_image.bits(), -                               [=] { -                                   screenshot_image.mirrored(false, true).save(screenshot_path); -                                   LOG_INFO(Frontend, "The screenshot is saved."); -                               }, -                               layout); +    renderer.RequestScreenshot( +        screenshot_image.bits(), +        [=] { +            const std::string std_screenshot_path = screenshot_path.toStdString(); +            if (screenshot_image.mirrored(false, true).save(screenshot_path)) { +                LOG_INFO(Frontend, "Screenshot saved to \"{}\"", std_screenshot_path); +            } else { +                LOG_ERROR(Frontend, "Failed to save screenshot to \"{}\"", std_screenshot_path); +            } +        }, +        layout);  } -void GRenderWindow::OnMinimalClientAreaChangeRequest( -    const std::pair<unsigned, unsigned>& minimal_size) { +void GRenderWindow::OnMinimalClientAreaChangeRequest(std::pair<u32, u32> minimal_size) {      setMinimumSize(minimal_size.first, minimal_size.second);  } diff --git a/src/yuzu/bootmanager.h b/src/yuzu/bootmanager.h index 3df33aca1..2fc64895f 100644 --- a/src/yuzu/bootmanager.h +++ b/src/yuzu/bootmanager.h @@ -27,11 +27,12 @@ namespace VideoCore {  enum class LoadCallbackStage;  } -class EmuThread : public QThread { +class EmuThread final : public QThread {      Q_OBJECT  public:      explicit EmuThread(GRenderWindow* render_window); +    ~EmuThread() override;      /**       * Start emulation (on new thread) @@ -114,7 +115,7 @@ class GRenderWindow : public QWidget, public Core::Frontend::EmuWindow {      Q_OBJECT  public: -    GRenderWindow(QWidget* parent, EmuThread* emu_thread); +    GRenderWindow(GMainWindow* parent, EmuThread* emu_thread);      ~GRenderWindow() override;      // EmuWindow implementation @@ -133,17 +134,17 @@ public:      QByteArray saveGeometry();                        // overridden      qreal GetWindowPixelRatio() const; -    std::pair<unsigned, unsigned> ScaleTouch(const QPointF pos) const; +    std::pair<u32, u32> ScaleTouch(QPointF pos) const;      void closeEvent(QCloseEvent* event) override;      bool event(QEvent* event) override;      void focusOutEvent(QFocusEvent* event) override; -    void OnClientAreaResized(unsigned width, unsigned height); +    void OnClientAreaResized(u32 width, u32 height);      void InitRenderTarget(); -    void CaptureScreenshot(u16 res_scale, const QString& screenshot_path); +    void CaptureScreenshot(u32 res_scale, const QString& screenshot_path);  public slots:      void moveContext(); // overridden @@ -162,8 +163,7 @@ private:      void TouchUpdateEvent(const QTouchEvent* event);      void TouchEndEvent(); -    void OnMinimalClientAreaChangeRequest( -        const std::pair<unsigned, unsigned>& minimal_size) override; +    void OnMinimalClientAreaChangeRequest(std::pair<u32, u32> minimal_size) override;      QWidget* container = nullptr;      GGLWidgetInternal* child = nullptr; diff --git a/src/yuzu/configuration/config.cpp b/src/yuzu/configuration/config.cpp index db27da23e..b1942bedc 100644 --- a/src/yuzu/configuration/config.cpp +++ b/src/yuzu/configuration/config.cpp @@ -645,6 +645,8 @@ void Config::ReadUIGamelistValues() {      UISettings::values.icon_size = ReadSetting(QStringLiteral("icon_size"), 64).toUInt();      UISettings::values.row_1_text_id = ReadSetting(QStringLiteral("row_1_text_id"), 3).toUInt();      UISettings::values.row_2_text_id = ReadSetting(QStringLiteral("row_2_text_id"), 2).toUInt(); +    UISettings::values.cache_game_list = +        ReadSetting(QStringLiteral("cache_game_list"), true).toBool();      qt_config->endGroup();  } @@ -1009,6 +1011,7 @@ void Config::SaveUIGamelistValues() {      WriteSetting(QStringLiteral("icon_size"), UISettings::values.icon_size, 64);      WriteSetting(QStringLiteral("row_1_text_id"), UISettings::values.row_1_text_id, 3);      WriteSetting(QStringLiteral("row_2_text_id"), UISettings::values.row_2_text_id, 2); +    WriteSetting(QStringLiteral("cache_game_list"), UISettings::values.cache_game_list, true);      qt_config->endGroup();  } diff --git a/src/yuzu/configuration/configure_audio.cpp b/src/yuzu/configuration/configure_audio.cpp index b0f9b814d..110842eb2 100644 --- a/src/yuzu/configuration/configure_audio.cpp +++ b/src/yuzu/configuration/configure_audio.cpp @@ -22,11 +22,11 @@ ConfigureAudio::ConfigureAudio(QWidget* parent)      }      connect(ui->volume_slider, &QSlider::valueChanged, this, -            &ConfigureAudio::setVolumeIndicatorText); +            &ConfigureAudio::SetVolumeIndicatorText); -    this->setConfiguration(); +    SetConfiguration();      connect(ui->output_sink_combo_box, qOverload<int>(&QComboBox::currentIndexChanged), this, -            &ConfigureAudio::updateAudioDevices); +            &ConfigureAudio::UpdateAudioDevices);      const bool is_powered_on = Core::System::GetInstance().IsPoweredOn();      ui->output_sink_combo_box->setEnabled(!is_powered_on); @@ -35,20 +35,20 @@ ConfigureAudio::ConfigureAudio(QWidget* parent)  ConfigureAudio::~ConfigureAudio() = default; -void ConfigureAudio::setConfiguration() { -    setOutputSinkFromSinkID(); +void ConfigureAudio::SetConfiguration() { +    SetOutputSinkFromSinkID();      // The device list cannot be pre-populated (nor listed) until the output sink is known. -    updateAudioDevices(ui->output_sink_combo_box->currentIndex()); +    UpdateAudioDevices(ui->output_sink_combo_box->currentIndex()); -    setAudioDeviceFromDeviceID(); +    SetAudioDeviceFromDeviceID();      ui->toggle_audio_stretching->setChecked(Settings::values.enable_audio_stretching);      ui->volume_slider->setValue(Settings::values.volume * ui->volume_slider->maximum()); -    setVolumeIndicatorText(ui->volume_slider->sliderPosition()); +    SetVolumeIndicatorText(ui->volume_slider->sliderPosition());  } -void ConfigureAudio::setOutputSinkFromSinkID() { +void ConfigureAudio::SetOutputSinkFromSinkID() {      int new_sink_index = 0;      const QString sink_id = QString::fromStdString(Settings::values.sink_id); @@ -62,7 +62,7 @@ void ConfigureAudio::setOutputSinkFromSinkID() {      ui->output_sink_combo_box->setCurrentIndex(new_sink_index);  } -void ConfigureAudio::setAudioDeviceFromDeviceID() { +void ConfigureAudio::SetAudioDeviceFromDeviceID() {      int new_device_index = -1;      const QString device_id = QString::fromStdString(Settings::values.audio_device_id); @@ -76,11 +76,11 @@ void ConfigureAudio::setAudioDeviceFromDeviceID() {      ui->audio_device_combo_box->setCurrentIndex(new_device_index);  } -void ConfigureAudio::setVolumeIndicatorText(int percentage) { +void ConfigureAudio::SetVolumeIndicatorText(int percentage) {      ui->volume_indicator->setText(tr("%1%", "Volume percentage (e.g. 50%)").arg(percentage));  } -void ConfigureAudio::applyConfiguration() { +void ConfigureAudio::ApplyConfiguration() {      Settings::values.sink_id =          ui->output_sink_combo_box->itemText(ui->output_sink_combo_box->currentIndex())              .toStdString(); @@ -92,7 +92,7 @@ void ConfigureAudio::applyConfiguration() {          static_cast<float>(ui->volume_slider->sliderPosition()) / ui->volume_slider->maximum();  } -void ConfigureAudio::updateAudioDevices(int sink_index) { +void ConfigureAudio::UpdateAudioDevices(int sink_index) {      ui->audio_device_combo_box->clear();      ui->audio_device_combo_box->addItem(QString::fromUtf8(AudioCore::auto_device_name)); @@ -102,6 +102,6 @@ void ConfigureAudio::updateAudioDevices(int sink_index) {      }  } -void ConfigureAudio::retranslateUi() { +void ConfigureAudio::RetranslateUI() {      ui->retranslateUi(this);  } diff --git a/src/yuzu/configuration/configure_audio.h b/src/yuzu/configuration/configure_audio.h index 8771421c0..2bb92d9b5 100644 --- a/src/yuzu/configuration/configure_audio.h +++ b/src/yuzu/configuration/configure_audio.h @@ -18,16 +18,16 @@ public:      explicit ConfigureAudio(QWidget* parent = nullptr);      ~ConfigureAudio() override; -    void applyConfiguration(); -    void retranslateUi(); +    void ApplyConfiguration(); +    void RetranslateUI();  private: -    void updateAudioDevices(int sink_index); +    void UpdateAudioDevices(int sink_index); -    void setConfiguration(); -    void setOutputSinkFromSinkID(); -    void setAudioDeviceFromDeviceID(); -    void setVolumeIndicatorText(int percentage); +    void SetConfiguration(); +    void SetOutputSinkFromSinkID(); +    void SetAudioDeviceFromDeviceID(); +    void SetVolumeIndicatorText(int percentage);      std::unique_ptr<Ui::ConfigureAudio> ui;  }; diff --git a/src/yuzu/configuration/configure_audio.ui b/src/yuzu/configuration/configure_audio.ui index a29a0e265..a098b9acc 100644 --- a/src/yuzu/configuration/configure_audio.ui +++ b/src/yuzu/configuration/configure_audio.ui @@ -20,7 +20,7 @@        <item>         <layout class="QHBoxLayout">          <item> -         <widget class="QLabel" name="label"> +         <widget class="QLabel" name="label_1">            <property name="text">             <string>Output Engine:</string>            </property> @@ -44,7 +44,7 @@        <item>         <layout class="QHBoxLayout">          <item> -         <widget class="QLabel" name="label"> +         <widget class="QLabel" name="label_2">            <property name="text">             <string>Audio Device:</string>            </property> @@ -61,7 +61,7 @@           <number>0</number>          </property>          <item> -         <widget class="QLabel" name="label"> +         <widget class="QLabel" name="label_3">            <property name="text">             <string>Volume:</string>            </property> diff --git a/src/yuzu/configuration/configure_debug.cpp b/src/yuzu/configuration/configure_debug.cpp index 550cf9dca..afc2e3b38 100644 --- a/src/yuzu/configuration/configure_debug.cpp +++ b/src/yuzu/configuration/configure_debug.cpp @@ -16,7 +16,8 @@  ConfigureDebug::ConfigureDebug(QWidget* parent) : QWidget(parent), ui(new Ui::ConfigureDebug) {      ui->setupUi(this); -    this->setConfiguration(); +    SetConfiguration(); +      connect(ui->open_log_button, &QPushButton::pressed, []() {          QString path = QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::LogDir));          QDesktopServices::openUrl(QUrl::fromLocalFile(path)); @@ -25,7 +26,7 @@ ConfigureDebug::ConfigureDebug(QWidget* parent) : QWidget(parent), ui(new Ui::Co  ConfigureDebug::~ConfigureDebug() = default; -void ConfigureDebug::setConfiguration() { +void ConfigureDebug::SetConfiguration() {      ui->toggle_gdbstub->setChecked(Settings::values.use_gdbstub);      ui->gdbport_spinbox->setEnabled(Settings::values.use_gdbstub);      ui->gdbport_spinbox->setValue(Settings::values.gdbstub_port); @@ -37,7 +38,7 @@ void ConfigureDebug::setConfiguration() {      ui->dump_decompressed_nso->setChecked(Settings::values.dump_nso);  } -void ConfigureDebug::applyConfiguration() { +void ConfigureDebug::ApplyConfiguration() {      Settings::values.use_gdbstub = ui->toggle_gdbstub->isChecked();      Settings::values.gdbstub_port = ui->gdbport_spinbox->value();      UISettings::values.show_console = ui->toggle_console->isChecked(); diff --git a/src/yuzu/configuration/configure_debug.h b/src/yuzu/configuration/configure_debug.h index c6420b18c..06b89026c 100644 --- a/src/yuzu/configuration/configure_debug.h +++ b/src/yuzu/configuration/configure_debug.h @@ -18,10 +18,10 @@ public:      explicit ConfigureDebug(QWidget* parent = nullptr);      ~ConfigureDebug() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private: -    void setConfiguration(); +    void SetConfiguration();      std::unique_ptr<Ui::ConfigureDebug> ui;  }; diff --git a/src/yuzu/configuration/configure_debug.ui b/src/yuzu/configuration/configure_debug.ui index 758a92335..5ca9ce0e6 100644 --- a/src/yuzu/configuration/configure_debug.ui +++ b/src/yuzu/configuration/configure_debug.ui @@ -45,7 +45,7 @@             </spacer>            </item>            <item> -           <widget class="QLabel" name="label_2"> +           <widget class="QLabel" name="label_1">              <property name="text">               <string>Port:</string>              </property> @@ -70,11 +70,11 @@       <property name="title">        <string>Logging</string>       </property> -     <layout class="QVBoxLayout" name="verticalLayout"> +     <layout class="QVBoxLayout" name="verticalLayout_4">        <item> -       <layout class="QHBoxLayout" name="horizontalLayout"> +       <layout class="QHBoxLayout" name="horizontalLayout_2">          <item> -         <widget class="QLabel" name="label"> +         <widget class="QLabel" name="label_2">            <property name="text">             <string>Global Log Filter</string>            </property> @@ -86,7 +86,7 @@         </layout>        </item>        <item> -       <layout class="QHBoxLayout" name="horizontalLayout_2"> +       <layout class="QHBoxLayout" name="horizontalLayout_3">          <item>           <widget class="QCheckBox" name="toggle_console">            <property name="text"> @@ -111,11 +111,11 @@       <property name="title">        <string>Homebrew</string>       </property> -     <layout class="QVBoxLayout" name="verticalLayout"> +     <layout class="QVBoxLayout" name="verticalLayout_5">        <item> -       <layout class="QHBoxLayout" name="horizontalLayout"> +       <layout class="QHBoxLayout" name="horizontalLayout_4">          <item> -         <widget class="QLabel" name="label"> +         <widget class="QLabel" name="label_3">            <property name="text">             <string>Arguments String</string>            </property> @@ -134,7 +134,7 @@       <property name="title">        <string>Dump</string>       </property> -     <layout class="QVBoxLayout" name="verticalLayout_4"> +     <layout class="QVBoxLayout" name="verticalLayout_6">        <item>         <widget class="QCheckBox" name="dump_decompressed_nso">          <property name="whatsThis"> diff --git a/src/yuzu/configuration/configure_dialog.cpp b/src/yuzu/configuration/configure_dialog.cpp index 8086f9d6b..a1b1e00bc 100644 --- a/src/yuzu/configuration/configure_dialog.cpp +++ b/src/yuzu/configuration/configure_dialog.cpp @@ -15,11 +15,11 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry)      : QDialog(parent), ui(new Ui::ConfigureDialog), registry(registry) {      ui->setupUi(this);      ui->hotkeysTab->Populate(registry); -    this->setConfiguration(); -    this->PopulateSelectionList(); -      setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint); +    SetConfiguration(); +    PopulateSelectionList(); +      connect(ui->selectorList, &QListWidget::itemSelectionChanged, this,              &ConfigureDialog::UpdateVisibleTabs); @@ -29,19 +29,19 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry)  ConfigureDialog::~ConfigureDialog() = default; -void ConfigureDialog::setConfiguration() {} - -void ConfigureDialog::applyConfiguration() { -    ui->generalTab->applyConfiguration(); -    ui->gameListTab->applyConfiguration(); -    ui->systemTab->applyConfiguration(); -    ui->profileManagerTab->applyConfiguration(); -    ui->inputTab->applyConfiguration(); -    ui->hotkeysTab->applyConfiguration(registry); -    ui->graphicsTab->applyConfiguration(); -    ui->audioTab->applyConfiguration(); -    ui->debugTab->applyConfiguration(); -    ui->webTab->applyConfiguration(); +void ConfigureDialog::SetConfiguration() {} + +void ConfigureDialog::ApplyConfiguration() { +    ui->generalTab->ApplyConfiguration(); +    ui->gameListTab->ApplyConfiguration(); +    ui->systemTab->ApplyConfiguration(); +    ui->profileManagerTab->ApplyConfiguration(); +    ui->inputTab->ApplyConfiguration(); +    ui->hotkeysTab->ApplyConfiguration(registry); +    ui->graphicsTab->ApplyConfiguration(); +    ui->audioTab->ApplyConfiguration(); +    ui->debugTab->ApplyConfiguration(); +    ui->webTab->ApplyConfiguration();      Settings::Apply();      Settings::LogSettings();  } diff --git a/src/yuzu/configuration/configure_dialog.h b/src/yuzu/configuration/configure_dialog.h index 2363ba584..7e7d90f59 100644 --- a/src/yuzu/configuration/configure_dialog.h +++ b/src/yuzu/configuration/configure_dialog.h @@ -20,10 +20,10 @@ public:      explicit ConfigureDialog(QWidget* parent, HotkeyRegistry& registry);      ~ConfigureDialog() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private: -    void setConfiguration(); +    void SetConfiguration();      void UpdateVisibleTabs();      void PopulateSelectionList(); diff --git a/src/yuzu/configuration/configure_gamelist.cpp b/src/yuzu/configuration/configure_gamelist.cpp index 6f0d75605..4b5b0ee48 100644 --- a/src/yuzu/configuration/configure_gamelist.cpp +++ b/src/yuzu/configuration/configure_gamelist.cpp @@ -12,20 +12,20 @@  #include "yuzu/ui_settings.h"  namespace { -constexpr std::array<std::pair<u32, const char*>, 5> default_icon_sizes{{ +constexpr std::array default_icon_sizes{      std::make_pair(0, QT_TR_NOOP("None")),      std::make_pair(32, QT_TR_NOOP("Small (32x32)")),      std::make_pair(64, QT_TR_NOOP("Standard (64x64)")),      std::make_pair(128, QT_TR_NOOP("Large (128x128)")),      std::make_pair(256, QT_TR_NOOP("Full Size (256x256)")), -}}; +}; -constexpr std::array<const char*, 4> row_text_names{{ +constexpr std::array row_text_names{      QT_TR_NOOP("Filename"),      QT_TR_NOOP("Filetype"),      QT_TR_NOOP("Title ID"),      QT_TR_NOOP("Title Name"), -}}; +};  } // Anonymous namespace  ConfigureGameList::ConfigureGameList(QWidget* parent) @@ -35,7 +35,7 @@ ConfigureGameList::ConfigureGameList(QWidget* parent)      InitializeIconSizeComboBox();      InitializeRowComboBoxes(); -    this->setConfiguration(); +    SetConfiguration();      // Force game list reload if any of the relevant settings are changed.      connect(ui->show_unknown, &QCheckBox::stateChanged, this, @@ -50,7 +50,7 @@ ConfigureGameList::ConfigureGameList(QWidget* parent)  ConfigureGameList::~ConfigureGameList() = default; -void ConfigureGameList::applyConfiguration() { +void ConfigureGameList::ApplyConfiguration() {      UISettings::values.show_unknown = ui->show_unknown->isChecked();      UISettings::values.show_add_ons = ui->show_add_ons->isChecked();      UISettings::values.icon_size = ui->icon_size_combobox->currentData().toUInt(); @@ -63,7 +63,7 @@ void ConfigureGameList::RequestGameListUpdate() {      UISettings::values.is_game_list_reload_pending.exchange(true);  } -void ConfigureGameList::setConfiguration() { +void ConfigureGameList::SetConfiguration() {      ui->show_unknown->setChecked(UISettings::values.show_unknown);      ui->show_add_ons->setChecked(UISettings::values.show_add_ons);      ui->icon_size_combobox->setCurrentIndex( diff --git a/src/yuzu/configuration/configure_gamelist.h b/src/yuzu/configuration/configure_gamelist.h index bf3f1cdfa..e11822919 100644 --- a/src/yuzu/configuration/configure_gamelist.h +++ b/src/yuzu/configuration/configure_gamelist.h @@ -18,12 +18,12 @@ public:      explicit ConfigureGameList(QWidget* parent = nullptr);      ~ConfigureGameList() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private:      void RequestGameListUpdate(); -    void setConfiguration(); +    void SetConfiguration();      void changeEvent(QEvent*) override;      void RetranslateUI(); diff --git a/src/yuzu/configuration/configure_general.cpp b/src/yuzu/configuration/configure_general.cpp index dd25dc6e1..8bdc1787a 100644 --- a/src/yuzu/configuration/configure_general.cpp +++ b/src/yuzu/configuration/configure_general.cpp @@ -18,7 +18,7 @@ ConfigureGeneral::ConfigureGeneral(QWidget* parent)                                      QString::fromUtf8(theme.second));      } -    this->setConfiguration(); +    SetConfiguration();      connect(ui->toggle_deepscan, &QCheckBox::stateChanged, this,              [] { UISettings::values.is_game_list_reload_pending.exchange(true); }); @@ -28,7 +28,7 @@ ConfigureGeneral::ConfigureGeneral(QWidget* parent)  ConfigureGeneral::~ConfigureGeneral() = default; -void ConfigureGeneral::setConfiguration() { +void ConfigureGeneral::SetConfiguration() {      ui->toggle_deepscan->setChecked(UISettings::values.game_directory_deepscan);      ui->toggle_check_exit->setChecked(UISettings::values.confirm_before_closing);      ui->toggle_user_on_boot->setChecked(UISettings::values.select_user_on_boot); @@ -36,7 +36,7 @@ void ConfigureGeneral::setConfiguration() {      ui->use_cpu_jit->setChecked(Settings::values.use_cpu_jit);  } -void ConfigureGeneral::applyConfiguration() { +void ConfigureGeneral::ApplyConfiguration() {      UISettings::values.game_directory_deepscan = ui->toggle_deepscan->isChecked();      UISettings::values.confirm_before_closing = ui->toggle_check_exit->isChecked();      UISettings::values.select_user_on_boot = ui->toggle_user_on_boot->isChecked(); diff --git a/src/yuzu/configuration/configure_general.h b/src/yuzu/configuration/configure_general.h index df41d995b..fd5fd2a91 100644 --- a/src/yuzu/configuration/configure_general.h +++ b/src/yuzu/configuration/configure_general.h @@ -20,10 +20,10 @@ public:      explicit ConfigureGeneral(QWidget* parent = nullptr);      ~ConfigureGeneral() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private: -    void setConfiguration(); +    void SetConfiguration();      std::unique_ptr<Ui::ConfigureGeneral> ui;  }; diff --git a/src/yuzu/configuration/configure_graphics.cpp b/src/yuzu/configuration/configure_graphics.cpp index 08ea41b0f..02e91701a 100644 --- a/src/yuzu/configuration/configure_graphics.cpp +++ b/src/yuzu/configuration/configure_graphics.cpp @@ -51,29 +51,29 @@ Resolution FromResolutionFactor(float factor) {  ConfigureGraphics::ConfigureGraphics(QWidget* parent)      : QWidget(parent), ui(new Ui::ConfigureGraphics) { -      ui->setupUi(this); -    this->setConfiguration(); -    ui->frame_limit->setEnabled(Settings::values.use_frame_limit); -    connect(ui->toggle_frame_limit, &QCheckBox::stateChanged, ui->frame_limit, -            &QSpinBox::setEnabled); +    SetConfiguration(); + +    connect(ui->toggle_frame_limit, &QCheckBox::toggled, ui->frame_limit, &QSpinBox::setEnabled);      connect(ui->bg_button, &QPushButton::clicked, this, [this] {          const QColor new_bg_color = QColorDialog::getColor(bg_color); -        if (!new_bg_color.isValid()) +        if (!new_bg_color.isValid()) {              return; +        }          UpdateBackgroundColorButton(new_bg_color);      });  }  ConfigureGraphics::~ConfigureGraphics() = default; -void ConfigureGraphics::setConfiguration() { +void ConfigureGraphics::SetConfiguration() {      const bool runtime_lock = !Core::System::GetInstance().IsPoweredOn();      ui->resolution_factor_combobox->setCurrentIndex(          static_cast<int>(FromResolutionFactor(Settings::values.resolution_factor)));      ui->toggle_frame_limit->setChecked(Settings::values.use_frame_limit); +    ui->frame_limit->setEnabled(ui->toggle_frame_limit->isChecked());      ui->frame_limit->setValue(Settings::values.frame_limit);      ui->use_compatibility_profile->setEnabled(runtime_lock);      ui->use_compatibility_profile->setChecked(Settings::values.use_compatibility_profile); @@ -88,7 +88,7 @@ void ConfigureGraphics::setConfiguration() {                                                   Settings::values.bg_blue));  } -void ConfigureGraphics::applyConfiguration() { +void ConfigureGraphics::ApplyConfiguration() {      Settings::values.resolution_factor =          ToResolutionFactor(static_cast<Resolution>(ui->resolution_factor_combobox->currentIndex()));      Settings::values.use_frame_limit = ui->toggle_frame_limit->isChecked(); diff --git a/src/yuzu/configuration/configure_graphics.h b/src/yuzu/configuration/configure_graphics.h index f2799822d..6b3c39705 100644 --- a/src/yuzu/configuration/configure_graphics.h +++ b/src/yuzu/configuration/configure_graphics.h @@ -18,10 +18,10 @@ public:      explicit ConfigureGraphics(QWidget* parent = nullptr);      ~ConfigureGraphics() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private: -    void setConfiguration(); +    void SetConfiguration();      void UpdateBackgroundColorButton(QColor color); diff --git a/src/yuzu/configuration/configure_hotkeys.cpp b/src/yuzu/configuration/configure_hotkeys.cpp index 9fb970c21..04119e9d7 100644 --- a/src/yuzu/configuration/configure_hotkeys.cpp +++ b/src/yuzu/configuration/configure_hotkeys.cpp @@ -92,7 +92,7 @@ bool ConfigureHotkeys::IsUsedKey(QKeySequence key_sequence) const {      return false;  } -void ConfigureHotkeys::applyConfiguration(HotkeyRegistry& registry) { +void ConfigureHotkeys::ApplyConfiguration(HotkeyRegistry& registry) {      for (int key_id = 0; key_id < model->rowCount(); key_id++) {          const QStandardItem* parent = model->item(key_id, 0);          for (int key_column_id = 0; key_column_id < parent->rowCount(); key_column_id++) { @@ -113,6 +113,6 @@ void ConfigureHotkeys::applyConfiguration(HotkeyRegistry& registry) {      registry.SaveHotkeys();  } -void ConfigureHotkeys::retranslateUi() { +void ConfigureHotkeys::RetranslateUI() {      ui->retranslateUi(this);  } diff --git a/src/yuzu/configuration/configure_hotkeys.h b/src/yuzu/configuration/configure_hotkeys.h index e77d73c35..a1f4c7134 100644 --- a/src/yuzu/configuration/configure_hotkeys.h +++ b/src/yuzu/configuration/configure_hotkeys.h @@ -21,8 +21,8 @@ public:      explicit ConfigureHotkeys(QWidget* parent = nullptr);      ~ConfigureHotkeys() override; -    void applyConfiguration(HotkeyRegistry& registry); -    void retranslateUi(); +    void ApplyConfiguration(HotkeyRegistry& registry); +    void RetranslateUI();      /**       * Populates the hotkey list widget using data from the provided registry. diff --git a/src/yuzu/configuration/configure_input.cpp b/src/yuzu/configuration/configure_input.cpp index 87e459714..fb1210bcb 100644 --- a/src/yuzu/configuration/configure_input.cpp +++ b/src/yuzu/configuration/configure_input.cpp @@ -50,12 +50,12 @@ void OnDockedModeChanged(bool last_state, bool new_state) {  namespace {  template <typename Dialog, typename... Args>  void CallConfigureDialog(ConfigureInput& parent, Args&&... args) { -    parent.applyConfiguration(); +    parent.ApplyConfiguration();      Dialog dialog(&parent, std::forward<Args>(args)...);      const auto res = dialog.exec();      if (res == QDialog::Accepted) { -        dialog.applyConfiguration(); +        dialog.ApplyConfiguration();      }  }  } // Anonymous namespace @@ -79,24 +79,24 @@ ConfigureInput::ConfigureInput(QWidget* parent)                                    tr("Single Right Joycon"), tr("Single Left Joycon")});      } -    this->loadConfiguration(); -    updateUIEnabled(); +    LoadConfiguration(); +    UpdateUIEnabled();      connect(ui->restore_defaults_button, &QPushButton::pressed, this, -            &ConfigureInput::restoreDefaults); +            &ConfigureInput::RestoreDefaults);      for (auto* enabled : players_controller) {          connect(enabled, QOverload<int>::of(&QComboBox::currentIndexChanged), this, -                &ConfigureInput::updateUIEnabled); +                &ConfigureInput::UpdateUIEnabled);      } -    connect(ui->use_docked_mode, &QCheckBox::stateChanged, this, &ConfigureInput::updateUIEnabled); +    connect(ui->use_docked_mode, &QCheckBox::stateChanged, this, &ConfigureInput::UpdateUIEnabled);      connect(ui->handheld_connected, &QCheckBox::stateChanged, this, -            &ConfigureInput::updateUIEnabled); -    connect(ui->mouse_enabled, &QCheckBox::stateChanged, this, &ConfigureInput::updateUIEnabled); -    connect(ui->keyboard_enabled, &QCheckBox::stateChanged, this, &ConfigureInput::updateUIEnabled); -    connect(ui->debug_enabled, &QCheckBox::stateChanged, this, &ConfigureInput::updateUIEnabled); +            &ConfigureInput::UpdateUIEnabled); +    connect(ui->mouse_enabled, &QCheckBox::stateChanged, this, &ConfigureInput::UpdateUIEnabled); +    connect(ui->keyboard_enabled, &QCheckBox::stateChanged, this, &ConfigureInput::UpdateUIEnabled); +    connect(ui->debug_enabled, &QCheckBox::stateChanged, this, &ConfigureInput::UpdateUIEnabled);      connect(ui->touchscreen_enabled, &QCheckBox::stateChanged, this, -            &ConfigureInput::updateUIEnabled); +            &ConfigureInput::UpdateUIEnabled);      for (std::size_t i = 0; i < players_configure.size(); ++i) {          connect(players_configure[i], &QPushButton::pressed, this, @@ -118,7 +118,7 @@ ConfigureInput::ConfigureInput(QWidget* parent)  ConfigureInput::~ConfigureInput() = default; -void ConfigureInput::applyConfiguration() { +void ConfigureInput::ApplyConfiguration() {      for (std::size_t i = 0; i < players_controller.size(); ++i) {          const auto controller_type_index = players_controller[i]->currentIndex(); @@ -144,7 +144,7 @@ void ConfigureInput::applyConfiguration() {      Settings::values.touchscreen.enabled = ui->touchscreen_enabled->isChecked();  } -void ConfigureInput::updateUIEnabled() { +void ConfigureInput::UpdateUIEnabled() {      bool hit_disabled = false;      for (auto* player : players_controller) {          player->setDisabled(hit_disabled); @@ -168,7 +168,7 @@ void ConfigureInput::updateUIEnabled() {      ui->touchscreen_advanced->setEnabled(ui->touchscreen_enabled->isChecked());  } -void ConfigureInput::loadConfiguration() { +void ConfigureInput::LoadConfiguration() {      std::stable_partition(          Settings::values.players.begin(),          Settings::values.players.begin() + @@ -191,10 +191,10 @@ void ConfigureInput::loadConfiguration() {      ui->keyboard_enabled->setChecked(Settings::values.keyboard_enabled);      ui->touchscreen_enabled->setChecked(Settings::values.touchscreen.enabled); -    updateUIEnabled(); +    UpdateUIEnabled();  } -void ConfigureInput::restoreDefaults() { +void ConfigureInput::RestoreDefaults() {      players_controller[0]->setCurrentIndex(2);      for (std::size_t i = 1; i < players_controller.size(); ++i) { @@ -207,5 +207,5 @@ void ConfigureInput::restoreDefaults() {      ui->keyboard_enabled->setCheckState(Qt::Unchecked);      ui->debug_enabled->setCheckState(Qt::Unchecked);      ui->touchscreen_enabled->setCheckState(Qt::Checked); -    updateUIEnabled(); +    UpdateUIEnabled();  } diff --git a/src/yuzu/configuration/configure_input.h b/src/yuzu/configuration/configure_input.h index b8e62cc2b..6a2125215 100644 --- a/src/yuzu/configuration/configure_input.h +++ b/src/yuzu/configuration/configure_input.h @@ -30,15 +30,15 @@ public:      ~ConfigureInput() override;      /// Save all button configurations to settings file -    void applyConfiguration(); +    void ApplyConfiguration();  private: -    void updateUIEnabled(); +    void UpdateUIEnabled();      /// Load configuration settings. -    void loadConfiguration(); +    void LoadConfiguration();      /// Restore all buttons to their default values. -    void restoreDefaults(); +    void RestoreDefaults();      std::unique_ptr<Ui::ConfigureInput> ui; diff --git a/src/yuzu/configuration/configure_input.ui b/src/yuzu/configuration/configure_input.ui index 0a2d9f024..8378451c8 100644 --- a/src/yuzu/configuration/configure_input.ui +++ b/src/yuzu/configuration/configure_input.ui @@ -17,7 +17,7 @@     <item>      <layout class="QVBoxLayout" name="verticalLayout">       <item> -      <widget class="QGroupBox" name="gridGroupBox"> +      <widget class="QGroupBox" name="gridGroupBox_1">         <property name="title">          <string>Players</string>         </property> @@ -260,7 +260,7 @@        </widget>       </item>       <item> -      <widget class="QGroupBox" name="gridGroupBox"> +      <widget class="QGroupBox" name="gridGroupBox_2">         <property name="title">          <string>Handheld</string>         </property> @@ -332,7 +332,7 @@        </widget>       </item>       <item> -      <widget class="QGroupBox" name="gridGroupBox"> +      <widget class="QGroupBox" name="gridGroupBox_3">         <property name="title">          <string>Other</string>         </property> diff --git a/src/yuzu/configuration/configure_input_player.cpp b/src/yuzu/configuration/configure_input_player.cpp index 95b0a656a..32d2a6815 100644 --- a/src/yuzu/configuration/configure_input_player.cpp +++ b/src/yuzu/configuration/configure_input_player.cpp @@ -245,7 +245,7 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i          button->setContextMenuPolicy(Qt::CustomContextMenu);          connect(button, &QPushButton::released, [=] { -            handleClick( +            HandleClick(                  button_map[button_id],                  [=](const Common::ParamPackage& params) { buttons_param[button_id] = params; },                  InputCommon::Polling::DeviceType::Button); @@ -274,7 +274,7 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i              analog_button->setContextMenuPolicy(Qt::CustomContextMenu);              connect(analog_button, &QPushButton::released, [=]() { -                handleClick(analog_map_buttons[analog_id][sub_button_id], +                HandleClick(analog_map_buttons[analog_id][sub_button_id],                              [=](const Common::ParamPackage& params) {                                  SetAnalogButton(params, analogs_param[analog_id],                                                  analog_sub_buttons[sub_button_id]); @@ -304,7 +304,7 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i              QMessageBox::information(this, tr("Information"),                                       tr("After pressing OK, first move your joystick horizontally, "                                          "and then vertically.")); -            handleClick( +            HandleClick(                  analog_map_stick[analog_id],                  [=](const Common::ParamPackage& params) { analogs_param[analog_id] = params; },                  InputCommon::Polling::DeviceType::Analog); @@ -312,17 +312,17 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i      }      connect(ui->buttonClearAll, &QPushButton::released, [this] { ClearAll(); }); -    connect(ui->buttonRestoreDefaults, &QPushButton::released, [this]() { restoreDefaults(); }); +    connect(ui->buttonRestoreDefaults, &QPushButton::released, [this] { RestoreDefaults(); });      timeout_timer->setSingleShot(true); -    connect(timeout_timer.get(), &QTimer::timeout, [this]() { setPollingResult({}, true); }); +    connect(timeout_timer.get(), &QTimer::timeout, [this] { SetPollingResult({}, true); }); -    connect(poll_timer.get(), &QTimer::timeout, [this]() { +    connect(poll_timer.get(), &QTimer::timeout, [this] {          Common::ParamPackage params;          for (auto& poller : device_pollers) {              params = poller->GetNextInput();              if (params.Has("engine")) { -                setPollingResult(params, false); +                SetPollingResult(params, false);                  return;              }          } @@ -340,8 +340,8 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i                  [this, i] { OnControllerButtonClick(static_cast<int>(i)); });      } -    this->loadConfiguration(); -    this->resize(0, 0); +    LoadConfiguration(); +    resize(0, 0);      // TODO(wwylele): enable this when we actually emulate it      ui->buttonHome->setEnabled(false); @@ -349,7 +349,7 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i  ConfigureInputPlayer::~ConfigureInputPlayer() = default; -void ConfigureInputPlayer::applyConfiguration() { +void ConfigureInputPlayer::ApplyConfiguration() {      auto& buttons =          debug ? Settings::values.debug_pad_buttons : Settings::values.players[player_index].buttons;      auto& analogs = @@ -382,7 +382,7 @@ void ConfigureInputPlayer::OnControllerButtonClick(int i) {          QStringLiteral("QPushButton { background-color: %1 }").arg(controller_colors[i].name()));  } -void ConfigureInputPlayer::loadConfiguration() { +void ConfigureInputPlayer::LoadConfiguration() {      if (debug) {          std::transform(Settings::values.debug_pad_buttons.begin(),                         Settings::values.debug_pad_buttons.end(), buttons_param.begin(), @@ -399,7 +399,7 @@ void ConfigureInputPlayer::loadConfiguration() {                         [](const std::string& str) { return Common::ParamPackage(str); });      } -    updateButtonLabels(); +    UpdateButtonLabels();      if (debug)          return; @@ -421,7 +421,7 @@ void ConfigureInputPlayer::loadConfiguration() {      }  } -void ConfigureInputPlayer::restoreDefaults() { +void ConfigureInputPlayer::RestoreDefaults() {      for (int button_id = 0; button_id < Settings::NativeButton::NumButtons; button_id++) {          buttons_param[button_id] = Common::ParamPackage{              InputCommon::GenerateKeyboardParam(Config::default_buttons[button_id])}; @@ -434,7 +434,7 @@ void ConfigureInputPlayer::restoreDefaults() {              SetAnalogButton(params, analogs_param[analog_id], analog_sub_buttons[sub_button_id]);          }      } -    updateButtonLabels(); +    UpdateButtonLabels();  }  void ConfigureInputPlayer::ClearAll() { @@ -458,10 +458,10 @@ void ConfigureInputPlayer::ClearAll() {          }      } -    updateButtonLabels(); +    UpdateButtonLabels();  } -void ConfigureInputPlayer::updateButtonLabels() { +void ConfigureInputPlayer::UpdateButtonLabels() {      for (int button = 0; button < Settings::NativeButton::NumButtons; button++) {          button_map[button]->setText(ButtonToText(buttons_param[button]));      } @@ -481,7 +481,7 @@ void ConfigureInputPlayer::updateButtonLabels() {      }  } -void ConfigureInputPlayer::handleClick( +void ConfigureInputPlayer::HandleClick(      QPushButton* button, std::function<void(const Common::ParamPackage&)> new_input_setter,      InputCommon::Polling::DeviceType type) {      button->setText(tr("[press key]")); @@ -509,7 +509,7 @@ void ConfigureInputPlayer::handleClick(      poll_timer->start(200);     // Check for new inputs every 200ms  } -void ConfigureInputPlayer::setPollingResult(const Common::ParamPackage& params, bool abort) { +void ConfigureInputPlayer::SetPollingResult(const Common::ParamPackage& params, bool abort) {      releaseKeyboard();      releaseMouse();      timeout_timer->stop(); @@ -522,22 +522,23 @@ void ConfigureInputPlayer::setPollingResult(const Common::ParamPackage& params,          (*input_setter)(params);      } -    updateButtonLabels(); +    UpdateButtonLabels();      input_setter = std::nullopt;  }  void ConfigureInputPlayer::keyPressEvent(QKeyEvent* event) { -    if (!input_setter || !event) +    if (!input_setter || !event) {          return; +    }      if (event->key() != Qt::Key_Escape) {          if (want_keyboard_keys) { -            setPollingResult(Common::ParamPackage{InputCommon::GenerateKeyboardParam(event->key())}, +            SetPollingResult(Common::ParamPackage{InputCommon::GenerateKeyboardParam(event->key())},                               false);          } else {              // Escape key wasn't pressed and we don't want any keyboard keys, so don't stop polling              return;          }      } -    setPollingResult({}, true); +    SetPollingResult({}, true);  } diff --git a/src/yuzu/configuration/configure_input_player.h b/src/yuzu/configuration/configure_input_player.h index ade8d4435..27924fcce 100644 --- a/src/yuzu/configuration/configure_input_player.h +++ b/src/yuzu/configuration/configure_input_player.h @@ -38,28 +38,28 @@ public:      ~ConfigureInputPlayer() override;      /// Save all button configurations to settings file -    void applyConfiguration(); +    void ApplyConfiguration();  private:      void OnControllerButtonClick(int i);      /// Load configuration settings. -    void loadConfiguration(); +    void LoadConfiguration();      /// Restore all buttons to their default values. -    void restoreDefaults(); +    void RestoreDefaults();      /// Clear all input configuration      void ClearAll();      /// Update UI to reflect current configuration. -    void updateButtonLabels(); +    void UpdateButtonLabels();      /// Called when the button was pressed. -    void handleClick(QPushButton* button, +    void HandleClick(QPushButton* button,                       std::function<void(const Common::ParamPackage&)> new_input_setter,                       InputCommon::Polling::DeviceType type);      /// Finish polling and configure input using the input_setter -    void setPollingResult(const Common::ParamPackage& params, bool abort); +    void SetPollingResult(const Common::ParamPackage& params, bool abort);      /// Handle key press events.      void keyPressEvent(QKeyEvent* event) override; diff --git a/src/yuzu/configuration/configure_input_simple.cpp b/src/yuzu/configuration/configure_input_simple.cpp index 07d71e9d1..6140a5573 100644 --- a/src/yuzu/configuration/configure_input_simple.cpp +++ b/src/yuzu/configuration/configure_input_simple.cpp @@ -15,12 +15,12 @@ namespace {  template <typename Dialog, typename... Args>  void CallConfigureDialog(ConfigureInputSimple* caller, Args&&... args) { -    caller->applyConfiguration(); +    caller->ApplyConfiguration();      Dialog dialog(caller, std::forward<Args>(args)...);      const auto res = dialog.exec();      if (res == QDialog::Accepted) { -        dialog.applyConfiguration(); +        dialog.ApplyConfiguration();      }  } @@ -103,27 +103,29 @@ ConfigureInputSimple::ConfigureInputSimple(QWidget* parent)              &ConfigureInputSimple::OnSelectProfile);      connect(ui->profile_configure, &QPushButton::pressed, this, &ConfigureInputSimple::OnConfigure); -    this->loadConfiguration(); +    LoadConfiguration();  }  ConfigureInputSimple::~ConfigureInputSimple() = default; -void ConfigureInputSimple::applyConfiguration() { +void ConfigureInputSimple::ApplyConfiguration() {      auto index = ui->profile_combobox->currentIndex();      // Make the stored index for "Custom" very large so that if new profiles are added it      // doesn't change. -    if (index >= static_cast<int>(INPUT_PROFILES.size() - 1)) +    if (index >= static_cast<int>(INPUT_PROFILES.size() - 1)) {          index = std::numeric_limits<int>::max(); +    }      UISettings::values.profile_index = index;  } -void ConfigureInputSimple::loadConfiguration() { +void ConfigureInputSimple::LoadConfiguration() {      const auto index = UISettings::values.profile_index; -    if (index >= static_cast<int>(INPUT_PROFILES.size()) || index < 0) +    if (index >= static_cast<int>(INPUT_PROFILES.size()) || index < 0) {          ui->profile_combobox->setCurrentIndex(static_cast<int>(INPUT_PROFILES.size() - 1)); -    else +    } else {          ui->profile_combobox->setCurrentIndex(index); +    }  }  void ConfigureInputSimple::OnSelectProfile(int index) { diff --git a/src/yuzu/configuration/configure_input_simple.h b/src/yuzu/configuration/configure_input_simple.h index 5b6b69994..573c2db2b 100644 --- a/src/yuzu/configuration/configure_input_simple.h +++ b/src/yuzu/configuration/configure_input_simple.h @@ -27,11 +27,11 @@ public:      ~ConfigureInputSimple() override;      /// Save all button configurations to settings file -    void applyConfiguration(); +    void ApplyConfiguration();  private:      /// Load configuration settings. -    void loadConfiguration(); +    void LoadConfiguration();      void OnSelectProfile(int index);      void OnConfigure(); diff --git a/src/yuzu/configuration/configure_mouse_advanced.cpp b/src/yuzu/configuration/configure_mouse_advanced.cpp index a14bb1475..26f53128f 100644 --- a/src/yuzu/configuration/configure_mouse_advanced.cpp +++ b/src/yuzu/configuration/configure_mouse_advanced.cpp @@ -84,7 +84,7 @@ ConfigureMouseAdvanced::ConfigureMouseAdvanced(QWidget* parent)          button->setContextMenuPolicy(Qt::CustomContextMenu);          connect(button, &QPushButton::released, [=] { -            handleClick( +            HandleClick(                  button_map[button_id],                  [=](const Common::ParamPackage& params) { buttons_param[button_id] = params; },                  InputCommon::Polling::DeviceType::Button); @@ -105,48 +105,48 @@ ConfigureMouseAdvanced::ConfigureMouseAdvanced(QWidget* parent)      }      connect(ui->buttonClearAll, &QPushButton::released, [this] { ClearAll(); }); -    connect(ui->buttonRestoreDefaults, &QPushButton::released, [this]() { restoreDefaults(); }); +    connect(ui->buttonRestoreDefaults, &QPushButton::released, [this] { RestoreDefaults(); });      timeout_timer->setSingleShot(true); -    connect(timeout_timer.get(), &QTimer::timeout, [this]() { setPollingResult({}, true); }); +    connect(timeout_timer.get(), &QTimer::timeout, [this] { SetPollingResult({}, true); }); -    connect(poll_timer.get(), &QTimer::timeout, [this]() { +    connect(poll_timer.get(), &QTimer::timeout, [this] {          Common::ParamPackage params;          for (auto& poller : device_pollers) {              params = poller->GetNextInput();              if (params.Has("engine")) { -                setPollingResult(params, false); +                SetPollingResult(params, false);                  return;              }          }      }); -    loadConfiguration(); +    LoadConfiguration();      resize(0, 0);  }  ConfigureMouseAdvanced::~ConfigureMouseAdvanced() = default; -void ConfigureMouseAdvanced::applyConfiguration() { +void ConfigureMouseAdvanced::ApplyConfiguration() {      std::transform(buttons_param.begin(), buttons_param.end(),                     Settings::values.mouse_buttons.begin(),                     [](const Common::ParamPackage& param) { return param.Serialize(); });  } -void ConfigureMouseAdvanced::loadConfiguration() { +void ConfigureMouseAdvanced::LoadConfiguration() {      std::transform(Settings::values.mouse_buttons.begin(), Settings::values.mouse_buttons.end(),                     buttons_param.begin(),                     [](const std::string& str) { return Common::ParamPackage(str); }); -    updateButtonLabels(); +    UpdateButtonLabels();  } -void ConfigureMouseAdvanced::restoreDefaults() { +void ConfigureMouseAdvanced::RestoreDefaults() {      for (int button_id = 0; button_id < Settings::NativeMouseButton::NumMouseButtons; button_id++) {          buttons_param[button_id] = Common::ParamPackage{              InputCommon::GenerateKeyboardParam(Config::default_mouse_buttons[button_id])};      } -    updateButtonLabels(); +    UpdateButtonLabels();  }  void ConfigureMouseAdvanced::ClearAll() { @@ -157,16 +157,16 @@ void ConfigureMouseAdvanced::ClearAll() {          }      } -    updateButtonLabels(); +    UpdateButtonLabels();  } -void ConfigureMouseAdvanced::updateButtonLabels() { +void ConfigureMouseAdvanced::UpdateButtonLabels() {      for (int button = 0; button < Settings::NativeMouseButton::NumMouseButtons; button++) {          button_map[button]->setText(ButtonToText(buttons_param[button]));      }  } -void ConfigureMouseAdvanced::handleClick( +void ConfigureMouseAdvanced::HandleClick(      QPushButton* button, std::function<void(const Common::ParamPackage&)> new_input_setter,      InputCommon::Polling::DeviceType type) {      button->setText(tr("[press key]")); @@ -194,7 +194,7 @@ void ConfigureMouseAdvanced::handleClick(      poll_timer->start(200);     // Check for new inputs every 200ms  } -void ConfigureMouseAdvanced::setPollingResult(const Common::ParamPackage& params, bool abort) { +void ConfigureMouseAdvanced::SetPollingResult(const Common::ParamPackage& params, bool abort) {      releaseKeyboard();      releaseMouse();      timeout_timer->stop(); @@ -207,22 +207,23 @@ void ConfigureMouseAdvanced::setPollingResult(const Common::ParamPackage& params          (*input_setter)(params);      } -    updateButtonLabels(); +    UpdateButtonLabels();      input_setter = std::nullopt;  }  void ConfigureMouseAdvanced::keyPressEvent(QKeyEvent* event) { -    if (!input_setter || !event) +    if (!input_setter || !event) {          return; +    }      if (event->key() != Qt::Key_Escape) {          if (want_keyboard_keys) { -            setPollingResult(Common::ParamPackage{InputCommon::GenerateKeyboardParam(event->key())}, +            SetPollingResult(Common::ParamPackage{InputCommon::GenerateKeyboardParam(event->key())},                               false);          } else {              // Escape key wasn't pressed and we don't want any keyboard keys, so don't stop polling              return;          }      } -    setPollingResult({}, true); +    SetPollingResult({}, true);  } diff --git a/src/yuzu/configuration/configure_mouse_advanced.h b/src/yuzu/configuration/configure_mouse_advanced.h index e04da4bf2..373f992c9 100644 --- a/src/yuzu/configuration/configure_mouse_advanced.h +++ b/src/yuzu/configuration/configure_mouse_advanced.h @@ -25,26 +25,26 @@ public:      explicit ConfigureMouseAdvanced(QWidget* parent);      ~ConfigureMouseAdvanced() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private:      /// Load configuration settings. -    void loadConfiguration(); +    void LoadConfiguration();      /// Restore all buttons to their default values. -    void restoreDefaults(); +    void RestoreDefaults();      /// Clear all input configuration      void ClearAll();      /// Update UI to reflect current configuration. -    void updateButtonLabels(); +    void UpdateButtonLabels();      /// Called when the button was pressed. -    void handleClick(QPushButton* button, +    void HandleClick(QPushButton* button,                       std::function<void(const Common::ParamPackage&)> new_input_setter,                       InputCommon::Polling::DeviceType type);      /// Finish polling and configure input using the input_setter -    void setPollingResult(const Common::ParamPackage& params, bool abort); +    void SetPollingResult(const Common::ParamPackage& params, bool abort);      /// Handle key press events.      void keyPressEvent(QKeyEvent* event) override; diff --git a/src/yuzu/configuration/configure_per_general.cpp b/src/yuzu/configuration/configure_per_general.cpp index 2bdfc8e5a..275519c7b 100644 --- a/src/yuzu/configuration/configure_per_general.cpp +++ b/src/yuzu/configuration/configure_per_general.cpp @@ -13,6 +13,8 @@  #include <QTimer>  #include <QTreeView> +#include "common/common_paths.h" +#include "common/file_util.h"  #include "core/file_sys/control_metadata.h"  #include "core/file_sys/patch_manager.h"  #include "core/file_sys/xts_archive.h" @@ -65,12 +67,12 @@ ConfigurePerGameGeneral::ConfigurePerGameGeneral(QWidget* parent, u64 title_id)      connect(item_model, &QStandardItemModel::itemChanged,              [] { UISettings::values.is_game_list_reload_pending.exchange(true); }); -    this->loadConfiguration(); +    LoadConfiguration();  }  ConfigurePerGameGeneral::~ConfigurePerGameGeneral() = default; -void ConfigurePerGameGeneral::applyConfiguration() { +void ConfigurePerGameGeneral::ApplyConfiguration() {      std::vector<std::string> disabled_addons;      for (const auto& item : list_items) { @@ -79,15 +81,23 @@ void ConfigurePerGameGeneral::applyConfiguration() {              disabled_addons.push_back(item.front()->text().toStdString());      } +    auto current = Settings::values.disabled_addons[title_id]; +    std::sort(disabled_addons.begin(), disabled_addons.end()); +    std::sort(current.begin(), current.end()); +    if (disabled_addons != current) { +        FileUtil::Delete(FileUtil::GetUserPath(FileUtil::UserPath::CacheDir) + DIR_SEP + +                         "game_list" + DIR_SEP + fmt::format("{:016X}.pv.txt", title_id)); +    } +      Settings::values.disabled_addons[title_id] = disabled_addons;  } -void ConfigurePerGameGeneral::loadFromFile(FileSys::VirtualFile file) { +void ConfigurePerGameGeneral::LoadFromFile(FileSys::VirtualFile file) {      this->file = std::move(file); -    this->loadConfiguration(); +    LoadConfiguration();  } -void ConfigurePerGameGeneral::loadConfiguration() { +void ConfigurePerGameGeneral::LoadConfiguration() {      if (file == nullptr) {          return;      } diff --git a/src/yuzu/configuration/configure_per_general.h b/src/yuzu/configuration/configure_per_general.h index f8a7d5326..b95e07079 100644 --- a/src/yuzu/configuration/configure_per_general.h +++ b/src/yuzu/configuration/configure_per_general.h @@ -30,11 +30,13 @@ public:      ~ConfigurePerGameGeneral() override;      /// Save all button configurations to settings file -    void applyConfiguration(); +    void ApplyConfiguration(); -    void loadFromFile(FileSys::VirtualFile file); +    void LoadFromFile(FileSys::VirtualFile file);  private: +    void LoadConfiguration(); +      std::unique_ptr<Ui::ConfigurePerGameGeneral> ui;      FileSys::VirtualFile file;      u64 title_id; @@ -45,6 +47,4 @@ private:      QGraphicsScene* scene;      std::vector<QList<QStandardItem*>> list_items; - -    void loadConfiguration();  }; diff --git a/src/yuzu/configuration/configure_profile_manager.cpp b/src/yuzu/configuration/configure_profile_manager.cpp index 002a51780..7c1597488 100644 --- a/src/yuzu/configuration/configure_profile_manager.cpp +++ b/src/yuzu/configuration/configure_profile_manager.cpp @@ -33,14 +33,13 @@ constexpr std::array<u8, 107> backup_jpeg{      0x01, 0x01, 0x00, 0x00, 0x3f, 0x00, 0xd2, 0xcf, 0x20, 0xff, 0xd9,  }; -QString GetImagePath(Service::Account::UUID uuid) { +QString GetImagePath(Common::UUID uuid) {      const auto path = FileUtil::GetUserPath(FileUtil::UserPath::NANDDir) +                        "/system/save/8000000000000010/su/avators/" + uuid.FormatSwitch() + ".jpg";      return QString::fromStdString(path);  } -QString GetAccountUsername(const Service::Account::ProfileManager& manager, -                           Service::Account::UUID uuid) { +QString GetAccountUsername(const Service::Account::ProfileManager& manager, Common::UUID uuid) {      Service::Account::ProfileBase profile;      if (!manager.GetProfileBase(uuid, profile)) {          return {}; @@ -51,14 +50,14 @@ QString GetAccountUsername(const Service::Account::ProfileManager& manager,      return QString::fromStdString(text);  } -QString FormatUserEntryText(const QString& username, Service::Account::UUID uuid) { +QString FormatUserEntryText(const QString& username, Common::UUID uuid) {      return ConfigureProfileManager::tr("%1\n%2",                                         "%1 is the profile username, %2 is the formatted UUID (e.g. "                                         "00112233-4455-6677-8899-AABBCCDDEEFF))")          .arg(username, QString::fromStdString(uuid.FormatSwitch()));  } -QPixmap GetIcon(Service::Account::UUID uuid) { +QPixmap GetIcon(Common::UUID uuid) {      QPixmap icon{GetImagePath(uuid)};      if (!icon) { @@ -120,12 +119,12 @@ ConfigureProfileManager ::ConfigureProfileManager(QWidget* parent)      scene = new QGraphicsScene;      ui->current_user_icon->setScene(scene); -    this->setConfiguration(); +    SetConfiguration();  }  ConfigureProfileManager::~ConfigureProfileManager() = default; -void ConfigureProfileManager::setConfiguration() { +void ConfigureProfileManager::SetConfiguration() {      enabled = !Core::System::GetInstance().IsPoweredOn();      item_model->removeRows(0, item_model->rowCount());      list_items.clear(); @@ -165,9 +164,10 @@ void ConfigureProfileManager::UpdateCurrentUser() {      ui->current_user_username->setText(username);  } -void ConfigureProfileManager::applyConfiguration() { -    if (!enabled) +void ConfigureProfileManager::ApplyConfiguration() { +    if (!enabled) {          return; +    }      Settings::Apply();  } @@ -190,7 +190,7 @@ void ConfigureProfileManager::AddUser() {          return;      } -    const auto uuid = Service::Account::UUID::Generate(); +    const auto uuid = Common::UUID::Generate();      profile_manager->CreateNewUser(uuid, username.toStdString());      item_model->appendRow(new QStandardItem{GetIcon(uuid), FormatUserEntryText(username, uuid)}); diff --git a/src/yuzu/configuration/configure_profile_manager.h b/src/yuzu/configuration/configure_profile_manager.h index 7fe95a2a8..4e9b4e8ea 100644 --- a/src/yuzu/configuration/configure_profile_manager.h +++ b/src/yuzu/configuration/configure_profile_manager.h @@ -30,10 +30,11 @@ public:      explicit ConfigureProfileManager(QWidget* parent = nullptr);      ~ConfigureProfileManager() override; -    void applyConfiguration(); -    void setConfiguration(); +    void ApplyConfiguration();  private: +    void SetConfiguration(); +      void PopulateUserList();      void UpdateCurrentUser(); diff --git a/src/yuzu/configuration/configure_system.cpp b/src/yuzu/configuration/configure_system.cpp index ff18ace40..5f0ed2f61 100644 --- a/src/yuzu/configuration/configure_system.cpp +++ b/src/yuzu/configuration/configure_system.cpp @@ -16,49 +16,31 @@  #include "ui_configure_system.h"  #include "yuzu/configuration/configure_system.h" -namespace { -constexpr std::array<int, 12> days_in_month = {{ -    31, -    29, -    31, -    30, -    31, -    30, -    31, -    31, -    30, -    31, -    30, -    31, -}}; -} // Anonymous namespace -  ConfigureSystem::ConfigureSystem(QWidget* parent) : QWidget(parent), ui(new Ui::ConfigureSystem) {      ui->setupUi(this); -    connect(ui->combo_birthmonth, -            static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), this, -            &ConfigureSystem::UpdateBirthdayComboBox);      connect(ui->button_regenerate_console_id, &QPushButton::clicked, this,              &ConfigureSystem::RefreshConsoleID);      connect(ui->rng_seed_checkbox, &QCheckBox::stateChanged, this, [this](bool checked) {          ui->rng_seed_edit->setEnabled(checked); -        if (!checked) +        if (!checked) {              ui->rng_seed_edit->setText(QStringLiteral("00000000")); +        }      });      connect(ui->custom_rtc_checkbox, &QCheckBox::stateChanged, this, [this](bool checked) {          ui->custom_rtc_edit->setEnabled(checked); -        if (!checked) +        if (!checked) {              ui->custom_rtc_edit->setDateTime(QDateTime::currentDateTime()); +        }      }); -    this->setConfiguration(); +    SetConfiguration();  }  ConfigureSystem::~ConfigureSystem() = default; -void ConfigureSystem::setConfiguration() { +void ConfigureSystem::SetConfiguration() {      enabled = !Core::System::GetInstance().IsPoweredOn();      ui->combo_language->setCurrentIndex(Settings::values.language_index); @@ -81,49 +63,27 @@ void ConfigureSystem::setConfiguration() {  void ConfigureSystem::ReadSystemSettings() {} -void ConfigureSystem::applyConfiguration() { -    if (!enabled) +void ConfigureSystem::ApplyConfiguration() { +    if (!enabled) {          return; +    }      Settings::values.language_index = ui->combo_language->currentIndex(); -    if (ui->rng_seed_checkbox->isChecked()) +    if (ui->rng_seed_checkbox->isChecked()) {          Settings::values.rng_seed = ui->rng_seed_edit->text().toULongLong(nullptr, 16); -    else +    } else {          Settings::values.rng_seed = std::nullopt; +    } -    if (ui->custom_rtc_checkbox->isChecked()) +    if (ui->custom_rtc_checkbox->isChecked()) {          Settings::values.custom_rtc =              std::chrono::seconds(ui->custom_rtc_edit->dateTime().toSecsSinceEpoch()); -    else +    } else {          Settings::values.custom_rtc = std::nullopt; - -    Settings::Apply(); -} - -void ConfigureSystem::UpdateBirthdayComboBox(int birthmonth_index) { -    if (birthmonth_index < 0 || birthmonth_index >= 12) -        return; - -    // store current day selection -    int birthday_index = ui->combo_birthday->currentIndex(); - -    // get number of days in the new selected month -    int days = days_in_month[birthmonth_index]; - -    // if the selected day is out of range, -    // reset it to 1st -    if (birthday_index < 0 || birthday_index >= days) -        birthday_index = 0; - -    // update the day combo box -    ui->combo_birthday->clear(); -    for (int i = 1; i <= days; ++i) { -        ui->combo_birthday->addItem(QString::number(i));      } -    // restore the day selection -    ui->combo_birthday->setCurrentIndex(birthday_index); +    Settings::Apply();  }  void ConfigureSystem::RefreshConsoleID() { @@ -134,8 +94,10 @@ void ConfigureSystem::RefreshConsoleID() {                                "if you use an outdated config savegame. Continue?");      reply = QMessageBox::critical(this, tr("Warning"), warning_text,                                    QMessageBox::No | QMessageBox::Yes); -    if (reply == QMessageBox::No) +    if (reply == QMessageBox::No) {          return; +    } +      u64 console_id{};      ui->label_console_id->setText(          tr("Console ID: 0x%1").arg(QString::number(console_id, 16).toUpper())); diff --git a/src/yuzu/configuration/configure_system.h b/src/yuzu/configuration/configure_system.h index cf1e54de5..4c0329d57 100644 --- a/src/yuzu/configuration/configure_system.h +++ b/src/yuzu/configuration/configure_system.h @@ -20,20 +20,18 @@ public:      explicit ConfigureSystem(QWidget* parent = nullptr);      ~ConfigureSystem() override; -    void applyConfiguration(); -    void setConfiguration(); +    void ApplyConfiguration();  private: +    void SetConfiguration(); +      void ReadSystemSettings(); -    void UpdateBirthdayComboBox(int birthmonth_index);      void RefreshConsoleID();      std::unique_ptr<Ui::ConfigureSystem> ui;      bool enabled = false; -    int birthmonth = 0; -    int birthday = 0;      int language_index = 0;      int sound_index = 0;  }; diff --git a/src/yuzu/configuration/configure_system.ui b/src/yuzu/configuration/configure_system.ui index 073327298..65745a2f8 100644 --- a/src/yuzu/configuration/configure_system.ui +++ b/src/yuzu/configuration/configure_system.ui @@ -22,14 +22,21 @@          <string>System Settings</string>         </property>         <layout class="QGridLayout" name="gridLayout"> -        <item row="2" column="0"> +        <item row="1" column="0">           <widget class="QLabel" name="label_sound">            <property name="text">             <string>Sound output mode</string>            </property>           </widget>          </item> -        <item row="1" column="1"> +        <item row="2" column="0"> +         <widget class="QLabel" name="label_console_id"> +          <property name="text"> +           <string>Console ID:</string> +          </property> +         </widget> +        </item> +        <item row="0" column="1">           <widget class="QComboBox" name="combo_language">            <property name="toolTip">             <string>Note: this can be overridden when region setting is auto-select</string> @@ -121,108 +128,14 @@            </item>           </widget>          </item> -        <item row="0" column="1"> -         <layout class="QHBoxLayout" name="horizontalLayout_birthday2"> -          <item> -           <widget class="QComboBox" name="combo_birthmonth"> -            <item> -             <property name="text"> -              <string>January</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>February</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>March</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>April</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>May</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>June</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>July</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>August</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>September</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>October</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>November</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>December</string> -             </property> -            </item> -           </widget> -          </item> -          <item> -           <widget class="QComboBox" name="combo_birthday"/> -          </item> -         </layout> -        </item> -        <item row="3" column="0"> -         <widget class="QLabel" name="label_console_id"> -          <property name="text"> -           <string>Console ID:</string> -          </property> -         </widget> -        </item> -        <item row="0" column="0"> -         <widget class="QLabel" name="label_birthday"> -          <property name="text"> -           <string>Birthday</string> -          </property> -         </widget> -        </item> -        <item row="3" column="1"> -         <widget class="QPushButton" name="button_regenerate_console_id"> -          <property name="sizePolicy"> -           <sizepolicy hsizetype="Fixed" vsizetype="Fixed"> -            <horstretch>0</horstretch> -            <verstretch>0</verstretch> -           </sizepolicy> -          </property> -          <property name="layoutDirection"> -           <enum>Qt::RightToLeft</enum> -          </property> +        <item row="4" column="0"> +         <widget class="QCheckBox" name="rng_seed_checkbox">            <property name="text"> -           <string>Regenerate</string> +           <string>RNG Seed</string>            </property>           </widget>          </item> -        <item row="2" column="1"> +        <item row="1" column="1">           <widget class="QComboBox" name="combo_sound">            <item>             <property name="text"> @@ -241,49 +154,37 @@            </item>           </widget>          </item> -        <item row="5" column="0"> -         <widget class="QCheckBox" name="rng_seed_checkbox"> -          <property name="text"> -           <string>RNG Seed</string> -          </property> -         </widget> -        </item> -        <item row="1" column="0"> +        <item row="0" column="0">           <widget class="QLabel" name="label_language">            <property name="text">             <string>Language</string>            </property>           </widget>          </item> -        <item row="5" column="1"> -         <widget class="QLineEdit" name="rng_seed_edit"> +        <item row="2" column="1"> +         <widget class="QPushButton" name="button_regenerate_console_id">            <property name="sizePolicy"> -           <sizepolicy hsizetype="Minimum" vsizetype="Fixed"> +           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">              <horstretch>0</horstretch>              <verstretch>0</verstretch>             </sizepolicy>            </property> -          <property name="font"> -           <font> -            <family>Lucida Console</family> -           </font> -          </property> -          <property name="inputMask"> -           <string notr="true">HHHHHHHH</string> +          <property name="layoutDirection"> +           <enum>Qt::RightToLeft</enum>            </property> -          <property name="maxLength"> -           <number>8</number> +          <property name="text"> +           <string>Regenerate</string>            </property>           </widget>          </item> -        <item row="4" column="0"> +        <item row="3" column="0">           <widget class="QCheckBox" name="custom_rtc_checkbox">            <property name="text">             <string>Custom RTC</string>            </property>           </widget>          </item> -        <item row="4" column="1"> +        <item row="3" column="1">           <widget class="QDateTimeEdit" name="custom_rtc_edit">            <property name="minimumDate">             <date> @@ -297,6 +198,27 @@            </property>           </widget>          </item> +        <item row="4" column="1"> +         <widget class="QLineEdit" name="rng_seed_edit"> +          <property name="sizePolicy"> +           <sizepolicy hsizetype="Minimum" vsizetype="Fixed"> +            <horstretch>0</horstretch> +            <verstretch>0</verstretch> +           </sizepolicy> +          </property> +          <property name="font"> +           <font> +            <family>Lucida Console</family> +           </font> +          </property> +          <property name="inputMask"> +           <string notr="true">HHHHHHHH</string> +          </property> +          <property name="maxLength"> +           <number>8</number> +          </property> +         </widget> +        </item>         </layout>        </widget>       </item> diff --git a/src/yuzu/configuration/configure_touchscreen_advanced.cpp b/src/yuzu/configuration/configure_touchscreen_advanced.cpp index 9c1561e9d..bad224239 100644 --- a/src/yuzu/configuration/configure_touchscreen_advanced.cpp +++ b/src/yuzu/configuration/configure_touchscreen_advanced.cpp @@ -12,29 +12,29 @@ ConfigureTouchscreenAdvanced::ConfigureTouchscreenAdvanced(QWidget* parent)      ui->setupUi(this);      connect(ui->restore_defaults_button, &QPushButton::pressed, this, -            &ConfigureTouchscreenAdvanced::restoreDefaults); +            &ConfigureTouchscreenAdvanced::RestoreDefaults); -    loadConfiguration(); +    LoadConfiguration();      resize(0, 0);  }  ConfigureTouchscreenAdvanced::~ConfigureTouchscreenAdvanced() = default; -void ConfigureTouchscreenAdvanced::applyConfiguration() { +void ConfigureTouchscreenAdvanced::ApplyConfiguration() {      Settings::values.touchscreen.finger = ui->finger_box->value();      Settings::values.touchscreen.diameter_x = ui->diameter_x_box->value();      Settings::values.touchscreen.diameter_y = ui->diameter_y_box->value();      Settings::values.touchscreen.rotation_angle = ui->angle_box->value();  } -void ConfigureTouchscreenAdvanced::loadConfiguration() { +void ConfigureTouchscreenAdvanced::LoadConfiguration() {      ui->finger_box->setValue(Settings::values.touchscreen.finger);      ui->diameter_x_box->setValue(Settings::values.touchscreen.diameter_x);      ui->diameter_y_box->setValue(Settings::values.touchscreen.diameter_y);      ui->angle_box->setValue(Settings::values.touchscreen.rotation_angle);  } -void ConfigureTouchscreenAdvanced::restoreDefaults() { +void ConfigureTouchscreenAdvanced::RestoreDefaults() {      ui->finger_box->setValue(0);      ui->diameter_x_box->setValue(15);      ui->diameter_y_box->setValue(15); diff --git a/src/yuzu/configuration/configure_touchscreen_advanced.h b/src/yuzu/configuration/configure_touchscreen_advanced.h index 3d0772c87..94edd85b1 100644 --- a/src/yuzu/configuration/configure_touchscreen_advanced.h +++ b/src/yuzu/configuration/configure_touchscreen_advanced.h @@ -18,13 +18,13 @@ public:      explicit ConfigureTouchscreenAdvanced(QWidget* parent);      ~ConfigureTouchscreenAdvanced() override; -    void applyConfiguration(); +    void ApplyConfiguration();  private:      /// Load configuration settings. -    void loadConfiguration(); +    void LoadConfiguration();      /// Restore all buttons to their default values. -    void restoreDefaults(); +    void RestoreDefaults();      std::unique_ptr<Ui::ConfigureTouchscreenAdvanced> ui;  }; diff --git a/src/yuzu/configuration/configure_web.cpp b/src/yuzu/configuration/configure_web.cpp index 9dc34412d..8cacb75f3 100644 --- a/src/yuzu/configuration/configure_web.cpp +++ b/src/yuzu/configuration/configure_web.cpp @@ -22,12 +22,12 @@ ConfigureWeb::ConfigureWeb(QWidget* parent)  #ifndef USE_DISCORD_PRESENCE      ui->discord_group->setVisible(false);  #endif -    this->setConfiguration(); +    SetConfiguration();  }  ConfigureWeb::~ConfigureWeb() = default; -void ConfigureWeb::setConfiguration() { +void ConfigureWeb::SetConfiguration() {      ui->web_credentials_disclaimer->setWordWrap(true);      ui->telemetry_learn_more->setOpenExternalLinks(true);      ui->telemetry_learn_more->setText( @@ -56,7 +56,7 @@ void ConfigureWeb::setConfiguration() {      ui->toggle_discordrpc->setChecked(UISettings::values.enable_discord_presence);  } -void ConfigureWeb::applyConfiguration() { +void ConfigureWeb::ApplyConfiguration() {      Settings::values.enable_telemetry = ui->toggle_telemetry->isChecked();      UISettings::values.enable_discord_presence = ui->toggle_discordrpc->isChecked();      if (user_verified) { @@ -121,6 +121,6 @@ void ConfigureWeb::OnLoginVerified() {      }  } -void ConfigureWeb::retranslateUi() { +void ConfigureWeb::RetranslateUI() {      ui->retranslateUi(this);  } diff --git a/src/yuzu/configuration/configure_web.h b/src/yuzu/configuration/configure_web.h index 7752ae4a1..49bee171b 100644 --- a/src/yuzu/configuration/configure_web.h +++ b/src/yuzu/configuration/configure_web.h @@ -19,8 +19,8 @@ public:      explicit ConfigureWeb(QWidget* parent = nullptr);      ~ConfigureWeb() override; -    void applyConfiguration(); -    void retranslateUi(); +    void ApplyConfiguration(); +    void RetranslateUI();  private:      void RefreshTelemetryID(); @@ -28,7 +28,7 @@ private:      void VerifyLogin();      void OnLoginVerified(); -    void setConfiguration(); +    void SetConfiguration();      bool user_verified = true;      QFutureWatcher<bool> verify_watcher; diff --git a/src/yuzu/game_list_worker.cpp b/src/yuzu/game_list_worker.cpp index 82d2826ba..4f30e9147 100644 --- a/src/yuzu/game_list_worker.cpp +++ b/src/yuzu/game_list_worker.cpp @@ -8,7 +8,9 @@  #include <vector>  #include <QDir> +#include <QFile>  #include <QFileInfo> +#include <QSettings>  #include "common/common_paths.h"  #include "common/file_util.h" @@ -30,13 +32,108 @@  #include "yuzu/ui_settings.h"  namespace { + +QString GetGameListCachedObject(const std::string& filename, const std::string& ext, +                                const std::function<QString()>& generator) { +    if (!UISettings::values.cache_game_list || filename == "0000000000000000") { +        return generator(); +    } + +    const auto path = FileUtil::GetUserPath(FileUtil::UserPath::CacheDir) + DIR_SEP + "game_list" + +                      DIR_SEP + filename + '.' + ext; + +    FileUtil::CreateFullPath(path); + +    if (!FileUtil::Exists(path)) { +        const auto str = generator(); + +        QFile file{QString::fromStdString(path)}; +        if (file.open(QFile::WriteOnly)) { +            file.write(str.toUtf8()); +        } + +        return str; +    } + +    QFile file{QString::fromStdString(path)}; +    if (file.open(QFile::ReadOnly)) { +        return QString::fromUtf8(file.readAll()); +    } + +    return generator(); +} + +std::pair<std::vector<u8>, std::string> GetGameListCachedObject( +    const std::string& filename, const std::string& ext, +    const std::function<std::pair<std::vector<u8>, std::string>()>& generator) { +    if (!UISettings::values.cache_game_list || filename == "0000000000000000") { +        return generator(); +    } + +    const auto path1 = FileUtil::GetUserPath(FileUtil::UserPath::CacheDir) + DIR_SEP + "game_list" + +                       DIR_SEP + filename + ".jpeg"; +    const auto path2 = FileUtil::GetUserPath(FileUtil::UserPath::CacheDir) + DIR_SEP + "game_list" + +                       DIR_SEP + filename + ".appname.txt"; + +    FileUtil::CreateFullPath(path1); + +    if (!FileUtil::Exists(path1) || !FileUtil::Exists(path2)) { +        const auto [icon, nacp] = generator(); + +        QFile file1{QString::fromStdString(path1)}; +        if (!file1.open(QFile::WriteOnly)) { +            LOG_ERROR(Frontend, "Failed to open cache file."); +            return generator(); +        } + +        if (!file1.resize(icon.size())) { +            LOG_ERROR(Frontend, "Failed to resize cache file to necessary size."); +            return generator(); +        } + +        if (file1.write(reinterpret_cast<const char*>(icon.data()), icon.size()) != icon.size()) { +            LOG_ERROR(Frontend, "Failed to write data to cache file."); +            return generator(); +        } + +        QFile file2{QString::fromStdString(path2)}; +        if (file2.open(QFile::WriteOnly)) { +            file2.write(nacp.data(), nacp.size()); +        } + +        return std::make_pair(icon, nacp); +    } + +    QFile file1(QString::fromStdString(path1)); +    QFile file2(QString::fromStdString(path2)); + +    if (!file1.open(QFile::ReadOnly)) { +        LOG_ERROR(Frontend, "Failed to open cache file for reading."); +        return generator(); +    } + +    if (!file2.open(QFile::ReadOnly)) { +        LOG_ERROR(Frontend, "Failed to open cache file for reading."); +        return generator(); +    } + +    std::vector<u8> vec(file1.size()); +    if (file1.read(reinterpret_cast<char*>(vec.data()), vec.size()) != +        static_cast<s64>(vec.size())) { +        return generator(); +    } + +    const auto data = file2.readAll(); +    return std::make_pair(vec, data.toStdString()); +} +  void GetMetadataFromControlNCA(const FileSys::PatchManager& patch_manager, const FileSys::NCA& nca,                                 std::vector<u8>& icon, std::string& name) { -    auto [nacp, icon_file] = patch_manager.ParseControlNCA(nca); -    if (icon_file != nullptr) -        icon = icon_file->ReadAllBytes(); -    if (nacp != nullptr) -        name = nacp->GetApplicationName(); +    std::tie(icon, name) = GetGameListCachedObject( +        fmt::format("{:016X}", patch_manager.GetTitleID()), {}, [&patch_manager, &nca] { +            const auto [nacp, icon_f] = patch_manager.ParseControlNCA(nca); +            return std::make_pair(icon_f->ReadAllBytes(), nacp->GetApplicationName()); +        });  }  bool HasSupportedFileExtension(const std::string& file_name) { @@ -114,8 +211,11 @@ QList<QStandardItem*> MakeGameListEntry(const std::string& path, const std::stri      };      if (UISettings::values.show_add_ons) { -        list.insert( -            2, new GameListItem(FormatPatchNameVersions(patch, loader, loader.IsRomFSUpdatable()))); +        const auto patch_versions = GetGameListCachedObject( +            fmt::format("{:016X}", patch.GetTitleID()), "pv.txt", [&patch, &loader] { +                return FormatPatchNameVersions(patch, loader, loader.IsRomFSUpdatable()); +            }); +        list.insert(2, new GameListItem(patch_versions));      }      return list; diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp index cef2cc1ae..cd32623b4 100644 --- a/src/yuzu/main.cpp +++ b/src/yuzu/main.cpp @@ -238,15 +238,13 @@ void GMainWindow::ProfileSelectorSelectProfile() {      dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint |                            Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint);      dialog.setWindowModality(Qt::WindowModal); -    dialog.exec(); - -    if (!dialog.GetStatus()) { +    if (dialog.exec() == QDialog::Rejected) {          emit ProfileSelectorFinishedSelection(std::nullopt);          return;      }      Service::Account::ProfileManager manager; -    const auto uuid = manager.GetUser(dialog.GetIndex()); +    const auto uuid = manager.GetUser(static_cast<std::size_t>(dialog.GetIndex()));      if (!uuid.has_value()) {          emit ProfileSelectorFinishedSelection(std::nullopt);          return; @@ -261,9 +259,8 @@ void GMainWindow::SoftwareKeyboardGetText(      dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint |                            Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint);      dialog.setWindowModality(Qt::WindowModal); -    dialog.exec(); -    if (!dialog.GetStatus()) { +    if (dialog.exec() == QDialog::Rejected) {          emit SoftwareKeyboardFinishedText(std::nullopt);          return;      } @@ -850,11 +847,6 @@ bool GMainWindow::LoadROM(const QString& filename) {              QMessageBox::critical(this, tr("Error while loading ROM!"),                                    tr("The ROM format is not supported."));              break; -        case Core::System::ResultStatus::ErrorSystemMode: -            LOG_CRITICAL(Frontend, "Failed to load ROM!"); -            QMessageBox::critical(this, tr("Error while loading ROM!"), -                                  tr("Could not determine the system mode.")); -            break;          case Core::System::ResultStatus::ErrorVideoCore:              QMessageBox::critical(                  this, tr("An error occurred initializing the video core."), @@ -901,11 +893,12 @@ void GMainWindow::SelectAndSetCurrentUser() {      dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint |                            Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint);      dialog.setWindowModality(Qt::WindowModal); -    dialog.exec(); -    if (dialog.GetStatus()) { -        Settings::values.current_user = static_cast<s32>(dialog.GetIndex()); +    if (dialog.exec() == QDialog::Rejected) { +        return;      } + +    Settings::values.current_user = dialog.GetIndex();  }  void GMainWindow::BootGame(const QString& filename) { @@ -1055,14 +1048,13 @@ void GMainWindow::OnGameListOpenFolder(u64 program_id, GameListOpenTarget target          const std::string nand_dir = FileUtil::GetUserPath(FileUtil::UserPath::NANDDir);          ASSERT(program_id != 0); -        const auto select_profile = [this]() -> s32 { +        const auto select_profile = [this] {              QtProfileSelectionDialog dialog(this);              dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint |                                    Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint);              dialog.setWindowModality(Qt::WindowModal); -            dialog.exec(); -            if (!dialog.GetStatus()) { +            if (dialog.exec() == QDialog::Rejected) {                  return -1;              } @@ -1070,11 +1062,12 @@ void GMainWindow::OnGameListOpenFolder(u64 program_id, GameListOpenTarget target          };          const auto index = select_profile(); -        if (index == -1) +        if (index == -1) {              return; +        }          Service::Account::ProfileManager manager; -        const auto user_id = manager.GetUser(index); +        const auto user_id = manager.GetUser(static_cast<std::size_t>(index));          ASSERT(user_id);          path = nand_dir + FileSys::SaveDataFactory::GetFullPath(FileSys::SaveDataSpaceId::NandUser,                                                                  FileSys::SaveDataType::SaveData, @@ -1296,10 +1289,10 @@ void GMainWindow::OnGameListOpenPerGameProperties(const std::string& file) {      }      ConfigurePerGameGeneral dialog(this, title_id); -    dialog.loadFromFile(v_file); +    dialog.LoadFromFile(v_file);      auto result = dialog.exec();      if (result == QDialog::Accepted) { -        dialog.applyConfiguration(); +        dialog.ApplyConfiguration();          const auto reload = UISettings::values.is_game_list_reload_pending.exchange(false);          if (reload) { @@ -1396,6 +1389,8 @@ void GMainWindow::OnMenuInstallToNAND() {                                   tr("The file was successfully installed."));          game_list->PopulateAsync(UISettings::values.game_directory_path,                                   UISettings::values.game_directory_deepscan); +        FileUtil::DeleteDirRecursively(FileUtil::GetUserPath(FileUtil::UserPath::CacheDir) + +                                       DIR_SEP + "game_list");      };      const auto failed = [this]() { @@ -1688,26 +1683,31 @@ void GMainWindow::ToggleWindowMode() {  }  void GMainWindow::OnConfigure() { -    ConfigureDialog configureDialog(this, hotkey_registry); -    auto old_theme = UISettings::values.theme; +    const auto old_theme = UISettings::values.theme;      const bool old_discord_presence = UISettings::values.enable_discord_presence; -    auto result = configureDialog.exec(); -    if (result == QDialog::Accepted) { -        configureDialog.applyConfiguration(); -        InitializeHotkeys(); -        if (UISettings::values.theme != old_theme) -            UpdateUITheme(); -        if (UISettings::values.enable_discord_presence != old_discord_presence) -            SetDiscordEnabled(UISettings::values.enable_discord_presence); -        const auto reload = UISettings::values.is_game_list_reload_pending.exchange(false); -        if (reload) { -            game_list->PopulateAsync(UISettings::values.game_directory_path, -                                     UISettings::values.game_directory_deepscan); -        } +    ConfigureDialog configure_dialog(this, hotkey_registry); +    const auto result = configure_dialog.exec(); +    if (result != QDialog::Accepted) { +        return; +    } -        config->Save(); +    configure_dialog.ApplyConfiguration(); +    InitializeHotkeys(); +    if (UISettings::values.theme != old_theme) { +        UpdateUITheme(); +    } +    if (UISettings::values.enable_discord_presence != old_discord_presence) { +        SetDiscordEnabled(UISettings::values.enable_discord_presence);      } + +    const auto reload = UISettings::values.is_game_list_reload_pending.exchange(false); +    if (reload) { +        game_list->PopulateAsync(UISettings::values.game_directory_path, +                                 UISettings::values.game_directory_deepscan); +    } + +    config->Save();  }  void GMainWindow::OnLoadAmiibo() { diff --git a/src/yuzu/main.h b/src/yuzu/main.h index 7bf82e665..1137bbc7a 100644 --- a/src/yuzu/main.h +++ b/src/yuzu/main.h @@ -104,7 +104,7 @@ signals:      void ErrorDisplayFinished(); -    void ProfileSelectorFinishedSelection(std::optional<Service::Account::UUID> uuid); +    void ProfileSelectorFinishedSelection(std::optional<Common::UUID> uuid);      void SoftwareKeyboardFinishedText(std::optional<std::u16string> text);      void SoftwareKeyboardFinishedCheckDialog(); diff --git a/src/yuzu/ui_settings.h b/src/yuzu/ui_settings.h index dbd318e20..a62cd6911 100644 --- a/src/yuzu/ui_settings.h +++ b/src/yuzu/ui_settings.h @@ -79,6 +79,7 @@ struct Values {      uint8_t row_1_text_id;      uint8_t row_2_text_id;      std::atomic_bool is_game_list_reload_pending{false}; +    bool cache_game_list;  };  extern Values values; | 
