From 5dacb8ecb937b2b4167a36c4b6d17aa596cdde61 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Tue, 3 Oct 2023 01:23:30 +0300 Subject: [PATCH 37/37] Qt: Fix UTF8 handling See osdn #48795 Signed-off-by: Marko Lindqvist --- client/gui-qt/chatline.cpp | 6 +++--- client/gui-qt/citydlg.cpp | 10 +++++----- client/gui-qt/cityrep.cpp | 4 ++-- client/gui-qt/dialogs.cpp | 8 ++++---- client/gui-qt/fc_client.cpp | 16 ++++++++-------- client/gui-qt/fonts.cpp | 6 +++--- client/gui-qt/gui_main.cpp | 2 +- client/gui-qt/hudwidget.cpp | 2 +- client/gui-qt/luaconsole.cpp | 4 ++-- client/gui-qt/mapctrl.cpp | 2 +- client/gui-qt/menu.cpp | 6 +++--- client/gui-qt/pages.cpp | 14 +++++++------- client/gui-qt/sidebar.cpp | 2 +- client/gui-qt/themes.cpp | 6 +++--- 14 files changed, 44 insertions(+), 44 deletions(-) diff --git a/client/gui-qt/chatline.cpp b/client/gui-qt/chatline.cpp index 3960bf87f5..3a8de11ee3 100644 --- a/client/gui-qt/chatline.cpp +++ b/client/gui-qt/chatline.cpp @@ -146,7 +146,7 @@ void chat_listener::send_chat_message(const QString &message) if (!splayer.compare(s)) { if (is_ai(pplayer)) { - send_chat(message.toLocal8Bit()); + send_chat(message.toUtf8()); send_chat("/away"); return; } @@ -161,9 +161,9 @@ void chat_listener::send_chat_message(const QString &message) if (client_state() >= C_S_RUNNING && gui_options.gui_qt_allied_chat_only && is_plain_public_message(message)) { send_chat((QString(CHAT_ALLIES_PREFIX) - + " " + message).toLocal8Bit()); + + " " + message).toUtf8()); } else { - send_chat(message.toLocal8Bit()); + send_chat(message.toUtf8()); } } // Empty messages aren't sent diff --git a/client/gui-qt/citydlg.cpp b/client/gui-qt/citydlg.cpp index b2d943af87..52fdcd4cb1 100644 --- a/client/gui-qt/citydlg.cpp +++ b/client/gui-qt/citydlg.cpp @@ -2339,7 +2339,7 @@ void city_dialog::city_rename() return; } - ask_bytes = ask->input_edit.text().toLocal8Bit(); + ask_bytes = ask->input_edit.text().toUtf8(); ::city_rename(pcity, ask_bytes.data()); }); ask->show(); @@ -2385,7 +2385,7 @@ void city_dialog::save_cma() connect(ask, &hud_message_box::accepted, this, CAPTURE_DEFAULT_THIS () { struct cm_parameter param; - QByteArray ask_bytes = ask->input_edit.text().toLocal8Bit(); + QByteArray ask_bytes = ask->input_edit.text().toUtf8(); QString text = ask_bytes.data(); if (!text.isEmpty()) { param.allow_disorder = false; @@ -2399,7 +2399,7 @@ void city_dialog::save_cma() param.factor[i] = slider_tab[2 * i + 1]->value(); } - ask_bytes = text.toLocal8Bit(); + ask_bytes = text.toUtf8(); cmafec_preset_add(ask_bytes.data(), ¶m); update_cma_tab(); } @@ -3653,10 +3653,10 @@ void city_dialog::save_worklist() QString text; struct city *pcity = game_city_by_number(city_id); - ask_bytes = ask->input_edit.text().toLocal8Bit(); + ask_bytes = ask->input_edit.text().toUtf8(); text = ask_bytes.data(); if (!text.isEmpty()) { - ask_bytes = text.toLocal8Bit(); + ask_bytes = text.toUtf8(); gw = global_worklist_new(ask_bytes.data()); city_get_queue(pcity, &queue); global_worklist_set(gw, &queue); diff --git a/client/gui-qt/cityrep.cpp b/client/gui-qt/cityrep.cpp index 40cfaa836f..6e213d3c3e 100644 --- a/client/gui-qt/cityrep.cpp +++ b/client/gui-qt/cityrep.cpp @@ -43,8 +43,8 @@ bool city_sort_model::lessThan(const QModelIndex &left, qleft = sourceModel()->data(left); qright = sourceModel()->data(right); - l_bytes = qleft.toString().toLocal8Bit(); - r_bytes = qright.toString().toLocal8Bit(); + l_bytes = qleft.toString().toUtf8(); + r_bytes = qright.toString().toUtf8(); i = cityrepfield_compare(l_bytes.data(), r_bytes.data()); if (i >= 0) { diff --git a/client/gui-qt/dialogs.cpp b/client/gui-qt/dialogs.cpp index 752edf1c18..5c930794ec 100644 --- a/client/gui-qt/dialogs.cpp +++ b/client/gui-qt/dialogs.cpp @@ -903,9 +903,9 @@ void notify_dialog::restart() q = q + QChar('\n'); } } - capt_bytes = qcaption.toLocal8Bit(); - hl_bytes = qheadline.toLocal8Bit(); - qb_bytes = q.toLocal8Bit(); + capt_bytes = qcaption.toUtf8(); + hl_bytes = qheadline.toUtf8(); + qb_bytes = q.toUtf8(); popup_notify_dialog(capt_bytes.data(), hl_bytes.data(), qb_bytes.data()); @@ -1151,7 +1151,7 @@ void races_dialog::nationset_changed(int index) struct option *poption = optset_option_by_name(server_optset, "nationset"); rule_name = qnation_set->currentData().toString(); - rn_bytes = rule_name.toLocal8Bit(); /* Hold QByteArray in a variable to + rn_bytes = rule_name.toUtf8(); /* Hold QByteArray in a variable to * extend its, and data() buffer's, * lifetime */ rn = rn_bytes.data(); diff --git a/client/gui-qt/fc_client.cpp b/client/gui-qt/fc_client.cpp index b3c0bfc555..e420c49f32 100644 --- a/client/gui-qt/fc_client.cpp +++ b/client/gui-qt/fc_client.cpp @@ -1023,16 +1023,16 @@ QIcon fc_icons::get_icon(const QString &id) str = QString("themes") + DIR_SEPARATOR + "gui-qt" + DIR_SEPARATOR; /* Try custom icon from theme */ - pn_bytes = str.toLocal8Bit(); + pn_bytes = str.toUtf8(); png_bytes = QString(pn_bytes.data() + current_theme + DIR_SEPARATOR - + id + ".png").toLocal8Bit(); + + id + ".png").toUtf8(); icon.addFile(fileinfoname(get_data_dirs(), png_bytes.data())); str = str + "icons" + DIR_SEPARATOR; /* Try icon from icons dir */ if (icon.isNull()) { - pn_bytes = str.toLocal8Bit(); - png_bytes = QString(pn_bytes.data() + id + ".png").toLocal8Bit(); + pn_bytes = str.toUtf8(); + png_bytes = QString(pn_bytes.data() + id + ".png").toUtf8(); icon.addFile(fileinfoname(get_data_dirs(), png_bytes.data())); } @@ -1056,13 +1056,13 @@ QPixmap *fc_icons::get_pixmap(const QString &id) } str = QString("themes") + DIR_SEPARATOR + "gui-qt" + DIR_SEPARATOR; png_bytes = QString(str + current_theme + DIR_SEPARATOR - + id + ".png").toLocal8Bit(); + + id + ".png").toUtf8(); status = pm->load(fileinfoname(get_data_dirs(), png_bytes.data())); if (!status) { str = str + "icons" + DIR_SEPARATOR; - png_bytes = QString(str + id + ".png").toLocal8Bit(); + png_bytes = QString(str + id + ".png").toUtf8(); pm->load(fileinfoname(get_data_dirs(), png_bytes.data())); } QPixmapCache::insert(id, *pm); @@ -1080,7 +1080,7 @@ QString fc_icons::get_path(const QString &id) str = QString("themes") + DIR_SEPARATOR + "gui-qt" + DIR_SEPARATOR + "icons" + DIR_SEPARATOR; - png_bytes = QString(str + id + ".png").toLocal8Bit(); + png_bytes = QString(str + id + ".png").toUtf8(); return fileinfoname(get_data_dirs(), png_bytes.data()); @@ -1333,7 +1333,7 @@ void pregame_options::ruleset_change(int i) if (!cruleset->currentText().isEmpty()) { QByteArray rn_bytes; - rn_bytes = cruleset->currentText().toLocal8Bit(); + rn_bytes = cruleset->currentText().toUtf8(); set_ruleset(rn_bytes.data()); } } diff --git a/client/gui-qt/fonts.cpp b/client/gui-qt/fonts.cpp index 26997d1869..2a79701491 100644 --- a/client/gui-qt/fonts.cpp +++ b/client/gui-qt/fonts.cpp @@ -139,13 +139,13 @@ static void configure_single(QString role, QStringList sl, int size, if (font_name.isEmpty()) { QByteArray fn_bytes; - fn_bytes = role.toLocal8Bit(); + fn_bytes = role.toUtf8(); log_error(_("Failed to setup font for role %s."), fn_bytes.data()); } else { QByteArray fn_bytes; - fn_bytes = font_name.toLocal8Bit(); + fn_bytes = font_name.toUtf8(); fc_strlcpy(font_opt, fn_bytes.data(), FONT_NAME_SIZE); } } @@ -260,7 +260,7 @@ QString configure_font(QString font_name, QStringList sl, int size, f->setBold(true); } fc_font::instance()->set_font(font_name, f); - fn_bytes = f->toString().toLocal8Bit(); + fn_bytes = f->toString().toUtf8(); return fn_bytes.data(); } diff --git a/client/gui-qt/gui_main.cpp b/client/gui-qt/gui_main.cpp index dc28a2c908..2026ace0fa 100644 --- a/client/gui-qt/gui_main.cpp +++ b/client/gui-qt/gui_main.cpp @@ -579,7 +579,7 @@ void qtg_insert_client_build_info(char *outbuf, size_t outlen) { /* There's also an separate entry about Qt in help menu. */ - QByteArray ver = QLibraryInfo::version().toString().toLocal8Bit(); + QByteArray ver = QLibraryInfo::version().toString().toUtf8(); cat_snprintf(outbuf, outlen, _("\nBuilt against Qt %s, using %s"), QT_VERSION_STR, ver.data()); diff --git a/client/gui-qt/hudwidget.cpp b/client/gui-qt/hudwidget.cpp index 64017e52f9..007d49d14b 100644 --- a/client/gui-qt/hudwidget.cpp +++ b/client/gui-qt/hudwidget.cpp @@ -655,7 +655,7 @@ void hud_units::update_actions(unit_list *punits) } else if (num > 1) { QByteArray ut_bytes; - ut_bytes = snum.toLocal8Bit(); + ut_bytes = snum.toUtf8(); /* TRANS: preserve leading space */ text_str = text_str + QString(PL_(" +%1 unit", " +%1 units", num-1)) diff --git a/client/gui-qt/luaconsole.cpp b/client/gui-qt/luaconsole.cpp index 9bd833228c..8c8f192566 100644 --- a/client/gui-qt/luaconsole.cpp +++ b/client/gui-qt/luaconsole.cpp @@ -79,7 +79,7 @@ void qload_lua_script() _("Load lua script"), QDir::homePath(), str); if (!qlua_filename.isEmpty()) { - script_client_do_file(qlua_filename.toLocal8Bit().constData()); + script_client_do_file(qlua_filename.toUtf8().constData()); } } @@ -89,6 +89,6 @@ void qload_lua_script() void qreload_lua_script() { if (!qlua_filename.isEmpty()) { - script_client_do_file(qlua_filename.toLocal8Bit().constData()); + script_client_do_file(qlua_filename.toUtf8().constData()); } } diff --git a/client/gui-qt/mapctrl.cpp b/client/gui-qt/mapctrl.cpp index 697a084d7b..eed6d6920f 100644 --- a/client/gui-qt/mapctrl.cpp +++ b/client/gui-qt/mapctrl.cpp @@ -63,7 +63,7 @@ void popup_newcity_dialog(struct unit *punit, const char *suggestname) if (result == QDialog::Accepted) { QByteArray ask_bytes; - ask_bytes = ask->input_edit.text().toLocal8Bit(); + ask_bytes = ask->input_edit.text().toUtf8(); finish_city(index_to_tile(&(wld.map), index), ask_bytes.data()); } else { diff --git a/client/gui-qt/menu.cpp b/client/gui-qt/menu.cpp index 4dc405015c..e90c59db39 100644 --- a/client/gui-qt/menu.cpp +++ b/client/gui-qt/menu.cpp @@ -3647,7 +3647,7 @@ void mr_menu::tileset_custom_load() foreach (s, sl) { QByteArray on_bytes; - on_bytes = s.toLocal8Bit(); + on_bytes = s.toUtf8(); poption = optset_option_by_name(client_optset, on_bytes.data()); tlset_list = get_tileset_list(poption); strvec_iterate(tlset_list, value) { @@ -3670,7 +3670,7 @@ void mr_menu::load_new_tileset() QByteArray tn_bytes; but = qobject_cast(sender()); - tn_bytes = but->text().toLocal8Bit(); + tn_bytes = but->text().toUtf8(); tilespec_reread(tn_bytes.data(), true, 1.0f); gui()->map_scale = 1.0f; but->parentWidget()->close(); @@ -3870,7 +3870,7 @@ void mr_menu::save_game_as() if (!current_file.isEmpty()) { QByteArray cf_bytes; - cf_bytes = current_file.toLocal8Bit(); + cf_bytes = current_file.toUtf8(); send_save_game(cf_bytes.data()); } } diff --git a/client/gui-qt/pages.cpp b/client/gui-qt/pages.cpp index 92db5718ce..15e47a7ec7 100644 --- a/client/gui-qt/pages.cpp +++ b/client/gui-qt/pages.cpp @@ -1106,7 +1106,7 @@ void fc_client::start_scenario() if (is_server_running() && !current_file.isEmpty()) { QByteArray c_bytes; - c_bytes = current_file.toLocal8Bit(); + c_bytes = current_file.toUtf8(); send_chat_printf("/load %s", c_bytes.data()); switch_page(PAGE_GAME + 1); } @@ -1124,7 +1124,7 @@ void fc_client::start_from_save() if (is_server_running() && !current_file.isEmpty()) { QByteArray c_bytes; - c_bytes = current_file.toLocal8Bit(); + c_bytes = current_file.toUtf8(); send_chat_printf("/load %s", c_bytes.data()); switch_page(PAGE_GAME + 1); } @@ -1231,7 +1231,7 @@ void fc_client::slot_selection_changed(const QItemSelection &selected, load_save_text->setText(""); break; } - fn_bytes = current_file.toLocal8Bit(); + fn_bytes = current_file.toUtf8(); if ((sf = secfile_load_section(fn_bytes.data(), "game", TRUE))) { const char *sname; @@ -1258,7 +1258,7 @@ void fc_client::slot_selection_changed(const QItemSelection &selected, } for (int i = 0; i < num_players; i++) { pl_str = QString("player") + QString::number(i); - pl_bytes = pl_str.toLocal8Bit(); + pl_bytes = pl_str.toUtf8(); if ((sf = secfile_load_section(fn_bytes.data(), pl_bytes.data(), true))) { if (!secfile_lookup_bool_default(sf, true, @@ -1276,7 +1276,7 @@ void fc_client::slot_selection_changed(const QItemSelection &selected, } /* Information about human player */ - pl_bytes = pl_str.toLocal8Bit(); + pl_bytes = pl_str.toUtf8(); if ((sf = secfile_load_section(fn_bytes.data(), pl_bytes.data(), true))) { sname = secfile_lookup_str_default(sf, nullptr, "player%d.nation", @@ -1609,9 +1609,9 @@ void fc_client::slot_connect() switch (connection_status) { case LOGIN_TYPE: - ba_bytes = connect_login_edit->text().toLocal8Bit(); + ba_bytes = connect_login_edit->text().toUtf8(); sz_strlcpy(user_name, ba_bytes.data()); - ba_bytes = connect_host_edit->text().toLocal8Bit(); + ba_bytes = connect_host_edit->text().toUtf8(); sz_strlcpy(server_host, ba_bytes.data()); server_port = connect_port_edit->text().toInt(); diff --git a/client/gui-qt/sidebar.cpp b/client/gui-qt/sidebar.cpp index f38a829d48..17cb23a716 100644 --- a/client/gui-qt/sidebar.cpp +++ b/client/gui-qt/sidebar.cpp @@ -382,7 +382,7 @@ void fc_sidewidget::some_slot() QByteArray cn_bytes; s = QString("/observe \"%1\"").arg(obs_player->name); - cn_bytes = s.toLocal8Bit(); + cn_bytes = s.toUtf8(); send_chat(cn_bytes.data()); } } diff --git a/client/gui-qt/themes.cpp b/client/gui-qt/themes.cpp index 9d339a90c4..4fffc50f2e 100644 --- a/client/gui-qt/themes.cpp +++ b/client/gui-qt/themes.cpp @@ -178,9 +178,9 @@ char **qtg_get_useable_themes_in_directory(const char *directory, int *count) for (int i = 0; i < *count; i++) { QByteArray tn_bytes; - qba = theme_list[i].toLocal8Bit(); - data = new char[theme_list[i].toLocal8Bit().length() + 1]; - tn_bytes = theme_list[i].toLocal8Bit(); + qba = theme_list[i].toUtf8(); + data = new char[theme_list[i].toUtf8().length() + 1]; + tn_bytes = theme_list[i].toUtf8(); strcpy(data, tn_bytes.data()); array[i] = data; } -- 2.40.1