Freeciv-3.1
Loading...
Searching...
No Matches
menu.cpp
Go to the documentation of this file.
1/***********************************************************************
2 Freeciv - Copyright (C) 1996 - A Kjeldberg, L Gregersen, P Unold
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License as published by
5 the Free Software Foundation; either version 2, or (at your option)
6 any later version.
7
8 This program is distributed in the hope that it will be useful,
9 but WITHOUT ANY WARRANTY; without even the implied warranty of
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 GNU General Public License for more details.
12***********************************************************************/
13
14#ifdef HAVE_CONFIG_H
15#include <fc_config.h>
16#endif
17
18// Qt
19#include <QActionGroup>
20#include <QApplication>
21#include <QFileDialog>
22#include <QMainWindow>
23#include <QMessageBox>
24#include <QScrollArea>
25#include <QStandardPaths>
26#include <QVBoxLayout>
27
28// utility
29#include "string_vector.h"
30
31// common
32#include "game.h"
33#include "government.h"
34#include "goto.h"
35#include "name_translation.h"
36#include "road.h"
37#include "unit.h"
38
39// client
40#include "connectdlg_common.h"
41#include "control.h"
42#include "helpdata.h"
43
44// gui-qt
45#include "fc_client.h"
46#include "chatline.h"
47#include "cityrep.h"
48#include "dialogs.h"
49#include "gotodlg.h"
50#include "gui_main.h"
51#include "hudwidget.h"
52#include "mapctrl.h"
53#include "messagedlg.h"
54#include "plrdlg.h"
55#include "ratesdlg.h"
56#include "repodlgs.h"
57#include "shortcuts.h"
58#include "spaceshipdlg.h"
59#include "sprite.h"
60
61#include "menu.h"
62
63static void enable_interface(bool enable);
64
65/**********************************************************************/
69{
70 city = pcity;
71 tile = nullptr;
72 trade_num = 0;
74}
75
76/**********************************************************************/
83
84/**********************************************************************/
88{
89 int i, s;
90 struct city *pcity;
92 s = city_list_size(client.conn.playing->cities);
93 if (s == 0) {
94 return;
95 }
96 for (i = 0; i < s; i++) {
97 pcity = city_list_get(client.conn.playing->cities, i);
98 add_city(pcity);
99 }
100}
101
102/**********************************************************************/
106{
107 struct city *pcity;
108 trade_city *tc;
109
110 foreach(pcity, virtual_cities) {
112 }
113 virtual_cities.clear();
114 foreach(tc, cities) {
115 delete tc;
116 }
117 cities.clear();
118 lines.clear();
119 gui()->mapview_wdg->repaint();
120}
121
122/**********************************************************************/
126{
127 trade_city *tc = new trade_city(pcity);
128
129 cities.append(tc);
130 gui()->infotab->chtwdg->append(QString(_("Adding city %1 to trade planning"))
131 .arg(tc->city->name));
132}
133
134/**********************************************************************/
138{
139 struct city *pcity;
140 trade_city *tc;
141
142 pcity = tile_city(ptile);
143
144 foreach (tc, cities) {
145 if (pcity != nullptr) {
146 if (tc->city == pcity) {
147 remove_city(pcity);
148 return;
149 }
150 }
151 if (tc->city->tile == ptile) {
152 remove_virtual_city(ptile);
153 return;
154 }
155 }
156
157 if (pcity != nullptr) {
158 add_city(pcity);
159 return;
160 }
161
162 pcity = create_city_virtual(client_player(), ptile, "Virtual");
163 add_city(pcity);
164 virtual_cities.append(pcity);
165}
166
167/**********************************************************************/
171{
172 trade_city *tc;
173
174 foreach (tc, cities) {
175 if (tc->city->tile == pcity->tile) {
176 cities.removeAll(tc);
177 gui()->infotab->chtwdg->append(
178 QString(_("Removing city %1 from trade planning"))
179 .arg(tc->city->name));
180 return;
181 }
182 }
183}
184
185/**********************************************************************/
189{
190 struct city *c;
191 trade_city *tc;
192
193 foreach (c, virtual_cities) {
194 if (c->tile == ptile) {
195 virtual_cities.removeAll(c);
196 gui()->infotab->chtwdg->append(
197 QString(_("Removing city %1 from trade planning")).arg(c->name));
198 }
199 }
200
201 foreach (tc, cities) {
202 if (tc->city->tile == ptile) {
203 cities.removeAll(tc);
204 return;
205 }
206 }
207}
208
209/**********************************************************************/
215{
216 trade_city *ttc;
217
218 foreach (ttc, cities) {
219 if (!have_cities_trade_route(tc->city, ttc->city)
220 && can_establish_trade_route(tc->city, ttc->city)) {
221 tc->poss_trade_num++;
222 tc->pos_cities.append(ttc->city);
223 }
224 tc->over_max = tc->trade_num + tc->poss_trade_num
225 - max_trade_routes(tc->city);
226 }
227}
228
229/**********************************************************************/
233{
234 trade_city *tc;
235 int i;
236 bool tdone;
237 int count = cities.size();
238 int *cities_ids = (int *)fc_malloc(sizeof(int) * count);
239 trade_city **cities_order = (trade_city **)fc_malloc(sizeof(trade_city *) * count);
240
241 for (i = 0; i < 100; i++) {
242 int n;
243
244 tdone = true;
245
246 for (n = 0; n < count; n++) {
247 cities_ids[n] = n;
248 cities_order[n] = cities[n];
249 }
250 array_shuffle(cities_ids, count);
251
252 cities.clear();
253 for (n = 0; n < count; n++) {
254 cities.append(cities_order[cities_ids[n]]);
255 }
256
257 lines.clear();
258 foreach (tc, cities) {
259 tc->pos_cities.clear();
260 tc->new_tr_cities.clear();
261 tc->curr_tr_cities.clear();
262 }
263 foreach (tc, cities) {
265 tc->poss_trade_num = 0;
266 tc->pos_cities.clear();
267 tc->new_tr_cities.clear();
268 tc->curr_tr_cities.clear();
269 tc->done = false;
270 calculate_inner(tc);
271 }
272
274 discard();
276
277 foreach (tc, cities) {
278 if (!tc->done) {
279 tdone = false;
280 }
281 }
282 if (tdone) {
283 break;
284 }
285 }
286 foreach (tc, cities) {
287 if (!tc->done) {
288 char text[1024];
289 fc_snprintf(text, sizeof(text),
290 PL_("City %s - 1 free trade route.",
291 "City %s - %d free trade routes.",
292 max_trade_routes(tc->city) - tc->trade_num),
293 city_link(tc->city),
294 max_trade_routes(tc->city) - tc->trade_num);
296 }
297 }
298
299 free(cities_ids);
300 free(cities_order);
301
302 gui()->mapview_wdg->repaint();
303}
304
305/**********************************************************************/
309int trade_generator::find_over_max(struct city *pcity = nullptr)
310{
311 trade_city *tc;
312 int max = 0;
313
314 foreach (tc, cities) {
315 if (pcity != tc->city) {
316 max = qMax(max, tc->over_max);
317 }
318 }
319 return max;
320}
321
322/**********************************************************************/
326{
327 trade_city *tc;
328 trade_city *rc = nullptr;
329 int max = 0;
330
331 foreach (tc, cities) {
332 if (max < tc->over_max) {
333 max = tc->over_max;
334 rc = tc;
335 }
336 }
337 return rc;
338}
339
340/**********************************************************************/
344{
345 trade_city *tc;
346 int j = 5;
347
348 for (int i = j; i > -j; i--) {
349 while ((tc = find_most_free())) {
350 if (!discard_one(tc)) {
351 if (!discard_any(tc, i)) {
352 break;
353 }
354 }
355 }
356 }
357}
358
359/**********************************************************************/
363{
364 tc->pos_cities.removeOne(ttc->city);
365 ttc->pos_cities.removeOne(tc->city);
366 tc->poss_trade_num--;
367 ttc->poss_trade_num--;
368 tc->over_max--;
369 ttc->over_max--;
370 check_if_done(tc, ttc);
371}
372
373/**********************************************************************/
377{
378 int best = 0;
379 int current_candidate = 0;
380 int best_id;
381 trade_city *ttc;
382
383 for (int i = cities.size() - 1 ; i >= 0; i--) {
384 ttc = cities.at(i);
385 current_candidate = ttc->over_max;
386 if (current_candidate > best) {
387 best_id = i;
388 }
389 }
390 if (best == 0) {
391 return false;
392 }
393
394 ttc = cities.at(best_id);
395 discard_trade(tc, ttc);
396 return true;
397}
398
399/**********************************************************************/
403{
404 trade_city *ttc;
405
406 for (int i = cities.size() - 1 ; i >= 0; i--) {
407 ttc = cities.at(i);
408 if (tc->pos_cities.contains(ttc->city)
409 && ttc->pos_cities.contains(tc->city)
410 && ttc->over_max > freeroutes) {
411 discard_trade(tc, ttc);
412 return true;
413 }
414 }
415 return false;
416}
417
418/**********************************************************************/
424{
425 trade_city *ttc;
426
427 foreach (ttc, cities) {
428 if (ttc->done || ttc->over_max > 0
429 || tc == ttc || tc->done || tc->over_max > 0) {
430 continue;
431 }
432 if (tc->pos_cities.contains(ttc->city)
433 && ttc->pos_cities.contains(tc->city)) {
434 struct qtiles gilles;
435
436 tc->pos_cities.removeOne(ttc->city);
437 ttc->pos_cities.removeOne(tc->city);
438 tc->poss_trade_num--;
439 ttc->poss_trade_num--;
440 tc->new_tr_cities.append(ttc->city);
441 ttc->new_tr_cities.append(ttc->city);
442 tc->trade_num++;
443 ttc->trade_num++;
444 tc->over_max--;
445 ttc->over_max--;
446 check_if_done(tc, ttc);
447 gilles.t1 = tc->city->tile;
448 gilles.t2 = ttc->city->tile;
449 gilles.autocaravan = nullptr;
450 lines.append(gilles);
451 }
452 }
453}
454
455/**********************************************************************/
459{
460 trade_city *tc;
461
462 foreach (tc, cities) {
463 if (tc->done || tc->over_max > 0) {
464 continue;
465 }
467 }
468}
469
470/**********************************************************************/
474{
475 if (tc1->trade_num == max_trade_routes(tc1->city)) {
476 tc1->done = true;
477 }
478 if (tc2->trade_num == max_trade_routes(tc2->city)) {
479 tc2->done = true;
480 }
481}
482
483/**********************************************************************/
489
490/**********************************************************************/
494{
495 unit_list.append(fui);
496}
497
498/**********************************************************************/
502{
503 unit_list.clear();
504}
505
506/**********************************************************************/
511{
513 return;
514 }
515 gui()->menu_bar->clear();
516 gui()->menu_bar->setup_menus();
517
519
520 /* A new ruleset may have been loaded. */
522}
523
524/**********************************************************************/
529{
530 if (C_S_RUNNING <= client_state()) {
531 gui()->menuBar()->setVisible(true);
532 if (!is_waiting_turn_change()) {
533 gui()->menu_bar->menus_sensitive();
534 gui()->menu_bar->update_airlift_menu();
535 gui()->menu_bar->update_roads_menu();
536 gui()->menu_bar->update_bases_menu();
539 gui()->unitinfo_wdg->update_actions(nullptr);
540 }
541 } else {
542 gui()->menuBar()->setVisible(false);
543 }
544}
545
546/**********************************************************************/
551static const char *get_tile_change_menu_text(struct tile *ptile,
552 enum unit_activity activity)
553{
554 struct tile *newtile = tile_virtual_new(ptile);
555 const char *text;
556
557 tile_apply_activity(newtile, activity, NULL);
558 text = tile_get_info_text(newtile, FALSE, 0);
559 tile_virtual_destroy(newtile);
560
561 return text;
562}
563
564/**********************************************************************/
567gov_menu::gov_menu(QWidget* parent) :
568 QMenu(_("Government"), parent)
569{
570 // Register ourselves to get updates for free.
571 instances << this;
572 setAttribute(Qt::WA_TranslucentBackground);
573}
574
575/**********************************************************************/
579{
580 qDeleteAll(actions);
581 instances.remove(this);
582}
583
584/**********************************************************************/
588 QAction *action;
589 struct government *gov, *revol_gov;
590 int gov_count, i;
591
592 // Clear any content
593 foreach(action, QWidget::actions()) {
594 removeAction(action);
595 action->deleteLater();
596 }
597 actions.clear();
598
599 gov_count = government_count();
600 actions.reserve(gov_count + 1);
601 action = addAction(_("Revolution..."));
602 connect(action, &QAction::triggered, this, &gov_menu::revolution);
603 actions.append(action);
604
605 addSeparator();
606
607 // Add an action for each government. There is no icon yet.
609 for (i = 0; i < gov_count; ++i) {
610 gov = government_by_number(i);
611 if (gov != revol_gov) { // Skip revolution goverment
612 // Defeat keyboard shortcut mnemonics
613 action = addAction(QString(government_name_translation(gov))
614 .replace("&", "&&"));
615 // We need to keep track of the gov <-> action mapping to be able to
616 // set enabled/disabled depending on available govs.
617 actions.append(action);
618 QObject::connect(action, &QAction::triggered, [this,i]() {
619 change_gov(i);
620 });
621 }
622 }
623}
624
625/**********************************************************************/
629{
630 struct government *gov, *revol_gov;
631 struct sprite *sprite;
632 int gov_count, i, j;
633
634 gov_count = government_count();
636 for (i = 0, j = 0; i < gov_count; i++) {
637 gov = government_by_number(i);
638 if (gov != revol_gov) { // Skip revolution goverment
640 if (sprite != NULL) {
641 actions[j + 1]->setIcon(QIcon(*(sprite->pm)));
642 }
643 actions[j + 1]->setEnabled(
645 j++;
646 } else {
647 actions[0]->setEnabled(!client_is_observer()
649 }
650 }
651}
652
653/**********************************************************************/
660
661/**********************************************************************/
664void gov_menu::change_gov(int target_gov)
665{
667}
668
669/**************************************************************************
670 Keeps track of all gov_menu instances.
671**************************************************************************/
672QSet<gov_menu *> gov_menu::instances = QSet<gov_menu *>();
673
674/**********************************************************************/
678{
679 foreach (gov_menu *m, instances) {
680 m->create();
681 }
682}
683
684/**********************************************************************/
688{
689 foreach (gov_menu *m, instances) {
690 m->update();
691 }
692}
693
694/**********************************************************************/
698 : QMenu(_("Go to and..."), parent)
699{
700 /* Will need auto updates etc. */
701 instances << this;
702}
703
704/**********************************************************************/
708{
709 /* Updates are no longer needed. */
710 instances.remove(this);
711}
712
713/**********************************************************************/
716static void reset_menu_and_sub_menues(QMenu *menu)
717{
718 QAction *action;
719
720 /* Delete each existing menu item. */
721 foreach(action, menu->actions()) {
722 if (action->menu() != nullptr) {
723 /* Delete the sub menu */
725 action->menu()->deleteLater();
726 }
727
728 menu->removeAction(action);
729 action->deleteLater();
730 }
731}
732
733/**********************************************************************/
737{
738 /* Clear menu item to action ID mapping. */
739 items.clear();
740
741 /* Remove the menu items */
743}
744
745/**********************************************************************/
749{
750 QAction *item;
751 int tgt_kind_group;
752
753 /* Group goto and perform action menu items by target kind. */
754 for (tgt_kind_group = 0; tgt_kind_group < ATK_COUNT; tgt_kind_group++) {
755 action_iterate(act_id) {
756 struct action *paction = action_by_number(act_id);
757 QString action_name = (QString(action_name_translation(paction))
758 .replace("&", "&&"));
759
760 if (action_id_get_actor_kind(act_id) != AAK_UNIT) {
761 /* This action isn't performed by a unit. */
762 continue;
763 }
764
765 if (action_id_get_target_kind(act_id) != tgt_kind_group) {
766 /* Wrong group. */
767 continue;
768 }
769
770 if (action_id_has_complex_target(act_id)) {
771 QMenu *sub_target_menu = addMenu(action_name);
772 items.insert(sub_target_menu->menuAction(), act_id);
773
774#define CREATE_SUB_ITEM(_menu_, _act_id_, _sub_tgt_id_, _sub_tgt_name_) \
775 { \
776 QAction *_sub_item_ = _menu_->addAction(_sub_tgt_name_); \
777 int _sub_target_id_ = _sub_tgt_id_; \
778 QObject::connect(_sub_item_, &QAction::triggered, \
779 [this, _act_id_, _sub_target_id_]() { \
780 start_go_act(_act_id_, _sub_target_id_); \
781 }); \
782 }
783
784 switch (action_get_sub_target_kind(paction)) {
785 case ASTK_BUILDING:
786 improvement_iterate(pimpr) {
787 CREATE_SUB_ITEM(sub_target_menu, act_id,
788 improvement_number(pimpr),
791 break;
792 case ASTK_TECH:
793 advance_iterate(A_FIRST, ptech) {
794 CREATE_SUB_ITEM(sub_target_menu, act_id,
795 advance_number(ptech),
798 break;
799 case ASTK_EXTRA:
800 case ASTK_EXTRA_NOT_THERE:
801 extra_type_iterate(pextra) {
802 if (!(action_creates_extra(paction, pextra)
803 || action_removes_extra(paction, pextra))) {
804 /* Not relevant */
805 continue;
806 }
807
808 CREATE_SUB_ITEM(sub_target_menu, act_id,
809 extra_number(pextra),
810 extra_name_translation(pextra));
812 break;
813 case ASTK_NONE:
814 /* Should not be here. */
815 fc_assert(action_get_sub_target_kind(paction) != ASTK_NONE);
816 break;
817 case ASTK_COUNT:
818 /* Should not exits */
819 fc_assert(action_get_sub_target_kind(paction) != ASTK_COUNT);
820 break;
821 }
822 continue;
823 }
824
825#define ADD_OLD_SHORTCUT(wanted_action_id, sc_id) \
826 if (act_id == wanted_action_id) { \
827 item->setShortcut(QKeySequence(shortcut_to_string( \
828 fc_shortcuts::sc()->get_shortcut(sc_id)))); \
829 }
830
831 /* Create and add the menu item. It will be hidden or shown based on
832 * unit type. */
833 item = addAction(action_name);
834 items.insert(item, act_id);
835
836 /* Add the keyboard shortcuts for "Go to and..." menu items that
837 * existed independently before the "Go to and..." menu arrived. */
838 ADD_OLD_SHORTCUT(ACTION_FOUND_CITY, SC_GOBUILDCITY);
839 ADD_OLD_SHORTCUT(ACTION_JOIN_CITY, SC_GOJOINCITY);
840 ADD_OLD_SHORTCUT(ACTION_NUKE, SC_NUKE);
841
842 QObject::connect(item, &QAction::triggered, [this,act_id]() {
843 start_go_act(act_id, NO_TARGET);
844 });
846 }
847}
848
849/**********************************************************************/
853{
854 bool can_do_something = false;
855
856 if (!actions_are_ready()) {
857 /* Nothing to do. */
858 return;
859 }
860
861 if (items.isEmpty()) {
862 /* The goto and act menu needs menu items. */
863 create();
864 }
865
866 /* Enable a menu item if it is theoretically possible that one of the
867 * selected units can perform it. Checking if the action can be performed
868 * at the current tile is pointless since it should be performed at the
869 * target tile. */
870 foreach(QAction *item, items.keys()) {
872 items.value(item), TRUE)) {
873 item->setVisible(true);
874 can_do_something = true;
875 } else {
876 item->setVisible(false);
877 }
878 }
879
880 if (can_do_something) {
881 /* At least one menu item is enabled for one of the selected units. */
882 setEnabled(true);
883 } else {
884 /* No menu item is enabled any of the selected units. */
885 setEnabled(false);
886 }
887}
888
889/**********************************************************************/
892void go_act_menu::start_go_act(int act_id, int sub_tgt_id)
893{
894 request_unit_goto(ORDER_PERFORM_ACTION, act_id, sub_tgt_id);
895}
896
897/**************************************************************************
898 Store all goto and act menu items so they can be updated etc
899**************************************************************************/
900QSet<go_act_menu *> go_act_menu::instances;
901
902/**********************************************************************/
906{
907 foreach (go_act_menu *m, instances) {
908 m->reset();
909 }
910}
911
912/**********************************************************************/
916{
917 foreach (go_act_menu *m, instances) {
918 m->update();
919 }
920}
921
922/**********************************************************************/
926{
928 struct tile *ptile = nullptr;
929 struct unit *zunit;
930 struct unit *qunit;
931
932 int i = 0;
933 qunit = punit;
934 foreach (fui, units_list.unit_list) {
935 zunit = unit_list_find(client_player()->units, fui->id);
936 i++;
937 if (i >= pos) {
938 punit = qunit;
939 return ptile;
940 }
941 if (zunit == nullptr) {
942 continue;
943 }
944
945 if (punit == zunit) { /* Unit found */
946 /* Unit was ordered to attack city so it might stay in
947 front of that city */
949 ptile = tile_before_end_path(punit, fui->ptile);
950 if (ptile == nullptr) {
951 ptile = fui->ptile;
952 }
953 } else {
954 ptile = fui->ptile;
955 }
956 // Unit found in transport
957 } else if (unit_contained_in(punit, zunit)) {
958 ptile = fui->ptile;
959 }
960 }
961 return nullptr;
962}
963
964/**********************************************************************/
967mr_menu::mr_menu() : QMenuBar()
968{
969}
970
971/**********************************************************************/
977{
978 QAction *act;
979 QMenu *menu;
980 QMenu *pr;
981 QList<QMenu*> menus;
982 int i;
983
984 delayed_order = false;
985 airlift_type_id = 0;
986 quick_airlifting = false;
987
988 /* Game Menu */
989 menu = this->addMenu(_("Game"));
990 pr = menu;
991
992#ifdef __APPLE__
993 // On Mac, Qt would try to move menu entry named just "Options" to
994 // application menu, but as this is submenu and not an action
995 // 1) It would fail to appear in the destination
996 // 2) It's impossible to override the behavior with QAction::menuRule()
997 // We add an invisible character for the string comparison to fail.
998 menu = menu->addMenu(QString("\u200B") + _("Options"));
999#else // __APPLE__
1000 menu = menu->addMenu(_("Options"));
1001#endif // __APPLE__
1002
1003 act = menu->addAction(_("Set local options"));
1004 connect(act, &QAction::triggered, this, &mr_menu::local_options);
1005 act = menu->addAction(_("Server Options"));
1006 connect(act, &QAction::triggered, this, &mr_menu::server_options);
1007 act = menu->addAction(_("Messages"));
1008 connect(act, &QAction::triggered, this, &mr_menu::messages_options);
1009 act = menu->addAction(_("Shortcuts"));
1010 connect(act, &QAction::triggered, this, &mr_menu::shortcut_options);
1011 act = menu->addAction(_("Load another tileset"));
1012 connect(act, &QAction::triggered, this, &mr_menu::tileset_custom_load);
1013 act = menu->addAction(_("Save Options Now"));
1014 act->setIcon(style()->standardIcon(QStyle::SP_DialogSaveButton));
1015 connect(act, &QAction::triggered, this, &mr_menu::save_options_now);
1016 act = menu->addAction(_("Save Options on Exit"));
1017 act->setCheckable(true);
1018 act->setChecked(gui_options.save_options_on_exit);
1019 menu = pr;
1020 menu->addSeparator();
1021 act = menu->addAction(_("Save Game"));
1022 act->setShortcut(QKeySequence(tr("Ctrl+s")));
1023 act->setIcon(style()->standardIcon(QStyle::SP_DialogSaveButton));
1024 menu_list.insert(SAVE, act);
1025 connect(act, &QAction::triggered, this, &mr_menu::save_game);
1026 act = menu->addAction(_("Save Game As..."));
1027 menu_list.insert(SAVE, act);
1028 act->setIcon(style()->standardIcon(QStyle::SP_DialogSaveButton));
1029 connect(act, &QAction::triggered, this, &mr_menu::save_game_as);
1030 act = menu->addAction(_("Save Map to Image"));
1031 connect(act, &QAction::triggered, this, &mr_menu::save_image);
1032 menu->addSeparator();
1033 act = menu->addAction(_("Leave game"));
1034 act->setIcon(style()->standardIcon(QStyle::SP_DialogDiscardButton));
1035 connect(act, &QAction::triggered, this, &mr_menu::back_to_menu);
1036 act = menu->addAction(_("Quit"));
1037 act->setIcon(style()->standardIcon(QStyle::SP_TitleBarCloseButton));
1038 connect(act, &QAction::triggered, this, &mr_menu::quit_game);
1039
1040 /* View Menu */
1041 menu = this->addMenu(Q_("?verb:View"));
1042 act = menu->addAction(_("Center View"));
1043 act->setShortcut(QKeySequence(shortcut_to_string(
1044 fc_shortcuts::sc()->get_shortcut(SC_CENTER_VIEW))));
1045 connect(act, &QAction::triggered, this, &mr_menu::slot_center_view);
1046 menu->addSeparator();
1047 act = menu->addAction(_("Fullscreen"));
1048 act->setShortcut(QKeySequence(shortcut_to_string(
1049 fc_shortcuts::sc()->get_shortcut(SC_FULLSCREEN))));
1050 act->setCheckable(true);
1051 act->setChecked(gui_options.gui_qt_fullscreen);
1052 connect(act, &QAction::triggered, this, &mr_menu::slot_fullscreen);
1053 menu->addSeparator();
1054 minimap_status = menu->addAction(_("Minimap"));
1055 minimap_status->setCheckable(true);
1056 minimap_status->setShortcut(QKeySequence(shortcut_to_string(
1057 fc_shortcuts::sc()->get_shortcut(SC_MINIMAP))));
1058 minimap_status->setChecked(true);
1059 connect(minimap_status, &QAction::triggered, this,
1061 osd_status = menu->addAction(_("Show new turn information"));
1062 osd_status->setCheckable(true);
1063 osd_status->setChecked(gui()->qt_settings.show_new_turn_text);
1064 connect(osd_status, &QAction::triggered, this,
1066 btlog_status = menu->addAction(_("Show combat detailed information"));
1067 btlog_status->setCheckable(true);
1068 btlog_status->setChecked(gui()->qt_settings.show_battle_log);
1069 connect(btlog_status, &QAction::triggered, this, &mr_menu::slot_battlelog);
1070 lock_status = menu->addAction(_("Lock interface"));
1071 lock_status->setCheckable(true);
1072 lock_status->setShortcut(QKeySequence(shortcut_to_string(
1073 fc_shortcuts::sc()->get_shortcut(SC_IFACE_LOCK))));
1074 lock_status->setChecked(false);
1075 connect(lock_status, &QAction::triggered, this, &mr_menu::slot_lock);
1076 connect(minimap_status, &QAction::triggered, this, &mr_menu::slot_lock);
1077 menu->addSeparator();
1078 act = menu->addAction(_("Zoom in"));
1079 act->setShortcut(QKeySequence(shortcut_to_string(
1080 fc_shortcuts::sc()->get_shortcut(SC_ZOOM_IN))));
1081 connect(act, &QAction::triggered, this, &mr_menu::zoom_in);
1082 act = menu->addAction(_("Zoom default"));
1083 act->setShortcut(QKeySequence(shortcut_to_string(
1084 fc_shortcuts::sc()->get_shortcut(SC_ZOOM_RESET))));
1085 connect(act, &QAction::triggered, this, &mr_menu::zoom_reset);
1086 act = menu->addAction(_("Zoom out"));
1087 act->setShortcut(QKeySequence(shortcut_to_string(
1088 fc_shortcuts::sc()->get_shortcut(SC_ZOOM_OUT))));
1089 connect(act, &QAction::triggered, this, &mr_menu::zoom_out);
1090 scale_fonts_status = menu->addAction(_("Scale fonts"));
1091 connect(scale_fonts_status, &QAction::triggered, this,
1093 scale_fonts_status->setCheckable(true);
1094 scale_fonts_status->setChecked(true);
1095 menu->addSeparator();
1096 act = menu->addAction(_("City Outlines"));
1097 act->setCheckable(true);
1098 act->setChecked(gui_options.draw_city_outlines);
1099 connect(act, &QAction::triggered, this, &mr_menu::slot_city_outlines);
1100 act = menu->addAction(_("City Output"));
1101 act->setCheckable(true);
1102 act->setChecked(gui_options.draw_city_output);
1103 act->setShortcut(QKeySequence(shortcut_to_string(
1104 fc_shortcuts::sc()->get_shortcut(SC_CITY_OUTPUT))));
1105 connect(act, &QAction::triggered, this, &mr_menu::slot_city_output);
1106 act = menu->addAction(_("Map Grid"));
1107 act->setShortcut(QKeySequence(shortcut_to_string(
1108 fc_shortcuts::sc()->get_shortcut(SC_MAP_GRID))));
1109 act->setCheckable(true);
1110 act->setChecked(gui_options.draw_map_grid);
1111 connect(act, &QAction::triggered, this, &mr_menu::slot_map_grid);
1112 act = menu->addAction(_("National Borders"));
1113 act->setCheckable(true);
1114 act->setChecked(gui_options.draw_borders);
1115 act->setShortcut(QKeySequence(shortcut_to_string(
1116 fc_shortcuts::sc()->get_shortcut(SC_NAT_BORDERS))));
1117 connect(act, &QAction::triggered, this, &mr_menu::slot_borders);
1118 act = menu->addAction(_("Native Tiles"));
1119 act->setCheckable(true);
1120 act->setChecked(gui_options.draw_native);
1121 act->setShortcut(QKeySequence(tr("ctrl+shift+n")));
1122 connect(act, &QAction::triggered, this, &mr_menu::slot_native_tiles);
1123 act = menu->addAction(_("City Full Bar"));
1124 act->setCheckable(true);
1125 act->setShortcut(QKeySequence(shortcut_to_string(
1126 fc_shortcuts::sc()->get_shortcut(SC_SHOW_FULLBAR))));
1127 act->setChecked(gui_options.draw_full_citybar);
1128 connect(act, &QAction::triggered, this, &mr_menu::slot_fullbar);
1129 act = menu->addAction(_("City Names"));
1130 act->setCheckable(true);
1131 act->setChecked(gui_options.draw_city_names);
1132 act->setShortcut(QKeySequence(shortcut_to_string(
1133 fc_shortcuts::sc()->get_shortcut(SC_CITY_NAMES))));
1134 connect(act, &QAction::triggered, this, &mr_menu::slot_city_names);
1135 act = menu->addAction(_("City Growth"));
1136 act->setCheckable(true);
1137 act->setChecked(gui_options.draw_city_growth);
1138 act->setShortcut(QKeySequence(tr("ctrl+o")));
1139 connect(act, &QAction::triggered, this, &mr_menu::slot_city_growth);
1140 act = menu->addAction(_("City Production"));
1141 act->setCheckable(true);
1142 act->setChecked(gui_options.draw_city_productions);
1143 act->setShortcut(QKeySequence(shortcut_to_string(
1144 fc_shortcuts::sc()->get_shortcut(SC_CITY_PROD))));
1145 connect(act, &QAction::triggered, this, &mr_menu::slot_city_production);
1146 act = menu->addAction(_("City Buy Cost"));
1147 act->setCheckable(true);
1148 act->setChecked(gui_options.draw_city_buycost);
1149 connect(act, &QAction::triggered, this, &mr_menu::slot_city_buycost);
1150 act = menu->addAction(_("City Trade Routes"));
1151 act->setCheckable(true);
1152 act->setChecked(gui_options.draw_city_trade_routes);
1153 act->setShortcut(QKeySequence(shortcut_to_string(
1154 fc_shortcuts::sc()->get_shortcut(SC_TRADE_ROUTES))));
1155 connect(act, &QAction::triggered, this, &mr_menu::slot_city_trade_routes);
1156 act = menu->addAction(_("Unit Stack Size"));
1157 act->setCheckable(true);
1158 act->setChecked(gui_options.draw_unit_stack_size);
1159 act->setShortcut(QKeySequence(shortcut_to_string(
1160 fc_shortcuts::sc()->get_shortcut(SC_STACK_SIZE))));
1161 connect(act, &QAction::triggered, this, &mr_menu::slot_stack_size);
1162
1163 /* Select Menu */
1164 menu = this->addMenu(_("Select"));
1165 act = menu->addAction(_("Single Unit (Unselect Others)"));
1166 act->setShortcut(QKeySequence(tr("shift+z")));
1167 menu_list.insert(STANDARD, act);
1168 connect(act, &QAction::triggered, this, &mr_menu::slot_select_one);
1169 act = menu->addAction(_("All On Tile"));
1170 act->setShortcut(QKeySequence(tr("v")));
1171 menu_list.insert(STANDARD, act);
1172 connect(act, &QAction::triggered, this, &mr_menu::slot_select_all_tile);
1173 menu->addSeparator();
1174 act = menu->addAction(_("Same Type on Tile"));
1175 act->setShortcut(QKeySequence(tr("shift+v")));
1176 menu_list.insert(STANDARD, act);
1177 connect(act, &QAction::triggered, this, &mr_menu::slot_select_same_tile);
1178 act = menu->addAction(_("Same Type on Continent"));
1179 act->setShortcut(QKeySequence(tr("shift+c")));
1180 menu_list.insert(STANDARD, act);
1181 connect(act, &QAction::triggered, this,
1183 act = menu->addAction(_("Same Type Everywhere"));
1184 act->setShortcut(QKeySequence(tr("shift+x")));
1185 menu_list.insert(STANDARD, act);
1186 connect(act, &QAction::triggered, this,
1188 menu->addSeparator();
1189 act = menu->addAction(_("Wait"));
1190 act->setShortcut(QKeySequence(shortcut_to_string(
1191 fc_shortcuts::sc()->get_shortcut(SC_WAIT))));
1192 menu_list.insert(STANDARD, act);
1193 connect(act, &QAction::triggered, this, &mr_menu::slot_wait);
1194 act = menu->addAction(_("Done"));
1195 act->setShortcut(QKeySequence(shortcut_to_string(
1196 fc_shortcuts::sc()->get_shortcut(SC_DONE_MOVING))));
1197 menu_list.insert(STANDARD, act);
1198 connect(act, &QAction::triggered, this, &mr_menu::slot_done_moving);
1199
1200 act = menu->addAction(_("Advanced unit selection"));
1201 act->setShortcut(QKeySequence(tr("ctrl+e")));
1202 menu_list.insert(NOT_4_OBS, act);
1203 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_filter);
1204
1205 /* Unit Menu */
1206 menu = this->addMenu(_("Unit"));
1207 act = menu->addAction(_("Go to Tile"));
1208 act->setShortcut(QKeySequence(shortcut_to_string(
1209 fc_shortcuts::sc()->get_shortcut(SC_GOTO))));
1210 menu_list.insert(STANDARD, act);
1211 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_goto);
1212
1213 // The goto and act sub menu is handled as a separate object.
1214 menu->addMenu(new go_act_menu(this));
1215
1216 act = menu->addAction(_("Go to Nearest City"));
1217 act->setShortcut(QKeySequence(tr("shift+g")));
1218 menu_list.insert(GOTO_CITY, act);
1219 connect(act, &QAction::triggered, this, &mr_menu::slot_return_to_city);
1220 act = menu->addAction(_("Go to/Airlift to City..."));
1221 act->setShortcut(QKeySequence(shortcut_to_string(
1222 fc_shortcuts::sc()->get_shortcut(SC_GOTOAIRLIFT))));
1223 menu_list.insert(AIRLIFT, act);
1224 connect(act, &QAction::triggered, this, &mr_menu::slot_airlift);
1225 menu->addSeparator();
1226 act = menu->addAction(_("Auto Explore"));
1227 menu_list.insert(EXPLORE, act);
1228 act->setShortcut(QKeySequence(shortcut_to_string(
1229 fc_shortcuts::sc()->get_shortcut(SC_AUTOEXPLORE))));
1230 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_explore);
1231 act = menu->addAction(_("Patrol"));
1232 menu_list.insert(STANDARD, act);
1233 act->setEnabled(false);
1234 act->setShortcut(QKeySequence(shortcut_to_string(
1235 fc_shortcuts::sc()->get_shortcut(SC_PATROL))));
1236 connect(act, &QAction::triggered, this, &mr_menu::slot_patrol);
1237 menu->addSeparator();
1238 act = menu->addAction(_("Sentry"));
1239 act->setShortcut(QKeySequence(shortcut_to_string(
1240 fc_shortcuts::sc()->get_shortcut(SC_SENTRY))));
1241 menu_list.insert(SENTRY, act);
1242 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_sentry);
1243 act = menu->addAction(_("Unsentry All On Tile"));
1244 act->setShortcut(QKeySequence(shortcut_to_string(
1245 fc_shortcuts::sc()->get_shortcut(SC_UNSENTRY_TILE))));
1246 menu_list.insert(WAKEUP, act);
1247 connect(act, &QAction::triggered, this, &mr_menu::slot_unsentry);
1248 menu->addSeparator();
1249 act = menu->addAction(_("Load"));
1250 act->setShortcut(QKeySequence(shortcut_to_string(
1251 fc_shortcuts::sc()->get_shortcut(SC_BOARD))));
1252 menu_list.insert(BOARD, act);
1253 connect(act, &QAction::triggered, this, &mr_menu::slot_board);
1254 act = menu->addAction(_("Unload"));
1255 act->setShortcut(QKeySequence(shortcut_to_string(
1256 fc_shortcuts::sc()->get_shortcut(SC_DEBOARD))));
1257 menu_list.insert(DEBOARD, act);
1258 connect(act, &QAction::triggered, this, &mr_menu::slot_deboard);
1259 act = menu->addAction(_("Unload All From Transporter"));
1260 act->setShortcut(QKeySequence(tr("shift+t")));
1261 menu_list.insert(TRANSPORTER, act);
1262 connect(act, &QAction::triggered, this, &mr_menu::slot_unload_all);
1263 menu->addSeparator();
1264 // Defeat keyboard shortcut mnemonics
1265 act = menu->addAction(QString(action_id_name_translation(ACTION_HOME_CITY))
1266 .replace("&", "&&"));
1267 menu_list.insert(HOMECITY, act);
1268 act->setShortcut(QKeySequence(shortcut_to_string(
1269 fc_shortcuts::sc()->get_shortcut(SC_SETHOME))));
1270 connect(act, &QAction::triggered, this, &mr_menu::slot_set_home);
1271 act = menu->addAction(_("Upgrade"));
1272 act->setShortcut(QKeySequence(shortcut_to_string(
1273 fc_shortcuts::sc()->get_shortcut(SC_UPGRADE_UNIT))));
1274 menu_list.insert(UPGRADE, act);
1275 connect(act, &QAction::triggered, this, &mr_menu::slot_upgrade);
1276 act = menu->addAction(_("Convert"));
1277 act->setShortcut(QKeySequence(tr("shift+o")));
1278 menu_list.insert(CONVERT, act);
1279 connect(act, &QAction::triggered, this, &mr_menu::slot_convert);
1280 act = menu->addAction(_("Disband"));
1281 act->setShortcut(QKeySequence(tr("shift+d")));
1282 menu_list.insert(DISBAND, act);
1283 connect(act, &QAction::triggered, this, &mr_menu::slot_disband);
1284
1285 /* Combat Menu */
1286 menu = this->addMenu(_("Combat"));
1287 act = menu->addAction(_("Fortify Unit"));
1288 menu_list.insert(FORTIFY, act);
1289 act->setShortcut(QKeySequence(shortcut_to_string(
1290 fc_shortcuts::sc()->get_shortcut(SC_FORTIFY))));
1291 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_fortify);
1292 act = menu->addAction(QString(Q_(terrain_control.gui_type_base0))
1293 .replace("&", "&&"));
1294 menu_list.insert(FORTRESS, act);
1295 act->setShortcut(QKeySequence(tr("shift+f")));
1296 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_fortress);
1297 act = menu->addAction(QString(Q_(terrain_control.gui_type_base1))
1298 .replace("&", "&&"));
1299 menu_list.insert(AIRBASE, act);
1300 act->setShortcut(QKeySequence(tr("shift+e")));
1301 connect(act, &QAction::triggered, this, &mr_menu::slot_unit_airbase);
1302 bases_menu = menu->addMenu(_("Build Base"));
1303 menu->addSeparator();
1304 act = menu->addAction(_("Pillage"));
1305 menu_list.insert(PILLAGE, act);
1306 act->setShortcut(QKeySequence(tr("shift+p")));
1307 connect(act, &QAction::triggered, this, &mr_menu::slot_pillage);
1308 /* TRANS: Menu item to bring up the action selection dialog. */
1309 act = menu->addAction(_("Do..."));
1310 menu_list.insert(ORDER_DIPLOMAT_DLG, act);
1311 act->setShortcut(QKeySequence(shortcut_to_string(
1312 fc_shortcuts::sc()->get_shortcut(SC_DO))));
1313 connect(act, &QAction::triggered, this, &mr_menu::slot_action);
1314
1315 /* Work Menu */
1316 menu = this->addMenu(_("Work"));
1317 act = menu->addAction(QString(action_id_name_translation(ACTION_FOUND_CITY))
1318 .replace("&", "&&"));
1319 act->setShortcut(QKeySequence(shortcut_to_string(
1320 fc_shortcuts::sc()->get_shortcut(SC_BUILDCITY))));
1321 menu_list.insert(BUILD, act);
1322 connect(act, &QAction::triggered, this, &mr_menu::slot_build_city);
1323 act = menu->addAction(_("Auto Settler"));
1324 act->setShortcut(QKeySequence(shortcut_to_string(
1325 fc_shortcuts::sc()->get_shortcut(SC_AUTOMATE))));
1326 menu_list.insert(AUTOSETTLER, act);
1327 connect(act, &QAction::triggered, this, &mr_menu::slot_auto_settler);
1328 menu->addSeparator();
1329 act = menu->addAction(_("Build Road"));
1330 menu_list.insert(ROAD, act);
1331 act->setShortcut(QKeySequence(shortcut_to_string(
1332 fc_shortcuts::sc()->get_shortcut(SC_BUILDROAD))));
1333 connect(act, &QAction::triggered, this, &mr_menu::slot_build_road);
1334 roads_menu = menu->addMenu(_("Build Path"));
1335 act = menu->addAction(_("Build Irrigation"));
1336 act->setShortcut(QKeySequence(shortcut_to_string(
1337 fc_shortcuts::sc()->get_shortcut(SC_BUILDIRRIGATION))));
1338 menu_list.insert(IRRIGATION, act);
1339 connect(act, &QAction::triggered, this, &mr_menu::slot_build_irrigation);
1340 act = menu->addAction(_("Cultivate"));
1341 act->setShortcut(QKeySequence(shortcut_to_string(
1342 fc_shortcuts::sc()->get_shortcut(SC_CULTIVATE))));
1343 menu_list.insert(CULTIVATE, act);
1344 connect(act, &QAction::triggered, this, &mr_menu::slot_cultivate);
1345 act = menu->addAction(_("Build Mine"));
1346 act->setShortcut(QKeySequence(shortcut_to_string(
1347 fc_shortcuts::sc()->get_shortcut(SC_BUILDMINE))));
1348 menu_list.insert(MINE, act);
1349 connect(act, &QAction::triggered, this, &mr_menu::slot_build_mine);
1350 act = menu->addAction(_("Plant"));
1351 act->setShortcut(QKeySequence(shortcut_to_string(
1352 fc_shortcuts::sc()->get_shortcut(SC_PLANT))));
1353 menu_list.insert(PLANT, act);
1354 connect(act, &QAction::triggered, this, &mr_menu::slot_plant);
1355 menu->addSeparator();
1356 act = menu->addAction(_("Connect With Road"));
1357 act->setShortcut(QKeySequence(tr("ctrl+r")));
1358 menu_list.insert(CONNECT_ROAD, act);
1359 connect(act, &QAction::triggered, this, &mr_menu::slot_conn_road);
1360 act = menu->addAction(_("Connect With Railroad"));
1361 menu_list.insert(CONNECT_RAIL, act);
1362 act->setShortcut(QKeySequence(tr("ctrl+l")));
1363 connect(act, &QAction::triggered, this, &mr_menu::slot_conn_rail);
1364 act = menu->addAction(_("Connect With Maglev"));
1365 menu_list.insert(CONNECT_MAGLEV, act);
1366 act->setShortcut(QKeySequence(tr("ctrl+m")));
1367 connect(act, &QAction::triggered, this, &mr_menu::slot_conn_maglev);
1368 act = menu->addAction(_("Connect With Irrigation"));
1369 menu_list.insert(CONNECT_IRRIGATION, act);
1370 act->setShortcut(QKeySequence(tr("ctrl+i")));
1371 connect(act, &QAction::triggered, this, &mr_menu::slot_conn_irrigation);
1372 menu->addSeparator();
1373 act = menu->addAction(_("Transform Terrain"));
1374 menu_list.insert(TRANSFORM, act);
1375 act->setShortcut(QKeySequence(shortcut_to_string(
1376 fc_shortcuts::sc()->get_shortcut(SC_TRANSFORM))));
1377 connect(act, &QAction::triggered, this, &mr_menu::slot_transform);
1378 act = menu->addAction(_("Clean Pollution"));
1379 menu_list.insert(POLLUTION, act);
1380 act->setShortcut(QKeySequence(shortcut_to_string(
1381 fc_shortcuts::sc()->get_shortcut(SC_PARADROP))));
1382 connect(act, &QAction::triggered, this, &mr_menu::slot_clean_pollution);
1383 act = menu->addAction(_("Clean Nuclear Fallout"));
1384 menu_list.insert(FALLOUT, act);
1385 act->setShortcut(QKeySequence(tr("n")));
1386 connect(act, &QAction::triggered, this, &mr_menu::slot_clean_fallout);
1387 act = menu->addAction(QString(action_id_name_translation(ACTION_HELP_WONDER))
1388 .replace("&", "&&"));
1389 act->setShortcut(QKeySequence(tr("b")));
1390 menu_list.insert(BUILD_WONDER, act);
1391 connect(act, &QAction::triggered, this, &mr_menu::slot_build_city);
1392 act = menu->addAction(QString(action_id_name_translation(ACTION_TRADE_ROUTE))
1393 .replace("&", "&&"));
1394 act->setShortcut(QKeySequence(tr("r")));
1395 menu_list.insert(ORDER_TRADE_ROUTE, act);
1396 connect(act, &QAction::triggered, this, &mr_menu::slot_build_road);
1397
1398 // Multiplayer Menu
1399 multiplayer_menu = this->addMenu(_("Multiplayer"));
1400 act = multiplayer_menu->addAction(_("Delayed Goto"));
1401 act->setShortcut(QKeySequence(tr("z")));
1402 connect(act, &QAction::triggered, this, &mr_menu::slot_delayed_goto);
1403 act = multiplayer_menu->addAction(_("Delayed Orders Execute"));
1404 act->setShortcut(QKeySequence(tr("ctrl+z")));
1405 connect(act, &QAction::triggered, this, &mr_menu::slot_execute_orders);
1406 act = multiplayer_menu->addAction(_("Clear Orders"));
1407 act->setShortcut(QKeySequence(tr("ctrl+shift+c")));
1408 connect(act, &QAction::triggered, this, &mr_menu::slot_orders_clear);
1409 act = multiplayer_menu->addAction(_("Add all cities to trade planning"));
1410 connect(act, &QAction::triggered, this, &mr_menu::slot_trade_add_all);
1411 act = multiplayer_menu->addAction(_("Calculate trade planning"));
1412 connect(act, &QAction::triggered, this, &mr_menu::slot_calculate);
1413 act = multiplayer_menu->addAction(_("Add/Remove City"));
1414 act->setShortcut(QKeySequence(tr("ctrl+t")));
1415 connect(act, &QAction::triggered, this, &mr_menu::slot_trade_city);
1416 act = multiplayer_menu->addAction(_("Clear Trade Planning"));
1417 connect(act, &QAction::triggered, this, &mr_menu::slot_clear_trade);
1418 act = multiplayer_menu->addAction(_("Automatic caravan"));
1419 menu_list.insert(AUTOTRADEROUTE, act);
1420 connect(act, &QAction::triggered, this, &mr_menu::slot_autocaravan);
1421 act->setShortcut(QKeySequence(tr("ctrl+j")));
1422 act = multiplayer_menu->addAction(_("Set/Unset rally point"));
1423 act->setShortcut(QKeySequence(tr("shift+s")));
1424 connect(act, &QAction::triggered, this, &mr_menu::slot_rally);
1425 act = multiplayer_menu->addAction(_("Quick Airlift"));
1426 act->setShortcut(QKeySequence(tr("ctrl+y")));
1427 connect(act, &QAction::triggered, this, &mr_menu::slot_quickairlift);
1428 airlift_type = new QActionGroup(this);
1429 airlift_menu = multiplayer_menu->addMenu(_("Unit type for quickairlifting"));
1430
1431 /* Default diplo */
1432 action_vs_city = new QActionGroup(this);
1433 action_vs_unit = new QActionGroup(this);
1434 action_unit_menu = multiplayer_menu->addMenu(_("Default action vs unit"));
1435
1436 act = action_unit_menu->addAction(_("Ask"));
1437 act->setCheckable(true);
1438 act->setChecked(true);
1439 act->setData(-1);
1440 action_vs_unit->addAction(act);
1441 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_unit);
1442
1443 act = action_unit_menu->addAction(_("Bribe"));
1444 act->setCheckable(true);
1445 act->setChecked(false);
1446 act->setData(ACTION_SPY_BRIBE_UNIT);
1447 action_vs_unit->addAction(act);
1448 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_unit);
1449
1450 act = action_unit_menu->addAction(_("Sabotage"));
1451 act->setCheckable(true);
1452 act->setChecked(false);
1453 act->setData(ACTION_SPY_SABOTAGE_UNIT);
1454 action_vs_unit->addAction(act);
1455 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_unit);
1456
1457 act = action_unit_menu->addAction(_("Sabotage Unit Escape"));
1458 act->setCheckable(true);
1459 act->setChecked(false);
1460 act->setData(ACTION_SPY_SABOTAGE_UNIT_ESC);
1461 action_vs_unit->addAction(act);
1462 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_unit);
1463
1464 action_city_menu = multiplayer_menu->addMenu(_("Default action vs city"));
1465 act = action_city_menu->addAction(_("Ask"));
1466 act->setCheckable(true);
1467 act->setChecked(true);
1468 act->setData(-1);
1469 action_vs_city->addAction(act);
1470 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1471
1472 act = action_city_menu->addAction(_("Investigate city"));
1473 act->setCheckable(true);
1474 act->setChecked(false);
1475 act->setData(ACTION_SPY_INVESTIGATE_CITY);
1476 action_vs_city->addAction(act);
1477 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1478
1479 act = action_city_menu->addAction(_("Investigate city (spends the unit)"));
1480 act->setCheckable(true);
1481 act->setChecked(false);
1482 act->setData(ACTION_INV_CITY_SPEND);
1483 action_vs_city->addAction(act);
1484 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1485
1486 act = action_city_menu->addAction(_("Establish embassy"));
1487 act->setCheckable(true);
1488 act->setChecked(false);
1489 act->setData(ACTION_ESTABLISH_EMBASSY);
1490 action_vs_city->addAction(act);
1491 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1492
1493 act = action_city_menu->addAction(_("Become Ambassador"));
1494 act->setCheckable(true);
1495 act->setChecked(false);
1496 act->setData(ACTION_ESTABLISH_EMBASSY_STAY);
1497 action_vs_city->addAction(act);
1498 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1499
1500 act = action_city_menu->addAction(_("Steal technology"));
1501 act->setCheckable(true);
1502 act->setChecked(false);
1503 act->setData(ACTION_SPY_STEAL_TECH);
1504 action_vs_city->addAction(act);
1505 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1506
1507 act = action_city_menu->addAction(_("Steal technology and escape"));
1508 act->setCheckable(true);
1509 act->setChecked(false);
1510 act->setData(ACTION_SPY_STEAL_TECH_ESC);
1511 action_vs_city->addAction(act);
1512 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1513
1514 act = action_city_menu->addAction(_("Incite a revolt"));
1515 act->setCheckable(true);
1516 act->setChecked(false);
1517 act->setData(ACTION_SPY_INCITE_CITY);
1518 action_vs_city->addAction(act);
1519 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1520
1521 act = action_city_menu->addAction(_("Incite a Revolt and Escape"));
1522 act->setCheckable(true);
1523 act->setChecked(false);
1524 act->setData(ACTION_SPY_INCITE_CITY_ESC);
1525 action_vs_city->addAction(act);
1526 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1527
1528 act = action_city_menu->addAction(_("Poison city"));
1529 act->setCheckable(true);
1530 act->setChecked(false);
1531 act->setData(ACTION_SPY_POISON);
1532 action_vs_city->addAction(act);
1533 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1534
1535 act = action_city_menu->addAction(_("Poison City Escape"));
1536 act->setCheckable(true);
1537 act->setChecked(false);
1538 act->setData(ACTION_SPY_POISON_ESC);
1539 action_vs_city->addAction(act);
1540 connect(act, &QAction::triggered, this, &mr_menu::slot_action_vs_city);
1541
1542 /* Civilization menu */
1543 menu = this->addMenu(_("Civilization"));
1544 act = menu->addAction(_("Tax Rates..."));
1545 menu_list.insert(NOT_4_OBS, act);
1546 connect(act, &QAction::triggered, this, &mr_menu::slot_popup_tax_rates);
1547 menu->addSeparator();
1548
1549 act = menu->addAction(_("Policies..."));
1550 menu_list.insert(MULTIPLIERS, act);
1551 connect(act, &QAction::triggered, this, &mr_menu::slot_popup_mult_rates);
1552 menu->addSeparator();
1553
1554 menu->addMenu(new class gov_menu(this));
1555 menu->addSeparator();
1556
1557 act = menu->addAction(Q_("?noun:View"));
1558 act->setShortcut(QKeySequence(tr("F1")));
1559 connect(act, &QAction::triggered, this, &mr_menu::slot_show_map);
1560
1561 act = menu->addAction(_("Units"));
1562 act->setShortcut(QKeySequence(tr("F2")));
1563 connect(act, &QAction::triggered, this, &mr_menu::slot_show_units_report);
1564
1565 act = menu->addAction(_("Nations"));
1566 act->setShortcut(QKeySequence(tr("F3")));
1567 connect(act, &QAction::triggered, this, &mr_menu::slot_show_nations);
1568
1569 act = menu->addAction(_("Cities"));
1570 act->setShortcut(QKeySequence(tr("F4")));
1571 connect(act, &QAction::triggered, this, &mr_menu::slot_show_cities);
1572
1573 act = menu->addAction(_("Economy"));
1574 act->setShortcut(QKeySequence(tr("F5")));
1575 connect(act, &QAction::triggered, this, &mr_menu::slot_show_eco_report);
1576
1577 act = menu->addAction(_("Research"));
1578 act->setShortcut(QKeySequence(tr("F6")));
1579 connect(act, &QAction::triggered, this, &mr_menu::slot_show_research_tab);
1580
1581 act = menu->addAction(_("Wonders of the World"));
1582 act->setShortcut(QKeySequence(tr("F7")));
1583 connect(act, &QAction::triggered, this, &mr_menu::slot_traveler);
1584
1585 act = menu->addAction(_("Top Five Cities"));
1586 act->setShortcut(QKeySequence(tr("F8")));
1587 connect(act, &QAction::triggered, this, &mr_menu::slot_top_five);
1588
1589 act = menu->addAction(_("Demographics"));
1590 act->setShortcut(QKeySequence(tr("F11")));
1591 connect(act, &QAction::triggered, this, &mr_menu::slot_demographics);
1592
1593 act = menu->addAction(_("Spaceship"));
1594 act->setShortcut(QKeySequence(tr("F12")));
1595 connect(act, &QAction::triggered, this, &mr_menu::slot_spaceship);
1596
1597 act = menu->addAction(_("Achievements"));
1598 connect(act, &QAction::triggered, this, &mr_menu::slot_achievements);
1599
1600 act = menu->addAction(_("Endgame report"));
1601 menu_list.insert(ENDGAME, act);
1602 connect(act, &QAction::triggered, this, &mr_menu::slot_endgame);
1603
1604 // Battle Groups Menu
1605 menu = this->addMenu(_("Battle Groups"));
1606
1607 act = menu->addAction(_("Select Battle Group 1"));
1608 act->setShortcut(QKeySequence(tr("Shift+F1")));
1609 connect(act, &QAction::triggered, this, &mr_menu::slot_bg1select);
1610
1611 act = menu->addAction(_("Assign Battle Group 1"));
1612 act->setShortcut(QKeySequence(tr("Ctrl+F1")));
1613 connect(act, &QAction::triggered, this, &mr_menu::slot_bg1assign);
1614
1615 act = menu->addAction(_("Append to Battle Group 1"));
1616 act->setShortcut(QKeySequence(tr("Ctrl+Shift+F1")));
1617 connect(act, &QAction::triggered, this, &mr_menu::slot_bg1append);
1618
1619 act = menu->addAction(_("Select Battle Group 2"));
1620 act->setShortcut(QKeySequence(tr("Shift+F2")));
1621 connect(act, &QAction::triggered, this, &mr_menu::slot_bg2select);
1622
1623 act = menu->addAction(_("Assign Battle Group 2"));
1624 act->setShortcut(QKeySequence(tr("Ctrl+F2")));
1625 connect(act, &QAction::triggered, this, &mr_menu::slot_bg2assign);
1626
1627 act = menu->addAction(_("Append to Battle Group 2"));
1628 act->setShortcut(QKeySequence(tr("Ctrl+Shift+F2")));
1629 connect(act, &QAction::triggered, this, &mr_menu::slot_bg2append);
1630
1631 act = menu->addAction(_("Select Battle Group 3"));
1632 act->setShortcut(QKeySequence(tr("Shift+F3")));
1633 connect(act, &QAction::triggered, this, &mr_menu::slot_bg3select);
1634
1635 act = menu->addAction(_("Assign Battle Group 3"));
1636 act->setShortcut(QKeySequence(tr("Ctrl+F3")));
1637 connect(act, &QAction::triggered, this, &mr_menu::slot_bg3assign);
1638
1639 act = menu->addAction(_("Append to Battle Group 3"));
1640 act->setShortcut(QKeySequence(tr("Ctrl+Shift+F3")));
1641 connect(act, &QAction::triggered, this, &mr_menu::slot_bg3append);
1642
1643 act = menu->addAction(_("Select Battle Group 4"));
1644 act->setShortcut(QKeySequence(tr("Shift+F4")));
1645 connect(act, &QAction::triggered, this, &mr_menu::slot_bg4select);
1646
1647 act = menu->addAction(_("Assign Battle Group 4"));
1648 act->setShortcut(QKeySequence(tr("Ctrl+F4")));
1649 connect(act, &QAction::triggered, this, &mr_menu::slot_bg4assign);
1650
1651 act = menu->addAction(_("Append to Battle Group 4"));
1652 act->setShortcut(QKeySequence(tr("Ctrl+Shift+F4")));
1653 connect(act, &QAction::triggered, this, &mr_menu::slot_bg4append);
1654
1655 // Help Menu
1656 menu = this->addMenu(_("Help"));
1657
1658 act = menu->addAction(Q_(HELP_OVERVIEW_ITEM));
1659 QObject::connect(act, &QAction::triggered, [this]() {
1661 });
1662
1663 act = menu->addAction(Q_(HELP_PLAYING_ITEM));
1664 QObject::connect(act, &QAction::triggered, [this]() {
1666 });
1667
1668 act = menu->addAction(Q_(HELP_TERRAIN_ITEM));
1669 QObject::connect(act, &QAction::triggered, [this]() {
1671 });
1672
1673 act = menu->addAction(Q_(HELP_ECONOMY_ITEM));
1674 QObject::connect(act, &QAction::triggered, [this]() {
1676 });
1677
1678 act = menu->addAction(Q_(HELP_CITIES_ITEM));
1679 QObject::connect(act, &QAction::triggered, [this]() {
1681 });
1682
1683 act = menu->addAction(Q_(HELP_IMPROVEMENTS_ITEM));
1684 QObject::connect(act, &QAction::triggered, [this]() {
1686 });
1687
1688 act = menu->addAction(Q_(HELP_WONDERS_ITEM));
1689 QObject::connect(act, &QAction::triggered, [this]() {
1691 });
1692
1693 act = menu->addAction(Q_(HELP_UNITS_ITEM));
1694 QObject::connect(act, &QAction::triggered, [this]() {
1696 });
1697
1698 act = menu->addAction(Q_(HELP_COMBAT_ITEM));
1699 QObject::connect(act, &QAction::triggered, [this]() {
1701 });
1702
1703 act = menu->addAction(Q_(HELP_ZOC_ITEM));
1704 QObject::connect(act, &QAction::triggered, [this]() {
1706 });
1707
1708 act = menu->addAction(Q_(HELP_GOVERNMENT_ITEM));
1709 QObject::connect(act, &QAction::triggered, [this]() {
1711 });
1712
1713 act = menu->addAction(Q_(HELP_ECONOMY_ITEM));
1714 QObject::connect(act, &QAction::triggered, [this]() {
1716 });
1717
1718 act = menu->addAction(Q_(HELP_DIPLOMACY_ITEM));
1719 QObject::connect(act, &QAction::triggered, [this]() {
1721 });
1722
1723 act = menu->addAction(Q_(HELP_TECHS_ITEM));
1724 QObject::connect(act, &QAction::triggered, [this]() {
1726 });
1727
1728 act = menu->addAction(Q_(HELP_SPACE_RACE_ITEM));
1729 QObject::connect(act, &QAction::triggered, [this]() {
1731 });
1732
1733 act = menu->addAction(Q_(HELP_IMPROVEMENTS_ITEM));
1734 QObject::connect(act, &QAction::triggered, [this]() {
1736 });
1737
1738 act = menu->addAction(Q_(HELP_RULESET_ITEM));
1739 QObject::connect(act, &QAction::triggered, [this]() {
1741 });
1742
1743 act = menu->addAction(Q_(HELP_TILESET_ITEM));
1744 QObject::connect(act, &QAction::triggered, [this]() {
1746 });
1747
1748 act = menu->addAction(Q_(HELP_NATIONS_ITEM));
1749 QObject::connect(act, &QAction::triggered, [this]() {
1751 });
1752
1753 menu->addSeparator();
1754
1755 act = menu->addAction(Q_(HELP_CONNECTING_ITEM));
1756 QObject::connect(act, &QAction::triggered, [this]() {
1758 });
1759
1760 act = menu->addAction(Q_(HELP_CONTROLS_ITEM));
1761 QObject::connect(act, &QAction::triggered, [this]() {
1763 });
1764
1765 act = menu->addAction(Q_(HELP_CMA_ITEM));
1766 QObject::connect(act, &QAction::triggered, [this]() {
1768 });
1769
1770 act = menu->addAction(Q_(HELP_CHATLINE_ITEM));
1771 QObject::connect(act, &QAction::triggered, [this]() {
1773 });
1774
1775 act = menu->addAction(Q_(HELP_WORKLIST_EDITOR_ITEM));
1776 QObject::connect(act, &QAction::triggered, [this]() {
1778 });
1779
1780 menu->addSeparator();
1781
1782 act = menu->addAction(Q_(HELP_LANGUAGES_ITEM));
1783 QObject::connect(act, &QAction::triggered, [this]() {
1785 });
1786
1787 act = menu->addAction(Q_(HELP_COPYING_ITEM));
1788 QObject::connect(act, &QAction::triggered, [this]() {
1790 });
1791
1792 act = menu->addAction(Q_(HELP_ABOUT_ITEM));
1793 QObject::connect(act, &QAction::triggered, [this]() {
1795 });
1796
1797 menus = this->findChildren<QMenu*>();
1798 for (i = 0; i < menus.count(); i++) {
1799 menus[i]->setAttribute(Qt::WA_TranslucentBackground);
1800 }
1801 this->setVisible(false);
1802}
1803
1804/**********************************************************************/
1808{
1809 for (int i=0; i < units_list.nr_units; i++) {
1810 units_list.unit_list.at(units_list.unit_list.count() - i -1)->ptile = ptile;
1811 }
1812}
1813
1814/**********************************************************************/
1819bool mr_menu::execute_shortcut_inner(const QMenu *m, QKeySequence seq)
1820{
1821 foreach (QAction *a, m->actions()) {
1822 if (a->shortcut() == seq && a->isEnabled()) {
1823 a->activate(QAction::Trigger);
1824 return TRUE;
1825 }
1826 }
1827
1828 return FALSE;
1829}
1830
1831/**********************************************************************/
1835{
1836 QList<QMenu*> menus;
1837 QKeySequence seq;
1838 fc_shortcut *fcs;
1839
1840 if (sid == SC_GOTO) {
1841 gui()->mapview_wdg->menu_click = true;
1843 return;
1844 }
1845 fcs = fc_shortcuts::sc()->get_shortcut(static_cast<shortcut_id>(sid));
1846 seq = QKeySequence(shortcut_to_string(fcs));
1847
1848 menus = findChildren<QMenu*>();
1849 foreach (const QMenu *m, menus) {
1850 if (execute_shortcut_inner(m, seq)) {
1851 return;
1852 }
1853 }
1854}
1855
1856/**********************************************************************/
1861bool mr_menu::shortcut_exist_inner(const QMenu *m, QKeySequence seq,
1862 fc_shortcut *fcs, QString *ret)
1863{
1864 foreach (QAction *a, m->actions()) {
1865 if (a->shortcut() == seq && fcs->mouse == Qt::AllButtons) {
1866 *ret = a->text();
1867
1868 return TRUE;
1869 }
1870 }
1871
1872 return FALSE;
1873}
1874
1875/**********************************************************************/
1879{
1880 QList<QMenu*> menus;
1881 QKeySequence seq;
1882
1883 seq = QKeySequence(shortcut_to_string(fcs));
1884 menus = findChildren<QMenu *>();
1885 foreach (const QMenu *m, menus) {
1886 QString ret;
1887
1888 if (shortcut_exist_inner(m, seq, fcs, &ret)) {
1889 return ret;
1890 }
1891 }
1892
1893 return QString();
1894}
1895
1896/**********************************************************************/
1901bool mr_menu::shortcut_2_menustring_inner(const QMenu *m, QKeySequence seq,
1902 QString *ret)
1903{
1904 foreach (QAction *a, m->actions()) {
1905 if (a->shortcut() == seq) {
1906 *ret = a->text() + " ("
1907 + a->shortcut().toString(QKeySequence::NativeText) + ")";
1908
1909 return TRUE;
1910 }
1911 }
1912
1913 return FALSE;
1914}
1915
1916/**********************************************************************/
1920{
1921 QList<QMenu *> menus;
1922 QKeySequence seq;
1923 fc_shortcut *fcs;
1924
1925 fcs = fc_shortcuts::sc()->get_shortcut(static_cast<shortcut_id>(sid));
1926 seq = QKeySequence(shortcut_to_string(fcs));
1927
1928 menus = findChildren<QMenu *>();
1929 foreach (const QMenu *m, menus) {
1930 QString ret;
1931
1932 if (shortcut_2_menustring_inner(m, seq, &ret)) {
1933 return ret;
1934 }
1935 }
1936
1937 return QString();
1938}
1939
1940/**********************************************************************/
1944{
1945 Unit_type_id utype_id;
1946 QAction *act;
1947
1948 airlift_menu->clear();
1949 if (client_is_observer()) {
1950 return;
1951 }
1952 unit_type_iterate(utype) {
1953 utype_id = utype_index(utype);
1954
1956 || !utype_can_do_action(utype, ACTION_AIRLIFT)) {
1957 continue;
1958 }
1960 && !has_player_unit_type(utype_id)) {
1961 continue;
1962 }
1963 // Defeat keyboard shortcut mnemonics
1964 act = airlift_menu->addAction(QString(utype_name_translation(utype))
1965 .replace("&", "&&"));
1966 act->setCheckable(true);
1967 act->setData(utype_id);
1968 if (airlift_type_id == utype_id) {
1969 act->setChecked(true);
1970 }
1971 connect(act, &QAction::triggered, this, &mr_menu::slot_quickairlift_set);
1972 airlift_type->addAction(act);
1974}
1975
1976/****************************************************************************
1977 Updates "build path" menu
1978****************************************************************************/
1980{
1981 QAction *act;
1982 struct unit_list *punits = nullptr;
1983 bool enabled = false;
1984
1985 foreach(act, roads_menu->actions()) {
1986 removeAction(act);
1987 act->deleteLater();
1988 }
1989 roads_menu->clear();
1990 roads_menu->setDisabled(true);
1991 if (client_is_observer()) {
1992 return;
1993 }
1994
1995 punits = get_units_in_focus();
1996 extra_type_by_cause_iterate(EC_ROAD, pextra) {
1997 if (pextra->buildable) {
1998 int road_id;
1999
2000 // Defeat keyboard shortcut mnemonics
2001 act = roads_menu->addAction(QString(extra_name_translation(pextra))
2002 .replace("&", "&&"));
2003 road_id = pextra->id;
2004 act->setData(road_id);
2005 QObject::connect(act, &QAction::triggered, [this,road_id]() {
2006 slot_build_path(road_id);
2007 });
2009 ACTIVITY_GEN_ROAD, pextra)) {
2010 act->setEnabled(true);
2011 enabled = true;
2012 } else {
2013 act->setDisabled(true);
2014 }
2015 }
2017
2018 if (enabled) {
2019 roads_menu->setEnabled(true);
2020 }
2021}
2022
2023/****************************************************************************
2024 Updates "build bases" menu
2025****************************************************************************/
2027{
2028 QAction *act;
2029 struct unit_list *punits = nullptr;
2030 bool enabled = false;
2031
2032 foreach(act, bases_menu->actions()) {
2033 removeAction(act);
2034 act->deleteLater();
2035 }
2036 bases_menu->clear();
2037 bases_menu->setDisabled(true);
2038
2039 if (client_is_observer()) {
2040 return;
2041 }
2042
2043 punits = get_units_in_focus();
2044 extra_type_by_cause_iterate(EC_BASE, pextra) {
2045 if (pextra->buildable) {
2046 int base_id;
2047
2048 // Defeat keyboard shortcut mnemonics
2049 act = bases_menu->addAction(QString(extra_name_translation(pextra))
2050 .replace("&", "&&"));
2051 base_id = pextra->id;
2052 act->setData(base_id);
2053 QObject::connect(act, &QAction::triggered, [this,base_id]() {
2054 slot_build_base(base_id);
2055 });
2056 if (can_units_do_activity_targeted_client(punits, ACTIVITY_BASE, pextra)) {
2057 act->setEnabled(true);
2058 enabled = true;
2059 } else {
2060 act->setDisabled(true);
2061 }
2062 }
2064
2065 if (enabled) {
2066 bases_menu->setEnabled(true);
2067 }
2068}
2069
2070/**********************************************************************/
2074{
2075 QList <QAction * >values;
2076 QList <munit > keys;
2077 QMultiHash <munit, QAction *>::iterator i;
2078 struct unit_list *punits = nullptr;
2079 struct road_type *proad;
2080 struct extra_type *tgt;
2081 bool any_cities = false;
2082 bool city_on_tile = false;
2083 bool units_all_same_tile = true;
2084 const struct tile *ptile = NULL;
2085 const struct unit_type *ptype = NULL;
2086
2087 players_iterate(pplayer) {
2088 if (city_list_size(pplayer->cities)) {
2089 any_cities = true;
2090 break;
2091 }
2093
2095 foreach(QAction *a, menu_list) {
2096 a->setEnabled(false);
2097 }
2098
2099 if (client_is_observer()) {
2100 multiplayer_menu->setDisabled(true);
2101 } else {
2102 multiplayer_menu->setDisabled(false);
2103 }
2104
2105 /* Non unit menus */
2106 keys = menu_list.keys();
2107 foreach (munit key, keys) {
2108 i = menu_list.find(key);
2109 while (i != menu_list.end() && i.key() == key) {
2110 switch (key) {
2111 case SAVE:
2113 i.value()->setEnabled(true);
2114 }
2115 break;
2116 case NOT_4_OBS:
2117 if (!client_is_observer()) {
2118 i.value()->setEnabled(true);
2119 }
2120 break;
2121 case MULTIPLIERS:
2122 if (!client_is_observer() && multiplier_count() > 0) {
2123 i.value()->setEnabled(true);
2124 i.value()->setVisible(true);
2125 } else {
2126 i.value()->setVisible(false);
2127 }
2128 break;
2129 case ENDGAME:
2130 if (gui()->is_repo_dlg_open("END")) {
2131 i.value()->setEnabled(true);
2132 i.value()->setVisible(true);
2133 } else {
2134 i.value()->setVisible(false);
2135 }
2136 break;
2137 default:
2138 break;
2139 }
2140 i++;
2141 }
2142 }
2143
2145 return;
2146 }
2147
2148 punits = get_units_in_focus();
2149 unit_list_iterate(punits, punit) {
2150 if (tile_city(unit_tile(punit))) {
2151 city_on_tile = true;
2152 break;
2153 }
2155
2156 unit_list_iterate(punits, punit) {
2157 const struct unit_type *ntype;
2158
2159 fc_assert((ptile == NULL) == (ptype == NULL));
2160
2161 ntype = unit_type_get(punit);
2162
2163 // 'ntype == ptype' is correct check even when ptype is still nullptr
2164 if (ptile != nullptr && ntype == ptype && unit_tile(punit) != ptile) {
2165 units_all_same_tile = false;
2166 }
2167
2168 if (ptype == nullptr || ntype == ptype) {
2169 ptile = unit_tile(punit);
2170 ptype = ntype;
2171 }
2173
2174 keys = menu_list.keys();
2175 foreach(munit key, keys) {
2176 i = menu_list.find(key);
2177 while (i != menu_list.end() && i.key() == key) {
2178 switch (key) {
2179 case STANDARD:
2180 i.value()->setEnabled(true);
2181 break;
2182
2183 case EXPLORE:
2184 if (can_units_do_activity_client(punits, ACTIVITY_EXPLORE)) {
2185 i.value()->setEnabled(true);
2186 }
2187 break;
2188
2189 case BOARD:
2190 if (units_can_load(punits)) {
2191 i.value()->setEnabled(true);
2192 }
2193 break;
2194
2195 case DEBOARD:
2196 if (units_can_unload(punits)) {
2197 i.value()->setEnabled(true);
2198 }
2199 break;
2200
2201 case TRANSPORTER:
2202 if (units_are_occupied(punits)) {
2203 i.value()->setEnabled(true);
2204 }
2205 break;
2206
2207 case CONVERT:
2208 if (units_can_convert(&(wld.map), punits)) {
2209 i.value()->setEnabled(true);
2210 }
2211 break;
2212
2213 case MINE:
2214 if (can_units_do_activity_client(punits, ACTIVITY_MINE)) {
2215 i.value()->setEnabled(true);
2216 }
2217
2218 if (units_all_same_tile) {
2219 if (units_have_type_flag(punits, UTYF_SETTLERS, TRUE)) {
2220 struct extra_type *pextra = NULL;
2221
2222 /* FIXME: this overloading doesn't work well with multiple focus
2223 * units. */
2224 unit_list_iterate(punits, builder) {
2225 pextra = next_extra_for_tile(unit_tile(builder), EC_MINE,
2226 unit_owner(builder), builder);
2227 if (pextra != NULL) {
2228 break;
2229 }
2231
2232 if (pextra != NULL) {
2233 i.value()->setText(
2234 /* TRANS: Build mine of specific type */
2235 QString(_("Build %1"))
2236 .arg(extra_name_translation(pextra))
2237 .replace("&", "&&"));
2238 } else {
2239 i.value()->setText(QString(_("Build Mine")));
2240 }
2241 } else {
2242 i.value()->setText(QString(_("Build Mine")));
2243 }
2244 }
2245 break;
2246
2247 case IRRIGATION:
2248 if (can_units_do_activity_client(punits, ACTIVITY_IRRIGATE)) {
2249 i.value()->setEnabled(true);
2250 }
2251 if (units_all_same_tile) {
2252 if (units_have_type_flag(punits, UTYF_SETTLERS, TRUE)) {
2253 struct extra_type *pextra = NULL;
2254
2255 /* FIXME: this overloading doesn't work well with multiple focus
2256 * units. */
2257 unit_list_iterate(punits, builder) {
2258 pextra = next_extra_for_tile(unit_tile(builder), EC_IRRIGATION,
2259 unit_owner(builder), builder);
2260 if (pextra != NULL) {
2261 break;
2262 }
2264
2265 if (pextra != NULL) {
2266 i.value()->setText(
2267 /* TRANS: Build irrigation of specific type */
2268 QString(_("Build %1"))
2269 .arg(extra_name_translation(pextra))
2270 .replace("&", "&&"));
2271 } else {
2272 i.value()->setText(QString(_("Build Irrigation")));
2273 }
2274 } else {
2275 i.value()->setText(QString(_("Build Irrigation")));
2276 }
2277 }
2278 break;
2279
2280 case CULTIVATE:
2281 if (can_units_do_activity_client(punits, ACTIVITY_CULTIVATE)) {
2282 i.value()->setEnabled(true);
2283 }
2284 if (units_all_same_tile) {
2285 struct unit *punit = unit_list_get(punits, 0);
2286 struct tile *atile = unit_tile(punit);
2287 struct terrain *pterrain = tile_terrain(atile);
2288
2289 if (pterrain->cultivate_result != T_NONE) {
2290 i.value()->setText(
2291 /* TRANS: Transform terrain to specific type */
2292 QString(_("Cultivate to %1"))
2293 .arg(QString(get_tile_change_menu_text(atile, ACTIVITY_CULTIVATE)))
2294 .replace("&", "&&"));
2295 } else {
2296 i.value()->setText(QString(_("Cultivate")));
2297 }
2298 } else {
2299 i.value()->setText(QString(_("Cultivate")));
2300 }
2301 break;
2302
2303 case PLANT:
2304 if (can_units_do_activity_client(punits, ACTIVITY_PLANT)) {
2305 i.value()->setEnabled(true);
2306 }
2307 if (units_all_same_tile) {
2308 struct unit *punit = unit_list_get(punits, 0);
2309 struct tile *atile = unit_tile(punit);
2310 struct terrain *pterrain = tile_terrain(atile);
2311
2312 if (pterrain->plant_result != T_NONE) {
2313 i.value()->setText(
2314 /* TRANS: Transform terrain to specific type */
2315 QString(_("Plant to %1"))
2316 .arg(QString(get_tile_change_menu_text(atile, ACTIVITY_PLANT)))
2317 .replace("&", "&&"));
2318 } else {
2319 i.value()->setText(QString(_("Plant")));
2320 }
2321 } else {
2322 i.value()->setText(QString(_("Plant")));
2323 }
2324 break;
2325
2326 case TRANSFORM:
2327 if (can_units_do_activity_client(punits, ACTIVITY_TRANSFORM)) {
2328 i.value()->setEnabled(true);
2329 } else {
2330 break;
2331 }
2332 if (units_all_same_tile) {
2333 struct unit *punit = unit_list_get(punits, 0);
2334 struct tile *atile = unit_tile(punit);
2335 struct terrain *pterrain = tile_terrain(atile);
2336
2337 if (pterrain->transform_result != T_NONE
2338 && pterrain->transform_result != pterrain) {
2339 i.value()->setText(
2340 /* TRANS: Transform terrain to specific type */
2341 QString(_("Transform to %1"))
2342 .arg(QString(get_tile_change_menu_text(atile, ACTIVITY_TRANSFORM)))
2343 .replace("&", "&&"));
2344 } else {
2345 i.value()->setText(_("Transform Terrain"));
2346 }
2347 }
2348 break;
2349
2350 case BUILD:
2352 i.value()->setEnabled(true);
2353 }
2354 if (city_on_tile
2355 && units_can_do_action(punits, ACTION_JOIN_CITY, true)) {
2356 i.value()->setText(
2357 QString(action_id_name_translation(ACTION_JOIN_CITY))
2358 .replace("&", "&&"));
2359 } else {
2360 i.value()->setText(
2361 QString(action_id_name_translation(ACTION_FOUND_CITY))
2362 .replace("&", "&&"));
2363 }
2364 break;
2365
2366 case ROAD:
2367 {
2368 struct extra_type *pextra = nullptr;
2369
2370 if (can_units_do_any_road(&(wld.map), punits)) {
2371 i.value()->setEnabled(true);
2372 }
2373 unit_list_iterate(punits, punit) {
2374 pextra = next_extra_for_tile(unit_tile(punit), EC_ROAD,
2376 if (pextra != nullptr) {
2377 break;
2378 }
2380
2381 if (pextra != nullptr) {
2382 i.value()->setText(
2383 /* TRANS: Build road of specific type */
2384 QString(_("Build %1"))
2385 .arg(extra_name_translation(pextra))
2386 .replace("&", "&&"));
2387 }
2388 }
2389 break;
2390
2391 case FORTIFY:
2392 if (can_units_do_activity_client(punits, ACTIVITY_FORTIFYING)) {
2393 i.value()->setEnabled(true);
2394 }
2395 break;
2396
2397 case FORTRESS:
2398 if (can_units_do_base_gui(punits, BASE_GUI_FORTRESS)) {
2399 i.value()->setEnabled(true);
2400 }
2401 break;
2402
2403 case AIRBASE:
2404 if (can_units_do_base_gui(punits, BASE_GUI_AIRBASE)) {
2405 i.value()->setEnabled(true);
2406 }
2407 break;
2408
2409 case POLLUTION:
2410 if (can_units_do_activity_client(punits, ACTIVITY_POLLUTION)
2411 || can_units_do_on_map(&(wld.map), punits, can_unit_paradrop)) {
2412 i.value()->setEnabled(true);
2413 }
2414 if (units_can_do_action_with_result(punits, ACTRES_PARADROP,
2415 true)
2417 ACTRES_PARADROP_CONQUER,
2418 true)) {
2419 i.value()->setText(
2420 QString(action_id_name_translation(ACTION_PARADROP))
2421 .replace("&", "&&"));
2422 } else {
2423 i.value()->setText(_("Clean Pollution"));
2424 }
2425 break;
2426
2427 case FALLOUT:
2428 if (can_units_do_activity_client(punits, ACTIVITY_FALLOUT)) {
2429 i.value()->setEnabled(true);
2430 }
2431 break;
2432
2433 case SENTRY:
2434 if (can_units_do_activity_client(punits, ACTIVITY_SENTRY)) {
2435 i.value()->setEnabled(true);
2436 }
2437 break;
2438
2439 case PILLAGE:
2440 if (can_units_do_activity_client(punits, ACTIVITY_PILLAGE)) {
2441 i.value()->setEnabled(true);
2442 }
2443 break;
2444
2445 case HOMECITY:
2447 i.value()->setEnabled(true);
2448 }
2449 break;
2450
2451 case WAKEUP:
2452 if (units_have_activity_on_tile(punits, ACTIVITY_SENTRY)) {
2453 i.value()->setEnabled(true);
2454 }
2455 break;
2456
2457 case AUTOSETTLER:
2459 i.value()->setEnabled(true);
2460 }
2461 if (units_contain_cityfounder(punits)) {
2462 i.value()->setText(_("Auto Settler"));
2463 } else {
2464 i.value()->setText(_("Auto Worker"));
2465 }
2466 break;
2467 case CONNECT_ROAD:
2468 proad = road_by_gui_type(ROAD_GUI_ROAD);
2469 if (proad != NULL) {
2470 tgt = road_extra_get(proad);
2471 } else {
2472 break;
2473 }
2474 if (can_units_do_connect(punits, ACTIVITY_GEN_ROAD, tgt)) {
2475 i.value()->setEnabled(true);
2476 }
2477 break;
2478
2479 case DISBAND:
2480 if (units_can_do_action(punits, ACTION_DISBAND_UNIT, true)) {
2481 i.value()->setEnabled(true);
2482 }
2483 break;
2484
2485 case CONNECT_RAIL:
2486 proad = road_by_gui_type(ROAD_GUI_RAILROAD);
2487 if (proad != NULL) {
2488 tgt = road_extra_get(proad);
2489 } else {
2490 break;
2491 }
2492 if (can_units_do_connect(punits, ACTIVITY_GEN_ROAD, tgt)) {
2493 i.value()->setEnabled(true);
2494 }
2495 break;
2496
2497 case CONNECT_MAGLEV:
2498 proad = road_by_gui_type(ROAD_GUI_MAGLEV);
2499 if (proad != NULL) {
2500 tgt = road_extra_get(proad);
2501 } else {
2502 break;
2503 }
2504 if (can_units_do_connect(punits, ACTIVITY_GEN_ROAD, tgt)) {
2505 i.value()->setEnabled(true);
2506 }
2507 break;
2508
2509 case CONNECT_IRRIGATION:
2510 {
2511 struct extra_type_list *extras = extra_type_list_by_cause(EC_IRRIGATION);
2512
2513 if (extra_type_list_size(extras) > 0) {
2514 struct extra_type *pextra;
2515
2516 pextra = extra_type_list_get(extra_type_list_by_cause(EC_IRRIGATION), 0);
2517 if (can_units_do_connect(punits, ACTIVITY_IRRIGATE, pextra)) {
2518 i.value()->setEnabled(true);
2519 }
2520 }
2521 }
2522 break;
2523
2524 case GOTO_CITY:
2525 if (any_cities) {
2526 i.value()->setEnabled(true);
2527 }
2528 break;
2529
2530 case AIRLIFT:
2531 if (any_cities) {
2532 i.value()->setEnabled(true);
2533 }
2534 break;
2535
2536 case BUILD_WONDER:
2537 i.value()->setText(
2538 QString(action_id_name_translation(ACTION_HELP_WONDER))
2539 .replace("&", "&&"));
2541 i.value()->setEnabled(true);
2542 }
2543 break;
2544
2545 case AUTOTRADEROUTE:
2546 if (units_can_do_action(punits, ACTION_TRADE_ROUTE, TRUE)) {
2547 i.value()->setEnabled(true);
2548 }
2549 break;
2550
2551 case ORDER_TRADE_ROUTE:
2552 i.value()->setText(
2553 QString(action_id_name_translation(ACTION_TRADE_ROUTE))
2554 .replace("&", "&&"));
2556 i.value()->setEnabled(true);
2557 }
2558 break;
2559
2560 case ORDER_DIPLOMAT_DLG:
2561 if (units_can_do_action(punits, ACTION_ANY, TRUE)) {
2562 i.value()->setEnabled(true);
2563 }
2564 break;
2565
2566 case UPGRADE:
2567 if (units_can_upgrade(&(wld.map), punits)) {
2568 i.value()->setEnabled(true);
2569 }
2570 break;
2571 default:
2572 break;
2573 }
2574
2575 i++;
2576 }
2577 }
2578}
2579
2580/**********************************************************************/
2587
2588/**********************************************************************/
2592{
2593 if (NULL != client.conn.playing) {
2595 }
2596}
2597
2598/**********************************************************************/
2605
2606/**********************************************************************/
2610{
2611 ::gui()->game_tab_widget->setCurrentIndex(0);
2612}
2613
2614/**********************************************************************/
2621
2622/**********************************************************************/
2626{
2627 popup_players_dialog(false);
2628}
2629
2630/**********************************************************************/
2637
2638/**********************************************************************/
2642{
2644 /* FIXME: this can provide different actions for different units...
2645 * not good! */
2646 /* Enable the button for adding to a city in all cases, so we
2647 get an eventual error message from the server if we try. */
2650 } else if (utype_can_do_action(unit_type_get(punit), ACTION_HELP_WONDER)) {
2651 request_unit_caravan_action(punit, ACTION_HELP_WONDER);
2652 }
2654}
2655
2656/**********************************************************************/
2663
2664/**********************************************************************/
2668{
2670 /* FIXME: this can provide different actions for different units...
2671 * not good! */
2672 struct extra_type *pextra;
2673
2674 pextra = prev_extra_in_tile(unit_tile(punit), ERM_CLEANPOLLUTION,
2676 if (pextra != NULL) {
2677 request_new_unit_activity_targeted(punit, ACTIVITY_POLLUTION, pextra);
2678 } else if (can_unit_paradrop(&(wld.map), punit)) {
2679 /* FIXME: This is getting worse, we use a key_unit_*() function
2680 * which assign the order for all units! Very bad! */
2682 }
2684}
2685
2686/**********************************************************************/
2690{
2691 struct extra_type_list *extras = extra_type_list_by_cause(EC_IRRIGATION);
2692
2693 if (extra_type_list_size(extras) > 0) {
2694 struct extra_type *pextra;
2695
2696 pextra = extra_type_list_get(extra_type_list_by_cause(EC_IRRIGATION), 0);
2697
2698 key_unit_connect(ACTIVITY_IRRIGATE, pextra);
2699 }
2700}
2701
2702/**********************************************************************/
2706{
2707 struct road_type *prail = road_by_gui_type(ROAD_GUI_RAILROAD);
2708
2709 if (prail != NULL) {
2710 struct extra_type *tgt;
2711
2712 tgt = road_extra_get(prail);
2713 key_unit_connect(ACTIVITY_GEN_ROAD, tgt);
2714 }
2715}
2716
2717/**********************************************************************/
2721{
2722 struct road_type *pmaglev = road_by_gui_type(ROAD_GUI_MAGLEV);
2723
2724 if (pmaglev != NULL) {
2725 struct extra_type *tgt;
2726
2727 tgt = road_extra_get(pmaglev);
2728 key_unit_connect(ACTIVITY_GEN_ROAD, tgt);
2729 }
2730}
2731
2732/**********************************************************************/
2739
2740/**********************************************************************/
2747
2748/**********************************************************************/
2752{
2753 struct road_type *proad = road_by_gui_type(ROAD_GUI_ROAD);
2754
2755 if (proad != NULL) {
2756 struct extra_type *tgt;
2757
2758 tgt = road_extra_get(proad);
2759 key_unit_connect(ACTIVITY_GEN_ROAD, tgt);
2760 }
2761}
2762
2763/**********************************************************************/
2770
2771/**********************************************************************/
2775{
2777}
2778
2779/**********************************************************************/
2786
2787/**********************************************************************/
2794
2795/**********************************************************************/
2799{
2801 /* FIXME: this can provide different actions for different units...
2802 * not good! */
2804 EC_ROAD,
2806 punit);
2807 bool building_road = false;
2808
2809 if (tgt != NULL
2810 && can_unit_do_activity_targeted_client(punit, ACTIVITY_GEN_ROAD, tgt)) {
2811 request_new_unit_activity_targeted(punit, ACTIVITY_GEN_ROAD, tgt);
2812 building_road = true;
2813 }
2814
2815 if (!building_road && unit_can_est_trade_route_here(punit)) {
2816 request_unit_caravan_action(punit, ACTION_TRADE_ROUTE);
2817 }
2819}
2820
2821/**********************************************************************/
2828
2829/**********************************************************************/
2836
2837/**********************************************************************/
2841{
2842 key_unit_mine();
2843}
2844
2845/**********************************************************************/
2849{
2851}
2852
2853/**********************************************************************/
2860
2861/**********************************************************************/
2868
2869/**********************************************************************/
2873{
2875}
2876
2877/**********************************************************************/
2884
2885/**********************************************************************/
2889{
2890 delayed_order = false;
2891 units_list.clear();
2892}
2893
2894/**********************************************************************/
2898{
2899 gui()->rallies.hover_tile = false;
2900 gui()->rallies.hover_city = true;
2901}
2902
2903/**********************************************************************/
2907{
2908 gui()->trade_gen.hover_city = true;
2909}
2910
2911/**********************************************************************/
2915{
2916 gui()->trade_gen.add_all_cities();
2917}
2918
2919/**********************************************************************/
2923{
2924 gui()->trade_gen.calculate();
2925}
2926
2927/**********************************************************************/
2931{
2932 gui()->trade_gen.clear_trade_planing();
2933}
2934
2935/**********************************************************************/
2939{
2940 qtiles gilles;
2941 struct unit *punit;
2942 struct city *homecity;
2943 struct tile *home_tile;
2944 struct tile *dest_tile;
2945 bool sent = false;
2946
2948 homecity = game_city_by_number(punit->homecity);
2949 home_tile = homecity->tile;
2950 foreach(gilles, gui()->trade_gen.lines) {
2951 if ((gilles.t1 == home_tile || gilles.t2 == home_tile)
2952 && gilles.autocaravan == nullptr) {
2953 /* send caravan */
2954 if (gilles.t1 == home_tile) {
2955 dest_tile = gilles.t2;
2956 } else {
2957 dest_tile = gilles.t1;
2958 }
2959 if (send_goto_tile(punit, dest_tile)) {
2960 int i;
2961 i = gui()->trade_gen.lines.indexOf(gilles);
2962 gilles = gui()->trade_gen.lines.takeAt(i);
2963 gilles.autocaravan = punit;
2964 gui()->trade_gen.lines.append(gilles);
2965 sent = true;
2966 break;
2967 }
2968 }
2969 }
2970
2971 if (!sent) {
2972 gui()->infotab->chtwdg->append(_("Didn't find any trade route"
2973 " to establish"));
2974 }
2975}
2976
2977/**********************************************************************/
2981{
2982 QVariant v;
2983 QAction *act;
2984
2985 act = qobject_cast<QAction *>(sender());
2986 v = act->data();
2987 airlift_type_id = v.toInt();
2988}
2989
2990/**********************************************************************/
2994{
2995 QAction *act;
2996
2997 act = qobject_cast<QAction *>(sender());
2998 qdef_act::action()->vs_unit_set(act->data().toInt());
2999}
3000
3001/**********************************************************************/
3005{
3006 QAction *act;
3007
3008 act = qobject_cast<QAction *>(sender());
3009 qdef_act::action()->vs_city_set(act->data().toInt());
3010}
3011
3012/**********************************************************************/
3016{
3017 quick_airlifting = true;
3018}
3019
3020/**********************************************************************/
3024{
3026 int i = 0;
3027 delay_order dg;
3028
3029 delayed_order = true;
3030 dg = D_GOTO;
3031
3032 struct unit_list *punits = get_units_in_focus();
3033 if (unit_list_size(punits) == 0) {
3034 return;
3035 }
3036 if (hover_state != HOVER_GOTO) {
3037 set_hover_state(punits, HOVER_GOTO, ACTIVITY_LAST, NULL,
3039 enter_goto_state(punits);
3042 }
3044 i++;
3047 units_list.nr_units = i;
3049}
3050
3051/**********************************************************************/
3055{
3057 struct unit *punit;
3058 struct tile *last_tile;
3059 struct tile *new_tile;
3060 int i = 0;
3061
3062 foreach (fui, units_list.unit_list) {
3063 i++;
3064 punit = unit_list_find(client_player()->units, fui->id);
3065 if (punit == nullptr) {
3066 continue;
3067 }
3068 last_tile = punit->tile;
3069 new_tile = find_last_unit_pos(punit, i);
3070 if (new_tile != nullptr) {
3071 punit->tile = new_tile;
3072 }
3073 if (is_tiles_adjacent(punit->tile, fui->ptile)) {
3076 punit->tile,
3077 fui->ptile));
3078 } else {
3080 }
3081 punit->tile = last_tile;
3082 }
3083 units_list.clear();
3084}
3085
3086/**********************************************************************/
3095
3096/**********************************************************************/
3100{
3102}
3103
3104/**********************************************************************/
3113
3114/**********************************************************************/
3118{
3120}
3121
3122/**********************************************************************/
3129
3130/**********************************************************************/
3139
3140/**********************************************************************/
3147
3148/**********************************************************************/
3155
3156/**********************************************************************/
3163
3164/**********************************************************************/
3168{
3169 key_unit_goto();
3170}
3171
3172/**********************************************************************/
3179
3180/**********************************************************************/
3187
3188/**********************************************************************/
3192{
3193 if (gui()->interface_locked) {
3194 enable_interface(false);
3195 } else {
3196 enable_interface(true);
3197 }
3198 gui()->interface_locked = !gui()->interface_locked;
3199}
3200
3201/**********************************************************************/
3205{
3206 QList<close_widget *> lc;
3207 QList<move_widget *> lm;
3208 QList<resize_widget *> lr;
3209 int i;
3210
3211 lc = gui()->findChildren<close_widget *>();
3212 lm = gui()->findChildren<move_widget *>();
3213 lr = gui()->findChildren<resize_widget *>();
3214
3215 for (i = 0; i < lc.size(); ++i) {
3216 lc.at(i)->setVisible(!enable);
3217 }
3218 for (i = 0; i < lm.size(); ++i) {
3219 lm.at(i)->setVisible(!enable);
3220 }
3221 for (i = 0; i < lr.size(); ++i) {
3222 lr.at(i)->setVisible(!enable);
3223 }
3224}
3225
3226/**********************************************************************/
3230{
3232
3233 gui()->apply_fullscreen();
3234}
3235
3236/**********************************************************************/
3240{
3241 if (minimap_status->isChecked()) {
3242 ::gui()->minimapview_wdg->show();
3243 } else {
3244 ::gui()->minimapview_wdg->hide();
3245 }
3246}
3247
3248/**********************************************************************/
3252{
3253 if (osd_status->isChecked()) {
3254 gui()->qt_settings.show_new_turn_text = true;
3255 } else {
3256 gui()->qt_settings.show_new_turn_text = false;
3257 }
3258}
3259
3260/**********************************************************************/
3264{
3265 if (btlog_status->isChecked()) {
3266 gui()->qt_settings.show_battle_log = true;
3267 } else {
3268 gui()->qt_settings.show_battle_log = false;
3269 }
3270}
3271
3272/**********************************************************************/
3279
3280/**********************************************************************/
3287
3288/**********************************************************************/
3295
3296/**********************************************************************/
3303
3304/**********************************************************************/
3308{
3309 gui()->map_scale = gui()->map_scale * 1.2f;
3310 tilespec_reread(tileset_basename(tileset), true, gui()->map_scale);
3311}
3312
3313/**********************************************************************/
3317{
3318 QFont *qf;
3319
3320 gui()->map_scale = 1.0f;
3322 qf->setPointSize(fc_font::instance()->city_fontsize);
3324 qf->setPointSize(fc_font::instance()->prod_fontsize);
3325 tilespec_reread(tileset_basename(tileset), true, gui()->map_scale);
3326}
3327
3328/**********************************************************************/
3332{
3333 QFont *qf;
3334
3335 if (scale_fonts_status->isChecked()) {
3336 gui()->map_font_scale = true;
3337 } else {
3339 qf->setPointSize(fc_font::instance()->city_fontsize);
3341 qf->setPointSize(fc_font::instance()->prod_fontsize);
3342 gui()->map_font_scale = false;
3343 }
3345}
3346
3347
3348/**********************************************************************/
3352{
3353 gui()->map_scale = gui()->map_scale / 1.2f;
3354 tilespec_reread(tileset_basename(tileset), true, gui()->map_scale);
3355}
3356
3357/**********************************************************************/
3364
3365/**********************************************************************/
3372
3373/**********************************************************************/
3380
3381/**********************************************************************/
3388
3389/**********************************************************************/
3396
3397/**********************************************************************/
3404
3405/**********************************************************************/
3412
3413/**********************************************************************/
3420
3421/**********************************************************************/
3425{
3426 key_unit_done();
3427}
3428
3429/**********************************************************************/
3433{
3434 request_unit_select(get_units_in_focus(), SELTYPE_ALL, SELLOC_TILE);
3435}
3436
3437/**********************************************************************/
3441{
3442 request_unit_select(get_units_in_focus(), SELTYPE_SINGLE, SELLOC_TILE);
3443}
3444
3445/**********************************************************************/
3454
3455/**********************************************************************/
3464
3465/**********************************************************************/
3469{
3470 request_unit_select(get_units_in_focus(), SELTYPE_SAME, SELLOC_TILE);
3471}
3472
3473/**********************************************************************/
3477{
3478 key_unit_wait();
3479}
3480
3481/**********************************************************************/
3485{
3486 unit_hud_selector *uhs;
3487 uhs = new unit_hud_selector(gui()->central_wdg);
3488 uhs->show_me();
3489}
3490
3491/**********************************************************************/
3498
3499/**********************************************************************/
3506
3507/**********************************************************************/
3514
3515/**********************************************************************/
3522
3523/**********************************************************************/
3530
3531/**********************************************************************/
3538
3539/**********************************************************************/
3546
3547/**********************************************************************/
3554
3555/**********************************************************************/
3562
3563/**********************************************************************/
3570
3571/**********************************************************************/
3578
3579/**********************************************************************/
3586
3587/**********************************************************************/
3594
3595/**********************************************************************/
3602
3603/**********************************************************************/
3610
3611/**********************************************************************/
3618
3619/**********************************************************************/
3626
3627/**********************************************************************/
3631{
3632 QDialog *dialog = new QDialog(this);
3633 QLabel *label;
3634 QPushButton *but;
3635 QVBoxLayout *layout;
3636 const struct strvec *tlset_list;
3637 const struct option *poption;
3638 QStringList sl;
3639 QString s;
3640
3641 sl << "default_tileset_overhead_name" << "default_tileset_iso_name"
3642 << "default_tileset_hex_name" << "default_tileset_isohex_name";
3643 layout = new QVBoxLayout;
3644 dialog->setWindowTitle(_("Available tilesets"));
3645 label = new QLabel;
3646 label->setText(_("Some tilesets might not be compatible with current"
3647 " map topology!"));
3648 layout->addWidget(label);
3649
3650 foreach (s, sl) {
3651 QByteArray on_bytes;
3652
3653 on_bytes = s.toUtf8();
3654 poption = optset_option_by_name(client_optset, on_bytes.data());
3655 tlset_list = get_tileset_list(poption);
3656 strvec_iterate(tlset_list, value) {
3657 but = new QPushButton(value);
3658 connect(but, &QAbstractButton::clicked, this, &mr_menu::load_new_tileset);
3659 layout->addWidget(but);
3661 }
3662 dialog->setSizeGripEnabled(true);
3663 dialog->setLayout(layout);
3664 dialog->show();
3665}
3666
3667/**********************************************************************/
3671{
3672 QPushButton *but;
3673 QByteArray tn_bytes;
3674
3675 but = qobject_cast<QPushButton *>(sender());
3676 tn_bytes = but->text().toUtf8();
3677 tilespec_reread(tn_bytes.data(), true, 1.0f);
3678 gui()->map_scale = 1.0f;
3679 but->parentWidget()->close();
3680}
3681
3682/**********************************************************************/
3686{
3687 gui()->trade_gen.calculate();
3688}
3689
3690/**********************************************************************/
3697
3698/**********************************************************************/
3705
3706/**********************************************************************/
3709void mr_menu::slot_help(const QString &topic)
3710{
3711 popup_help_dialog_typed(Q_(topic.toStdString().c_str()), HELP_ANY);
3712}
3713
3714/****************************************************************
3715 Actions "BUILD_PATH_*"
3716*****************************************************************/
3718{
3720 extra_type_by_cause_iterate(EC_ROAD, pextra) {
3721 if (pextra->buildable && pextra->id == id
3722 && can_unit_do_activity_targeted_client(punit, ACTIVITY_GEN_ROAD,
3723 pextra)) {
3724 request_new_unit_activity_targeted(punit, ACTIVITY_GEN_ROAD, pextra);
3725 }
3728}
3729
3730/****************************************************************
3731 Actions "BUILD_BASE_*"
3732*****************************************************************/
3734{
3736 extra_type_by_cause_iterate(EC_BASE, pextra) {
3737 if (pextra->buildable && pextra->id == id
3739 pextra)) {
3740 request_new_unit_activity_targeted(punit, ACTIVITY_BASE, pextra);
3741 }
3744}
3745
3746
3747
3748/**********************************************************************/
3752{
3753 gui()->popup_client_options();
3754}
3755
3756/**********************************************************************/
3763
3764/**********************************************************************/
3768{
3769 gui()->pr_options->popup_server_options();
3770}
3771
3772/**********************************************************************/
3779
3780/**********************************************************************/
3784{
3785 options_save(NULL);
3786}
3787
3788/**********************************************************************/
3792{
3794}
3795
3796/**********************************************************************/
3800{
3801 int current_width, current_height;
3802 int full_size_x, full_size_y;
3803 QString path, storage_path;
3804 hud_message_box *saved = new hud_message_box(gui()->central_wdg);
3805 bool map_saved;
3806 QString img_name;
3807
3808 full_size_x = (wld.map.xsize + 2) * tileset_tile_width(tileset);
3809 full_size_y = (wld.map.ysize + 2) * tileset_tile_height(tileset);
3810 current_width = gui()->mapview_wdg->width();
3811 current_height = gui()->mapview_wdg->height();
3812 if (tileset_hex_width(tileset) > 0) {
3813 full_size_y = full_size_y * 11 / 20;
3814 } else if (tileset_is_isometric(tileset)) {
3815 full_size_y = full_size_y / 2;
3816 }
3817 map_canvas_resized(full_size_x, full_size_y);
3818 img_name = QString("Freeciv-Turn%1").arg(game.info.turn);
3819 if (client_has_player()) {
3820 img_name = img_name + "-"
3822 }
3823 storage_path = freeciv_storage_dir();
3824 path = QStandardPaths::writableLocation(QStandardPaths::PicturesLocation);
3825 if (!storage_path.isEmpty() && QDir(storage_path).isReadable()) {
3826 img_name = storage_path + DIR_SEPARATOR + img_name;
3827 } else if (!path.isEmpty()) {
3828 img_name = path + DIR_SEPARATOR + img_name;
3829 } else {
3830 img_name = QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
3831 + DIR_SEPARATOR + img_name;
3832 }
3833 map_saved = mapview.store->map_pixmap.save(img_name, "png");
3834 map_canvas_resized(current_width, current_height);
3835 saved->setStandardButtons(QMessageBox::Ok);
3836 saved->setDefaultButton(QMessageBox::Cancel);
3837 saved->setAttribute(Qt::WA_DeleteOnClose);
3838 if (map_saved) {
3839 saved->set_text_title("Image saved as:\n" + img_name, _("Success"));
3840 } else {
3841 saved->set_text_title(_("Failed to save image of the map"), _("Error"));
3842 }
3843 saved->show();
3844}
3845
3846/**********************************************************************/
3850{
3851 send_save_game(NULL);
3852}
3853
3854/**********************************************************************/
3858{
3859 QString str;
3860 QString current_file;
3861 QString location;
3862
3863 strvec_iterate(get_save_dirs(), dirname) {
3864 location = dirname;
3865 // choose last location
3867
3868 str = QString(_("Save Games"))
3869 + QString(" (*.sav *.sav.bz2 *.sav.gz *.sav.xz)");
3870 current_file = QFileDialog::getSaveFileName(gui()->central_wdg,
3871 _("Save Game As..."),
3872 location, str);
3873 if (!current_file.isEmpty()) {
3874 QByteArray cf_bytes;
3875
3876 cf_bytes = current_file.toUtf8();
3877 send_save_game(cf_bytes.data());
3878 }
3879}
3880
3881/**********************************************************************/
3885{
3886 hud_message_box *ask;
3887
3888 if (is_server_running()) {
3889 ask = new hud_message_box(gui()->central_wdg);
3890 ask->set_text_title(_("Leaving a local game will end it!"), "Leave game");
3891 ask->setStandardButtons(QMessageBox::Cancel | QMessageBox::Ok);
3892 ask->setDefaultButton(QMessageBox::Cancel);
3893 ask->setAttribute(Qt::WA_DeleteOnClose);
3894
3895 connect(ask, &hud_message_box::accepted, [=]() {
3896 if (client.conn.used) {
3897 disconnect_from_server();
3898 }
3899 });
3900 ask->show();
3901 } else {
3903 }
3904}
3905
3906/**********************************************************************/
3910{
3911 hud_message_box* ask = new hud_message_box(gui()->central_wdg);
3912
3913 ask->setIcon(QMessageBox::Warning);
3914 ask->setStandardButtons(QMessageBox::Cancel | QMessageBox::Ok);
3915 ask->setDefaultButton(QMessageBox::Cancel);
3916 ask->setAttribute(Qt::WA_DeleteOnClose);
3917 return (ask->set_text_title(_("Selection will cancel current assignments!"),
3918 _("Confirm Disruptive Selection"), true)
3919 == QMessageBox::Ok);
3920}
3921
3922/**********************************************************************/
3925void multiairlift(struct city *acity, Unit_type_id ut)
3926{
3927 struct tile *ptile;
3929 if (get_city_bonus(pcity, EFT_AIRLIFT) > 0) {
3930 ptile = city_tile(pcity);
3931 unit_list_iterate(ptile->units, punit) {
3932 if (punit->utype == utype_by_number(ut)) {
3934 break;
3935 }
3937 }
3939}
bool action_removes_extra(const struct action *paction, const struct extra_type *pextra)
Definition actions.c:2312
const char * action_name_translation(const struct action *action)
Definition actions.c:1890
const char * action_id_name_translation(action_id act_id)
Definition actions.c:1910
enum action_sub_target_kind action_get_sub_target_kind(const struct action *paction)
Definition actions.c:1751
bool actions_are_ready(void)
Definition actions.c:1583
bool action_creates_extra(const struct action *paction, const struct extra_type *pextra)
Definition actions.c:2224
static struct action * action_by_number(action_id act_id)
Definition actions.h:638
#define action_iterate_end
Definition actions.h:472
#define action_id_get_actor_kind(act_id)
Definition actions.h:651
#define action_iterate(_act_)
Definition actions.h:467
#define ACTION_ANY
Definition actions.h:290
#define action_id_get_target_kind(act_id)
Definition actions.h:655
#define action_id_has_complex_target(act_id)
Definition actions.h:673
#define ACTION_NONE
Definition actions.h:293
#define str
Definition astring.c:76
#define n
Definition astring.c:77
void output_window_append(const struct ft_color color, const char *featured_text)
struct city * create_city_virtual(struct player *pplayer, struct tile *ptile, const char *name)
Definition city.c:3339
void destroy_city_virtual(struct city *pcity)
Definition city.c:3415
static bool is_non_allied_city_tile(const struct tile *ptile, const struct player *pplayer)
Definition city.h:741
#define city_list_iterate(citylist, pcity)
Definition city.h:488
#define city_tile(_pcity_)
Definition city.h:544
#define city_list_iterate_end
Definition city.h:490
static fc_font * instance()
Definition fonts.cpp:41
QFont * get_font(QString name)
Definition fonts.cpp:63
static fc_shortcuts * sc()
fc_shortcut * get_shortcut(shortcut_id id)
static void update_all()
Definition menu.cpp:915
virtual ~go_act_menu()
Definition menu.cpp:707
void start_go_act(int act_id, int sub_tgt_id)
Definition menu.cpp:892
void reset()
Definition menu.cpp:736
static QSet< go_act_menu * > instances
Definition menu.h:236
void update()
Definition menu.cpp:852
go_act_menu(QWidget *parent=nullptr)
Definition menu.cpp:697
static void reset_all()
Definition menu.cpp:905
void create()
Definition menu.cpp:748
QMap< QAction *, int > items
Definition menu.h:238
static QSet< gov_menu * > instances
Definition menu.h:211
virtual ~gov_menu()
Definition menu.cpp:578
static void create_all()
Definition menu.cpp:677
void revolution()
Definition menu.cpp:656
QVector< QAction * > actions
Definition menu.h:213
static void update_all()
Definition menu.cpp:687
void change_gov(int target_gov)
Definition menu.cpp:664
gov_menu(QWidget *parent=0)
Definition menu.cpp:567
void create()
Definition menu.cpp:587
void update()
Definition menu.cpp:628
int set_text_title(QString s1, QString s2, bool return_exec=false)
bool shortcut_2_menustring_inner(const QMenu *m, QKeySequence seq, QString *ret)
Definition menu.cpp:1901
void slot_unit_sentry()
Definition menu.cpp:2864
QActionGroup * action_vs_city
Definition menu.h:266
void slot_bg3select()
Definition menu.cpp:3582
void slot_traveler()
Definition menu.cpp:3526
bool execute_shortcut_inner(const QMenu *m, QKeySequence seq)
Definition menu.cpp:1819
void slot_delayed_goto()
Definition menu.cpp:3023
void zoom_in()
Definition menu.cpp:3307
void slot_autocaravan()
Definition menu.cpp:2938
QMenu * multiplayer_menu
Definition menu.h:263
void slot_build_irrigation()
Definition menu.cpp:2824
void slot_execute_orders()
Definition menu.cpp:3054
void update_bases_menu()
Definition menu.cpp:2026
QString shortcut_exist(fc_shortcut *fcs)
Definition menu.cpp:1878
void tileset_custom_load()
Definition menu.cpp:3630
void update_roads_menu()
Definition menu.cpp:1979
void slot_calculate()
Definition menu.cpp:2922
void slot_conn_road()
Definition menu.cpp:2751
void slot_conn_irrigation()
Definition menu.cpp:2689
QMenu * bases_menu
Definition menu.h:262
QActionGroup * airlift_type
Definition menu.h:265
void slot_quickairlift_set()
Definition menu.cpp:2980
void slot_battlelog()
Definition menu.cpp:3263
QMultiHash< munit, QAction * > menu_list
Definition menu.h:270
void slot_trade_add_all()
Definition menu.cpp:2914
void update_airlift_menu()
Definition menu.cpp:1943
void slot_show_cities()
Definition menu.cpp:2633
void slot_transform()
Definition menu.cpp:2766
void slot_action_vs_unit()
Definition menu.cpp:2993
void slot_achievements()
Definition menu.cpp:3502
void slot_show_research_tab()
Definition menu.cpp:2583
void shortcut_options()
Definition menu.cpp:3759
void slot_city_output()
Definition menu.cpp:3376
void slot_show_eco_report()
Definition menu.cpp:2601
QMenu * airlift_menu
Definition menu.h:261
QAction * osd_status
Definition menu.h:286
void slot_bg1select()
Definition menu.cpp:3534
void slot_unload_all()
Definition menu.cpp:3143
void slot_airlift()
Definition menu.cpp:3117
void slot_select_same_continent()
Definition menu.cpp:3448
void slot_city_production()
Definition menu.cpp:3384
void slot_set_home()
Definition menu.cpp:3125
QAction * lock_status
Definition menu.h:285
void slot_native_tiles()
Definition menu.cpp:3283
void slot_unit_explore()
Definition menu.cpp:3175
void slot_bg4assign()
Definition menu.cpp:3614
void slot_bg1append()
Definition menu.cpp:3550
void slot_upgrade()
Definition menu.cpp:3159
void execute_shortcut(int sid)
Definition menu.cpp:1834
void slot_popup_mult_rates()
Definition menu.cpp:3701
void slot_select_same_everywhere()
Definition menu.cpp:3458
void slot_map_grid()
Definition menu.cpp:3416
void slot_unit_filter()
Definition menu.cpp:3484
void slot_bg2select()
Definition menu.cpp:3558
void slot_clean_pollution()
Definition menu.cpp:2667
void slot_done_moving()
Definition menu.cpp:3424
void calc_trade_routes()
Definition menu.cpp:3685
void slot_city_buycost()
Definition menu.cpp:3291
void slot_action()
Definition menu.cpp:2782
void slot_bg4append()
Definition menu.cpp:3622
QMenu * roads_menu
Definition menu.h:264
QAction * minimap_status
Definition menu.h:283
bool shortcut_exist_inner(const QMenu *m, QKeySequence seq, fc_shortcut *fcs, QString *ret)
Definition menu.cpp:1861
void slot_select_all_tile()
Definition menu.cpp:3432
void save_game()
Definition menu.cpp:3849
struct tile * find_last_unit_pos(struct unit *punit, int pos)
Definition menu.cpp:925
void save_image()
Definition menu.cpp:3799
void slot_pillage()
Definition menu.cpp:2774
void zoom_reset()
Definition menu.cpp:3316
void slot_board()
Definition menu.cpp:3089
void slot_center_view()
Definition menu.cpp:3183
void slot_build_mine()
Definition menu.cpp:2840
void server_options()
Definition menu.cpp:3767
void load_new_tileset()
Definition menu.cpp:3670
void set_tile_for_order(struct tile *ptile)
Definition menu.cpp:1807
void slot_fullscreen()
Definition menu.cpp:3229
void slot_bg4select()
Definition menu.cpp:3606
void slot_top_five()
Definition menu.cpp:3518
void slot_show_nations()
Definition menu.cpp:2625
void slot_build_road()
Definition menu.cpp:2798
void slot_unsentry()
Definition menu.cpp:3151
void slot_show_new_turn_text()
Definition menu.cpp:3251
void local_options()
Definition menu.cpp:3751
bool delayed_order
Definition menu.h:290
void slot_borders()
Definition menu.cpp:3275
void slot_clear_trade()
Definition menu.cpp:2930
void zoom_scale_fonts()
Definition menu.cpp:3331
void slot_conn_rail()
Definition menu.cpp:2705
void slot_select_same_tile()
Definition menu.cpp:3468
void slot_convert()
Definition menu.cpp:2872
QMenu * action_unit_menu
Definition menu.h:268
QActionGroup * action_vs_unit
Definition menu.h:267
void slot_endgame()
Definition menu.cpp:3510
void slot_bg2assign()
Definition menu.cpp:3566
void slot_select_one()
Definition menu.cpp:3440
void menus_sensitive()
Definition menu.cpp:2073
void messages_options()
Definition menu.cpp:3775
void slot_unit_goto()
Definition menu.cpp:3167
void slot_cultivate()
Definition menu.cpp:2832
void slot_stack_size()
Definition menu.cpp:3400
void slot_conn_maglev()
Definition menu.cpp:2720
void slot_patrol()
Definition menu.cpp:3099
void slot_unit_fortress()
Definition menu.cpp:2735
void slot_wait()
Definition menu.cpp:3476
void slot_demographics()
Definition menu.cpp:3494
void slot_build_city()
Definition menu.cpp:2641
void slot_city_growth()
Definition menu.cpp:3299
void slot_city_trade_routes()
Definition menu.cpp:3392
void slot_rally()
Definition menu.cpp:2897
void slot_plant()
Definition menu.cpp:2848
void slot_build_path(int id)
Definition menu.cpp:3717
void slot_bg1assign()
Definition menu.cpp:3542
void slot_return_to_city()
Definition menu.cpp:3107
Unit_type_id airlift_type_id
Definition menu.h:292
void slot_show_map()
Definition menu.cpp:2609
void slot_bg3assign()
Definition menu.cpp:3590
QAction * scale_fonts_status
Definition menu.h:284
void slot_minimap_view()
Definition menu.cpp:3239
void slot_trade_city()
Definition menu.cpp:2906
void quit_game()
Definition menu.cpp:3791
void slot_help(const QString &topic)
Definition menu.cpp:3709
void save_game_as()
Definition menu.cpp:3857
void slot_bg2append()
Definition menu.cpp:3574
bool quick_airlifting
Definition menu.h:291
void slot_spaceship()
Definition menu.cpp:2591
void slot_city_names()
Definition menu.cpp:3360
void slot_clean_fallout()
Definition menu.cpp:2659
QMenu * action_city_menu
Definition menu.h:269
void save_options_now()
Definition menu.cpp:3783
QAction * btlog_status
Definition menu.h:287
void slot_unit_fortify()
Definition menu.cpp:2856
void slot_show_units_report()
Definition menu.cpp:2617
void slot_quickairlift()
Definition menu.cpp:3015
QString shortcut_2_menustring(int sid)
Definition menu.cpp:1919
void slot_lock()
Definition menu.cpp:3191
void back_to_menu()
Definition menu.cpp:3884
void slot_deboard()
Definition menu.cpp:3133
void slot_popup_tax_rates()
Definition menu.cpp:3693
void slot_auto_settler()
Definition menu.cpp:2790
void slot_build_base(int id)
Definition menu.cpp:3733
qfc_units_list units_list
Definition menu.h:271
void setup_menus()
Definition menu.cpp:976
mr_menu()
Definition menu.cpp:967
void slot_bg3append()
Definition menu.cpp:3598
void slot_action_vs_city()
Definition menu.cpp:3004
void zoom_out()
Definition menu.cpp:3351
void slot_disband()
Definition menu.cpp:2880
void slot_unit_airbase()
Definition menu.cpp:2743
void slot_fullbar()
Definition menu.cpp:3408
void slot_city_outlines()
Definition menu.cpp:3368
bool confirm_disruptive_selection()
Definition menu.cpp:3909
void slot_orders_clear()
Definition menu.cpp:2888
static qdef_act * action()
Definition dialogs.cpp:1019
void vs_city_set(int i)
Definition dialogs.cpp:1041
void vs_unit_set(int i)
Definition dialogs.cpp:1049
struct tile * ptile
Definition menu.h:118
QList< qfc_delayed_unit_item * > unit_list
Definition menu.h:130
void add(qfc_delayed_unit_item *fui)
Definition menu.cpp:493
int nr_units
Definition menu.h:131
void clear()
Definition menu.cpp:501
bool done
Definition menu.h:142
unsigned trade_num
Definition menu.h:145
int poss_trade_num
Definition menu.h:144
QList< struct city * > pos_cities
Definition menu.h:148
QList< struct city * > new_tr_cities
Definition menu.h:147
int over_max
Definition menu.h:143
trade_city(struct city *pcity)
Definition menu.cpp:68
QList< struct city * > curr_tr_cities
Definition menu.h:146
struct city * city
Definition menu.h:149
void calculate_inner(trade_city *tc)
Definition menu.cpp:214
bool discard_one(trade_city *tc)
Definition menu.cpp:376
void add_city(struct city *pcity)
Definition menu.cpp:125
void find_certain_routes()
Definition menu.cpp:458
QList< trade_city * > cities
Definition menu.h:181
void find_certain_routes_inner(trade_city *tc)
Definition menu.cpp:423
trade_city * find_most_free()
Definition menu.cpp:325
void discard_trade(trade_city *tc1, trade_city *tc2)
Definition menu.cpp:362
void add_tile(struct tile *ptile)
Definition menu.cpp:137
void remove_virtual_city(struct tile *ptile)
Definition menu.cpp:188
bool hover_city
Definition menu.h:178
void add_all_cities()
Definition menu.cpp:87
void clear_trade_planing()
Definition menu.cpp:105
void discard()
Definition menu.cpp:343
void remove_city(struct city *pcity)
Definition menu.cpp:170
QList< qtiles > lines
Definition menu.h:179
bool discard_any(trade_city *tc, int freeroutes)
Definition menu.cpp:402
void check_if_done(trade_city *tc1, trade_city *tc2)
Definition menu.cpp:473
QList< struct city * > virtual_cities
Definition menu.h:180
int find_over_max(struct city *pcity)
Definition menu.cpp:309
void calculate()
Definition menu.cpp:232
bool client_is_observer(void)
struct civclient client
enum client_states client_state(void)
bool is_waiting_turn_change(void)
void send_report_request(enum report_type type)
bool can_client_issue_orders(void)
bool client_has_player(void)
#define client_player()
@ C_S_RUNNING
Definition client_main.h:47
bool can_units_do_connect(struct unit_list *punits, enum unit_activity activity, struct extra_type *tgt)
Definition climisc.c:1224
void disconnect_from_server(void)
Definition clinet.c:305
void send_save_game(const char *filename)
bool is_server_running(void)
bool can_client_access_hack(void)
void key_unit_sentry(void)
Definition control.c:3607
void request_unit_airlift(struct unit *punit, struct city *pcity)
Definition control.c:1512
void key_city_output_toggle(void)
Definition control.c:3704
void request_unit_return(struct unit *punit)
Definition control.c:1521
void request_unit_caravan_action(struct unit *punit, action_id action)
Definition control.c:2121
void key_unit_auto_explore(void)
Definition control.c:3383
void key_unit_auto_settle(void)
Definition control.c:3396
void key_unit_connect(enum unit_activity activity, struct extra_type *tgt)
Definition control.c:3189
void key_city_full_bar_toggle(void)
Definition control.c:3736
void key_map_native_toggle(void)
Definition control.c:3728
void request_unit_goto(enum unit_orders last_order, action_id act_id, int sub_tgt_id)
Definition control.c:1103
void key_unit_paradrop(void)
Definition control.c:3293
struct unit_list * get_units_in_focus(void)
Definition control.c:177
void request_center_focus_unit(void)
Definition control.c:2610
void key_city_productions_toggle(void)
Definition control.c:3770
void key_unit_plant(void)
Definition control.c:3529
void key_unit_fortress(void)
Definition control.c:3438
void key_unit_mine(void)
Definition control.c:3521
void key_unit_pillage(void)
Definition control.c:3541
void request_unit_unload(struct unit *pcargo)
Definition control.c:2092
void request_new_unit_activity_targeted(struct unit *punit, enum unit_activity act, struct extra_type *tgt)
Definition control.c:1837
void key_unit_irrigate(void)
Definition control.c:3501
void request_unit_build_city(struct unit *punit)
Definition control.c:1714
void key_unit_unload_all(void)
Definition control.c:3323
void key_city_outlines_toggle(void)
Definition control.c:3696
void key_unit_homecity(void)
Definition control.c:3455
void set_hover_state(struct unit_list *punits, enum cursor_hover_state state, enum unit_activity activity, struct extra_type *tgt, int last_tgt, int last_sub_tgt, action_id action, enum unit_orders order)
Definition control.c:285
void key_unit_patrol(void)
Definition control.c:3301
void key_unit_wakeup_others(void)
Definition control.c:3356
enum cursor_hover_state hover_state
Definition control.c:89
void key_unit_stack_size_toggle(void)
Definition control.c:3787
void key_unit_wait(void)
Definition control.c:3348
void key_unit_select_battlegroup(int battlegroup, bool append)
Definition control.c:3670
void key_map_grid_toggle(void)
Definition control.c:3712
struct unit * head_of_units_in_focus(void)
Definition control.c:406
void key_city_growth_toggle(void)
Definition control.c:3753
void key_unit_action_select_tgt(void)
Definition control.c:3220
void key_unit_fallout(void)
Definition control.c:3418
void key_city_buycost_toggle(void)
Definition control.c:3762
int get_num_units_in_focus(void)
Definition control.c:185
void key_unit_transform(void)
Definition control.c:3619
void request_move_unit_direction(struct unit *punit, int dir)
Definition control.c:1777
void key_unit_done(void)
Definition control.c:3277
void key_city_trade_routes_toggle(void)
Definition control.c:3779
void key_city_names_toggle(void)
Definition control.c:3744
void request_unit_select(struct unit_list *punits, enum unit_select_type_mode seltype, enum unit_select_location_mode selloc)
Definition control.c:1590
void key_unit_airbase(void)
Definition control.c:3366
void key_unit_goto(void)
Definition control.c:3285
void control_mouse_cursor(struct tile *ptile)
Definition control.c:1188
void key_unit_convert(void)
Definition control.c:3408
void key_unit_fortify(void)
Definition control.c:3426
void key_unit_assign_battlegroup(int battlegroup, bool append)
Definition control.c:3631
void key_unit_cultivate(void)
Definition control.c:3509
void key_map_borders_toggle(void)
Definition control.c:3720
#define can_unit_do_activity_targeted_client(_punit_, _act_, _tgt_)
Definition control.h:42
#define can_units_do_activity_targeted_client(_punits_, _act_, _tgt_)
Definition control.h:46
@ HOVER_GOTO
Definition control.h:27
#define can_units_do_activity_client(_punits_, _act_)
Definition control.h:44
bool qtg_request_transport(struct unit *pcargo, struct tile *ptile)
Definition dialogs.cpp:4758
struct unit struct city struct unit struct tile struct extra_type const struct act_prob *act_probs int actor_unit_id struct unit struct unit * punit
Definition dialogs_g.h:73
int get_city_bonus(const struct city *pcity, enum effect_type effect_type)
Definition effects.c:789
struct extra_type * next_extra_for_tile(const struct tile *ptile, enum extra_cause cause, const struct player *pplayer, const struct unit *punit)
Definition extras.c:740
int extra_number(const struct extra_type *pextra)
Definition extras.c:153
struct extra_type_list * extra_type_list_by_cause(enum extra_cause cause)
Definition extras.c:241
struct extra_type * prev_extra_in_tile(const struct tile *ptile, enum extra_rmcause rmcause, const struct player *pplayer, const struct unit *punit)
Definition extras.c:765
static struct extra_type extras[MAX_EXTRA_TYPES]
Definition extras.c:31
const char * extra_name_translation(const struct extra_type *pextra)
Definition extras.c:186
#define extra_type_iterate(_p)
Definition extras.h:291
#define extra_type_iterate_end
Definition extras.h:297
#define extra_type_by_cause_iterate_end
Definition extras.h:315
#define extra_type_by_cause_iterate(_cause, _extra)
Definition extras.h:309
#define NO_TARGET
Definition fc_types.h:324
int Unit_type_id
Definition fc_types.h:352
#define Q_(String)
Definition fcintl.h:70
#define PL_(String1, String2, n)
Definition fcintl.h:71
#define _(String)
Definition fcintl.h:67
const struct ft_color ftc_client
const char * city_link(const struct city *pcity)
struct civ_game game
Definition game.c:57
struct world wld
Definition game.c:58
struct city * game_city_by_number(int id)
Definition game.c:102
struct tile * tile_before_end_path(struct unit *punit, struct tile *ptile)
Definition goto.c:2012
bool send_attack_tile(struct unit *punit, struct tile *ptile)
Definition goto.c:1621
bool send_goto_tile(struct unit *punit, struct tile *ptile)
Definition goto.c:1551
void enter_goto_state(struct unit_list *punits)
Definition goto.c:998
const char * government_name_translation(const struct government *pgovern)
Definition government.c:142
bool untargeted_revolution_allowed(void)
Definition government.c:564
Government_type_id government_count(void)
Definition government.c:70
struct government * government_by_number(const Government_type_id gov)
Definition government.c:102
bool can_change_to_government(struct player *pplayer, const struct government *gov)
Definition government.c:165
static PangoLayout * layout
Definition canvas.c:331
void city_report_dialog_popup(bool raise)
Definition cityrep.c:292
void popup_upgrade_dialog(struct unit_list *punits)
Definition dialogs.c:1444
void popup_disband_dialog(struct unit_list *punits)
Definition dialogs.c:1482
static struct tile * pos
Definition finddlg.c:53
void popup_multiplier_dialog(void)
Definition gamedlgs.c:383
void popup_rates_dialog(void)
Definition gamedlgs.c:533
void popup_goto_dialog(void)
Definition gotodlg.c:257
void popup_quit_dialog(void)
Definition gui_main.c:2154
void popup_help_dialog_typed(const char *item, enum help_page_type htype)
Definition helpdlg.c:195
void create_line_at_mouse_pos(void)
Definition mapctrl.c:347
void update_city_descriptions(void)
Definition mapview.c:470
static const char * get_tile_change_menu_text(struct tile *ptile, enum unit_activity activity)
Definition menu.c:2302
#define CREATE_SUB_ITEM(_sub_target_, _sub_target_key_, _sub_target_name_)
void popup_messageopt_dialog(void)
Definition messagedlg.c:51
void popup_players_dialog(bool raise)
Definition plrdlg.c:91
void science_report_dialog_popup(bool raise)
Definition repodlgs.c:716
void economy_report_dialog_popup(bool raise)
Definition repodlgs.c:1242
void popup_spaceship_dialog(struct player *pplayer)
delay_order
Definition menu.h:81
@ D_GOTO
Definition menu.h:82
munit
Definition menu.h:39
@ AIRLIFT
Definition menu.h:69
@ CONNECT_RAIL
Definition menu.h:65
@ TRANSFORM
Definition menu.h:51
@ FORTIFY
Definition menu.h:55
@ GOTO_CITY
Definition menu.h:68
@ TRANSPORTER
Definition menu.h:44
@ BUILD
Definition menu.h:53
@ IRRIGATION
Definition menu.h:49
@ CONNECT_IRRIGATION
Definition menu.h:67
@ CONNECT_ROAD
Definition menu.h:64
@ HOMECITY
Definition menu.h:61
@ CONVERT
Definition menu.h:46
@ PILLAGE
Definition menu.h:52
@ FALLOUT
Definition menu.h:59
@ BUILD_WONDER
Definition menu.h:70
@ DISBAND
Definition menu.h:45
@ DEBOARD
Definition menu.h:43
@ NOT_4_OBS
Definition menu.h:75
@ UPGRADE
Definition menu.h:74
@ SAVE
Definition menu.h:78
@ MULTIPLIERS
Definition menu.h:76
@ PLANT
Definition menu.h:48
@ ORDER_TRADE_ROUTE
Definition menu.h:72
@ POLLUTION
Definition menu.h:58
@ WAKEUP
Definition menu.h:62
@ MINE
Definition menu.h:47
@ SENTRY
Definition menu.h:60
@ ORDER_DIPLOMAT_DLG
Definition menu.h:73
@ EXPLORE
Definition menu.h:41
@ STANDARD
Definition menu.h:40
@ ROAD
Definition menu.h:54
@ CONNECT_MAGLEV
Definition menu.h:66
@ CULTIVATE
Definition menu.h:50
@ AUTOSETTLER
Definition menu.h:63
@ BOARD
Definition menu.h:42
@ FORTRESS
Definition menu.h:56
@ ENDGAME
Definition menu.h:77
@ AUTOTRADEROUTE
Definition menu.h:71
@ AIRBASE
Definition menu.h:57
void popup_revolution_dialog(void)
Definition dialogs.c:109
#define HELP_CITIES_ITEM
#define HELP_TERRAIN_ITEM
#define HELP_LANGUAGES_ITEM
#define HELP_CONNECTING_ITEM
#define HELP_TILESET_ITEM
#define HELP_CHATLINE_ITEM
#define HELP_RULESET_ITEM
#define HELP_GOVERNMENT_ITEM
#define HELP_ABOUT_ITEM
#define HELP_PLAYING_ITEM
#define HELP_IMPROVEMENTS_ITEM
#define HELP_UNITS_ITEM
#define HELP_ZOC_ITEM
#define HELP_WORKLIST_EDITOR_ITEM
#define HELP_WONDERS_ITEM
#define HELP_COMBAT_ITEM
#define HELP_SPACE_RACE_ITEM
#define HELP_COPYING_ITEM
#define HELP_OVERVIEW_ITEM
#define HELP_NATIONS_ITEM
#define HELP_TECHS_ITEM
#define HELP_DIPLOMACY_ITEM
#define HELP_ECONOMY_ITEM
@ HELP_ANY
Definition helpdlg_g.h:20
#define HELP_CMA_ITEM
#define HELP_CONTROLS_ITEM
bool has_player_unit_type(Unit_type_id utype)
Definition hudwidget.cpp:60
Impr_type_id improvement_number(const struct impr_type *pimprove)
const char * improvement_name_translation(const struct impr_type *pimprove)
#define improvement_iterate_end
#define improvement_iterate(_p)
#define fc_assert(condition)
Definition log.h:176
int get_direction_for_step(const struct civ_map *nmap, const struct tile *start_tile, const struct tile *end_tile)
Definition map.c:1345
bool is_tiles_adjacent(const struct tile *tile0, const struct tile *tile1)
Definition map.c:929
struct terrain_misc terrain_control
Definition map.c:69
struct view mapview
bool map_canvas_resized(int width, int height)
#define fc_malloc(sz)
Definition mem.h:34
#define ADD_OLD_SHORTCUT(wanted_action_id, sc_id)
static void enable_interface(bool enable)
Definition menu.cpp:3204
void multiairlift(struct city *acity, Unit_type_id ut)
Definition menu.cpp:3925
void real_menus_init(void)
Definition menu.cpp:510
static const char * get_tile_change_menu_text(struct tile *ptile, enum unit_activity activity)
Definition menu.cpp:551
static void reset_menu_and_sub_menues(QMenu *menu)
Definition menu.cpp:716
void real_menus_update(void)
Definition menu.cpp:528
static mpgui * gui
Definition mpgui_qt.cpp:52
Multiplier_type_id multiplier_count(void)
Definition multipliers.c:88
const char *const city_productions
Definition fonts.h:33
const char *const city_names
Definition fonts.h:32
const char * nation_plural_for_player(const struct player *pplayer)
Definition nation.c:177
const struct option_set * client_optset
Definition options.c:1255
void options_save(option_save_log_callback log_cb)
Definition options.c:6053
struct client_options gui_options
Definition options.c:71
struct option * optset_option_by_name(const struct option_set *poptset, const char *name)
Definition options.c:406
@ REPORT_WONDERS_OF_THE_WORLD
Definition packets.h:74
@ REPORT_DEMOGRAPHIC
Definition packets.h:76
@ REPORT_TOP_5_CITIES
Definition packets.h:75
@ REPORT_ACHIEVEMENTS
Definition packets.h:77
void popup_shortcuts_dialog()
void toggle_units_report(bool)
#define players_iterate_end
Definition player.h:535
#define players_iterate(_pplayer)
Definition player.h:530
void popup_endgame_report()
struct extra_type * road_extra_get(const struct road_type *proad)
Definition road.c:42
struct road_type * road_by_gui_type(enum road_gui_type gui_type)
Definition road.c:180
const struct strvec * get_save_dirs(void)
Definition shared.c:934
void array_shuffle(int *array, int n)
Definition shared.c:1997
char * freeciv_storage_dir(void)
Definition shared.c:672
#define DIR_SEPARATOR
Definition shared.h:127
QString shortcut_to_string(fc_shortcut *sc)
shortcut_id
Definition shortcuts.h:33
@ SC_PARADROP
Definition shortcuts.h:82
@ SC_UPGRADE_UNIT
Definition shortcuts.h:63
@ SC_BUILDIRRIGATION
Definition shortcuts.h:67
@ SC_BUILDCITY
Definition shortcuts.h:70
@ SC_DONE_MOVING
Definition shortcuts.h:57
@ SC_BUILDROAD
Definition shortcuts.h:69
@ SC_UNSENTRY_TILE
Definition shortcuts.h:61
@ SC_CULTIVATE
Definition shortcuts.h:68
@ SC_DO
Definition shortcuts.h:62
@ SC_CENTER_VIEW
Definition shortcuts.h:36
@ SC_SENTRY
Definition shortcuts.h:71
@ SC_GOBUILDCITY
Definition shortcuts.h:92
@ SC_NUKE
Definition shortcuts.h:76
@ SC_AUTOEXPLORE
Definition shortcuts.h:59
@ SC_SETHOME
Definition shortcuts.h:64
@ SC_PLANT
Definition shortcuts.h:66
@ SC_BUILDMINE
Definition shortcuts.h:65
@ SC_FULLSCREEN
Definition shortcuts.h:37
@ SC_TRADE_ROUTES
Definition shortcuts.h:54
@ SC_CITY_OUTPUT
Definition shortcuts.h:39
@ SC_TRANSFORM
Definition shortcuts.h:75
@ SC_STACK_SIZE
Definition shortcuts.h:94
@ SC_FORTIFY
Definition shortcuts.h:72
@ SC_ZOOM_IN
Definition shortcuts.h:87
@ SC_GOJOINCITY
Definition shortcuts.h:93
@ SC_MAP_GRID
Definition shortcuts.h:40
@ SC_MINIMAP
Definition shortcuts.h:38
@ SC_CITY_PROD
Definition shortcuts.h:55
@ SC_PATROL
Definition shortcuts.h:60
@ SC_GOTO
Definition shortcuts.h:73
@ SC_GOTOAIRLIFT
Definition shortcuts.h:58
@ SC_WAIT
Definition shortcuts.h:74
@ SC_IFACE_LOCK
Definition shortcuts.h:80
@ SC_DEBOARD
Definition shortcuts.h:78
@ SC_ZOOM_RESET
Definition shortcuts.h:91
@ SC_ZOOM_OUT
Definition shortcuts.h:88
@ SC_AUTOMATE
Definition shortcuts.h:81
@ SC_CITY_NAMES
Definition shortcuts.h:56
@ SC_BOARD
Definition shortcuts.h:77
@ SC_NAT_BORDERS
Definition shortcuts.h:41
@ SC_SHOW_FULLBAR
Definition shortcuts.h:86
#define strvec_iterate(psv, str)
#define strvec_iterate_end
QPixmap map_pixmap
Definition canvas.h:25
Definition city.h:309
char * name
Definition city.h:310
struct tile * tile
Definition city.h:311
struct packet_game_info info
Definition game.h:89
struct civ_game::@30::@33 client
bool ruleset_ready
Definition game.h:116
struct government * government_during_revolution
Definition game.h:94
int xsize
Definition map_types.h:77
int ysize
Definition map_types.h:77
struct connection conn
Definition client_main.h:96
bool gui_qt_fullscreen
Definition options.h:386
bool draw_native
Definition options.h:207
bool draw_city_output
Definition options.h:186
bool draw_city_names
Definition options.h:188
bool draw_city_productions
Definition options.h:190
bool draw_borders
Definition options.h:206
bool draw_city_buycost
Definition options.h:191
bool draw_unit_stack_size
Definition options.h:210
bool draw_city_trade_routes
Definition options.h:192
bool unit_selection_clears_orders
Definition options.h:168
bool save_options_on_exit
Definition options.h:121
bool draw_map_grid
Definition options.h:187
bool draw_city_growth
Definition options.h:189
bool draw_city_outlines
Definition options.h:185
bool draw_full_citybar
Definition options.h:208
struct player * playing
Definition connection.h:156
Qt::MouseButton mouse
Definition shortcuts.h:107
Definition climisc.h:80
struct city_list * cities
Definition player.h:281
Definition menu.h:159
struct tile * t1
Definition menu.h:160
struct tile * t2
Definition menu.h:161
struct unit * autocaravan
Definition menu.h:162
QPixmap * pm
Definition sprite.h:25
struct terrain * cultivate_result
Definition terrain.h:203
struct terrain * plant_result
Definition terrain.h:206
struct terrain * transform_result
Definition terrain.h:217
Definition tile.h:49
struct unit_list * units
Definition tile.h:57
Definition unit.h:138
int id
Definition unit.h:145
struct tile * tile
Definition unit.h:140
int homecity
Definition unit.h:146
const struct unit_type * utype
Definition unit.h:139
struct canvas * store
struct civ_map map
int fc_snprintf(char *str, size_t n, const char *format,...)
Definition support.c:969
#define TRUE
Definition support.h:46
#define FALSE
Definition support.h:47
const char * advance_name_translation(const struct advance *padvance)
Definition tech.c:290
Tech_type_id advance_number(const struct advance *padvance)
Definition tech.c:98
#define advance_iterate(_start, _p)
Definition tech.h:264
#define A_FIRST
Definition tech.h:44
#define advance_iterate_end
Definition tech.h:270
#define T_NONE
Definition terrain.h:56
void tile_virtual_destroy(struct tile *vtile)
Definition tile.c:1018
bool tile_apply_activity(struct tile *ptile, Activity_type_id act, struct extra_type *tgt)
Definition tile.c:658
struct tile * tile_virtual_new(const struct tile *ptile)
Definition tile.c:966
const char * tile_get_info_text(const struct tile *ptile, bool include_nuisances, int linebreaks)
Definition tile.c:756
struct city * tile_city(const struct tile *ptile)
Definition tile.c:83
#define tile_terrain(_tile)
Definition tile.h:109
struct sprite * get_government_sprite(const struct tileset *t, const struct government *gov)
Definition tilespec.c:6508
int tileset_hex_width(const struct tileset *t)
Definition tilespec.c:684
const struct strvec * get_tileset_list(const struct option *poption)
Definition tilespec.c:1047
bool tileset_is_isometric(const struct tileset *t)
Definition tilespec.c:675
const char * tileset_basename(const struct tileset *t)
Definition tilespec.c:667
int tileset_tile_height(const struct tileset *t)
Definition tilespec.c:728
int tileset_tile_width(const struct tileset *t)
Definition tilespec.c:716
bool tilespec_reread(const char *new_tileset_name, bool game_fully_initialized, float scale)
Definition tilespec.c:1299
int city_num_trade_routes(const struct city *pcity)
unsigned max_trade_routes(const struct city *pcity)
Definition traderoutes.c:48
bool can_establish_trade_route(const struct city *pc1, const struct city *pc2)
bool have_cities_trade_route(const struct city *pc1, const struct city *pc2)
bool can_unit_change_homecity(const struct unit *punit)
Definition unit.c:464
bool unit_can_est_trade_route_here(const struct unit *punit)
Definition unit.c:289
bool unit_can_add_or_build_city(const struct unit *punit)
Definition unit.c:430
bool unit_contained_in(const struct unit *pcargo, const struct unit *ptrans)
Definition unit.c:2506
bool can_unit_do_autosettlers(const struct unit *punit)
Definition unit.c:583
bool unit_can_help_build_wonder_here(const struct unit *punit)
Definition unit.c:263
bool can_unit_paradrop(const struct civ_map *nmap, const struct unit *punit)
Definition unit.c:827
#define unit_tile(_pu)
Definition unit.h:388
@ ORDER_LAST
Definition unit.h:49
@ ORDER_PERFORM_ACTION
Definition unit.h:47
#define unit_owner(_pu)
Definition unit.h:387
bool units_can_convert(const struct civ_map *nmap, const struct unit_list *punits)
Definition unitlist.c:353
bool units_are_occupied(const struct unit_list *punits)
Definition unitlist.c:277
bool units_can_do_action_with_result(const struct unit_list *punits, enum action_result result, bool can_do)
Definition unitlist.c:262
bool can_units_do_base_gui(const struct unit_list *punits, enum base_gui_type base_gui)
Definition unitlist.c:184
bool units_contain_cityfounder(const struct unit_list *punits)
Definition unitlist.c:221
bool can_units_do_any_road(const struct civ_map *nmap, const struct unit_list *punits)
Definition unitlist.c:165
struct unit * unit_list_find(const struct unit_list *punitlist, int unit_id)
Definition unitlist.c:30
bool units_can_upgrade(const struct civ_map *nmap, const struct unit_list *punits)
Definition unitlist.c:338
bool units_can_unload(const struct unit_list *punits)
Definition unitlist.c:305
bool units_have_activity_on_tile(const struct unit_list *punits, enum unit_activity activity)
Definition unitlist.c:322
bool units_have_type_flag(const struct unit_list *punits, enum unit_type_flag_id flag, bool has_flag)
Definition unitlist.c:206
bool can_units_do(const struct unit_list *punits, bool(can_fn)(const struct unit *punit))
Definition unitlist.c:95
bool units_can_do_action(const struct unit_list *punits, action_id act_id, bool can_do)
Definition unitlist.c:243
bool units_can_load(const struct unit_list *punits)
Definition unitlist.c:291
bool can_units_do_on_map(const struct civ_map *nmap, const struct unit_list *punits, bool(can_fn)(const struct civ_map *nmap, const struct unit *punit))
Definition unitlist.c:111
#define unit_list_iterate(unitlist, punit)
Definition unitlist.h:31
#define unit_list_iterate_end
Definition unitlist.h:33
const struct unit_type * unit_type_get(const struct unit *punit)
Definition unittype.c:123
struct unit_type * utype_by_number(const Unit_type_id id)
Definition unittype.c:112
Unit_type_id utype_index(const struct unit_type *punittype)
Definition unittype.c:91
bool can_player_build_unit_now(const struct player *p, const struct unit_type *punittype)
Definition unittype.c:2131
const char * utype_name_translation(const struct unit_type *punittype)
Definition unittype.c:1612
bool utype_can_do_action(const struct unit_type *putype, const action_id act_id)
Definition unittype.c:443
#define unit_type_iterate(_p)
Definition unittype.h:838
#define unit_type_iterate_end
Definition unittype.h:845
#define enable(id)
Definition widget.h:223