From 6d6f5dbf8c8e39aa0cf641a932d4da12200160fe Mon Sep 17 00:00:00 2001 From: Star Rauchenberger Date: Mon, 3 Mar 2025 11:20:59 -0500 Subject: Handle unicode conversion between wx and rest of app --- src/connection_dialog.cpp | 39 +++++++++++++++++++++++---------------- 1 file changed, 23 insertions(+), 16 deletions(-) (limited to 'src/connection_dialog.cpp') diff --git a/src/connection_dialog.cpp b/src/connection_dialog.cpp index 64fee98..45a5b53 100644 --- a/src/connection_dialog.cpp +++ b/src/connection_dialog.cpp @@ -4,14 +4,17 @@ ConnectionDialog::ConnectionDialog() : wxDialog(nullptr, wxID_ANY, "Connect to Archipelago") { - server_box_ = - new wxTextCtrl(this, -1, GetTrackerConfig().connection_details.ap_server, - wxDefaultPosition, {300, -1}); - player_box_ = - new wxTextCtrl(this, -1, GetTrackerConfig().connection_details.ap_player, - wxDefaultPosition, {300, -1}); + server_box_ = new wxTextCtrl( + this, -1, + wxString::FromUTF8(GetTrackerConfig().connection_details.ap_server), + wxDefaultPosition, {300, -1}); + player_box_ = new wxTextCtrl( + this, -1, + wxString::FromUTF8(GetTrackerConfig().connection_details.ap_player), + wxDefaultPosition, {300, -1}); password_box_ = new wxTextCtrl( - this, -1, GetTrackerConfig().connection_details.ap_password, + this, -1, + wxString::FromUTF8(GetTrackerConfig().connection_details.ap_password), wxDefaultPosition, {300, -1}); wxFlexGridSizer* form_sizer = new wxFlexGridSizer(2, 10, 10); @@ -30,17 +33,19 @@ ConnectionDialog::ConnectionDialog() form_sizer->Add(password_box_, wxSizerFlags().Expand()); history_list_ = new wxListBox(this, -1); - for (const ConnectionDetails& details : GetTrackerConfig().connection_history) { + for (const ConnectionDetails& details : + GetTrackerConfig().connection_history) { wxString display_text; - display_text << details.ap_player; + display_text << wxString::FromUTF8(details.ap_player); display_text << " ("; - display_text << details.ap_server; + display_text << wxString::FromUTF8(details.ap_server); display_text << ")"; history_list_->Append(display_text); } - history_list_->Bind(wxEVT_LISTBOX, &ConnectionDialog::OnOldConnectionChosen, this); + history_list_->Bind(wxEVT_LISTBOX, &ConnectionDialog::OnOldConnectionChosen, + this); wxBoxSizer* mid_sizer = new wxBoxSizer(wxHORIZONTAL); mid_sizer->Add(form_sizer, wxSizerFlags().Proportion(3).Expand()); @@ -52,7 +57,8 @@ ConnectionDialog::ConnectionDialog() this, -1, "Enter the details to connect to Archipelago."), wxSizerFlags().Align(wxALIGN_LEFT).DoubleBorder()); top_sizer->Add(mid_sizer, wxSizerFlags().DoubleBorder().Expand()); - top_sizer->Add(CreateButtonSizer(wxOK | wxCANCEL), wxSizerFlags().Border().Center()); + top_sizer->Add(CreateButtonSizer(wxOK | wxCANCEL), + wxSizerFlags().Border().Center()); SetSizerAndFit(top_sizer); @@ -62,9 +68,10 @@ ConnectionDialog::ConnectionDialog() void ConnectionDialog::OnOldConnectionChosen(wxCommandEvent& e) { if (e.IsSelection()) { - const ConnectionDetails& details = GetTrackerConfig().connection_history.at(e.GetSelection()); - server_box_->SetValue(details.ap_server); - player_box_->SetValue(details.ap_player); - password_box_->SetValue(details.ap_password); + const ConnectionDetails& details = + GetTrackerConfig().connection_history.at(e.GetSelection()); + server_box_->SetValue(wxString::FromUTF8(details.ap_server)); + player_box_->SetValue(wxString::FromUTF8(details.ap_player)); + password_box_->SetValue(wxString::FromUTF8(details.ap_password)); } } -- cgit 1.4.1