Freeciv-3.1
Loading...
Searching...
No Matches
mapctrl_common.c
Go to the documentation of this file.
1/***********************************************************************
2 Freeciv - Copyright (C) 2002 - The Freeciv Project
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#include <stdlib.h> /* qsort */
19
20/* utility */
21#include "fcintl.h"
22#include "log.h"
23#include "support.h"
24
25/* common */
26#include "combat.h"
27#include "game.h"
28#include "unitlist.h"
29
30/* client */
31#include "agents.h"
32#include "chatline_common.h"
33#include "cityrep_g.h"
34#include "client_main.h"
35#include "climisc.h"
36#include "cma_core.h"
37#include "control.h"
38#include "editor.h"
39#include "fcintl.h"
40#include "goto.h"
41#include "mapctrl_common.h"
42#include "mapctrl_g.h"
43#include "mapview_g.h"
44#include "options.h"
45#include "overview_common.h"
46#include "tilespec.h"
47#include "zoom.h"
48
49/* Selection Rectangle */
50static float rec_anchor_x, rec_anchor_y; /* canvas coordinates for anchor */
52static int rec_corner_x, rec_corner_y; /* corner to iterate from */
53static int rec_w, rec_h; /* width, heigth in pixels */
54
57
58/* This changes the behaviour of left mouse
59 button in Area Selection mode. */
61
62/* The mapcanvas clipboard */
64{ .kind = VUT_NONE,
65 .value = {.building = NULL}
66};
67
68/* Goto with drag and drop. */
72
73/* Update the workers for a city on the map, when the update is received */
75
76/*************************************************************************/
77
78static void clipboard_send_production_packet(struct city *pcity);
79static void define_tiles_within_rectangle(bool append);
80
81/**********************************************************************/
99
100/**********************************************************************/
114static void define_tiles_within_rectangle(bool append)
115{
116 const int W = tileset_tile_width(tileset), half_W = W / 2;
117 const int H = tileset_tile_height(tileset), half_H = H / 2;
118 const int segments_x = abs(rec_w / half_W);
119 const int segments_y = abs(rec_h / half_H);
120
121 /* Iteration direction */
122 const int inc_x = (rec_w > 0 ? half_W : -half_W);
123 const int inc_y = (rec_h > 0 ? half_H : -half_H);
124 int x, y, xx, yy;
125 float x2, y2;
126 struct unit_list *units = unit_list_new();
127 const struct city *pcity;
128 bool found_any_cities = FALSE;
129
130 if (!append) {
132 }
133
134 y = rec_corner_y;
135 for (yy = 0; yy <= segments_y; yy++, y += inc_y) {
136 x = rec_corner_x;
137 for (xx = 0; xx <= segments_x; xx++, x += inc_x) {
138 struct tile *ptile;
139
140 /* For diamond shaped tiles, every other row is indented.
141 */
142 if ((yy % 2 ^ xx % 2) != 0) {
143 continue;
144 }
145
146 ptile = canvas_pos_to_tile(x, y, map_zoom);
147 if (!ptile) {
148 continue;
149 }
150
151 /* "Half-tile" indentation must match, or we'll process
152 * some tiles twice in the case of rectangular shape tiles.
153 */
154 tile_to_canvas_pos(&x2, &y2, map_zoom, ptile);
155
156 if ((yy % 2) != 0 && ((rec_corner_x % W) ^ abs((int)x2 % W)) != 0) {
157 continue;
158 }
159
160 /* Tile passed all tests; process it.
161 */
162 pcity = tile_city(ptile);
163 if (pcity != NULL && city_owner(pcity) == client_player()) {
165 found_any_cities = tiles_hilited_cities = TRUE;
166 }
167 unit_list_iterate(ptile->units, punit) {
169 unit_list_append(units, punit);
170 }
172 }
173 }
174
175 if (!(gui_options.separate_unit_selection && found_any_cities)
176 && unit_list_size(units) > 0) {
177 if (!append) {
178 struct unit *punit = unit_list_get(units, 0);
179
181 unit_list_remove(units, punit);
182 }
183 unit_list_iterate(units, punit) {
186 }
187 unit_list_destroy(units);
188
189 /* Clear previous rectangle. */
191
192 /* Hilite in City List Window */
194 hilite_cities_from_canvas(); /* cityrep.c */
195 }
196}
197
198/**********************************************************************/
202{
203 const int W = tileset_tile_width(tileset), half_W = W / 2;
204 const int H = tileset_tile_height(tileset), half_H = H / 2;
205 static struct tile *rec_tile = NULL;
206 int diff_x, diff_y;
207 struct tile *center_tile;
208 struct tile *ptile;
209
211
212 /* Did mouse pointer move beyond the current tile's
213 * boundaries? Avoid macros; tile may be unreal!
214 */
215 if (ptile == rec_tile) {
216 return;
217 }
218 rec_tile = ptile;
219
220 /* Clear previous rectangle. */
222
223 /* Fix canvas coords to the center of the tile. */
225 canvas_x += half_W;
226 canvas_y += half_H;
227
228 rec_w = rec_anchor_x - canvas_x; /* width */
229 rec_h = rec_anchor_y - canvas_y; /* height */
230
231 /* FIXME: This may be off-by-one. */
234
235 /* Adjust width, height if mapview has recentered.
236 */
237 if (diff_x != 0 || diff_y != 0) {
238
240 rec_w += (diff_x - diff_y) * half_W;
241 rec_h += (diff_x + diff_y) * half_H;
242
243 /* Iso wrapping */
244 if (abs(rec_w) > wld.map.xsize * half_W / 2) {
245 int wx = wld.map.xsize * half_W, wy = wld.map.xsize * half_H;
246
247 rec_w > 0 ? (rec_w -= wx, rec_h -= wy) : (rec_w += wx, rec_h += wy);
248 }
249
250 } else {
251 rec_w += diff_x * W;
252 rec_h += diff_y * H;
253
254 /* X wrapping */
255 if (abs(rec_w) > wld.map.xsize * half_W) {
256 int wx = wld.map.xsize * W;
257
258 rec_w > 0 ? (rec_w -= wx) : (rec_w += wx);
259 }
260 }
261 }
262
263 if (rec_w == 0 && rec_h == 0) {
265 return;
266 }
267
268 /* It is currently drawn only to the screen, not backing store */
273}
274
275/**********************************************************************/
284
285/**********************************************************************/
289{
290 if (rectangle_active) {
293
294 /* Erase the previously drawn selection rectangle. */
296 }
297}
298
299/**********************************************************************/
302bool is_city_hilited(struct city *pcity)
303{
304 return pcity && mapdeco_is_highlight_set(city_tile(pcity));
305}
306
307/**********************************************************************/
317
318/**********************************************************************/
333
334/**********************************************************************/
337void toggle_tile_hilite(struct tile *ptile)
338{
339 struct city *pcity = tile_city(ptile);
340
341 if (mapdeco_is_highlight_set(ptile)) {
343 if (pcity) {
344 toggle_city_hilite(pcity, FALSE); /* cityrep.c */
345 }
346 }
347 else if (NULL != pcity && city_owner(pcity) == client.conn.playing) {
350 toggle_city_hilite(pcity, TRUE);
351 } else {
352 return;
353 }
354}
355
356/**********************************************************************/
361{
363
364 if (can_client_change_view() && ptile) {
365 struct unit *punit;
366 struct city *pcity = find_city_or_settler_near_tile(ptile, &punit);
367
368 if (pcity) {
369 toggle_city_color(pcity);
370 } else if (punit) {
372 }
373 }
374}
375
376/**********************************************************************/
381{
382 char buffer[256];
383 struct city *pcity = tile_city(ptile);
384
386 return FALSE;
387 }
388
389 if (pcity) {
390 if (city_owner(pcity) != client.conn.playing) {
391 return FALSE;
392 }
393 clipboard = pcity->production;
394 } else {
395 struct unit *punit = find_visible_unit(ptile);
396 if (!punit) {
397 return FALSE;
398 }
401 create_event(ptile, E_BAD_COMMAND, ftc_client,
402 _("You don't know how to build %s!"),
404 return TRUE;
405 }
406 clipboard.kind = VUT_UTYPE;
408 }
410
411 create_event(ptile, E_CITY_PRODUCTION_CHANGED, /* ? */
412 ftc_client, _("Copy %s to clipboard."),
413 universal_name_translation(&clipboard, buffer, sizeof(buffer)));
414 return TRUE;
415}
416
417/**********************************************************************/
422{
424 return;
425 }
426 if (NULL == clipboard.value.building) {
427 create_event(city_tile(pcity), E_BAD_COMMAND, ftc_client,
428 _("Clipboard is empty."));
429 return;
430 }
432 if (NULL != pcity && city_owner(pcity) == client.conn.playing) {
434 }
435 return;
436 } else {
439 if (is_city_hilited(hilicity)) {
441 }
444 }
445}
446
447/**********************************************************************/
450static void clipboard_send_production_packet(struct city *pcity)
451{
453 || !can_city_build_now(&(wld.map), pcity, &clipboard)) {
454 return;
455 }
456
457 dsend_packet_city_change(&client.conn, pcity->id, pcity->id,
460}
461
462/**********************************************************************/
467{
469 return;
470 }
471 if (VUT_UTYPE == clipboard.kind) {
472 const struct unit_type *u =
474
475 if (u) {
477 }
478 }
479}
480
481/**********************************************************************/
499
500/**********************************************************************/
515
516/**********************************************************************/
524
525/**********************************************************************/
528bool can_end_turn(void)
529{
530 struct option *opt;
531
532 opt = optset_option_by_name(server_optset, "fixedlength");
533 if (opt != NULL && option_bool_get(opt)) {
534 return FALSE;
535 }
536
540 && !is_server_busy()
542 && !agents_busy());
543}
544
545/**********************************************************************/
549void scroll_mapview(enum direction8 gui_dir)
550{
551 int gui_x = mapview.gui_x0, gui_y = mapview.gui_y0;
552
553 if (!can_client_change_view()) {
554 return;
555 }
556
557 gui_x += DIR_DX[gui_dir] * mapview.width / 2;
558 gui_y += DIR_DY[gui_dir] * mapview.height / 2;
559 set_mapview_origin(gui_x, gui_y, map_zoom);
560}
561
562/**********************************************************************/
568 enum quickselect_type qtype)
569{
571
572 if (can_client_change_view() && ptile) {
573 /* FIXME: Some actions here will need to check can_client_issue_orders.
574 * But all we can check is the lowest common requirement. */
575 do_map_click(ptile, qtype);
576 }
577}
578
579/**********************************************************************/
583{
585
586 if (can_client_issue_orders() && ptile) {
588 }
589}
590
591/**********************************************************************/
595{
597
598 if (NULL != ptile && can_client_issue_orders()) {
599 struct city *pcity = find_city_near_tile(ptile);
600
601 if (pcity && !cma_is_city_under_agent(pcity, NULL)) {
602#ifndef FREECIV_NDEBUG
603 int city_x, city_y;
604#endif
605
606 fc_assert_ret(city_base_to_city_map(&city_x, &city_y, pcity, ptile));
607
608 if (NULL != tile_worked(ptile) && tile_worked(ptile) == pcity) {
610 pcity->id, pcity->id, ptile->index);
611 } else if (city_can_work_tile(pcity, ptile)) {
613 pcity->id, pcity->id, ptile->index);
614 } else {
615 return;
616 }
617
618 /* When the city info packet is received, update the workers on the
619 * map. This is a bad hack used to selectively update the mapview
620 * when we receive the corresponding city packet. */
621 city_workers_display = pcity;
622 }
623 }
624}
625
626/**********************************************************************/
631{
632 /* We use the "nearest" tile here so off-map clicks will still work. */
634 mouse_zoom);
635
636 if (can_client_change_view() && ptile) {
638 }
639}
640
641/**********************************************************************/
645{
646 bool turn_done_state = get_turn_done_button_state();
647
648 set_turn_done_button_state(turn_done_state);
649
650 if (can_end_turn()) {
653 } else {
655 }
656 }
657}
658
659/**********************************************************************/
663{
664 struct tile *ptile;
665 struct unit_list *punits;
666
667 switch (hover_state) {
668 case HOVER_GOTO:
669 case HOVER_PATROL:
670 case HOVER_CONNECT:
672
674 break;
677 punits = get_units_in_focus();
678
680 ptile->index, goto_last_sub_tgt,
682 break;
683 case HOVER_NONE:
684 case HOVER_PARADROP:
686 break;
687 };
688}
689
690/**********************************************************************/
693void overview_update_line(int overview_x, int overview_y)
694{
695 struct tile *ptile;
696 struct unit_list *punits;
697 int x, y;
698
699 switch (hover_state) {
700 case HOVER_GOTO:
701 case HOVER_PATROL:
702 case HOVER_CONNECT:
703 overview_to_map_pos(&x, &y, overview_x, overview_y);
704 ptile = map_pos_to_tile(&(wld.map), x, y);
705
707 break;
709 overview_to_map_pos(&x, &y, overview_x, overview_y);
710 ptile = map_pos_to_tile(&(wld.map), x, y);
711 punits = get_units_in_focus();
712
714 ptile->index, goto_last_sub_tgt,
716 break;
717 case HOVER_NONE:
718 case HOVER_PARADROP:
720 break;
721 };
722}
723
724/**********************************************************************/
731static int unit_list_compare(const void *a, const void *b)
732{
733 const struct unit *punit1 = *(struct unit **)a;
734 const struct unit *punit2 = *(struct unit **)b;
735
736 if (unit_transport_get(punit1) == unit_transport_get(punit2)) {
737 /* For units with the same transporter or no transporter: sort by id. */
738 /* Perhaps we should sort by name instead? */
739 return punit1->id - punit2->id;
740 } else if (unit_transport_get(punit1) == punit2) {
741 return 1;
742 } else if (unit_transport_get(punit2) == punit1) {
743 return -1;
744 } else {
745 /* If the transporters aren't the same, put in order by the
746 * transporters. */
747 const struct unit *ptrans1 = unit_transport_get(punit1);
748 const struct unit *ptrans2 = unit_transport_get(punit2);
749
750 if (!ptrans1) {
751 ptrans1 = punit1;
752 }
753 if (!ptrans2) {
754 ptrans2 = punit2;
755 }
756
757 return unit_list_compare(&ptrans1, &ptrans2);
758 }
759}
760
761/**********************************************************************/
764void fill_tile_unit_list(const struct tile *ptile, struct unit **unit_list)
765{
766 int i = 0;
767
768 /* First populate the unit list. */
769 unit_list_iterate(ptile->units, punit) {
770 unit_list[i] = punit;
771 i++;
773
774 /* Then sort it. */
775 qsort(unit_list, i, sizeof(*unit_list), unit_list_compare);
776}
#define ACTION_NONE
Definition actions.h:293
bool agents_busy(void)
Definition agents.c:799
struct canvas int int canvas_y
Definition canvas_g.h:43
struct canvas int canvas_x
Definition canvas_g.h:43
bool city_base_to_city_map(int *city_map_x, int *city_map_y, const struct city *const pcity, const struct tile *map_tile)
Definition city.c:276
bool can_city_build_now(const struct civ_map *nmap, const struct city *pcity, const struct universal *target)
Definition city.c:991
bool city_can_work_tile(const struct city *pcity, const struct tile *ptile)
Definition city.c:1429
#define city_list_iterate(citylist, pcity)
Definition city.h:488
#define city_tile(_pcity_)
Definition city.h:544
#define city_owner(_pcity_)
Definition city.h:543
#define city_list_iterate_end
Definition city.h:490
bool waiting_for_end_turn
void send_turn_done(void)
struct civclient client
bool can_client_issue_orders(void)
bool is_server_busy(void)
bool can_client_change_view(void)
#define client_player()
void create_event(struct tile *ptile, enum event_type event, const struct ft_color color, const char *format,...)
Definition climisc.c:1086
bool cma_is_city_under_agent(const struct city *pcity, struct cm_parameter *parameter)
Definition cma_core.c:551
void connection_do_buffer(struct connection *pc)
Definition connection.c:323
void connection_do_unbuffer(struct connection *pc)
Definition connection.c:335
enum unit_orders goto_last_order
Definition control.c:96
void clear_hover_state(void)
Definition control.c:328
void do_map_click(struct tile *ptile, enum quickselect_type qtype)
Definition control.c:2795
void unit_focus_add(struct unit *punit)
Definition control.c:562
void unit_focus_set(struct unit *punit)
Definition control.c:507
void request_unit_goto(enum unit_orders last_order, action_id act_id, int sub_tgt_id)
Definition control.c:1129
struct extra_type * connect_tgt
Definition control.c:91
struct unit_list * get_units_in_focus(void)
Definition control.c:177
enum unit_activity connect_activity
Definition control.c:90
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:290
enum cursor_hover_state hover_state
Definition control.c:89
int goto_last_sub_tgt
Definition control.c:95
struct unit * find_visible_unit(struct tile *ptile)
Definition control.c:823
int get_num_units_in_focus(void)
Definition control.c:185
void wakeup_sentried_units(struct tile *ptile)
Definition control.c:1578
action_id goto_last_action
Definition control.c:93
void do_unit_goto(struct tile *ptile)
Definition control.c:3005
quickselect_type
Definition control.h:36
@ HOVER_GOTO
Definition control.h:27
@ HOVER_PARADROP
Definition control.h:28
@ HOVER_ACT_SEL_TGT
Definition control.h:31
@ HOVER_NONE
Definition control.h:26
@ HOVER_CONNECT
Definition control.h:29
@ HOVER_PATROL
Definition control.h:30
@ HOVER_GOTO_SEL_TGT
Definition control.h:32
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
#define _(String)
Definition fcintl.h:67
const struct ft_color ftc_client
struct civ_game game
Definition game.c:57
bool is_player_phase(const struct player *pplayer, int phase)
Definition game.c:687
struct world wld
Definition game.c:58
bool is_valid_goto_draw_line(struct tile *dest_tile)
Definition goto.c:1335
void toggle_city_hilite(struct city *pcity, bool on_off)
Definition cityrep.c:2096
void hilite_cities_from_canvas(void)
Definition cityrep.c:2071
void set_turn_done_button_state(bool state)
Definition mapctrl.c:207
void update_turn_done_button(bool do_restore)
Definition mapview.c:75
void draw_selection_rectangle(int canvas_x, int canvas_y, int w, int h)
Definition mapview.c:728
void update_unit_info_label(struct unit_list *punits)
Definition mapview.c:258
#define fc_assert_ret(condition)
Definition log.h:191
const int DIR_DY[8]
Definition map.c:87
const int DIR_DX[8]
Definition map.c:86
struct tile * map_pos_to_tile(const struct civ_map *nmap, int map_x, int map_y)
Definition map.c:417
bool same_pos(const struct tile *tile1, const struct tile *tile2)
Definition map.c:938
void map_distance_vector(int *dx, int *dy, const struct tile *tile0, const struct tile *tile1)
Definition map.c:1071
void cancel_selection_rectangle(void)
void update_line(int canvas_x, int canvas_y)
void maybe_activate_keyboardless_goto(int canvas_x, int canvas_y)
void adjust_workers_button_pressed(int canvas_x, int canvas_y)
bool rbutton_down
static int rec_corner_y
bool rectangle_active
void release_goto_button(int canvas_x, int canvas_y)
static int rec_h
bool tiles_hilited_cities
struct universal clipboard
void redraw_selection_rectangle(void)
void recenter_button_pressed(int canvas_x, int canvas_y)
void upgrade_canvas_clipboard(void)
void update_turn_done_button_state(void)
void action_button_pressed(int canvas_x, int canvas_y, enum quickselect_type qtype)
void wakeup_button_pressed(int canvas_x, int canvas_y)
struct city * city_workers_display
static float rec_anchor_y
bool get_turn_done_button_state(void)
void scroll_mapview(enum direction8 gui_dir)
void release_right_button(int canvas_x, int canvas_y, bool shift)
bool keyboardless_goto_button_down
static int rec_corner_x
void key_city_overlay(int canvas_x, int canvas_y)
static float rec_anchor_x
void update_selection_rectangle(float canvas_x, float canvas_y)
bool can_end_turn(void)
void overview_update_line(int overview_x, int overview_y)
void anchor_selection_rectangle(int canvas_x, int canvas_y)
void cancel_tile_hiliting(void)
bool keyboardless_goto_active
void clipboard_paste_production(struct city *pcity)
static struct tile * rec_canvas_center_tile
void fill_tile_unit_list(const struct tile *ptile, struct unit **unit_list)
static void define_tiles_within_rectangle(bool append)
static void clipboard_send_production_packet(struct city *pcity)
bool clipboard_copy_production(struct tile *ptile)
static int rec_w
bool is_city_hilited(struct city *pcity)
static int unit_list_compare(const void *a, const void *b)
struct tile * keyboardless_goto_start_tile
void toggle_tile_hilite(struct tile *ptile)
void mapdeco_set_highlight(const struct tile *ptile, bool highlight)
struct city * find_city_or_settler_near_tile(const struct tile *ptile, struct unit **punit)
void set_mapview_origin(float gui_x0, float gui_y0, float zoom)
struct view mapview
struct tile * get_center_tile_mapcanvas(void)
struct tile * canvas_pos_to_tile(float canvas_x, float canvas_y, float zoom)
struct city * find_city_near_tile(const struct tile *ptile)
bool mapdeco_is_highlight_set(const struct tile *ptile)
void center_tile_mapcanvas(const struct tile *ptile)
void toggle_city_color(struct city *pcity)
struct tile * canvas_pos_to_nearest_tile(float canvas_x, float canvas_y, float zoom)
const struct tile * center_tile
void mapdeco_clear_highlights(void)
void toggle_unit_color(struct unit *punit)
bool tile_to_canvas_pos(float *canvas_x, float *canvas_y, float zoom, const struct tile *ptile)
#define H(x, y, z)
Definition md5.c:92
const struct option_set * server_optset
Definition options.c:4009
bool option_bool_get(const struct option *poption)
Definition options.c:772
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
void overview_to_map_pos(int *map_x, int *map_y, int overview_x, int overview_y)
int dsend_packet_city_make_worker(struct connection *pc, int city_id16, int city_id32, int tile_id)
int dsend_packet_city_make_specialist(struct connection *pc, int city_id16, int city_id32, int tile_id)
int dsend_packet_city_change(struct connection *pc, int city_id16, int city_id32, int production_kind, int production_value)
#define is_human(plr)
Definition player.h:233
bool are_universals_equal(const struct universal *psource1, const struct universal *psource2)
int universal_number(const struct universal *source)
const char * universal_name_translation(const struct universal *psource, char *buf, size_t bufsz)
Definition city.h:309
int id
Definition city.h:315
struct universal production
Definition city.h:382
struct packet_game_info info
Definition game.h:89
int xsize
Definition map_types.h:77
struct connection conn
Definition client_main.h:96
bool ai_manual_turn_done
Definition options.h:147
bool separate_unit_selection
Definition options.h:167
struct player * playing
Definition connection.h:156
struct city_list * cities
Definition player.h:281
bool is_alive
Definition player.h:268
bool phase_done
Definition player.h:263
Definition tile.h:49
int index
Definition tile.h:50
struct unit_list * units
Definition tile.h:57
Definition unit.h:138
int id
Definition unit.h:145
enum universals_n kind
Definition fc_types.h:758
universals_u value
Definition fc_types.h:757
int height
float gui_x0
float gui_y0
int width
struct civ_map map
#define TRUE
Definition support.h:46
#define FALSE
Definition support.h:47
struct city * tile_city(const struct tile *ptile)
Definition tile.c:83
#define tile_worked(_tile)
Definition tile.h:113
bool tileset_is_isometric(const struct tileset *t)
Definition tilespec.c:675
int tileset_tile_height(const struct tileset *t)
Definition tilespec.c:728
int tileset_tile_width(const struct tileset *t)
Definition tilespec.c:716
const struct unit_type * utype
Definition fc_types.h:604
const struct impr_type * building
Definition fc_types.h:598
struct unit * unit_transport_get(const struct unit *pcargo)
Definition unit.c:2425
@ ORDER_LAST
Definition unit.h:49
#define unit_owner(_pu)
Definition unit.h:394
#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
const char * unit_name_translation(const struct unit *punit)
Definition unittype.c:1621
const struct unit_type * can_upgrade_unittype(const struct player *pplayer, const struct unit_type *punittype)
Definition unittype.c:1755
bool can_player_build_unit_direct(const struct player *p, const struct unit_type *punittype)
Definition unittype.c:2015
float mouse_zoom
Definition zoom.c:28
float map_zoom
Definition zoom.c:25