From 1640c47a4d264b5c9bc44e0efc6f34ec949ba96f Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Wed, 23 Nov 2022 01:19:04 +0200 Subject: [PATCH 28/28] Client: Add "Connect Maglev" Implemented for gtk3.22- and qt-clients Requested by alain_bkr See osdn #41990 Signed-off-by: Marko Lindqvist --- client/gui-gtk-3.22/menu.c | 40 +++++++++++++++++++++++++++++++++++++- client/gui-qt/menu.cpp | 31 +++++++++++++++++++++++++++++ client/gui-qt/menu.h | 2 ++ data/gtk3.22_menus.xml | 3 +++ data/helpdata.txt | 1 + 5 files changed, 76 insertions(+), 1 deletion(-) diff --git a/client/gui-gtk-3.22/menu.c b/client/gui-gtk-3.22/menu.c index 0e6cf6924f..cb60a0aa0d 100644 --- a/client/gui-gtk-3.22/menu.c +++ b/client/gui-gtk-3.22/menu.c @@ -250,6 +250,7 @@ static void build_mine_callback(GtkMenuItem *item, gpointer data); static void plant_callback(GtkMenuItem *item, gpointer data); static void connect_road_callback(GtkMenuItem *item, gpointer data); static void connect_rail_callback(GtkMenuItem *item, gpointer data); +static void connect_maglev_callback(GtkMenuItem *item, gpointer data); static void connect_irrigation_callback(GtkMenuItem *item, gpointer data); static void transform_terrain_callback(GtkMenuItem *item, gpointer data); static void clean_pollution_callback(GtkMenuItem *item, gpointer data); @@ -573,6 +574,8 @@ static struct menu_entry_info menu_entries[] = G_CALLBACK(connect_road_callback), MGROUP_UNIT }, { "CONNECT_RAIL", N_("Connect With Rai_l"), GDK_KEY_l, GDK_CONTROL_MASK, G_CALLBACK(connect_rail_callback), MGROUP_UNIT }, + { "CONNECT_MAGLEV", N_("Connect With _Maglev"), GDK_KEY_m, GDK_CONTROL_MASK, + G_CALLBACK(connect_maglev_callback), MGROUP_UNIT }, { "CONNECT_IRRIGATION", N_("Connect With Irri_gation"), GDK_KEY_i, GDK_CONTROL_MASK, G_CALLBACK(connect_irrigation_callback), MGROUP_UNIT }, @@ -1842,6 +1845,22 @@ static void connect_rail_callback(GtkMenuItem *action, gpointer data) } } +/************************************************************************//** + Action "CONNECT_MAGLEV" callback. +****************************************************************************/ +static void connect_maglev_callback(GtkMenuItem *action, gpointer data) +{ + struct road_type *pmaglev = road_by_gui_type(ROAD_GUI_MAGLEV); + + if (pmaglev != NULL) { + struct extra_type *tgt; + + tgt = road_extra_get(pmaglev); + + key_unit_connect(ACTIVITY_GEN_ROAD, tgt); + } +} + /************************************************************************//** Action "CONNECT_IRRIGATION" callback. ****************************************************************************/ @@ -2371,6 +2390,13 @@ void real_menus_update(void) extra_name_translation(road_extra_get(proad))); menus_rename("CONNECT_RAIL", road_buf); } + + proad = road_by_gui_type(ROAD_GUI_MAGLEV); + if (proad != NULL) { + snprintf(road_buf, sizeof(road_buf), _("Connect With %s"), + extra_name_translation(road_extra_get(proad))); + menus_rename("CONNECT_MAGLEV", road_buf); + } } { @@ -2572,6 +2598,18 @@ void real_menus_update(void) } menu_entry_set_sensitive("CONNECT_RAIL", conn_possible); + proad = road_by_gui_type(ROAD_GUI_MAGLEV); + if (proad != NULL) { + struct extra_type *tgt; + + tgt = road_extra_get(proad); + + conn_possible = can_units_do_connect(punits, ACTIVITY_GEN_ROAD, tgt); + } else { + conn_possible = FALSE; + } + menu_entry_set_sensitive("CONNECT_MAGLEV", conn_possible); + extras = extra_type_list_by_cause(EC_IRRIGATION); if (extra_type_list_size(extras) > 0) { @@ -2631,7 +2669,7 @@ void real_menus_update(void) } unit_list_iterate_end; if (pextra != NULL) { - /* TRANS: Build road of specific type (Road/Railroad) */ + /* TRANS: Build road of specific type (Road/Railroad/Maglev) */ snprintf(road_item, sizeof(road_item), _("Build %s"), extra_name_translation(pextra)); menus_rename("BUILD_ROAD", road_item); diff --git a/client/gui-qt/menu.cpp b/client/gui-qt/menu.cpp index 01aafc379a..84d40e544c 100644 --- a/client/gui-qt/menu.cpp +++ b/client/gui-qt/menu.cpp @@ -1344,6 +1344,10 @@ void mr_menu::setup_menus() menu_list.insert(CONNECT_RAIL, act); act->setShortcut(QKeySequence(tr("ctrl+l"))); connect(act, &QAction::triggered, this, &mr_menu::slot_conn_rail); + act = main_menu->addAction(_("Connect With Maglev")); + menu_list.insert(CONNECT_MAGLEV, act); + act->setShortcut(QKeySequence(tr("ctrl+m"))); + connect(act, &QAction::triggered, this, &mr_menu::slot_conn_maglev); act = main_menu->addAction(_("Connect With Irrigation")); menu_list.insert(CONNECT_IRRIGATION, act); act->setShortcut(QKeySequence(tr("ctrl+i"))); @@ -2419,6 +2423,18 @@ void mr_menu::menus_sensitive() } break; + case CONNECT_MAGLEV: + proad = road_by_gui_type(ROAD_GUI_MAGLEV); + if (proad != NULL) { + tgt = road_extra_get(proad); + } else { + break; + } + if (can_units_do_connect(punits, ACTIVITY_GEN_ROAD, tgt)) { + i.value()->setEnabled(true); + } + break; + case CONNECT_IRRIGATION: { struct extra_type_list *extras = extra_type_list_by_cause(EC_IRRIGATION); @@ -2621,6 +2637,21 @@ void mr_menu::slot_conn_rail() } } +/**********************************************************************//** + Action "CONNECT WITH MAGLEV" +**************************************************************************/ +void mr_menu::slot_conn_maglev() +{ + struct road_type *pmaglev = road_by_gui_type(ROAD_GUI_MAGLEV); + + if (pmaglev != NULL) { + struct extra_type *tgt; + + tgt = road_extra_get(pmaglev); + key_unit_connect(ACTIVITY_GEN_ROAD, tgt); + } +} + /**********************************************************************//** Action "BUILD FORTRESS" **************************************************************************/ diff --git a/client/gui-qt/menu.h b/client/gui-qt/menu.h index 3495372d2b..8c3e6df199 100644 --- a/client/gui-qt/menu.h +++ b/client/gui-qt/menu.h @@ -64,6 +64,7 @@ enum munit { AUTOSETTLER, CONNECT_ROAD, CONNECT_RAIL, + CONNECT_MAGLEV, CONNECT_IRRIGATION, GOTO_CITY, AIRLIFT, @@ -322,6 +323,7 @@ private slots: void slot_plant(); void slot_conn_road(); void slot_conn_rail(); + void slot_conn_maglev(); void slot_conn_irrigation(); void slot_transform(); void slot_clean_pollution(); diff --git a/data/gtk3.22_menus.xml b/data/gtk3.22_menus.xml index d391794979..4dd9ecea18 100644 --- a/data/gtk3.22_menus.xml +++ b/data/gtk3.22_menus.xml @@ -371,6 +371,9 @@ + + + diff --git a/data/helpdata.txt b/data/helpdata.txt index 201a79bce6..ee9e473738 100644 --- a/data/helpdata.txt +++ b/data/helpdata.txt @@ -1657,6 +1657,7 @@ Unit Orders:\n\ Ctrl+L: set a rai(L) waypoint (when connecting with rail)\n\ m: build (m)ine or convert terrain (settler/worker units)\n\ M: change terrain by planting\n\ + Ctrl+M: connect current and target tile with M)aglev\n\ n: clean (n)uclear fallout\n\ N: explode (N)uclear\n\ o: transf(o)rm terrain (engineer unit)\n\ -- 2.35.1