From bf37d4714f572efa13088863ef6e8ef0132c4021 Mon Sep 17 00:00:00 2001 From: briangood35 Date: Sun, 3 Dec 2023 22:59:17 -0500 Subject: [PATCH] Sort language list in the Preferences dialog Sort langlist before displaying using custom less than operator. Fix #14245, close #14443 --- PowerEditor/src/Parameters.h | 8 ++++++++ .../src/WinControls/Preference/preferenceDlg.cpp | 11 ++++++++++- 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/PowerEditor/src/Parameters.h b/PowerEditor/src/Parameters.h index 004eb5b32..fefe29787 100644 --- a/PowerEditor/src/Parameters.h +++ b/PowerEditor/src/Parameters.h @@ -586,6 +586,14 @@ struct LangMenuItem final LangMenuItem(LangType lt, int cmdID = 0, const std::wstring& langName = TEXT("")): _langType(lt), _cmdID(cmdID), _langName(langName){}; + + bool operator<(const LangMenuItem& rhs) + { + std::wstring lhs_lang(this->_langName.length(), ' '), rhs_lang(rhs._langName.length(), ' '); + std::transform(this->_langName.begin(), this->_langName.end(), lhs_lang.begin(), towlower); + std::transform(rhs._langName.begin(), rhs._langName.end(), rhs_lang.begin(), towlower); + return lhs_lang < rhs_lang; + } }; struct PrintSettings final { diff --git a/PowerEditor/src/WinControls/Preference/preferenceDlg.cpp b/PowerEditor/src/WinControls/Preference/preferenceDlg.cpp index d178837bc..094eb958e 100644 --- a/PowerEditor/src/WinControls/Preference/preferenceDlg.cpp +++ b/PowerEditor/src/WinControls/Preference/preferenceDlg.cpp @@ -19,6 +19,7 @@ #include "lesDlgs.h" #include "EncodingMapper.h" #include "localization.h" +#include #define MyGetGValue(rgb) (LOBYTE((rgb)>>8)) @@ -2861,12 +2862,20 @@ intptr_t CALLBACK LanguageSubDlg::run_dlgProc(UINT message, WPARAM wParam, LPARA if (str.length() > 0) { _langList.push_back(LangMenuItem(static_cast(i), cmdID, str)); - ::SendDlgItemMessage(_hSelf, IDC_LIST_ENABLEDLANG, LB_ADDSTRING, 0, reinterpret_cast(str.c_str())); } } } } + std::sort(_langList.begin(), _langList.end()); + + for (size_t i = 0, len = _langList.size(); i < len; ++i) + { + ::SendDlgItemMessage(_hSelf, IDC_LIST_ENABLEDLANG, LB_ADDSTRING, 0, reinterpret_cast(_langList[i]._langName.c_str())); + } + + std::sort(nppGUI._excludedLangList.begin(), nppGUI._excludedLangList.end()); + for (size_t i = 0, len = nppGUI._excludedLangList.size(); i < len ; ++i) { ::SendDlgItemMessage(_hSelf, IDC_LIST_DISABLEDLANG, LB_ADDSTRING, 0, reinterpret_cast(nppGUI._excludedLangList[i]._langName.c_str()));