Additional localization fixes (#966)

This commit is contained in:
Francesco Saltori 2023-09-14 12:47:59 +02:00 committed by GitHub
parent c66ab0c51a
commit 96800c6f97
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
16 changed files with 68 additions and 123 deletions

View file

@ -29,8 +29,8 @@ jobs:
- name: "Generate POT file using xgettext" - name: "Generate POT file using xgettext"
run: > run: >
find src -name *.cpp -o -name *.hpp -o -name *.h | find src -name *.cpp -o -name *.hpp -o -name *.h |
xargs xgettext --from-code=utf-8 xargs xgettext --from-code=utf-8 -w 100
-k_ -kwxTRANSLATE -w 100 --keyword="_" --keyword="wxTRANSLATE" --keyword="wxPLURAL:1,2"
--check=space-ellipsis --omit-header --check=space-ellipsis --omit-header
-o cemu.pot -o cemu.pot

View file

@ -424,7 +424,7 @@ bool DownloadManager::syncAccountTickets()
bool DownloadManager::syncSystemTitleTickets() bool DownloadManager::syncSystemTitleTickets()
{ {
setStatusMessage(std::string(_("Downloading system tickets...")), DLMGR_STATUS_CODE::CONNECTING); setStatusMessage(_("Downloading system tickets...").utf8_string(), DLMGR_STATUS_CODE::CONNECTING);
// todo - add GetAuth() function // todo - add GetAuth() function
NAPI::AuthInfo authInfo; NAPI::AuthInfo authInfo;
authInfo.accountId = m_authInfo.nnidAccountName; authInfo.accountId = m_authInfo.nnidAccountName;
@ -486,7 +486,7 @@ bool DownloadManager::syncSystemTitleTickets()
// build list of updates for which either an installed game exists or the base title ticket is cached // build list of updates for which either an installed game exists or the base title ticket is cached
bool DownloadManager::syncUpdateTickets() bool DownloadManager::syncUpdateTickets()
{ {
setStatusMessage(std::string(_("Retrieving update information...")), DLMGR_STATUS_CODE::CONNECTING); setStatusMessage(_("Retrieving update information...").utf8_string(), DLMGR_STATUS_CODE::CONNECTING);
// download update version list // download update version list
downloadTitleVersionList(); downloadTitleVersionList();
if (!m_hasTitleVersionList) if (!m_hasTitleVersionList)
@ -566,7 +566,7 @@ bool DownloadManager::syncTicketCache()
setStatusMessage(msg, DLMGR_STATUS_CODE::CONNECTING); setStatusMessage(msg, DLMGR_STATUS_CODE::CONNECTING);
prepareIDBE(ticketInfo.titleId); prepareIDBE(ticketInfo.titleId);
} }
setStatusMessage(std::string(_("Connected. Right click entries in the list to start downloading")), DLMGR_STATUS_CODE::CONNECTED); setStatusMessage(_("Connected. Right click entries in the list to start downloading").utf8_string(), DLMGR_STATUS_CODE::CONNECTED);
return true; return true;
} }
@ -652,7 +652,7 @@ void DownloadManager::_handle_connect()
// reset login state // reset login state
m_iasToken.serviceAccountId.clear(); m_iasToken.serviceAccountId.clear();
m_iasToken.deviceToken.clear(); m_iasToken.deviceToken.clear();
setStatusMessage(std::string(_("Logging in..")), DLMGR_STATUS_CODE::CONNECTING); setStatusMessage(_("Logging in...").utf8_string(), DLMGR_STATUS_CODE::CONNECTING);
// retrieve ECS AccountId + DeviceToken from cache // retrieve ECS AccountId + DeviceToken from cache
if (s_nupFileCache) if (s_nupFileCache)
{ {
@ -675,7 +675,7 @@ void DownloadManager::_handle_connect()
cemuLog_log(LogType::Force, "Failed to request IAS token"); cemuLog_log(LogType::Force, "Failed to request IAS token");
cemu_assert_debug(false); cemu_assert_debug(false);
m_connectState.store(CONNECT_STATE::FAILED); m_connectState.store(CONNECT_STATE::FAILED);
setStatusMessage(std::string(_("Login failed. Outdated or incomplete online files?")), DLMGR_STATUS_CODE::FAILED); setStatusMessage(_("Login failed. Outdated or incomplete online files?").utf8_string(), DLMGR_STATUS_CODE::FAILED);
return; return;
} }
} }
@ -683,16 +683,16 @@ void DownloadManager::_handle_connect()
if (!_connect_queryAccountStatusAndServiceURLs()) if (!_connect_queryAccountStatusAndServiceURLs())
{ {
m_connectState.store(CONNECT_STATE::FAILED); m_connectState.store(CONNECT_STATE::FAILED);
setStatusMessage(std::string(_("Failed to query account status. Invalid account information?")), DLMGR_STATUS_CODE::FAILED); setStatusMessage(_("Failed to query account status. Invalid account information?").utf8_string(), DLMGR_STATUS_CODE::FAILED);
return; return;
} }
// load ticket cache and sync // load ticket cache and sync
setStatusMessage(std::string(_("Updating ticket cache")), DLMGR_STATUS_CODE::CONNECTING); setStatusMessage(_("Updating ticket cache").utf8_string(), DLMGR_STATUS_CODE::CONNECTING);
loadTicketCache(); loadTicketCache();
if (!syncTicketCache()) if (!syncTicketCache())
{ {
m_connectState.store(CONNECT_STATE::FAILED); m_connectState.store(CONNECT_STATE::FAILED);
setStatusMessage(std::string(_("Failed to request tickets (invalid NNID?)")), DLMGR_STATUS_CODE::FAILED); setStatusMessage(_("Failed to request tickets (invalid NNID?)").utf8_string(), DLMGR_STATUS_CODE::FAILED);
return; return;
} }
searchForIncompleteDownloads(); searchForIncompleteDownloads();
@ -716,7 +716,7 @@ void DownloadManager::connect(
if (nnidAccountName.empty()) if (nnidAccountName.empty())
{ {
m_connectState.store(CONNECT_STATE::FAILED); m_connectState.store(CONNECT_STATE::FAILED);
setStatusMessage(std::string(_("This account is not linked with an NNID")), DLMGR_STATUS_CODE::FAILED); setStatusMessage(_("This account is not linked with an NNID").utf8_string(), DLMGR_STATUS_CODE::FAILED);
return; return;
} }
runManager(); runManager();
@ -726,7 +726,7 @@ void DownloadManager::connect(
{ {
cemuLog_log(LogType::Force, "DLMgr: Invalid password hash"); cemuLog_log(LogType::Force, "DLMgr: Invalid password hash");
m_connectState.store(CONNECT_STATE::FAILED); m_connectState.store(CONNECT_STATE::FAILED);
setStatusMessage(std::string(_("Failed. Account does not have password set")), DLMGR_STATUS_CODE::FAILED); setStatusMessage(_("Failed. Account does not have password set").utf8_string(), DLMGR_STATUS_CODE::FAILED);
return; return;
} }
m_authInfo.region = region; m_authInfo.region = region;

View file

@ -169,7 +169,7 @@ bool CemuApp::OnInit()
"Thank you for testing the in-development build of Cemu for macOS.\n \n" "Thank you for testing the in-development build of Cemu for macOS.\n \n"
"The macOS port is currently purely experimental and should not be considered stable or ready for issue-free gameplay. " "The macOS port is currently purely experimental and should not be considered stable or ready for issue-free gameplay. "
"There are also known issues with degraded performance due to the use of MoltenVk and Rosetta for ARM Macs. We appreciate your patience while we improve Cemu for macOS."); "There are also known issues with degraded performance due to the use of MoltenVk and Rosetta for ARM Macs. We appreciate your patience while we improve Cemu for macOS.");
wxMessageDialog dialog(nullptr, message, "Preview version", wxCENTRE | wxOK | wxICON_WARNING); wxMessageDialog dialog(nullptr, message, _("Preview version"), wxCENTRE | wxOK | wxICON_WARNING);
dialog.SetOKLabel(_("I understand")); dialog.SetOKLabel(_("I understand"));
dialog.ShowModal(); dialog.ShowModal();
GetConfig().did_show_macos_disclaimer = true; GetConfig().did_show_macos_disclaimer = true;

View file

@ -166,7 +166,7 @@ GameProfileWindow::GameProfileWindow(wxWindow* parent, uint64_t title_id)
for (int i = 0; i < 8; ++i) for (int i = 0; i < 8; ++i)
{ {
profile_sizer->Add(new wxStaticText(panel, wxID_ANY, fmt::format("{} {}", _("Controller").utf8_string(), (i + 1))), 0, wxALIGN_CENTER_VERTICAL | wxALL, 5); profile_sizer->Add(new wxStaticText(panel, wxID_ANY, formatWxString(_("Controller {}"), i + 1)), 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
m_controller_profile[i] = new wxComboBox(panel, wxID_ANY,"", wxDefaultPosition, wxDefaultSize, 0, nullptr, wxCB_DROPDOWN| wxCB_READONLY); m_controller_profile[i] = new wxComboBox(panel, wxID_ANY,"", wxDefaultPosition, wxDefaultSize, 0, nullptr, wxCB_DROPDOWN| wxCB_READONLY);
m_controller_profile[i]->SetMinSize(wxSize(250, -1)); m_controller_profile[i]->SetMinSize(wxSize(250, -1));
@ -244,7 +244,7 @@ void GameProfileWindow::SetProfileInt(gameProfileIntegerOption_t& option, wxChec
void GameProfileWindow::ApplyProfile() void GameProfileWindow::ApplyProfile()
{ {
if(m_game_profile.m_gameName) if(m_game_profile.m_gameName)
this->SetTitle(fmt::format("{} - {}", _("Edit game profile").utf8_string(), m_game_profile.m_gameName.value())); this->SetTitle(_("Edit game profile") + " - " + m_game_profile.m_gameName.value());
// general // general
m_load_libs->SetValue(m_game_profile.m_loadSharedLibraries.value()); m_load_libs->SetValue(m_game_profile.m_loadSharedLibraries.value());

View file

@ -10,24 +10,24 @@
#include "gui/helpers/wxHelpers.h" #include "gui/helpers/wxHelpers.h"
#include "wxHelper.h" #include "wxHelper.h"
std::string _GetTitleIdTypeStr(TitleId titleId) wxString _GetTitleIdTypeStr(TitleId titleId)
{ {
TitleIdParser tip(titleId); TitleIdParser tip(titleId);
switch (tip.GetType()) switch (tip.GetType())
{ {
case TitleIdParser::TITLE_TYPE::AOC: case TitleIdParser::TITLE_TYPE::AOC:
return _("DLC").utf8_string(); return _("DLC");
case TitleIdParser::TITLE_TYPE::BASE_TITLE: case TitleIdParser::TITLE_TYPE::BASE_TITLE:
return _("Base game").utf8_string(); return _("Base game");
case TitleIdParser::TITLE_TYPE::BASE_TITLE_DEMO: case TitleIdParser::TITLE_TYPE::BASE_TITLE_DEMO:
return _("Demo").utf8_string(); return _("Demo");
case TitleIdParser::TITLE_TYPE::SYSTEM_TITLE: case TitleIdParser::TITLE_TYPE::SYSTEM_TITLE:
case TitleIdParser::TITLE_TYPE::SYSTEM_OVERLAY_TITLE: case TitleIdParser::TITLE_TYPE::SYSTEM_OVERLAY_TITLE:
return _("System title").utf8_string(); return _("System title");
case TitleIdParser::TITLE_TYPE::SYSTEM_DATA: case TitleIdParser::TITLE_TYPE::SYSTEM_DATA:
return _("System data title").utf8_string(); return _("System data title");
case TitleIdParser::TITLE_TYPE::BASE_TITLE_UPDATE: case TitleIdParser::TITLE_TYPE::BASE_TITLE_UPDATE:
return _("Update").utf8_string(); return _("Update");
default: default:
break; break;
} }
@ -57,8 +57,8 @@ bool GameUpdateWindow::ParseUpdate(const fs::path& metaPath)
if (tip.GetType() != tipOther.GetType()) if (tip.GetType() != tipOther.GetType())
{ {
std::string typeStrToInstall = _GetTitleIdTypeStr(m_title_info.GetAppTitleId()); auto typeStrToInstall = _GetTitleIdTypeStr(m_title_info.GetAppTitleId());
std::string typeStrCurrentlyInstalled = _GetTitleIdTypeStr(tmp.GetAppTitleId()); auto typeStrCurrentlyInstalled = _GetTitleIdTypeStr(tmp.GetAppTitleId());
auto wxMsg = _("It seems that there is already a title installed at the target location but it has a different type.\nCurrently installed: \'{}\' Installing: \'{}\'\n\nThis can happen for titles which were installed with very old Cemu versions.\nDo you still want to continue with the installation? It will replace the currently installed title."); auto wxMsg = _("It seems that there is already a title installed at the target location but it has a different type.\nCurrently installed: \'{}\' Installing: \'{}\'\n\nThis can happen for titles which were installed with very old Cemu versions.\nDo you still want to continue with the installation? It will replace the currently installed title.");
wxMessageDialog dialog(this, formatWxString(wxMsg, typeStrCurrentlyInstalled, typeStrToInstall), _("Warning"), wxCENTRE | wxYES_NO | wxICON_EXCLAMATION); wxMessageDialog dialog(this, formatWxString(wxMsg, typeStrCurrentlyInstalled, typeStrToInstall), _("Warning"), wxCENTRE | wxYES_NO | wxICON_EXCLAMATION);
@ -131,8 +131,8 @@ bool GameUpdateWindow::ParseUpdate(const fs::path& metaPath)
const fs::space_info targetSpace = fs::space(ActiveSettings::GetMlcPath()); const fs::space_info targetSpace = fs::space(ActiveSettings::GetMlcPath());
if (targetSpace.free <= m_required_size) if (targetSpace.free <= m_required_size)
{ {
auto string = wxStringFormat(_("Not enough space available.\nRequired: {0} MB\nAvailable: {1} MB"), L"%lld %lld", (m_required_size / 1024 / 1024), (targetSpace.free / 1024 / 1024)); auto string = formatWxString(_("Not enough space available.\nRequired: {0} MB\nAvailable: {1} MB"), (m_required_size / 1024 / 1024), (targetSpace.free / 1024 / 1024));
throw std::runtime_error(string); throw std::runtime_error(string.utf8_string());
} }
return true; return true;

View file

@ -2043,17 +2043,17 @@ void GeneralSettings2::OnShowOnlineValidator(wxCommandEvent& event)
wxMessageBox(err, _("Online Status"), wxOK | wxCENTRE | wxICON_INFORMATION); wxMessageBox(err, _("Online Status"), wxOK | wxCENTRE | wxICON_INFORMATION);
} }
std::string GeneralSettings2::GetOnlineAccountErrorMessage(OnlineAccountError error) wxString GeneralSettings2::GetOnlineAccountErrorMessage(OnlineAccountError error)
{ {
switch (error) { switch (error) {
case OnlineAccountError::kNoAccountId: case OnlineAccountError::kNoAccountId:
return _("AccountId missing (The account is not connected to a NNID)").utf8_string(); return _("AccountId missing (The account is not connected to a NNID)");
case OnlineAccountError::kNoPasswordCached: case OnlineAccountError::kNoPasswordCached:
return _("IsPasswordCacheEnabled is set to false (The remember password option on your Wii U must be enabled for this account before dumping it)").utf8_string(); return _("IsPasswordCacheEnabled is set to false (The remember password option on your Wii U must be enabled for this account before dumping it)");
case OnlineAccountError::kPasswordCacheEmpty: case OnlineAccountError::kPasswordCacheEmpty:
return _("AccountPasswordCache is empty (The remember password option on your Wii U must be enabled for this account before dumping it)").utf8_string(); return _("AccountPasswordCache is empty (The remember password option on your Wii U must be enabled for this account before dumping it)");
case OnlineAccountError::kNoPrincipalId: case OnlineAccountError::kNoPrincipalId:
return _("PrincipalId missing").utf8_string(); return _("PrincipalId missing");
default: default:
return "no error"; return "no error";
} }

View file

@ -101,7 +101,7 @@ private:
void OnShowOnlineValidator(wxCommandEvent& event); void OnShowOnlineValidator(wxCommandEvent& event);
void OnOnlineEnable(wxCommandEvent& event); void OnOnlineEnable(wxCommandEvent& event);
void OnAccountServiceChanged(wxCommandEvent& event); void OnAccountServiceChanged(wxCommandEvent& event);
std::string GetOnlineAccountErrorMessage(OnlineAccountError error); static wxString GetOnlineAccountErrorMessage(OnlineAccountError error);
// updates cemu audio devices // updates cemu audio devices
void UpdateAudioDevice(); void UpdateAudioDevice();

View file

@ -445,7 +445,7 @@ void GraphicPacksWindow2::OnTreeSelectionChanged(wxTreeEvent& event)
m_graphic_pack_name->SetLabel(wxHelper::FromUtf8(m_gp_name)); m_graphic_pack_name->SetLabel(wxHelper::FromUtf8(m_gp_name));
if (gp->GetDescription().empty()) if (gp->GetDescription().empty())
m_gp_description = _("This graphic pack has no description"); m_gp_description = _("This graphic pack has no description").utf8_string();
else else
m_gp_description = gp->GetDescription(); m_gp_description = gp->GetDescription();
@ -609,7 +609,7 @@ void GraphicPacksWindow2::OnCheckForUpdates(wxCommandEvent& event)
// check if enabled graphic packs are lost: // check if enabled graphic packs are lost:
const auto& new_packs = GraphicPack2::GetGraphicPacks(); const auto& new_packs = GraphicPack2::GetGraphicPacks();
std::stringstream str; std::stringstream lost_packs;
for(const auto& p : old_packs) for(const auto& p : old_packs)
{ {
if (!p->IsEnabled()) if (!p->IsEnabled())
@ -622,15 +622,16 @@ void GraphicPacksWindow2::OnCheckForUpdates(wxCommandEvent& event)
if(it == new_packs.cend()) if(it == new_packs.cend())
{ {
str << p->GetPath() << std::endl; lost_packs << p->GetPath() << "\n";
} }
} }
const auto packs = str.str(); const auto lost_packs_str = lost_packs.str();
if(!packs.empty()) if (!lost_packs_str.empty())
{ {
wxMessageBox(fmt::format("{}\n \n{} \n{}", _("This update removed or renamed the following graphic packs:").utf8_string(), packs, _("You may need to set them up again.").utf8_string()), wxString message = _("This update removed or renamed the following graphic packs:");
_("Warning"), wxOK | wxCENTRE | wxICON_INFORMATION, this); message << "\n \n" << lost_packs_str << " \n" << _("You may need to set them up again.");
wxMessageBox(message, _("Warning"), wxOK | wxCENTRE | wxICON_INFORMATION, this);
} }
} }
} }

View file

@ -472,9 +472,7 @@ bool MemorySearcherTool::VerifySearchValue() const
void MemorySearcherTool::FillResultList() void MemorySearcherTool::FillResultList()
{ {
//char text[128]; auto text = formatWxString(_("Results ({0})"), m_searchBuffer.size());
//sprintf(text, "Results (%u)", (uint32)m_searchBuffer.size());
auto text = wxStringFormat(_("Results ({0})"), L"%llu", m_searchBuffer.size());
m_textEntryTable->SetLabelText(text); m_textEntryTable->SetLabelText(text);
m_listResults->DeleteAllItems(); m_listResults->DeleteAllItems();

View file

@ -799,7 +799,7 @@ void TitleManager::SetConnected(bool state)
void TitleManager::Callback_ConnectStatusUpdate(std::string statusText, DLMGR_STATUS_CODE statusCode) void TitleManager::Callback_ConnectStatusUpdate(std::string statusText, DLMGR_STATUS_CODE statusCode)
{ {
TitleManager* titleManager = static_cast<TitleManager*>(DownloadManager::GetInstance()->getUserData()); TitleManager* titleManager = static_cast<TitleManager*>(DownloadManager::GetInstance()->getUserData());
titleManager->SetDownloadStatusText(statusText); titleManager->SetDownloadStatusText(wxString::FromUTF8(statusText));
if (statusCode == DLMGR_STATUS_CODE::FAILED) if (statusCode == DLMGR_STATUS_CODE::FAILED)
{ {
auto* evt = new wxCommandEvent(wxEVT_DL_DISCONNECT_COMPLETE); auto* evt = new wxCommandEvent(wxEVT_DL_DISCONNECT_COMPLETE);

View file

@ -501,16 +501,16 @@ wxString wxDownloadManagerList::GetTitleEntryText(const TitleEntry& entry, ItemC
return wxEmptyString; return wxEmptyString;
} }
std::string wxDownloadManagerList::GetTranslatedTitleEntryType(EntryType type) wxString wxDownloadManagerList::GetTranslatedTitleEntryType(EntryType type)
{ {
switch (type) switch (type)
{ {
case EntryType::Base: case EntryType::Base:
return _("base").utf8_string(); return _("base");
case EntryType::Update: case EntryType::Update:
return _("update").utf8_string(); return _("update");
case EntryType::DLC: case EntryType::DLC:
return _("DLC").utf8_string(); return _("DLC");
default: default:
return std::to_string(static_cast<std::underlying_type_t<EntryType>>(type)); return std::to_string(static_cast<std::underlying_type_t<EntryType>>(type));
} }

View file

@ -150,6 +150,6 @@ private:
bool SortFunc(std::span<int> sortColumnOrder, const Type_t& v1, const Type_t& v2); bool SortFunc(std::span<int> sortColumnOrder, const Type_t& v1, const Type_t& v2);
static wxString GetTitleEntryText(const TitleEntry& entry, ItemColumn column); static wxString GetTitleEntryText(const TitleEntry& entry, ItemColumn column);
static std::string GetTranslatedTitleEntryType(EntryType entryType); static wxString GetTranslatedTitleEntryType(EntryType entryType);
std::future<bool> m_context_worker; std::future<bool> m_context_worker;
}; };

View file

@ -1009,15 +1009,20 @@ void wxGameList::OnGameEntryUpdatedByTitleId(wxTitleIdEvent& event)
if (iosu::pdm::GetStatForGamelist(baseTitleId, playTimeStat)) if (iosu::pdm::GetStatForGamelist(baseTitleId, playTimeStat))
{ {
// time played // time played
uint32 timePlayed = playTimeStat.numMinutesPlayed * 60; uint32 minutesPlayed = playTimeStat.numMinutesPlayed;
if (timePlayed == 0) if (minutesPlayed == 0)
SetItem(index, ColumnGameTime, wxEmptyString); SetItem(index, ColumnGameTime, wxEmptyString);
else if (timePlayed < 60) else if (minutesPlayed < 60)
SetItem(index, ColumnGameTime, fmt::format("{} seconds", timePlayed)); SetItem(index, ColumnGameTime, formatWxString(wxPLURAL("{} minute", "{} minutes", minutesPlayed), minutesPlayed));
else if (timePlayed < 60 * 60)
SetItem(index, ColumnGameTime, fmt::format("{} minutes", timePlayed / 60));
else else
SetItem(index, ColumnGameTime, fmt::format("{} hours {} minutes", timePlayed / 3600, (timePlayed / 60) % 60)); {
uint32 hours = minutesPlayed / 60;
uint32 minutes = minutesPlayed % 60;
wxString hoursText = formatWxString(wxPLURAL("{} hour", "{} hours", hours), hours);
wxString minutesText = formatWxString(wxPLURAL("{} minute", "{} minutes", minutes), minutes);
SetItem(index, ColumnGameTime, hoursText + " " + minutesText);
}
// last played // last played
if (playTimeStat.last_played.year != 0) if (playTimeStat.last_played.year != 0)
{ {

View file

@ -963,20 +963,20 @@ wxString wxTitleManagerList::GetTitleEntryText(const TitleEntry& entry, ItemColu
return wxEmptyString; return wxEmptyString;
} }
std::string wxTitleManagerList::GetTranslatedTitleEntryType(EntryType type) wxString wxTitleManagerList::GetTranslatedTitleEntryType(EntryType type)
{ {
switch (type) switch (type)
{ {
case EntryType::Base: case EntryType::Base:
return _("base").utf8_string(); return _("base");
case EntryType::Update: case EntryType::Update:
return _("update").utf8_string(); return _("update");
case EntryType::Dlc: case EntryType::Dlc:
return _("DLC").utf8_string(); return _("DLC");
case EntryType::Save: case EntryType::Save:
return _("save").utf8_string(); return _("save");
case EntryType::System: case EntryType::System:
return _("system").utf8_string(); return _("system");
default: default:
return std::to_string(static_cast<std::underlying_type_t<EntryType>>(type)); return std::to_string(static_cast<std::underlying_type_t<EntryType>>(type));
} }

View file

@ -132,7 +132,7 @@ private:
bool SortFunc(int column, const Type_t& v1, const Type_t& v2); bool SortFunc(int column, const Type_t& v1, const Type_t& v2);
static wxString GetTitleEntryText(const TitleEntry& entry, ItemColumn column); static wxString GetTitleEntryText(const TitleEntry& entry, ItemColumn column);
static std::string GetTranslatedTitleEntryType(EntryType entryType); static wxString GetTranslatedTitleEntryType(EntryType entryType);
std::future<bool> m_context_worker; std::future<bool> m_context_worker;
uint64 m_callbackIdTitleList; uint64 m_callbackIdTitleList;

View file

@ -1,5 +1,7 @@
#pragma once #pragma once
#define wxNO_UNSAFE_WXSTRING_CONV 1
#include <wx/wxprec.h> #include <wx/wxprec.h>
#ifndef WX_PRECOMP #ifndef WX_PRECOMP
#include <wx/wx.h> #include <wx/wx.h>
@ -36,67 +38,6 @@
extern bool g_inputConfigWindowHasFocus; extern bool g_inputConfigWindowHasFocus;
// wx helper functions
#include <wx/string.h>
struct wxStringFormatParameters
{
sint32 parameter_index;
sint32 parameter_count;
wchar_t* token_buffer;
wchar_t* substitude_parameter;
};
template <typename ...Args>
wxString wxStringFormat(std::wstring& format, wxStringFormatParameters& parameters)
{
return format;
}
template <typename T, typename ...Args>
wxString wxStringFormat(std::wstring& format, wxStringFormatParameters& parameters, T arg, Args... args)
{
wchar_t tmp[64];
swprintf(tmp, 64, LR"(\{[%d]+\})", parameters.parameter_index);
const std::wregex placeholder_regex(tmp);
auto result = format;
while (std::regex_search(result, placeholder_regex))
{
result = std::regex_replace(result, placeholder_regex, parameters.substitude_parameter, std::regex_constants::format_first_only);
result = wxString::Format(wxString(result), arg);
}
parameters.parameter_index++;
if (parameters.parameter_index == parameters.parameter_count)
return result;
parameters.substitude_parameter = std::wcstok(nullptr, LR"( )", &parameters.token_buffer);
return wxStringFormat(result, parameters, args...);
}
template <typename ...T>
wxString wxStringFormat(const wxString& format, const wchar_t* parameters, T... args)
{
const auto parameter_count = std::count(parameters, parameters + wcslen(parameters), '%');
if (parameter_count == 0)
return format;
const auto copy = wcsdup(parameters);
wxStringFormatParameters para;
para.substitude_parameter = std::wcstok(copy, LR"( )", &para.token_buffer);
para.parameter_count = parameter_count;
para.parameter_index = 0;
auto tmp_string = format.ToStdWstring();
auto result = wxStringFormat(tmp_string, para, args...);
free(copy);
return result;
}
inline bool SendSliderEvent(wxSlider* slider, int new_value) inline bool SendSliderEvent(wxSlider* slider, int new_value)
{ {
wxCommandEvent cevent(wxEVT_SLIDER, slider->GetId()); wxCommandEvent cevent(wxEVT_SLIDER, slider->GetId());