diff --git a/Source/Core/DolphinQt/Config/ARCodeWidget.cpp b/Source/Core/DolphinQt/Config/ARCodeWidget.cpp index 6a18a16937..667f9373c1 100644 --- a/Source/Core/DolphinQt/Config/ARCodeWidget.cpp +++ b/Source/Core/DolphinQt/Config/ARCodeWidget.cpp @@ -3,6 +3,7 @@ #include "DolphinQt/Config/ARCodeWidget.h" +#include #include #include @@ -113,6 +114,8 @@ void ARCodeWidget::OnContextMenuRequested() QMenu menu; menu.addAction(tr("Sort Alphabetically"), this, &ARCodeWidget::SortAlphabetically); + menu.addAction(tr("Show Enabled Codes First"), this, &ARCodeWidget::SortEnabledCodesFirst); + menu.addAction(tr("Show Disabled Codes First"), this, &ARCodeWidget::SortDisabledCodesFirst); menu.exec(QCursor::pos()); } @@ -123,6 +126,26 @@ void ARCodeWidget::SortAlphabetically() OnListReordered(); } +void ARCodeWidget::SortEnabledCodesFirst() +{ + std::stable_sort(m_ar_codes.begin(), m_ar_codes.end(), [](const auto& a, const auto& b) { + return a.enabled && a.enabled != b.enabled; + }); + + UpdateList(); + SaveCodes(); +} + +void ARCodeWidget::SortDisabledCodesFirst() +{ + std::stable_sort(m_ar_codes.begin(), m_ar_codes.end(), [](const auto& a, const auto& b) { + return !a.enabled && a.enabled != b.enabled; + }); + + UpdateList(); + SaveCodes(); +} + void ARCodeWidget::OnListReordered() { // Reorder codes based on the indices of table item diff --git a/Source/Core/DolphinQt/Config/ARCodeWidget.h b/Source/Core/DolphinQt/Config/ARCodeWidget.h index 862eaac1ab..d24c3fcaf8 100644 --- a/Source/Core/DolphinQt/Config/ARCodeWidget.h +++ b/Source/Core/DolphinQt/Config/ARCodeWidget.h @@ -43,6 +43,8 @@ private: void UpdateList(); void SaveCodes(); void SortAlphabetically(); + void SortEnabledCodesFirst(); + void SortDisabledCodesFirst(); void OnCodeAddClicked(); void OnCodeEditClicked();