Freeciv-3.2
Loading...
Searching...
No Matches
packhand.c
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#include <string.h>
19
20/* utility */
21#include "bitvector.h"
22#include "capability.h"
23#include "fcintl.h"
24#include "log.h"
25#include "mem.h"
26#include "rand.h"
27#include "string_vector.h"
28#include "support.h"
29
30/* common */
31#include "achievements.h"
32#include "actions.h"
33#include "capstr.h"
34#include "citizens.h"
35#include "counters.h"
36#include "events.h"
37#include "extras.h"
38#include "game.h"
39#include "government.h"
40#include "idex.h"
41#include "map.h"
42#include "name_translation.h"
43#include "movement.h"
44#include "multipliers.h"
45#include "nation.h"
46#include "packets.h"
47#include "player.h"
48#include "research.h"
49#include "rgbcolor.h"
50#include "road.h"
51#include "spaceship.h"
52#include "specialist.h"
53#include "style.h"
54#include "traderoutes.h"
55#include "unit.h"
56#include "unitlist.h"
57#include "worklist.h"
58
59/* client/include */
60#include "chatline_g.h"
61#include "citydlg_g.h"
62#include "cityrep_g.h"
63#include "connectdlg_g.h"
64#include "dialogs_g.h"
65#include "editgui_g.h"
66#include "gui_main_g.h"
67#include "inteldlg_g.h"
68#include "mapctrl_g.h" /* popup_newcity_dialog() */
69#include "mapview_g.h"
70#include "menu_g.h"
71#include "messagewin_g.h"
72#include "pages_g.h"
73#include "plrdlg_g.h"
74#include "ratesdlg_g.h"
75#include "repodlgs_g.h"
76#include "spaceshipdlg_g.h"
77#include "voteinfo_bar_g.h"
78#include "wldlg_g.h"
79
80/* client */
81#include "agents.h"
82#include "attribute.h"
83#include "audio.h"
84#include "client_main.h"
85#include "climap.h"
86#include "climisc.h"
87#include "clitreaty.h"
88#include "connectdlg_common.h"
89#include "control.h"
90#include "editor.h"
91#include "goto.h" /* client_goto_init() */
92#include "helpdata.h" /* boot_help_texts() */
93#include "mapview_common.h"
94#include "music.h"
95#include "options.h"
96#include "overview_common.h"
97#include "tilespec.h"
98#include "update_queue.h"
99#include "voteinfo.h"
100
101/* client/luascript */
102#include "script_client.h"
103
104#include "packhand.h"
105
106/* Define this macro to get additional debug output about the transport
107 * status of the units. */
108#undef DEBUG_TRANSPORT
109
110static void city_packet_common(struct city *pcity, struct tile *pcenter,
111 struct player *powner,
112 struct tile_list *worked_tiles,
113 bool is_new, bool popup, bool investigate);
114static bool handle_unit_packet_common(struct unit *packet_unit);
115
116
117/* The dumbest of cities, placeholders for unknown and unseen cities. */
118static struct {
119 struct city_list *cities;
121} invisible = {
122 .cities = NULL,
123 .placeholder = NULL
125
126static struct {
127 int len;
129 char *caption;
130 char *headline;
131 char *lines;
132 int parts;
133} page_msg_report = { .parts = 0 };
134
135extern const char forced_tileset_name[];
136
137static int last_turn = 0;
138
139/* Refresh the action selection dialog */
140#define REQEST_BACKGROUND_REFRESH (1)
141/* Get possible actions for fast auto attack. */
142#define REQEST_BACKGROUND_FAST_AUTO_ATTACK (2)
143
144/* A unit will auto attack with the following actions. */
160
161/* A unit will not auto attack if any of these actions are legal. */
209 /* Actually an attack but it needs a target to be specified. */
211 /* End the action list. */
213};
214
215/************************************************************************/
219{
220 if (NULL != invisible.cities) {
221 city_list_iterate(invisible.cities, pcity) {
222 idex_unregister_city(&wld, pcity);
225
227 invisible.cities = NULL;
228 }
229
230 if (NULL != invisible.placeholder) {
231 free(invisible.placeholder);
232 invisible.placeholder = NULL;
233 }
234}
235
236/************************************************************************/
239static void packhand_init(void)
240{
242
243 invisible.cities = city_list_new();
244
245 /* Can't use player_new() here, as it will register the player. */
246 invisible.placeholder = fc_calloc(1, sizeof(*invisible.placeholder));
247 memset(invisible.placeholder, 0, sizeof(*invisible.placeholder));
248 /* Set some values to prevent bugs ... */
249 sz_strlcpy(invisible.placeholder->name, ANON_PLAYER_NAME);
250 sz_strlcpy(invisible.placeholder->username, _(ANON_USER_NAME));
251 invisible.placeholder->unassigned_user = TRUE;
252 sz_strlcpy(invisible.placeholder->ranked_username, ANON_USER_NAME);
253 invisible.placeholder->unassigned_ranked = TRUE;
254}
255
256/************************************************************************/
264static struct unit *unpackage_unit(const struct packet_unit_info *packet)
265{
267 NULL,
268 utype_by_number(packet->type),
269 packet->veteran);
270
271 /* Owner, veteran, and type fields are already filled in by
272 * unit_virtual_create() */
274 punit->id = packet->id;
276 punit->facing = packet->facing;
277 punit->homecity = packet->homecity;
279 punit->upkeep[o] = packet->upkeep[o];
281 punit->moves_left = packet->movesleft;
282 punit->hp = packet->hp;
283 punit->activity = packet->activity;
285
286 if (packet->activity_tgt == EXTRA_NONE) {
288 } else {
290 }
291
294
295 if (packet->changed_from_tgt == EXTRA_NONE) {
297 } else {
299 }
300
302 punit->fuel = packet->fuel;
304 punit->paradropped = packet->paradropped;
305 punit->done_moving = packet->done_moving;
306 punit->stay = packet->stay;
307 punit->birth_turn = packet->birth_turn;
309
310 /* Transporter / transporting information. */
311 punit->client.occupied = packet->occupied;
312 if (packet->transported) {
314 } else {
316 }
317 if (packet->carrying >= 0) {
319 } else {
321 }
322
323 punit->battlegroup = packet->battlegroup;
324 punit->has_orders = packet->has_orders;
325 punit->orders.length = packet->orders_length;
326 punit->orders.index = packet->orders_index;
327 punit->orders.repeat = packet->orders_repeat;
329 if (punit->has_orders) {
330 int i;
331
332 for (i = 0; i < packet->orders_length; i++) {
333 /* Just an assert. The client doesn't use the action data. */
335 || action_id_exists(packet->orders[i].action));
336 }
338 = fc_malloc(punit->orders.length * sizeof(*punit->orders.list));
339 memcpy(punit->orders.list, packet->orders,
340 punit->orders.length * sizeof(*punit->orders.list));
341 }
342
346
348
349 return punit;
350}
351
352/************************************************************************/
362static struct unit *
364{
366 NULL,
367 utype_by_number(packet->type),
368 0);
369
370 /* Owner and type fields are already filled in by unit_virtual_create() */
371 punit->id = packet->id;
373 punit->facing = packet->facing;
375 punit->veteran = packet->veteran;
376 punit->hp = packet->hp;
377 punit->activity = packet->activity;
378
379 if (packet->activity_tgt == EXTRA_NONE) {
381 } else {
383 }
384
385 /* Transporter / transporting information. */
386 punit->client.occupied = packet->occupied;
387 if (packet->transported) {
389 } else {
391 }
392
393 return punit;
394}
395
396/************************************************************************/
400void handle_server_join_reply(bool you_can_join, const char *message,
401 const char *capability,
402 const char *challenge_file, int conn_id)
403{
404 const char *s_capability = client.conn.capability;
405
406 conn_set_capability(&client.conn, capability);
408
409 if (you_can_join) {
411
412 log_verbose("join game accept:%s", message);
414 client.conn.id = conn_id;
415
418
422 }
423
425#ifdef EMERGENCY_VERSION
426 client_info.emerg_version = EMERGENCY_VERSION;
427#else
428 client_info.emerg_version = 0;
429#endif
431 sizeof(client_info.distribution));
433
434 /* We could always use hack, verify we're local */
435#ifdef FREECIV_DEBUG
436 if (!hackless)
437#endif /* FREECIV_DEBUG */
438 {
439 send_client_wants_hack(challenge_file);
440 }
441
443 } else {
445 _("You were rejected from the game: %s"), message);
446 client.conn.id = -1; /* not in range of conn_info id */
447
448 if (auto_connect) {
449 log_normal(_("You were rejected from the game: %s"), message);
450 }
452
454 }
456 return;
457 }
458 output_window_printf(ftc_client, _("Client capability string: %s"),
460 output_window_printf(ftc_client, _("Server capability string: %s"),
462}
463
464/************************************************************************/
468void handle_city_remove(int city_id)
469{
470 struct city *pcity = game_city_by_number(city_id);
472
473 fc_assert_ret_msg(NULL != pcity, "Bad city %d.", city_id);
474
476
477 agents_city_remove(pcity);
479 client_remove_city(pcity);
480
481 /* Update menus if the focus unit is on the tile. */
482 if (need_menus_update) {
483 menus_update();
484 }
485}
486
487/************************************************************************/
491void handle_unit_remove(int unit_id)
492{
493 struct unit *punit = game_unit_by_number(unit_id);
494 struct unit_list *cargos;
495 struct player *powner;
497
498 if (!punit) {
499 log_error("Server wants us to remove unit id %d, "
500 "but we don't know about this unit!",
501 unit_id);
502 return;
503 }
504
505 /* Close the action selection dialog if the actor unit is lost. */
508 /* Open another action selection dialog if there are other actors in the
509 * current selection that want a decision. */
511 }
512
514 powner = unit_owner(punit);
515
516 /* Unload cargo if this is a transporter. */
518 if (unit_list_size(cargos) > 0) {
522 }
523
524 /* Unload unit if it is transported. */
527 }
529
533
534 if (!client_has_player() || powner == client_player()) {
537 }
539 }
540}
541
542/************************************************************************/
549
550/************************************************************************/
553void handle_team_name_info(int team_id, const char *team_name)
554{
555 struct team_slot *tslot = team_slot_by_number(team_id);
556
560}
561
562/************************************************************************/
569{
570 bool show_combat = FALSE;
573
574 if (punit0 && punit1) {
576 packet->attacker_hp, packet->defender_hp,
577 packet->make_att_veteran, packet->make_def_veteran);
584 } else {
586 }
588 }
589
590 if (show_combat) {
591 int hp0 = packet->attacker_hp, hp1 = packet->defender_hp;
592
594 unit_type_get(punit0)->sound_fight_alt,
595 NULL);
597 unit_type_get(punit1)->sound_fight_alt,
598 NULL);
599
602 } else {
603 punit0->hp = hp0;
604 punit1->hp = hp1;
605
609 }
610 }
611 if (packet->make_att_veteran && punit0) {
612 punit0->veteran++;
614 }
615 if (packet->make_def_veteran && punit1) {
616 punit1->veteran++;
618 }
619 }
620}
621
622/************************************************************************/
628static bool update_improvement_from_packet(struct city *pcity,
629 struct impr_type *pimprove,
630 bool have_impr)
631{
632 if (have_impr) {
633 if (pcity->built[improvement_index(pimprove)].turn <= I_NEVER) {
634 city_add_improvement(pcity, pimprove);
635 return TRUE;
636 }
637 } else {
638 if (pcity->built[improvement_index(pimprove)].turn > I_NEVER) {
639 city_remove_improvement(pcity, pimprove);
640 return TRUE;
641 }
642 }
643 return FALSE;
644}
645
646/************************************************************************/
650void handle_city_info(const struct packet_city_info *packet)
651{
652 struct universal product;
653 int i;
654 bool popup;
655 bool city_is_new = FALSE;
660 bool name_changed = FALSE;
663 bool production_changed = FALSE;
665 struct unit_list *pfocus_units = get_units_in_focus();
666 struct city *pcity = game_city_by_number(packet->id);
667 struct tile_list *worked_tiles = NULL;
668 struct tile *pcenter = index_to_tile(&(wld.map), packet->tile);
669 struct tile *ptile = NULL;
670 struct player *powner = player_by_number(packet->owner);
671
672 fc_assert_ret_msg(NULL != powner, "Bad player number %d.", packet->owner);
673 fc_assert_ret_msg(NULL != pcenter, "Invalid tile index %d.", packet->tile);
674
676 log_error("handle_city_info() bad production_kind %d.",
677 packet->production_kind);
678 product.kind = VUT_NONE;
679 } else {
681 packet->production_value);
682 if (!universals_n_is_valid(product.kind)) {
683 log_error("handle_city_info() "
684 "production_kind %d with bad production_value %d.",
685 packet->production_kind, packet->production_value);
686 product.kind = VUT_NONE;
687 }
688 }
689
690 if (NULL != pcity) {
691 ptile = city_tile(pcity);
692
693 if (NULL == ptile) {
694 /* Invisible worked city */
695 city_list_remove(invisible.cities, pcity);
697
698 pcity->tile = pcenter;
699 ptile = pcenter;
700 pcity->owner = powner;
701 } else if (city_owner(pcity) != powner) {
702 /* Remember what were the worked tiles. The server won't
703 * send them to us again. */
705 ptile, pworked, _index, _x, _y) {
706 if (pcity == tile_worked(pworked)) {
707 if (NULL == worked_tiles) {
708 worked_tiles = tile_list_new();
709 }
710 tile_list_append(worked_tiles, pworked);
711 }
713 client_remove_city(pcity);
714 pcity = NULL;
716 }
717 }
718
719 if (NULL == pcity) {
721 pcity = create_city_virtual(powner, pcenter, packet->name);
722 pcity->id = packet->id;
723 idex_register_city(&wld, pcity);
725 } else if (pcity->id != packet->id) {
726 log_error("handle_city_info() city id %d != id %d.",
727 pcity->id, packet->id);
728 return;
729 } else if (ptile != pcenter) {
730 log_error("handle_city_info() city tile (%d, %d) != (%d, %d).",
731 TILE_XY(ptile), TILE_XY(pcenter));
732 return;
733 } else {
734 name_changed = (fc_strncmp(packet->name, pcity->name, MAX_LEN_CITYNAME));
735
736 while (trade_route_list_size(pcity->routes) > packet->trade_route_count) {
737 struct trade_route *proute = trade_route_list_get(pcity->routes, -1);
738
742 }
743
744 /* Descriptions should probably be updated if the
745 * city name, production or time-to-grow changes.
746 * Note that if either the food stock or surplus
747 * have changed, the time-to-grow is likely to
748 * have changed as well. */
752 || pcity->surplus[O_SHIELD] != packet->surplus[O_SHIELD]
753 || pcity->shield_stock != packet->shield_stock))
755 && (pcity->food_stock != packet->food_stock
756 || pcity->surplus[O_FOOD] != packet->surplus[O_FOOD]))
758
759 city_name_set(pcity, packet->name);
760 }
761
762 pcity->original = player_by_number(packet->original);
763
764 /* Check data */
765 city_size_set(pcity, 0);
766 for (i = 0; i < FEELING_LAST; i++) {
767 pcity->feel[CITIZEN_HAPPY][i] = packet->ppl_happy[i];
768 pcity->feel[CITIZEN_CONTENT][i] = packet->ppl_content[i];
769 pcity->feel[CITIZEN_UNHAPPY][i] = packet->ppl_unhappy[i];
770 pcity->feel[CITIZEN_ANGRY][i] = packet->ppl_angry[i];
771 }
772 for (i = 0; i < CITIZEN_LAST; i++) {
773 city_size_add(pcity, pcity->feel[i][FEELING_FINAL]);
774 }
776 pcity->specialists[sp] = packet->specialists[sp];
777 city_size_add(pcity, pcity->specialists[sp]);
779
780 if (city_size_get(pcity) != packet->size) {
781 log_error("handle_city_info() "
782 "%d citizens not equal %d city size in \"%s\".",
783 city_size_get(pcity), packet->size, city_name_get(pcity));
784 city_size_set(pcity, packet->size);
785 }
786
787 pcity->history = packet->history;
788 pcity->client.culture = packet->culture;
789 pcity->client.buy_cost = packet->buy_cost;
790
791 pcity->city_radius_sq = packet->city_radius_sq;
792
793 pcity->city_options = packet->city_options;
794 pcity->wlcb = packet->wl_cb;
795
796 pcity->acquire_t = packet->acquire_type;
797
798 if (pcity->surplus[O_SCIENCE] != packet->surplus[O_SCIENCE]
799 || pcity->surplus[O_SCIENCE] != packet->surplus[O_SCIENCE]
800 || pcity->waste[O_SCIENCE] != packet->waste[O_SCIENCE]
801 || (pcity->unhappy_penalty[O_SCIENCE]
802 != packet->unhappy_penalty[O_SCIENCE])
803 || pcity->prod[O_SCIENCE] != packet->prod[O_SCIENCE]
804 || pcity->citizen_base[O_SCIENCE] != packet->citizen_base[O_SCIENCE]
805 || pcity->usage[O_SCIENCE] != packet->usage[O_SCIENCE]) {
807 }
808
809 pcity->food_stock = packet->food_stock;
810 if (pcity->shield_stock != packet->shield_stock) {
812 pcity->shield_stock = packet->shield_stock;
813 }
814 pcity->pollution = packet->pollution;
815 pcity->illness_trade = packet->illness_trade;
816
817 if (!are_universals_equal(&pcity->production, &product)) {
818 production_changed = TRUE;
819 }
820 /* Need to consider shield stock/surplus for unit dialog as used build
821 * slots may change, affecting number of "in-progress" units. */
822 if ((city_is_new && VUT_UTYPE == product.kind)
823 || (production_changed && (VUT_UTYPE == pcity->production.kind
824 || VUT_UTYPE == product.kind))
825 || pcity->surplus[O_SHIELD] != packet->surplus[O_SHIELD]
828 }
829 pcity->production = product;
830
832 pcity->surplus[o] = packet->surplus[o];
833 pcity->waste[o] = packet->waste[o];
834 pcity->unhappy_penalty[o] = packet->unhappy_penalty[o];
835 pcity->prod[o] = packet->prod[o];
836 pcity->citizen_base[o] = packet->citizen_base[o];
837 pcity->usage[o] = packet->usage[o];
839
840#ifdef DONE_BY_create_city_virtual
841 if (city_is_new) {
842 worklist_init(&pcity->worklist);
843
844 for (i = 0; i < ARRAY_SIZE(pcity->built); i++) {
845 pcity->built[i].turn = I_NEVER;
846 }
847 }
848#endif /* DONE_BY_create_city_virtual */
849
850 worklist_copy(&pcity->worklist, &packet->worklist);
851
852 pcity->airlift = packet->airlift;
853 pcity->did_buy = packet->did_buy;
854 pcity->did_sell = packet->did_sell;
855 pcity->was_happy = packet->was_happy;
856 pcity->had_famine = packet->had_famine;
857
858 pcity->turn_founded = packet->turn_founded;
859 pcity->turn_last_built = packet->turn_last_built;
860
862 log_error("handle_city_info() bad changed_from_kind %d.",
863 packet->changed_from_kind);
864 product.kind = VUT_NONE;
865 } else {
867 packet->changed_from_value);
868 if (!universals_n_is_valid(product.kind)) {
869 log_error("handle_city_info() bad changed_from_value %d.",
870 packet->changed_from_value);
871 product.kind = VUT_NONE;
872 }
873 }
874 pcity->changed_from = product;
875
877 pcity->disbanded_shields = packet->disbanded_shields;
878 pcity->caravan_shields = packet->caravan_shields;
880
881 improvement_iterate(pimprove) {
882 bool have = BV_ISSET(packet->improvements, improvement_index(pimprove));
883
884 if (have && !city_is_new
885 && pcity->built[improvement_index(pimprove)].turn <= I_NEVER) {
886 audio_play_sound(pimprove->soundtag, pimprove->soundtag_alt,
887 pimprove->soundtag_alt2);
888 }
890 update_improvement_from_packet(pcity, pimprove, have);
892
893 /* We should be able to see units in the city. But for a diplomat
894 * investigating an enemy city we can't. In that case we don't update
895 * the occupied flag at all: it's already been set earlier and we'll
896 * get an update if it changes. */
898 pcity->client.occupied
899 = (unit_list_size(pcity->tile->units) > 0);
900 }
901
902 pcity->client.walls = packet->walls;
903 if (pcity->client.walls > NUM_WALL_TYPES) {
904 pcity->client.walls = NUM_WALL_TYPES;
905 }
906 pcity->style = packet->style;
907 pcity->capital = packet->capital;
908 if (packet->capital == CAPITAL_PRIMARY) {
909 powner->primary_capital_id = pcity->id;
910 } else if (powner->primary_capital_id == pcity->id) {
911 powner->primary_capital_id = 0;
912 }
913 pcity->client.city_image = packet->city_image;
914 pcity->steal = packet->steal;
915
916 pcity->client.happy = city_happy(pcity);
917 pcity->client.unhappy = city_unhappy(pcity);
918
920 && powner == client.conn.playing
922 || packet->diplomat_investigate;
923
924 city_packet_common(pcity, pcenter, powner, worked_tiles,
926
928 agents_city_new(pcity);
929 } else {
930 agents_city_changed(pcity);
931 }
932
933 /* Update the description if necessary. */
936 }
937
938 /* Update focus unit info label if necessary. */
939 if (name_changed) {
941 if (pfocus_unit->homecity == pcity->id) {
943 break;
944 }
946 }
947
948 /* Update the science dialog if necessary. */
951 }
952
953 /* Update the units dialog if necessary. */
956 }
957
958 /* Update the economy dialog if necessary. */
961 }
962
963 /* Update the panel text (including civ population). */
965
966 /* Update caravan dialog */
967 if ((production_changed || shield_stock_changed)
968 && action_selection_target_city() == pcity->id) {
972 city_tile(pcity)->index,
975 }
976
979 || (city_is_new && 0 < city_num_trade_routes(pcity)))) {
981 }
982}
983
984/************************************************************************/
988{
989 struct city *pcity = game_city_by_number(packet->id);
990
991 /* The nationality of the citizens. */
992 if (pcity != NULL && game.info.citizen_nationality) {
993 int i;
994
995 citizens_init(pcity);
996 for (i = 0; i < packet->nationalities_count; i++) {
998 packet->nation_citizens[i]);
999 }
1000 fc_assert(citizens_count(pcity) == city_size_get(pcity));
1001 }
1002}
1003
1004/************************************************************************/
1008{
1009 struct city *pcity = game_city_by_number(packet->id);
1010
1011 if (pcity != NULL) {
1012 city_rally_point_receive(packet, pcity);
1013 }
1014}
1015
1016/************************************************************************/
1021static void city_packet_common(struct city *pcity, struct tile *pcenter,
1022 struct player *powner,
1023 struct tile_list *worked_tiles,
1024 bool is_new, bool popup, bool investigate)
1025{
1026 if (NULL != worked_tiles) {
1027 /* We need to transfer the worked infos because the server will assume
1028 * those infos are kept in our side and won't send to us again. */
1029 tile_list_iterate(worked_tiles, pwork) {
1030 tile_set_worked(pwork, pcity);
1032 tile_list_destroy(worked_tiles);
1033 }
1034
1035 if (is_new) {
1036 tile_set_worked(pcenter, pcity); /* is_free_worked() */
1037 city_list_prepend(powner->cities, pcity);
1038
1039 if (client_is_global_observer() || powner == client_player()) {
1041 }
1042
1044 unit_list_iterate(pp->units, punit) {
1045 if (punit->homecity == pcity->id) {
1047 }
1050
1052 } else {
1053 if (client_is_global_observer() || powner == client_player()) {
1055 }
1056 }
1057
1058 if (can_client_change_view()) {
1060 }
1061
1062 if (city_workers_display == pcity) {
1064 }
1065
1066 if (investigate) {
1067 /* Commit the collected supported and present units. */
1069 /* We got units, let's move the unit lists. */
1071
1073 pcity->client.info_units_present =
1076
1081 } else {
1082 /* We didn't get any unit, let's clear the unit lists. */
1084
1087 }
1088 }
1089
1090 if (popup
1091 && NULL != client.conn.playing
1094 menus_update();
1095 if (!city_dialog_is_open(pcity)) {
1096 popup_city_dialog(pcity);
1097 }
1098 }
1099
1100 if (!is_new
1102 refresh_city_dialog(pcity);
1103 }
1104
1105 /* update menus if the focus unit is on the tile. */
1107 menus_update();
1108 }
1109
1110 if (is_new) {
1111 log_debug("(%d,%d) creating city %d, %s %s", TILE_XY(pcenter),
1112 pcity->id, nation_rule_name(nation_of_city(pcity)),
1113 city_name_get(pcity));
1114 }
1115
1117}
1118
1119/************************************************************************/
1124{
1125 struct city *pcity = game_city_by_number(packet->city);
1126 struct trade_route *proute;
1127 bool city_changed = FALSE;
1128
1129 if (pcity == NULL) {
1130 return;
1131 }
1132
1133 proute = trade_route_list_get(pcity->routes, packet->index);
1134 if (proute == NULL) {
1135 fc_assert(trade_route_list_size(pcity->routes) == packet->index);
1136
1137 proute = fc_malloc(sizeof(struct trade_route));
1140 }
1141
1142 proute->partner = packet->partner;
1143 proute->value = packet->value;
1144 proute->dir = packet->direction;
1145 proute->goods = goods_by_number(packet->goods);
1146
1150 }
1151}
1152
1153/************************************************************************/
1159{
1161 bool city_is_new = FALSE;
1162 bool name_changed = FALSE;
1164 struct city *pcity = game_city_by_number(packet->id);
1165 struct tile *pcenter = index_to_tile(&(wld.map), packet->tile);
1166 struct tile *ptile = NULL;
1167 struct tile_list *worked_tiles = NULL;
1168 struct player *powner = player_by_number(packet->owner);
1169 struct player *original = player_by_number(packet->original);
1170 int radius_sq = game.info.init_city_radius_sq;
1171
1172 fc_assert_ret_msg(NULL != powner, "Bad player number %d.", packet->owner);
1173 fc_assert_ret_msg(NULL != pcenter, "Invalid tile index %d.", packet->tile);
1174
1175 if (NULL != pcity) {
1176 ptile = city_tile(pcity);
1177
1178 if (NULL == ptile) {
1179 /* Invisible worked city */
1180 city_list_remove(invisible.cities, pcity);
1181 city_is_new = TRUE;
1182
1183 pcity->tile = pcenter;
1184 pcity->owner = powner;
1185 pcity->original = original;
1186
1188 if (wtile->worked == pcity) {
1190
1191 if (dist_sq > city_map_radius_sq_get(pcity)) {
1193 }
1194 }
1196 } else if (city_owner(pcity) != powner) {
1197 /* Remember what were the worked tiles. The server won't
1198 * send to us again. */
1200 pworked, _index, _x, _y) {
1201 if (pcity == tile_worked(pworked)) {
1202 if (NULL == worked_tiles) {
1203 worked_tiles = tile_list_new();
1204 }
1205 tile_list_append(worked_tiles, pworked);
1206 }
1208 radius_sq = city_map_radius_sq_get(pcity);
1209 client_remove_city(pcity);
1210 pcity = NULL;
1212 }
1213 }
1214
1215 if (NULL == pcity) {
1216 city_is_new = TRUE;
1217 pcity = create_city_virtual(powner, pcenter, packet->name);
1218 pcity->id = packet->id;
1219 pcity->original = original;
1220 city_map_radius_sq_set(pcity, radius_sq);
1221 idex_register_city(&wld, pcity);
1222 } else if (pcity->id != packet->id) {
1223 log_error("handle_city_short_info() city id %d != id %d.",
1224 pcity->id, packet->id);
1225 return;
1226 } else if (city_tile(pcity) != pcenter) {
1227 log_error("handle_city_short_info() city tile (%d, %d) != (%d, %d).",
1228 TILE_XY(city_tile(pcity)), TILE_XY(pcenter));
1229 return;
1230 } else {
1231 name_changed = (fc_strncmp(packet->name, pcity->name, MAX_LEN_CITYNAME));
1232
1233 /* Check if city descriptions should be updated */
1236 }
1237
1238 city_name_set(pcity, packet->name);
1239
1240 memset(pcity->feel, 0, sizeof(pcity->feel));
1241 memset(pcity->specialists, 0, sizeof(pcity->specialists));
1242 }
1243
1244 pcity->specialists[DEFAULT_SPECIALIST] = packet->size;
1245 city_size_set(pcity, packet->size);
1246
1247 /* We can't actually see the internals of the city, but the server tells
1248 * us this much. */
1249 if (pcity->client.occupied != packet->occupied) {
1250 pcity->client.occupied = packet->occupied;
1253 }
1254 }
1255 pcity->client.walls = packet->walls;
1256 if (pcity->client.walls > NUM_WALL_TYPES) {
1257 pcity->client.walls = NUM_WALL_TYPES;
1258 }
1259 pcity->style = packet->style;
1260 pcity->capital = packet->capital;
1261 if (packet->capital == CAPITAL_PRIMARY) {
1262 powner->primary_capital_id = pcity->id;
1263 } else if (powner->primary_capital_id == pcity->id) {
1264 powner->primary_capital_id = 0;
1265 }
1266 pcity->client.city_image = packet->city_image;
1267
1268 pcity->client.happy = packet->happy;
1269 pcity->client.unhappy = packet->unhappy;
1270
1271 improvement_iterate(pimprove) {
1272 /* Don't update the non-visible improvements, they could hide the
1273 * previously seen information about the city (diplomat investigation).
1274 */
1275 if (is_improvement_visible(pimprove)) {
1276 bool have = BV_ISSET(packet->improvements,
1277 improvement_index(pimprove));
1278 update_improvement_from_packet(pcity, pimprove, have);
1279 }
1281
1282 city_packet_common(pcity, pcenter, powner, worked_tiles,
1284
1286 agents_city_new(pcity);
1287 } else {
1288 agents_city_changed(pcity);
1289 }
1290
1291 /* Update the description if necessary. */
1292 if (update_descriptions) {
1294 }
1295}
1296
1297/************************************************************************/
1300void handle_worker_task(const struct packet_worker_task *packet)
1301{
1302 struct city *pcity = game_city_by_number(packet->city_id);
1303 struct worker_task *ptask = NULL;
1304
1305 if (pcity == NULL
1306 || (pcity->owner != client.conn.playing && !client_is_global_observer())) {
1307 return;
1308 }
1309
1311 if (tile_index(ptask_old->ptile) == packet->tile_id) {
1312 ptask = ptask_old;
1313 break;
1314 }
1316
1317 if (ptask == NULL) {
1318 if (packet->activity == ACTIVITY_LAST) {
1319 return;
1320 } else {
1321 ptask = fc_malloc(sizeof(struct worker_task));
1323 }
1324 } else {
1325 if (packet->activity == ACTIVITY_LAST) {
1327 free(ptask);
1328 ptask = NULL;
1329 }
1330 }
1331
1332 if (ptask != NULL) {
1333 ptask->ptile = index_to_tile(&(wld.map), packet->tile_id);
1334 ptask->act = packet->activity;
1335 if (packet->tgt >= 0) {
1336 ptask->tgt = extra_by_number(packet->tgt);
1337 } else {
1338 ptask->tgt = NULL;
1339 }
1340 ptask->want = packet->want;
1341 }
1342
1343 if (ptask && !worker_task_is_sane(ptask)) {
1344 log_debug("Bad worker task");
1346 free(ptask);
1347 ptask = NULL;
1348 return;
1349 }
1350
1351 refresh_city_dialog(pcity);
1352}
1353
1354/************************************************************************/
1357void handle_new_year(int year, int fragments, int turn)
1358{
1359 game.info.year = year;
1360 game.info.fragment_count = fragments;
1361 /*
1362 * The turn was increased in handle_end_turn()
1363 */
1364 fc_assert(game.info.turn == turn);
1366
1369
1371 menus_update();
1372
1374
1375#if 0
1376 /* This information shouldn't be needed, but if it is this is the only
1377 * way we can get it. */
1378 if (NULL != client.conn.playing) {
1382 }
1383#endif
1384
1387
1390 _("Start of turn %d"), game.info.turn);
1391 }
1392
1394
1395 if (last_turn != turn) {
1396 start_turn();
1397 last_turn = turn;
1398 }
1399}
1400
1401/************************************************************************/
1407{
1408 /* Messagewindow will contain events happened since our own phase ended,
1409 * so player of the first phase and last phase are in equal situation. */
1411}
1412
1413/************************************************************************/
1417void handle_start_phase(int phase)
1418{
1420 /* We are on detached state, let ignore this packet. */
1421 return;
1422 }
1423
1424 if (phase < 0
1426 && phase >= player_count())
1428 && phase >= team_count())) {
1429 log_error("handle_start_phase() illegal phase %d.", phase);
1430 return;
1431 }
1432
1434
1435 game.info.phase = phase;
1436
1437 /* Possibly replace wait cursor with something else */
1438 if (phase == 0) {
1439 /* TODO: Have server set as busy also if switching phase
1440 * is taking long in a alternating phases mode. */
1442 }
1443
1444 if (NULL != client.conn.playing
1445 && is_player_phase(client.conn.playing, phase)) {
1448
1450
1454 }
1455
1457
1459 pcity->client.colored = FALSE;
1461
1465
1467 }
1468
1470}
1471
1472/************************************************************************/
1477{
1478 log_debug("handle_begin_turn()");
1479
1480 /* Server is still considered busy until it handles also the beginning
1481 * of the first phase. */
1482
1484}
1485
1486/************************************************************************/
1491{
1492 log_debug("handle_end_turn()");
1493
1494 /* Make sure wait cursor is in use */
1496
1498
1499 /*
1500 * The local idea of the game.info.turn is increased here since the
1501 * client will get unit updates (reset of move points for example)
1502 * between handle_end_turn() and handle_new_year(). These
1503 * unit updates will look like they did take place in the old turn
1504 * which is incorrect. If we get the authoritative information about
1505 * the game.info.turn in handle_new_year() we will check it.
1506 */
1507 game.info.turn++;
1508
1509 log_verbose(_("Beginning turn %d"), game.info.turn);
1510
1512}
1513
1514/************************************************************************/
1518{
1519 const char *sound_tag = get_event_tag(type);
1520
1521 if (sound_tag) {
1522 audio_play_sound(sound_tag, NULL, NULL);
1523 }
1524}
1525
1526/************************************************************************/
1530void handle_chat_msg(const struct packet_chat_msg *packet)
1531{
1532 handle_event(packet->message,
1533 index_to_tile(&(wld.map), packet->tile),
1534 packet->event,
1535 packet->turn,
1536 packet->phase,
1537 packet->conn_id);
1538}
1539
1540/************************************************************************/
1551{
1552 handle_event(packet->message,
1553 index_to_tile(&(wld.map), packet->tile),
1554 packet->event,
1555 packet->turn,
1556 packet->phase,
1557 packet->conn_id);
1558}
1559
1560/************************************************************************/
1565{
1566 popup_connect_msg(_("Welcome"), message);
1567}
1568
1569/************************************************************************/
1573void handle_server_info(const char *version_label, int major_version,
1574 int minor_version, int patch_version, int emerg_version)
1575{
1576 if (emerg_version > 0) {
1577 log_verbose("Server has version %d.%d.%d.%d%s",
1578 major_version, minor_version, patch_version, emerg_version,
1579 version_label);
1580 } else {
1581 log_verbose("Server has version %d.%d.%d%s",
1582 major_version, minor_version, patch_version, version_label);
1583 }
1584}
1585
1586/************************************************************************/
1589void handle_page_msg(const char *caption, const char *headline,
1590 enum event_type event, int len, int parts)
1591{
1592 if (!client_has_player()
1594 || event != E_BROADCAST_REPORT) {
1595 if (page_msg_report.parts > 0) {
1596 /* Previous one was never finished */
1597 free(page_msg_report.caption);
1598 free(page_msg_report.headline);
1599 free(page_msg_report.lines);
1600 }
1601 page_msg_report.len = len;
1602 page_msg_report.event = event;
1605 page_msg_report.parts = parts;
1606 page_msg_report.lines = fc_malloc(len + 1);
1607 page_msg_report.lines[0] = '\0';
1608
1609 if (parts == 0) {
1610 /* Empty report - handle as if last part was just received. */
1611 page_msg_report.parts = 1;
1613 }
1614 }
1615}
1616
1617/************************************************************************/
1621{
1622 if (page_msg_report.lines != NULL) {
1623 /* We have already decided to show the message at the time we got
1624 * the header packet. */
1626 page_msg_report.parts--;
1627
1628 if (page_msg_report.parts == 0) {
1629 /* This is the final part */
1631 page_msg_report.headline,
1632 page_msg_report.lines);
1634
1635 free(page_msg_report.caption);
1636 free(page_msg_report.headline);
1637 free(page_msg_report.lines);
1638 page_msg_report.lines = NULL;
1639 }
1640 }
1641}
1642
1643/************************************************************************/
1646void handle_unit_info(const struct packet_unit_info *packet)
1647{
1648 struct unit *punit;
1649
1650 punit = unpackage_unit(packet);
1654 }
1655}
1656
1657/**********************************************************************/
1663{
1666 if (utype_can_do_action(unit_type_get(punit), act_id)) {
1667 /* An auto action like auto attack could be legal. Check for those
1668 * at once so they won't have to wait for player focus. */
1670 punit->id,
1673 EXTRA_NONE,
1675 return;
1676 }
1678 }
1679
1680 /* This should be done in the foreground */
1682}
1683
1684/************************************************************************/
1701{
1702 struct city *pcity;
1703 struct unit *punit;
1704 bool need_menus_update = FALSE;
1707 bool repaint_unit = FALSE;
1708 bool repaint_city = FALSE; /* regards unit's homecity */
1709 struct tile *old_tile = NULL;
1710 bool check_focus = FALSE; /* conservative focus change */
1711 bool moved = FALSE;
1712 bool ret = FALSE;
1713
1715 if (!punit && game_unit_by_number(packet_unit->id)) {
1716 /* This means unit has changed owner. We deal with this here
1717 * by simply deleting the old one and creating a new one. */
1719 }
1720
1721 if (punit) {
1722 /* In some situations, the size of repaint units require can change;
1723 * in particular, city-builder units sometimes get a potential-city
1724 * outline, but to speed up redraws we don't repaint this whole area
1725 * unnecessarily. We need to ensure that when the footprint shrinks,
1726 * old bits aren't left behind on the canvas.
1727 * If the current (old) status of the unit is such that it gets a large
1728 * repaint, as a special case, queue a large repaint immediately, to
1729 * schedule the correct amount/location to be redrawn; but rely on the
1730 * repaint being deferred until the unit is updated, so that what's
1731 * drawn reflects the new status (e.g., no city outline). */
1734 }
1735
1736 ret = TRUE;
1737 punit->activity_count = packet_unit->activity_count;
1739 if (punit->ssa_controller != packet_unit->ssa_controller) {
1740 punit->ssa_controller = packet_unit->ssa_controller;
1742 /* AI is set: may change focus */
1743 /* AI is cleared: keep focus */
1744 if (packet_unit->ssa_controller != SSA_NONE
1745 && unit_is_in_focus(punit)) {
1746 check_focus = TRUE;
1747 }
1748 }
1749
1750 if (punit->facing != packet_unit->facing) {
1751 punit->facing = packet_unit->facing;
1753 }
1754
1755 if (punit->activity != packet_unit->activity
1756 || punit->activity_target == packet_unit->activity_target
1757 || punit->client.transported_by != packet_unit->client.transported_by
1758 || punit->client.occupied != packet_unit->client.occupied
1759 || punit->has_orders != packet_unit->has_orders
1760 || punit->orders.repeat != packet_unit->orders.repeat
1761 || punit->orders.vigilant != packet_unit->orders.vigilant
1762 || punit->orders.index != packet_unit->orders.index) {
1763
1764 /*** Change in activity or activity's target. ***/
1765
1766 /* May change focus if focus unit gets a new activity.
1767 * But if new activity is Idle, it means user specifically selected
1768 * the unit */
1770 && (packet_unit->activity != ACTIVITY_IDLE
1771 || packet_unit->has_orders)) {
1772 check_focus = TRUE;
1773 }
1774
1776
1777 /* Wakeup Focus */
1779 && NULL != client.conn.playing
1783 && packet_unit->activity == ACTIVITY_IDLE
1786 /* many wakeup units per tile are handled */
1788 check_focus = FALSE; /* and keep it */
1789 }
1790
1791 punit->activity = packet_unit->activity;
1792 punit->activity_target = packet_unit->activity_target;
1793
1795 != packet_unit->client.transported_by) {
1796 if (packet_unit->client.transported_by == -1) {
1797 /* The unit was unloaded from its transport. The check for a new
1798 * transport is done below. */
1800 }
1801
1802 punit->client.transported_by = packet_unit->client.transported_by;
1803 }
1804
1805 if (punit->client.occupied != packet_unit->client.occupied) {
1807 /* Special case: (un)loading a unit in a transporter on the same
1808 *tile as the focus unit may (dis)allow the focus unit to be
1809 * loaded. Thus the orders->(un)load menu item needs updating. */
1811 }
1812 punit->client.occupied = packet_unit->client.occupied;
1813 }
1814
1815 punit->has_orders = packet_unit->has_orders;
1816 punit->orders.length = packet_unit->orders.length;
1817 punit->orders.index = packet_unit->orders.index;
1818 punit->orders.repeat = packet_unit->orders.repeat;
1819 punit->orders.vigilant = packet_unit->orders.vigilant;
1820
1821 /* We cheat by just stealing the packet unit's list. */
1822 if (punit->orders.list) {
1824 }
1825 punit->orders.list = packet_unit->orders.list;
1826 packet_unit->orders.list = NULL;
1827
1828 if (NULL == client.conn.playing
1831 }
1832 } /*** End of Change in activity or activity's target. ***/
1833
1834 /* These two lines force the menus to be updated as appropriate when
1835 * the focus unit changes. */
1836 if (unit_is_in_focus(punit)) {
1838 }
1839
1840 if (punit->homecity != packet_unit->homecity) {
1841 /* change homecity */
1842 struct city *hcity;
1843
1845 unit_list_remove(hcity->units_supported, punit);
1847 }
1848
1849 punit->homecity = packet_unit->homecity;
1851 unit_list_prepend(hcity->units_supported, punit);
1853 }
1854
1855 /* This can change total upkeep figures */
1857 }
1858
1859 if (punit->hp != packet_unit->hp) {
1860 /* hp changed */
1861 punit->hp = packet_unit->hp;
1863 }
1864
1866 /* Unit type has changed (been upgraded) */
1867 struct city *ccity = tile_city(unit_tile(punit));
1868
1872 if (ccity != NULL && (ccity->id != punit->homecity)) {
1874 }
1875 if (unit_is_in_focus(punit)) {
1876 /* Update the orders menu -- the unit might have new abilities */
1878 }
1880 }
1881
1882 /* May change focus if an attempted move or attack exhausted unit */
1883 if (punit->moves_left != packet_unit->moves_left
1884 && unit_is_in_focus(punit)) {
1885 check_focus = TRUE;
1886 }
1887
1889 /*** Change position ***/
1890 struct city *ccity = tile_city(unit_tile(punit));
1891
1893 moved = TRUE;
1894
1895 /* Show where the unit is going. */
1897
1898 if (ccity != NULL) {
1900 /* Unit moved out of a city - update the occupied status. */
1901 bool new_occupied =
1902 (unit_list_size(ccity->tile->units) > 0);
1903
1904 if (ccity->client.occupied != new_occupied) {
1905 ccity->client.occupied = new_occupied;
1909 }
1910 }
1911 }
1912
1913 if (ccity->id == punit->homecity) {
1915 } else {
1917 }
1918 }
1919
1920 if ((ccity = tile_city(unit_tile(punit)))) {
1922 /* Unit moved into a city - obviously it's occupied. */
1923 if (!ccity->client.occupied) {
1924 ccity->client.occupied = TRUE;
1928 }
1929 }
1930 }
1931
1932 if (ccity->id == punit->homecity) {
1934 } else {
1936 }
1937 }
1938
1939 } /*** End of Change position. ***/
1940
1941 if (repaint_city || repaint_unit) {
1942 /* We repaint the city if the unit itself needs repainting or if
1943 * there is a special city-only redrawing to be done. */
1944 if ((pcity = game_city_by_number(punit->homecity))) {
1945 refresh_city_dialog(pcity);
1946 }
1948 && tile_city(unit_tile(punit)) != pcity) {
1949 /* Refresh the city we're occupying too. */
1951 }
1952 }
1953
1955 != packet_unit->upkeep[O_GOLD]);
1956 /* unit upkeep information */
1958 punit->upkeep[o] = packet_unit->upkeep[o];
1960
1961 punit->nationality = packet_unit->nationality;
1962 punit->veteran = packet_unit->veteran;
1963 punit->moves_left = packet_unit->moves_left;
1964 punit->fuel = packet_unit->fuel;
1965 punit->goto_tile = packet_unit->goto_tile;
1966 punit->paradropped = packet_unit->paradropped;
1967 punit->stay = packet_unit->stay;
1968 if (punit->done_moving != packet_unit->done_moving) {
1969 punit->done_moving = packet_unit->done_moving;
1970 check_focus = TRUE;
1971 }
1972 punit->carrying = packet_unit->carrying;
1973
1974 /* This won't change punit; it enqueues the call for later handling. */
1977
1978 if ((punit->action_decision_want != packet_unit->action_decision_want
1980 != packet_unit->action_decision_tile))
1982 /* The unit wants the player to decide. */
1984 /* Pop up an action selection dialog if the unit has focus or give
1985 * the unit higher priority in the focus queue if not. */
1986 punit->action_decision_tile = packet_unit->action_decision_tile;
1988 check_focus = TRUE;
1989 } else {
1990 /* Refresh already open action selection dialog. */
1994 tile_index(
1995 packet_unit->action_decision_tile),
1998 }
1999 }
2000 punit->action_decision_want = packet_unit->action_decision_want;
2001 punit->action_decision_tile = packet_unit->action_decision_tile;
2002 } else {
2003 /*** Create new unit ***/
2006
2009
2011
2012 if ((pcity = game_city_by_number(punit->homecity))) {
2014 }
2015
2016 log_debug("New %s %s id %d (%d %d) hc %d %s",
2020 (pcity ? city_name_get(pcity) : "(unknown)"));
2021
2024
2025 /* Check if we should link cargo units.
2026 * (This might be necessary if the cargo info was sent to us before
2027 * this transporter.) */
2028 if (punit->client.occupied) {
2030 if (aunit->client.transported_by == punit->id) {
2031 fc_assert(aunit->transporter == NULL);
2033 }
2035 }
2036
2037 if ((pcity = tile_city(unit_tile(punit)))) {
2038 /* The unit is in a city - obviously it's occupied. */
2039 pcity->client.occupied = TRUE;
2040 }
2041
2043 /* The unit wants the player to decide. */
2045 check_focus = TRUE;
2046 }
2047
2049 } /*** End of Create new unit ***/
2050
2052
2053 /* Check if we have to load the unit on a transporter. */
2054 if (punit->client.transported_by != -1) {
2055 struct unit *ptrans
2056 = game_unit_by_number(packet_unit->client.transported_by);
2057
2058 /* Load unit only if transporter is known by the client.
2059 * (If not, cargo will be loaded later when the transporter info is
2060 * sent to the client.) */
2062 /* First, we have to unload the unit from its old transporter. */
2065#ifdef DEBUG_TRANSPORT
2066 log_debug("load %s (ID: %d) onto %s (ID: %d)",
2069 } else if (ptrans && ptrans == unit_transport_get(punit)) {
2070 log_debug("%s (ID: %d) is loaded onto %s (ID: %d)",
2073 } else {
2074 log_debug("%s (ID: %d) is not loaded", unit_name_translation(punit),
2075 punit->id);
2076#endif /* DEBUG_TRANSPORT */
2077 }
2078 }
2079
2084 /* Update (an possible active) unit select dialog. */
2086 }
2087
2088 if (repaint_unit) {
2090 }
2091
2092 if ((check_focus || get_num_units_in_focus() == 0)
2093 && NULL != client.conn.playing
2097 }
2098
2099 if (need_menus_update) {
2100 menus_update();
2101 }
2102
2106 }
2109 }
2110 }
2111
2112 return ret;
2113}
2114
2115/************************************************************************/
2122{
2123 struct city *pcity = game_city_by_number(packet->city_id);
2124
2125 if (!pcity) {
2126 log_error("Investigate city: unknown city id %d!",
2127 packet->city_id);
2128 return;
2129 }
2130
2131 /* Start collecting supported and present units. */
2132
2133 /* Ensure we are not already in an investigate cycle. */
2140}
2141
2142/************************************************************************/
2146{
2147}
2148
2149/************************************************************************/
2153{
2154 struct city *pcity;
2155 struct unit *punit;
2156
2157 /* Special case for a diplomat/spy investigating a city: The investigator
2158 * needs to know the supported and present units of a city, whether or not
2159 * they are fogged. So, we send a list of them all before sending the city
2160 * info. */
2162 || packet->packet_use == UNIT_INFO_CITY_PRESENT) {
2163
2164 pcity = game_city_by_number(packet->info_city_id);
2165 if (!pcity) {
2166 log_error("Investigate city: unknown city id %d!",
2167 packet->info_city_id);
2168 return;
2169 }
2170
2171 /* Append a unit struct to the proper list. */
2172 punit = unpackage_short_unit(packet);
2173 if (packet->packet_use == UNIT_INFO_CITY_SUPPORTED) {
2176 } else {
2180 }
2181
2182 /* Done with special case. */
2183 return;
2184 }
2185
2186 if (player_by_number(packet->owner) == client.conn.playing) {
2187 log_error("handle_unit_short_info() for own unit.");
2188 }
2189
2190 punit = unpackage_short_unit(packet);
2194 }
2195}
2196
2197/************************************************************************/
2200void handle_set_topology(int topology_id, int wrap_id)
2201{
2202 wld.map.topology_id = topology_id;
2203 wld.map.wrap_id = wrap_id;
2204
2205 if (forced_tileset_name[0] == '\0'
2206 && (tileset_map_topo_compatible(topology_id, tileset, NULL)
2209 const char *ts_to_load;
2210
2212
2213 if (ts_to_load != NULL && ts_to_load[0] != '\0' && strcmp(tileset_basename(tileset), ts_to_load)) {
2215 }
2216 }
2217}
2218
2219/************************************************************************/
2223void handle_map_info(const struct packet_map_info *packet)
2224{
2225 int ts_topo;
2226
2227 if (!map_is_empty()) {
2228 map_free(&(wld.map));
2230 }
2231
2232 wld.map.xsize = packet->xsize;
2233 wld.map.ysize = packet->ysize;
2234
2237
2240 _("Map topology (%s) and tileset (%s) incompatible."),
2242 }
2243
2244 wld.map.topology_id = packet->topology_id;
2245 wld.map.wrap_id = packet->wrap_id;
2246
2251 mapdeco_init();
2252
2254
2256
2257 packhand_init();
2258}
2259
2260/************************************************************************/
2264{
2265 bool boot_help;
2267 bool toggle_edit_ui = FALSE;
2268
2269 if (game.info.aifill != pinfo->aifill) {
2271 }
2272 if (game.info.skill_level != pinfo->skill_level) {
2274 }
2275
2276 if (game.info.is_edit_mode != pinfo->is_edit_mode) {
2278
2280 /* Clears the current goto command. */
2282
2283 if (pinfo->is_edit_mode) {
2285 /* Gui didn't handle this */
2287 _("This scenario may have manually set properties the editor "
2288 "cannot handle."));
2290 _("They won't be saved when scenario is saved from the editor."));
2291 }
2292 }
2293 }
2294
2295 game.info = *pinfo;
2296
2297 /* check the values! */
2298#define VALIDATE(_count, _maximum, _string) \
2299 if (game.info._count > _maximum) { \
2300 log_error("handle_game_info(): Too many " _string "; using %d of %d", \
2301 _maximum, game.info._count); \
2302 game.info._count = _maximum; \
2303 }
2304
2305 VALIDATE(granary_num_inis, MAX_GRANARY_INIS, "granary entries");
2306#undef VALIDATE
2307
2312
2314 && game.info.victory_conditions != pinfo->victory_conditions);
2315 if (boot_help) {
2316 boot_help_texts(); /* reboot, after setting game.spacerace */
2317 }
2319 menus_update();
2323 }
2324
2325 if (can_client_change_view()) {
2327 }
2328
2329 if (toggle_edit_ui) {
2331 }
2332
2334}
2335
2336/************************************************************************/
2343
2344/************************************************************************/
2347void handle_timeout_info(float seconds_to_phasedone, float last_turn_change_time)
2348{
2349 if (current_turn_timeout() != 0 && seconds_to_phasedone >= 0) {
2350 /* If this packet is received in the middle of a turn, this value
2351 * represents the number of seconds from now to the end of the turn
2352 * (not from the start of the turn). So we need to restart our
2353 * timer. */
2354 set_seconds_to_turndone(seconds_to_phasedone);
2355 }
2356
2357 game.tinfo.last_turn_change_time = last_turn_change_time;
2358}
2359
2360/************************************************************************/
2372
2373/************************************************************************/
2382
2383/************************************************************************/
2388void handle_player_remove(int playerno)
2389{
2390 struct player_slot *pslot;
2391 struct player *pplayer;
2392 int plr_nbr;
2393
2394 pslot = player_slot_by_number(playerno);
2395
2396 if (NULL == pslot || !player_slot_is_used(pslot)) {
2397 /* Ok, just ignore. */
2398 return;
2399 }
2400
2401 pplayer = player_slot_get_player(pslot);
2402
2403 if (can_client_change_view()) {
2404 close_intel_dialog(pplayer);
2405 }
2406
2407 /* Update the connection information. */
2408 if (client_player() == pplayer) {
2410 }
2412 pconn->playing = NULL;
2414 conn_list_clear(pplayer->connections);
2415
2416 /* Save player number before player is freed */
2417 plr_nbr = player_number(pplayer);
2418
2419 player_destroy(pplayer);
2420
2423
2426}
2427
2428/************************************************************************/
2434{
2435 bool is_new_nation = FALSE;
2436 bool turn_done_changed = FALSE;
2437 bool new_player = FALSE;
2438 int i;
2439 struct player *pplayer, *my_player;
2440 struct nation_type *pnation;
2441 struct government *pgov, *ptarget_gov;
2442 struct player_slot *pslot;
2443 struct team_slot *tslot;
2444 bool gov_change;
2445
2446 /* Player. */
2447 pslot = player_slot_by_number(pinfo->playerno);
2448 fc_assert(NULL != pslot);
2450 pplayer = player_new(pslot);
2451
2452 if ((pplayer->rgb == NULL) != !pinfo->color_valid
2453 || (pinfo->color_valid
2454 && (pplayer->rgb->r != pinfo->color_red
2455 || pplayer->rgb->g != pinfo->color_green
2456 || pplayer->rgb->b != pinfo->color_blue))) {
2457 struct rgbcolor *prgbcolor;
2458
2459 if (pinfo->color_valid) {
2460 prgbcolor = rgbcolor_new(pinfo->color_red,
2461 pinfo->color_green,
2462 pinfo->color_blue);
2464 } else {
2465 prgbcolor = NULL;
2466 }
2467
2468 player_set_color(pplayer, prgbcolor);
2469 tileset_player_init(tileset, pplayer);
2470
2472
2473 /* Queue a map update -- may need to redraw borders, etc. */
2475 }
2476 pplayer->client.color_changeable = pinfo->color_changeable;
2477
2478 if (new_player) {
2479 /* Initialise client side player data (tile vision). At the moment
2480 * redundant as the values are initialised with 0 due to fc_calloc(). */
2481 client_player_init(pplayer);
2482 }
2483
2484 /* Team. */
2486 fc_assert(NULL != tslot);
2487
2488 /* Should never fail when slot given is not NULL */
2489 team_add_player(pplayer, team_new(tslot));
2490
2491 pnation = nation_by_number(pinfo->nation);
2492 pgov = government_by_number(pinfo->government);
2493 ptarget_gov = government_by_number(pinfo->target_government);
2494
2495 /* Now update the player information. */
2496 sz_strlcpy(pplayer->name, pinfo->name);
2497 sz_strlcpy(pplayer->username, pinfo->username);
2498 pplayer->unassigned_user = pinfo->unassigned_user;
2499
2500 is_new_nation = player_set_nation(pplayer, pnation);
2501 pplayer->is_male = pinfo->is_male;
2502 pplayer->score.game = pinfo->score;
2503 pplayer->was_created = pinfo->was_created;
2504
2505 pplayer->autoselect_weight = pinfo->autoselect_weight;
2506 pplayer->economic.gold = pinfo->gold;
2507 pplayer->economic.tax = pinfo->tax;
2508 pplayer->economic.science = pinfo->science;
2509 pplayer->economic.luxury = pinfo->luxury;
2510 if (has_capability("tu32", client.conn.capability)) {
2511 pplayer->client.tech_upkeep = pinfo->tech_upkeep_32;
2512 } else {
2513 pplayer->client.tech_upkeep = pinfo->tech_upkeep_16;
2514 }
2515 gov_change = (!new_player && pgov != pplayer->government
2516 && pplayer->government != NULL);
2517 pplayer->government = pgov;
2518 pplayer->target_government = ptarget_gov;
2519 pplayer->real_embassy = pinfo->real_embassy;
2520 pplayer->gives_shared_vision = pinfo->gives_shared_vision;
2521 pplayer->gives_shared_tiles = pinfo->gives_shared_tiles;
2522 pplayer->style = style_by_number(pinfo->style);
2523
2524 if (pplayer == client.conn.playing) {
2525 bool music_change = FALSE;
2526
2527 if (pplayer->music_style != pinfo->music_style) {
2528 pplayer->music_style = pinfo->music_style;
2530 }
2531 if (pplayer->client.mood != pinfo->mood) {
2532 pplayer->client.mood = pinfo->mood;
2534 }
2535
2536 if (music_change) {
2538 }
2539
2540 if (gov_change) {
2541 audio_play_sound(pgov->sound_str, pgov->sound_alt, pgov->sound_alt2);
2542 }
2543 }
2544
2545 pplayer->history = pinfo->history;
2546 pplayer->client.culture = pinfo->culture;
2547
2548 if (pplayer->economic.infra_points != pinfo->infrapoints) {
2549 pplayer->economic.infra_points = pinfo->infrapoints;
2551 }
2552
2553 /* Don't use player_iterate or player_slot_count here, because we ignore
2554 * the real number of players and we want to read all the datas. */
2555 fc_assert(ARRAY_SIZE(pplayer->ai_common.love) >= ARRAY_SIZE(pinfo->love));
2556 for (i = 0; i < ARRAY_SIZE(pinfo->love); i++) {
2557 pplayer->ai_common.love[i] = pinfo->love[i];
2558 }
2559
2561
2562 pplayer->is_connected = pinfo->is_connected;
2563
2564 for (i = 0; i < B_LAST; i++) {
2565 pplayer->wonders[i] = pinfo->wonders[i];
2566 }
2567
2568 /* Set AI.control. */
2569 if (is_ai(pplayer) != BV_ISSET(pinfo->flags, PLRF_AI)) {
2570 BV_SET_VAL(pplayer->flags, PLRF_AI, BV_ISSET(pinfo->flags, PLRF_AI));
2571 if (pplayer == my_player) {
2572 if (is_ai(my_player)) {
2573 output_window_append(ftc_client, _("AI mode is now ON."));
2574 if (!gui_options.ai_manual_turn_done && !pplayer->phase_done) {
2575 /* End turn immediately */
2577 }
2578 } else {
2579 output_window_append(ftc_client, _("AI mode is now OFF."));
2580 }
2581 }
2582 }
2583
2584 pplayer->flags = pinfo->flags;
2585
2586 pplayer->ai_common.science_cost = pinfo->science_cost;
2587
2588 turn_done_changed = (pplayer->phase_done != pinfo->phase_done
2589 || (BV_ISSET(pplayer->flags, PLRF_AI) !=
2590 BV_ISSET(pinfo->flags, PLRF_AI)));
2591 pplayer->phase_done = pinfo->phase_done;
2592
2593 pplayer->is_ready = pinfo->is_ready;
2594 pplayer->nturns_idle = pinfo->nturns_idle;
2595 pplayer->is_alive = pinfo->is_alive;
2596 pplayer->turns_alive = pinfo->turns_alive;
2597 pplayer->ai_common.barbarian_type = pinfo->barbarian_type;
2598 pplayer->revolution_finishes = pinfo->revolution_finishes;
2599 pplayer->ai_common.skill_level = pinfo->ai_skill_level;
2600
2601 fc_assert(pinfo->multip_count == multiplier_count());
2602 game.control.num_multipliers = pinfo->multip_count;
2603 multipliers_iterate(pmul) {
2604 int idx = multiplier_index(pmul);
2605
2606 pplayer->multipliers[idx].value = pinfo->multiplier[idx];
2607 pplayer->multipliers[idx].target = pinfo->multiplier_target[idx];
2608 pplayer->multipliers[idx].changed = pinfo->multiplier_changed[idx];
2610
2611 /* if the server requests that the client reset, then information about
2612 * connections to this player are lost. If this is the case, insert the
2613 * correct conn back into the player->connections list */
2614 if (conn_list_size(pplayer->connections) == 0) {
2616 if (pplayer == pconn->playing) {
2617 /* insert the controller into first position */
2618 if (pconn->observer) {
2620 } else {
2622 }
2623 }
2625 }
2626
2627
2628 /* The player information is now fully set. Update the GUI. */
2629
2630 if (pplayer == my_player && can_client_change_view()) {
2631 if (turn_done_changed) {
2633 }
2640 menus_update();
2641 }
2642
2644
2647
2648 if (is_new_nation) {
2650
2651 /* When changing nation during a running game, some refreshing is needed.
2652 * This may not be the only one! */
2654 }
2655
2656 if (can_client_change_view()) {
2657 /* Just about any changes above require an update to the intelligence
2658 * dialog. */
2659 update_intel_dialog(pplayer);
2660 }
2661
2664 FALSE);
2665}
2666
2667/************************************************************************/
2671{
2672 struct research *presearch;
2673 bool tech_changed = FALSE;
2674 bool poptechup = FALSE;
2676 int gained_techs_num = 0, i;
2678
2679#ifdef FREECIV_DEBUG
2680 log_verbose("Research nb %d inventions: %s",
2681 packet->id,
2682 packet->inventions);
2683#endif
2684 presearch = research_by_number(packet->id);
2686
2687 poptechup = (presearch->researching != packet->researching
2688 || presearch->tech_goal != packet->tech_goal);
2689 presearch->techs_researched = packet->techs_researched;
2690 if (presearch->future_tech == 0 && packet->future_tech > 0) {
2692 }
2693 presearch->future_tech = packet->future_tech;
2694 presearch->researching = packet->researching;
2695 presearch->client.researching_cost = packet->researching_cost;
2696 presearch->bulbs_researched = packet->bulbs_researched;
2697 presearch->tech_goal = packet->tech_goal;
2698 presearch->client.total_bulbs_prod = packet->total_bulbs_prod;
2699
2701 newstate = packet->inventions[advi] - '0';
2703
2704 if (newstate != oldstate) {
2705 if (TECH_KNOWN == newstate) {
2707 if (A_NONE != advi) {
2709 }
2710 } else if (TECH_KNOWN == oldstate) {
2712 }
2713 }
2715
2717
2718 if (C_S_RUNNING == client_state()) {
2720 if (poptechup && is_human(client_player())) {
2722 }
2724 if (tech_changed) {
2725 /* Some ways a new or lost tech can affect menus:
2726 * - If tech is needed for certain governments, the government
2727 * switching menus need updating.
2728 * - If we just learned/lost bridge building and focus is on a
2729 * worker on a river, the road menu item needs updating. */
2730 menus_update();
2731
2732 script_client_signal_emit("new_tech");
2733
2734 /* If we got a new tech the tech tree news an update. */
2736 }
2737 for (i = 0; i < gained_techs_num; i++) {
2739 }
2740 }
2741 if (editor_is_active()) {
2745 FALSE);
2747 }
2748 }
2749}
2750
2751/************************************************************************/
2755{
2757
2758 if (presearch == NULL) {
2759 log_error("Received unknown research for clearing: %d.", id);
2760 return;
2761 }
2762
2763 /* Do we need to set other fields? */
2764 presearch->researching = A_UNKNOWN;
2765 presearch->future_tech = 0;
2766 presearch->tech_goal = A_UNKNOWN;
2767
2771
2772 if (editor_is_active()) {
2776 FALSE);
2778 }
2779}
2780
2781/************************************************************************/
2785{
2786 struct player *plr1 = player_by_number(packet->plr1);
2787 struct player *plr2 = player_by_number(packet->plr2);
2788 struct player *my_player = client_player();
2789 struct player_diplstate *ds = player_diplstate_get(plr1, plr2);
2791
2792 fc_assert_ret(ds != NULL);
2793
2794 if (client_has_player() && my_player == plr2) {
2795 if (ds->type != packet->type) {
2797 }
2798
2799 /* Check if we detect change to armistice with us. If so,
2800 * ready all units for movement out of the territory in
2801 * question; otherwise they will be disbanded. */
2803 && DS_ARMISTICE == packet->type) {
2806 || tile_owner(unit_tile(punit)) != plr1) {
2807 continue;
2808 }
2811 }
2812 if (punit->activity != ACTIVITY_IDLE) {
2814 }
2816 }
2817 }
2818
2819 ds->type = packet->type;
2820 ds->turns_left = packet->turns_left;
2821 ds->has_reason_to_cancel = packet->has_reason_to_cancel;
2822 ds->contact_turns_left = packet->contact_turns_left;
2823
2826 }
2827
2830 /* An action selection dialog is open and our diplomatic state just
2831 * changed. Find out if the relationship that changed was to a
2832 * potential target. */
2833 struct tile *tgt_tile = NULL;
2834
2835 /* Is a refresh needed because of a unit target? */
2837 struct unit *tgt_unit;
2838
2840
2841 if (tgt_unit != NULL && tgt_unit->owner == plr1) {
2842 /* An update is needed because of this unit target. */
2845 }
2846 }
2847
2848 /* Is a refresh needed because of a city target? */
2850 struct city *tgt_city;
2851
2853
2854 if (tgt_city != NULL && tgt_city->owner == plr1) {
2855 /* An update is needed because of this city target.
2856 * Overwrites any target tile from a unit. */
2859 }
2860 }
2861
2862 if (tgt_tile
2863 || ((tgt_tile = index_to_tile(&(wld.map),
2865 && tile_owner(tgt_tile) == plr1)) {
2866 /* The diplomatic relationship to the target in an open action
2867 * selection dialog have changed. This probably changes
2868 * the set of available actions. */
2872 tgt_tile->index,
2875 }
2876 }
2877}
2878
2879/************************************************************************/
2886{
2887 struct connection *pconn = conn_by_number(pinfo->id);
2889
2890 log_debug("conn_info id%d used%d est%d plr%d obs%d acc%d",
2891 pinfo->id, pinfo->used, pinfo->established, pinfo->player_num,
2892 pinfo->observer, (int) pinfo->access_level);
2893 log_debug("conn_info \"%s\" \"%s\" \"%s\"",
2894 pinfo->username, pinfo->addr, pinfo->capability);
2895
2896 if (!pinfo->used) {
2897 /* Forget the connection */
2898 if (!pconn) {
2899 log_verbose("Server removed unknown connection %d", pinfo->id);
2900 return;
2901 }
2903 pconn = NULL;
2904 } else {
2905 struct player_slot *pslot = player_slot_by_number(pinfo->player_num);
2906 struct player *pplayer = NULL;
2907
2908 if (NULL != pslot) {
2909 pplayer = player_slot_get_player(pslot);
2910 }
2911
2912 if (!pconn) {
2913 log_verbose("Server reports new connection %d %s",
2914 pinfo->id, pinfo->username);
2915
2916 pconn = fc_calloc(1, sizeof(struct connection));
2917 pconn->buffer = NULL;
2918 pconn->send_buffer = NULL;
2919 pconn->ping_time = -1.0;
2920 if (pplayer) {
2922 }
2925 } else {
2926 log_packet("Server reports updated connection %d %s",
2927 pinfo->id, pinfo->username);
2928 if (pplayer != pconn->playing) {
2929 if (NULL != pconn->playing) {
2930 conn_list_remove(pconn->playing->connections, pconn);
2931 }
2932 if (pplayer) {
2934 }
2935 }
2936 }
2937
2938 pconn->id = pinfo->id;
2939 pconn->established = pinfo->established;
2940 pconn->observer = pinfo->observer;
2941 pconn->access_level = pinfo->access_level;
2942 pconn->playing = pplayer;
2943
2944 sz_strlcpy(pconn->username, pinfo->username);
2945 sz_strlcpy(pconn->addr, pinfo->addr);
2946 sz_strlcpy(pconn->capability, pinfo->capability);
2947
2948 if (pinfo->id == client.conn.id) {
2949 /* NB: In this case, pconn is not a duplication of client.conn.
2950 *
2951 * pconn->addr is our address that the server knows whereas
2952 * client.conn.addr is the address to the server. Also,
2953 * pconn->capability stores our capabilites known at server side
2954 * whereas client.conn.capability represents the capabilities of the
2955 * server. */
2956 if (client.conn.playing != pplayer
2957 || client.conn.observer != pinfo->observer) {
2958 /* Our connection state changed, let prepare the changes and reset
2959 * the game. */
2961 }
2962
2963 /* Copy our current state into the static structure (our connection
2964 * to the server). */
2965 client.conn.established = pinfo->established;
2966 client.conn.observer = pinfo->observer;
2967 client.conn.access_level = pinfo->access_level;
2968 client.conn.playing = pplayer;
2969 sz_strlcpy(client.conn.username, pinfo->username);
2970 }
2971 }
2972
2975
2976 if (pinfo->used && pinfo->id == client.conn.id) {
2977 /* For updating the sensitivity of the "Edit Mode" menu item,
2978 * among other things. */
2979 menus_update();
2980 }
2981
2984 }
2985}
2986
2987/************************************************************************/
2991void handle_conn_ping_info(int connections, const int *conn_id,
2992 const float *ping_time)
2993{
2994 int i;
2995
2996 for (i = 0; i < connections; i++) {
2997 struct connection *pconn = conn_by_number(conn_id[i]);
2998
2999 if (!pconn) {
3000 continue;
3001 }
3002
3003 pconn->ping_time = ping_time[i];
3004 log_debug("conn-id=%d, ping=%fs", pconn->id, pconn->ping_time);
3005 }
3006 /* The old_ping_time data is ignored. */
3007
3009}
3010
3011/************************************************************************/
3014void handle_achievement_info(int id, bool gained, bool first)
3015{
3016 struct achievement *pach;
3017
3019 log_error("Received illegal achievement info %d", id);
3020 return;
3021 }
3022
3024
3025 if (gained) {
3026 BV_SET(pach->achievers, player_index(client_player()));
3027 } else {
3028 BV_CLR(pach->achievers, player_index(client_player()));
3029 }
3030
3031 if (first) {
3032 pach->first = client_player();
3033 }
3034}
3035
3036/************************************************************************/
3051static bool spaceship_autoplace(struct player *pplayer,
3052 struct player_spaceship *ship)
3053{
3056
3057 if (next_spaceship_component(pplayer, ship, &place)) {
3059
3060 return TRUE;
3061 }
3062 }
3063
3064 return FALSE;
3065}
3066
3067/************************************************************************/
3071{
3072 struct player_spaceship *ship;
3073 struct player *pplayer = player_by_number(p->player_num);
3074
3075 fc_assert_ret_msg(NULL != pplayer, "Invalid player number %d.",
3076 p->player_num);
3077
3078 ship = &pplayer->spaceship;
3079 ship->state = p->sship_state;
3080 ship->structurals = p->structurals;
3081 ship->components = p->components;
3082 ship->modules = p->modules;
3083 ship->fuel = p->fuel;
3084 ship->propulsion = p->propulsion;
3085 ship->habitation = p->habitation;
3086 ship->life_support = p->life_support;
3087 ship->solar_panels = p->solar_panels;
3088 ship->launch_year = p->launch_year;
3089 ship->population = p->population;
3090 ship->mass = p->mass;
3091 ship->support_rate = p->support_rate;
3092 ship->energy_rate = p->energy_rate;
3093 ship->success_rate = p->success_rate;
3094 ship->travel_time = p->travel_time;
3095 ship->structure = p->structure;
3096
3097 if (pplayer != client_player()) {
3098 refresh_spaceship_dialog(pplayer);
3099 menus_update();
3100 return;
3101 }
3102
3103 if (!spaceship_autoplace(pplayer, ship)) {
3104 /* We refresh the dialog when the packet did *not* cause placing
3105 * of new part. That's because those cases where part is placed, are
3106 * followed by exactly one case where there's no more parts to place -
3107 * we want to refresh the dialog only when that last packet comes. */
3108 refresh_spaceship_dialog(pplayer);
3109 }
3110}
3111
3112/************************************************************************/
3115void handle_tile_info(const struct packet_tile_info *packet)
3116{
3117 enum known_type new_known;
3118 enum known_type old_known;
3119 bool known_changed = FALSE;
3120 bool tile_changed = FALSE;
3121 struct player *powner = player_by_number(packet->owner);
3122 struct player *eowner = player_by_number(packet->extras_owner);
3123 struct extra_type *presource = NULL;
3124 struct terrain *pterrain = terrain_by_number(packet->terrain);
3125 struct tile *ptile = index_to_tile(&(wld.map), packet->tile);
3126
3127 fc_assert_ret_msg(NULL != ptile, "Invalid tile index %d.", packet->tile);
3129
3130 if (packet->resource != MAX_EXTRA_TYPES) {
3131 presource = extra_by_number(packet->resource);
3132 }
3133
3134 if (NULL == tile_terrain(ptile) || pterrain != tile_terrain(ptile)) {
3136 switch (old_known) {
3137 case TILE_UNKNOWN:
3138 tile_set_terrain(ptile, pterrain);
3139 break;
3140 case TILE_KNOWN_UNSEEN:
3141 case TILE_KNOWN_SEEN:
3142 if (NULL != pterrain || TILE_UNKNOWN == packet->known) {
3143 tile_set_terrain(ptile, pterrain);
3144 } else {
3146 log_error("handle_tile_info() unknown terrain (%d, %d).",
3147 TILE_XY(ptile));
3148 }
3149 break;
3150 };
3151 }
3152
3153 if (!BV_ARE_EQUAL(ptile->extras, packet->extras)) {
3154 ptile->extras = packet->extras;
3156 }
3157
3158 tile_changed = tile_changed || (tile_resource(ptile) != presource);
3159
3160 /* always called after setting terrain */
3161 tile_set_resource(ptile, presource);
3162
3163 if (tile_owner(ptile) != powner) {
3164 tile_set_owner(ptile, powner, NULL);
3166 }
3167 if (extra_owner(ptile) != eowner) {
3168 ptile->extras_owner = eowner;
3170 }
3171
3172 if (packet->placing < 0) {
3173 if (ptile->placing != NULL) {
3175 ptile->placing = NULL;
3176 ptile->infra_turns = 0;
3177 }
3178 } else {
3179 struct extra_type *old = ptile->placing;
3180
3181 ptile->placing = extra_by_number(packet->placing);
3182 if (ptile->placing != old
3183 || ptile->infra_turns != packet->place_turn - game.info.turn) {
3185 }
3186 ptile->infra_turns = packet->place_turn - game.info.turn;
3187 }
3188
3189 if (NULL == tile_worked(ptile)
3190 || tile_worked(ptile)->id != packet->worked) {
3191 if (IDENTITY_NUMBER_ZERO != packet->worked) {
3192 struct city *pwork = game_city_by_number(packet->worked);
3193
3194 if (NULL == pwork) {
3195 char named[MAX_LEN_CITYNAME];
3196
3197 /* New unseen ("invisible") city, or before city_info */
3198 fc_snprintf(named, sizeof(named), "%06u", packet->worked);
3199
3200 pwork = create_city_virtual(invisible.placeholder, NULL, named);
3201 pwork->id = packet->worked;
3203
3205
3206 log_debug("(%d,%d) invisible city %d, %s",
3207 TILE_XY(ptile), pwork->id, city_name_get(pwork));
3208 } else if (NULL == city_tile(pwork)) {
3209 /* Old unseen ("invisible") city, or before city_info */
3210 if (NULL != powner && city_owner(pwork) != powner) {
3211 /* Update placeholder with current owner */
3212 pwork->owner = powner;
3213 pwork->original = NULL;
3214 }
3215 } else {
3216 /* We have a real (not invisible) city record for this ID, but
3217 * perhaps our info about that city is out of date. */
3218 int dist_sq = sq_map_distance(city_tile(pwork), ptile);
3219
3221 /* This is probably enemy city which has grown in diameter since we
3222 * last saw it. We need city_radius_sq to be at least big enough so
3223 * that all workers fit in, so set it so. */
3225 }
3226 /* This might be a known city that is open in a dialog.
3227 * (And this might be our only prompt to refresh the worked tiles
3228 * display in its city map, if a worker rearrangement does not
3229 * change anything else about the city such as output.) */
3230 {
3231 struct city *oldwork = tile_worked(ptile);
3232 if (oldwork && NULL != city_tile(oldwork)) {
3233 /* Refresh previous city too if it's real and different */
3235 }
3236 /* Refresh new city working tile (which we already know is real) */
3238 }
3239 }
3240
3241 /* This marks tile worked by (possibly invisible) city. Other
3242 * parts of the code have to handle invisible cities correctly
3243 * (ptile->worked->tile == NULL) */
3244 tile_set_worked(ptile, pwork);
3245 } else {
3246 /* Tile is no longer being worked by a city.
3247 * (Again, this might be our only prompt to refresh the worked tiles
3248 * display for the previous working city.) */
3249 if (tile_worked(ptile) && NULL != city_tile(tile_worked(ptile))) {
3251 }
3252 tile_set_worked(ptile, NULL);
3253 }
3254
3256 }
3257
3258 if (old_known != packet->known) {
3260 }
3261
3262 if (NULL != client.conn.playing) {
3267
3268 switch (packet->known) {
3269 case TILE_KNOWN_SEEN:
3274 break;
3275 case TILE_KNOWN_UNSEEN:
3277 break;
3278 case TILE_UNKNOWN:
3279 break;
3280 default:
3281 log_error("handle_tile_info() invalid known (%d).", packet->known);
3282 break;
3283 };
3284 }
3286
3287 if (packet->spec_sprite[0] != '\0') {
3288 if (!ptile->spec_sprite
3289 || strcmp(ptile->spec_sprite, packet->spec_sprite) != 0) {
3290 if (ptile->spec_sprite) {
3291 free(ptile->spec_sprite);
3292 }
3293 ptile->spec_sprite = fc_strdup(packet->spec_sprite);
3295 }
3296 } else {
3297 if (ptile->spec_sprite) {
3298 free(ptile->spec_sprite);
3299 ptile->spec_sprite = NULL;
3301 }
3302 }
3303
3305 /* This is an error. So first we log the error,
3306 * then make an assertion. */
3307 unit_list_iterate(ptile->units, punit) {
3308 log_error("%p %d %s at (%d,%d) %s", punit, punit->id,
3312 fc_assert_msg(0 == unit_list_size(ptile->units), "Ghost units seen");
3313 /* Repairing... */
3314 unit_list_clear(ptile->units);
3315 }
3316
3317 ptile->continent = packet->continent;
3319
3320 if (packet->label[0] == '\0') {
3321 if (ptile->label != NULL) {
3322 FC_FREE(ptile->label);
3323 ptile->label = NULL;
3325 }
3326 } else if (ptile->label == NULL || strcmp(packet->label, ptile->label)) {
3327 tile_set_label(ptile, packet->label);
3329 }
3330
3331 if (known_changed || tile_changed) {
3332 /*
3333 * A tile can only change if it was known before and is still
3334 * known. In the other cases the tile is new or removed.
3335 */
3337 agents_tile_new(ptile);
3338 } else if (known_changed && TILE_KNOWN_UNSEEN == new_known) {
3339 agents_tile_remove(ptile);
3340 } else {
3341 agents_tile_changed(ptile);
3342 }
3344 }
3345
3346 /* refresh tiles */
3347 if (can_client_change_view()) {
3348 /* the tile itself (including the necessary parts of adjacent tiles) */
3349 if (tile_changed || old_known != new_known) {
3351 }
3352 }
3353
3354 /* update menus if the focus unit is on the tile. */
3355 if (tile_changed) {
3356 if (get_focus_unit_on_tile(ptile)) {
3357 menus_update();
3358 }
3359 }
3360
3361 /* FIXME: we really ought to call refresh_city_dialog() for any city
3362 * whose radii include this tile, to update the city map display.
3363 * But that would be expensive. We deal with the (common) special
3364 * case of changes in worked tiles above. */
3365}
3366
3367/************************************************************************/
3387
3388/************************************************************************/
3391void handle_scenario_description(const char *description)
3392{
3394
3396}
3397
3398/************************************************************************/
3404{
3405 /* The ruleset is going to load new nations. So close
3406 * the nation selection dialog if it is open. */
3408
3414 game.control = *packet;
3415
3416 /* check the values! */
3417#define VALIDATE(_count, _maximum, _string) \
3418 if (game.control._count > _maximum) { \
3419 log_error("handle_ruleset_control(): Too many " _string \
3420 "; using %d of %d", _maximum, game.control._count); \
3421 game.control._count = _maximum; \
3422 }
3423
3424 VALIDATE(num_unit_classes, UCL_LAST, "unit classes");
3425 VALIDATE(num_unit_types, U_LAST, "unit types");
3426 VALIDATE(num_impr_types, B_LAST, "improvements");
3427 VALIDATE(num_tech_types, A_LAST, "advances");
3428 VALIDATE(num_base_types, MAX_EXTRA_TYPES, "bases");
3429 VALIDATE(num_road_types, MAX_EXTRA_TYPES, "roads");
3430 VALIDATE(num_resource_types, MAX_EXTRA_TYPES, "resources");
3431 VALIDATE(num_disaster_types, MAX_DISASTER_TYPES, "disasters");
3432 VALIDATE(num_achievement_types, MAX_ACHIEVEMENT_TYPES, "achievements");
3433 VALIDATE(num_counters, MAX_COUNTERS, "counters");
3434
3435 /* game.control.government_count, game.control.nation_count and
3436 * game.control.num_city_styles are allocated dynamically, and do
3437 * not need a size check. See the allocation below. */
3438
3440
3441 VALIDATE(num_specialist_types, SP_MAX, "specialists");
3442#undef VALIDATE
3443
3449
3450 if (game.control.desc_length > 0) {
3452 game.ruleset_description[0] = '\0';
3453 }
3454
3455 if (packet->preferred_tileset[0] != '\0') {
3456 /* There is tileset suggestion */
3458 /* It's not currently in use */
3461 } else {
3463 }
3464 }
3465 }
3466
3467 if (packet->preferred_soundset[0] != '\0') {
3468 /* There is soundset suggestion */
3470 /* It's not currently in use */
3473 } else {
3475 }
3476 }
3477 }
3478
3479 if (packet->preferred_musicset[0] != '\0') {
3480 /* There is musicset suggestion */
3482 /* It's not currently in use */
3485 } else {
3487 }
3488 }
3489 }
3490
3492
3494}
3495
3496/************************************************************************/
3500{
3501 int len;
3502
3503 if (game.ruleset_summary != NULL) {
3505 }
3506
3507 len = strlen(packet->text);
3508
3510
3511 fc_strlcpy(game.ruleset_summary, packet->text, len + 1);
3512}
3513
3514/************************************************************************/
3523
3524/************************************************************************/
3528{
3529 /* Setup extra hiders caches */
3530 extra_type_iterate(pextra) {
3531 pextra->hiders = extra_type_list_new();
3533 if (BV_ISSET(pextra->hidden_by, extra_index(phider))) {
3534 extra_type_list_append(pextra->hiders, phider);
3535 }
3537 pextra->bridged = extra_type_list_new();
3539 if (BV_ISSET(pextra->bridged_over, extra_index(pbridged))) {
3540 extra_type_list_append(pextra->bridged, pbridged);
3541 }
3544
3549
3550 /* Setup improvement feature caches */
3552
3553 /* Setup road integrators caches */
3555
3556 /* Pre calculate action related data. */
3558
3559 /* Setup unit unknown move cost caches */
3561 ptype->unknown_move_cost = utype_unknown_move_cost(ptype);
3565
3566 /* Cache what city production can receive help from caravans. */
3568
3569 /* Adjust editor for changed ruleset. */
3571
3572 /* We are not going to crop any more sprites from big sprites, free them. */
3574
3576}
3577
3578/************************************************************************/
3582{
3583 struct unit_class *c = uclass_by_number(p->id);
3584
3585 fc_assert_ret_msg(NULL != c, "Bad unit_class %d.", p->id);
3586
3587 names_set(&c->name, NULL, p->name, p->rule_name);
3588 c->min_speed = p->min_speed;
3589 c->hp_loss_pct = p->hp_loss_pct;
3591 c->flags = p->flags;
3592
3594}
3595
3596/************************************************************************/
3600{
3601 int i;
3602 struct unit_type *u = utype_by_number(p->id);
3603
3604 fc_assert_ret_msg(NULL != u, "Bad unit_type %d.", p->id);
3605
3606 names_set(&u->name, NULL, p->name, p->rule_name);
3614
3616 u->build_cost = p->build_cost;
3617 u->pop_cost = p->pop_cost;
3620 u->move_rate = p->move_rate;
3621 for (i = 0; i < p->build_reqs_count; i++) {
3623 }
3626 u->hp = p->hp;
3627 u->firepower = p->firepower;
3630 u->convert_time = p->convert_time;
3631 u->fuel = p->fuel;
3632 u->flags = p->flags;
3633 u->roles = p->roles;
3634 u->happy_cost = p->happy_cost;
3636 u->upkeep[o] = p->upkeep[o];
3639 u->bombard_rate = p->bombard_rate;
3640 u->city_size = p->city_size;
3641 u->city_slots = p->city_slots;
3642 u->tp_defense = p->tp_defense;
3643 u->cargo = p->cargo;
3644 u->targets = p->targets;
3645 u->embarks = p->embarks;
3646 u->disembarks = p->disembarks;
3647 u->vlayer = p->vlayer;
3648
3649 if (p->veteran_levels == 0) {
3650 u->veteran = NULL;
3651 } else {
3653
3654 for (i = 0; i < p->veteran_levels; i++) {
3656 p->power_fact[i], p->move_bonus[i],
3657 p->base_raise_chance[i],
3658 p->work_raise_chance[i]);
3659 }
3660 }
3661
3663
3664 u->adv.worker = p->worker;
3665
3667}
3668
3669/************************************************************************/
3673{
3674 struct unit_type *u = utype_by_number(p->unit);
3675 struct combat_bonus *bonus;
3676
3677 fc_assert_ret_msg(NULL != u, "Bad unit_type %d.", p->unit);
3678
3679 bonus = malloc(sizeof(*bonus));
3680
3681 bonus->flag = p->flag;
3682 bonus->type = p->type;
3683 bonus->value = p->value;
3684 bonus->quiet = p->quiet;
3685
3687}
3688
3689/************************************************************************/
3693{
3694 const char *flagname;
3695 const char *helptxt;
3696
3697 fc_assert_ret_msg(p->id >= UTYF_USER_FLAG_1 && p->id <= UTYF_LAST_USER_FLAG, "Bad user flag %d.", p->id);
3698
3699 if (p->name[0] == '\0') {
3700 flagname = NULL;
3701 } else {
3702 flagname = p->name;
3703 }
3704
3705 if (p->helptxt[0] == '\0') {
3706 helptxt = NULL;
3707 } else {
3708 helptxt = p->helptxt;
3709 }
3710
3712}
3713
3714/************************************************************************/
3718 const struct packet_ruleset_unit_class_flag *p)
3719{
3720 const char *flagname;
3721 const char *helptxt;
3722
3724 "Bad user flag %d.", p->id);
3725
3726 if (p->name[0] == '\0') {
3727 flagname = NULL;
3728 } else {
3729 flagname = p->name;
3730 }
3731
3732 if (p->helptxt[0] == '\0') {
3733 helptxt = NULL;
3734 } else {
3735 helptxt = p->helptxt;
3736 }
3737
3739}
3740
3741/************************************************************************/
3749static int unpack_tech_req(const enum tech_req r_num,
3750 const int reqs_size,
3751 const struct requirement *reqs,
3752 struct advance *a,
3753 int i)
3754{
3755 if (i < reqs_size
3756 && reqs[i].source.kind == VUT_ADVANCE) {
3757 /* Extract the tech req so the old code can reason about it. */
3758
3759 /* This IS a traditional tech req... right? */
3760 fc_assert(reqs[i].present);
3762
3763 /* Put it in the advance structure. */
3764 a->require[r_num] = reqs[i].source.value.advance;
3765
3766 /* Move on in the requirement vector. */
3767 i++;
3768 } else {
3769 /* No tech req. */
3771 }
3772
3773 return i;
3774}
3775
3776/************************************************************************/
3780{
3781 int i;
3782 struct advance *a = advance_by_number(p->id);
3783
3784 fc_assert_ret_msg(NULL != a, "Bad advance %d.", p->id);
3785
3786 names_set(&a->name, NULL, p->name, p->rule_name);
3789
3790 i = 0;
3791
3793 if (p->tclass >= 0) {
3795 } else {
3796 a->tclass = NULL;
3797 }
3798
3799 /* The tech requirements req1 and req2 are send inside research_reqs
3800 * since they too are required to be fulfilled before the tech can be
3801 * researched. */
3802
3803 if (p->removed) {
3804 /* The Freeciv data structures currently records that a tech is removed
3805 * by setting req1 and req2 to "Never". */
3806 a->require[AR_ONE] = A_NEVER;
3807 a->require[AR_TWO] = A_NEVER;
3808 } else {
3809 /* Unpack req1 and req2 from the research_reqs requirement vector. */
3812 }
3813
3814 /* Any remaining requirements are a part of the research_reqs requirement
3815 * vector. */
3816 for (; i < p->research_reqs_count; i++) {
3818 }
3819
3820 /* The packet's research_reqs should contain req1, req2 and the
3821 * requirements of the tech's research_reqs. */
3822 fc_assert((a->research_reqs.size
3823 + ((a->require[AR_ONE]
3824 && (advance_number(a->require[AR_ONE]) != A_NONE)) ?
3825 1 : 0)
3826 + ((a->require[AR_TWO]
3827 && (advance_number(a->require[AR_TWO]) != A_NONE)) ?
3828 1 : 0))
3829 == p->research_reqs_count);
3830
3832
3833 a->flags = p->flags;
3834 a->cost = p->cost;
3835 a->num_reqs = p->num_reqs;
3837
3839}
3840
3841/************************************************************************/
3845{
3847
3848 fc_assert_ret_msg(NULL != ptclass, "Bad tech_class %d.", p->id);
3849
3850 names_set(&ptclass->name, NULL, p->name, p->rule_name);
3851 ptclass->cost_pct = p->cost_pct;
3852}
3853
3854/************************************************************************/
3858{
3859 const char *flagname;
3860 const char *helptxt;
3861
3862 fc_assert_ret_msg(p->id >= TECH_USER_1 && p->id <= TECH_USER_LAST, "Bad user flag %d.", p->id);
3863
3864 if (p->name[0] == '\0') {
3865 flagname = NULL;
3866 } else {
3867 flagname = p->name;
3868 }
3869
3870 if (p->helptxt[0] == '\0') {
3871 helptxt = NULL;
3872 } else {
3873 helptxt = p->helptxt;
3874 }
3875
3876 set_user_tech_flag_name(p->id, flagname, helptxt);
3877}
3878
3879/************************************************************************/
3883{
3884 int i;
3885 struct impr_type *b = improvement_by_number(p->id);
3886
3887 fc_assert_ret_msg(NULL != b, "Bad improvement %d.", p->id);
3888
3889 b->genus = p->genus;
3890 names_set(&b->name, NULL, p->name, p->rule_name);
3894 for (i = 0; i < p->reqs_count; i++) {
3896 }
3897 fc_assert(b->reqs.size == p->reqs_count);
3898 for (i = 0; i < p->obs_count; i++) {
3900 }
3901 fc_assert(b->obsolete_by.size == p->obs_count);
3902 b->build_cost = p->build_cost;
3903 b->upkeep = p->upkeep;
3904 b->sabotage = p->sabotage;
3905 b->flags = p->flags;
3910
3911#ifdef FREECIV_DEBUG
3912 if (p->id == improvement_count() - 1) {
3914 log_debug("Improvement: %s...", improvement_rule_name(bdbg));
3915 log_debug(" build_cost %3d", bdbg->build_cost);
3916 log_debug(" upkeep %2d", bdbg->upkeep);
3917 log_debug(" sabotage %3d", bdbg->sabotage);
3918 if (NULL != bdbg->helptext) {
3919 strvec_iterate(bdbg->helptext, text) {
3920 log_debug(" helptext %s", text);
3922 }
3924 }
3925#endif /* FREECIV_DEBUG */
3926
3928}
3929
3930/************************************************************************/
3934{
3935 const char *flagname;
3936 const char *helptxt;
3937
3939 "Bad user flag %d.", p->id);
3940
3941 if (p->name[0] == '\0') {
3942 flagname = NULL;
3943 } else {
3944 flagname = p->name;
3945 }
3946
3947 if (p->helptxt[0] == '\0') {
3948 helptxt = NULL;
3949 } else {
3950 helptxt = p->helptxt;
3951 }
3952
3953 set_user_impr_flag_name(p->id, flagname, helptxt);
3954}
3955
3956/************************************************************************/
3960{
3961 struct multiplier *pmul = multiplier_by_number(p->id);
3962 int j;
3963
3964 fc_assert_ret_msg(NULL != pmul, "Bad multiplier %d.", p->id);
3965
3966 pmul->start = p->start;
3967 pmul->stop = p->stop;
3968 pmul->step = p->step;
3969 pmul->def = p->def;
3970 pmul->offset = p->offset;
3971 pmul->factor = p->factor;
3972 pmul->minimum_turns = p->minimum_turns;
3973
3974 names_set(&pmul->name, NULL, p->name, p->rule_name);
3975
3976 for (j = 0; j < p->reqs_count; j++) {
3977 requirement_vector_append(&pmul->reqs, p->reqs[j]);
3978 }
3979 fc_assert(pmul->reqs.size == p->reqs_count);
3980
3982}
3983
3984/************************************************************************/
3988{
3989 int j;
3990 struct government *gov = government_by_number(p->id);
3991
3992 fc_assert_ret_msg(NULL != gov, "Bad government %d.", p->id);
3993
3994 gov->item_number = p->id;
3995
3996 for (j = 0; j < p->reqs_count; j++) {
3997 requirement_vector_append(&gov->reqs, p->reqs[j]);
3998 }
3999 fc_assert(gov->reqs.size == p->reqs_count);
4000
4001 names_set(&gov->name, NULL, p->name, p->rule_name);
4004 sz_strlcpy(gov->sound_str, p->sound_str);
4005 sz_strlcpy(gov->sound_alt, p->sound_alt);
4007
4009
4011}
4012
4013/************************************************************************/
4017 (const struct packet_ruleset_government_ruler_title *packet)
4018{
4019 struct government *gov = government_by_number(packet->gov);
4020
4021 fc_assert_ret_msg(NULL != gov, "Bad government %d.", packet->gov);
4022
4024 packet->male_title,
4025 packet->female_title);
4026}
4027
4028/************************************************************************/
4032{
4033 int j;
4034 struct terrain *pterrain = terrain_by_number(p->id);
4035
4036 fc_assert_ret_msg(NULL != pterrain, "Bad terrain %d.", p->id);
4037
4038 pterrain->tclass = p->tclass;
4039 pterrain->native_to = p->native_to;
4040 names_set(&pterrain->name, NULL, p->name, p->rule_name);
4041 sz_strlcpy(pterrain->graphic_str, p->graphic_str);
4042 sz_strlcpy(pterrain->graphic_alt, p->graphic_alt);
4043 sz_strlcpy(pterrain->graphic_alt2, p->graphic_alt2);
4044 pterrain->movement_cost = p->movement_cost;
4045 pterrain->defense_bonus = p->defense_bonus;
4046
4048 pterrain->output[o] = p->output[o];
4050
4051 if (pterrain->resources != NULL) {
4052 free(pterrain->resources);
4053 }
4054 pterrain->resources = fc_calloc(p->num_resources + 1,
4055 sizeof(*pterrain->resources));
4056 if (pterrain->resource_freq != NULL) {
4057 free(pterrain->resource_freq);
4058 }
4059 pterrain->resource_freq = fc_calloc(p->num_resources + 1,
4060 sizeof(*pterrain->resource_freq));
4061 for (j = 0; j < p->num_resources; j++) {
4062 pterrain->resources[j] = extra_by_number(p->resources[j]);
4063 if (!pterrain->resources[j]) {
4064 log_error("handle_ruleset_terrain() "
4065 "Mismatched resource %d for terrain \"%s\".",
4066 p->resources[j], terrain_rule_name(pterrain));
4067 }
4068 pterrain->resource_freq[j] = p->resource_freq[j];
4069 }
4070 pterrain->resources[p->num_resources] = NULL;
4071 pterrain->resource_freq[p->num_resources] = 0;
4072
4076
4077 pterrain->base_time = p->base_time;
4078 pterrain->road_time = p->road_time;
4080 pterrain->cultivate_time = p->cultivate_time;
4082 pterrain->plant_time = p->plant_time;
4084 pterrain->irrigation_time = p->irrigation_time;
4086 pterrain->mining_time = p->mining_time;
4087 if (p->animal < 0) {
4088 pterrain->animal = NULL;
4089 } else {
4090 pterrain->animal = utype_by_number(p->animal);
4091 }
4093 pterrain->transform_time = p->transform_time;
4094 pterrain->placing_time = p->placing_time;
4095 pterrain->pillage_time = p->pillage_time;
4096
4097 for (j = 0; j < p->extra_count; j++) {
4098 pterrain->extra_removal_times[j] = p->extra_removal_times[j];
4099 }
4100
4101 pterrain->flags = p->flags;
4102
4103 fc_assert_ret(pterrain->rgb == NULL);
4104 pterrain->rgb = rgbcolor_new(p->color_red, p->color_green, p->color_blue);
4105
4107
4109}
4110
4111/************************************************************************/
4115{
4116 const char *flagname;
4117 const char *helptxt;
4118
4119 fc_assert_ret_msg(p->id >= TER_USER_1 && p->id <= TER_USER_LAST, "Bad user flag %d.", p->id);
4120
4121 if (p->name[0] == '\0') {
4122 flagname = NULL;
4123 } else {
4124 flagname = p->name;
4125 }
4126
4127 if (p->helptxt[0] == '\0') {
4128 helptxt = NULL;
4129 } else {
4130 helptxt = p->helptxt;
4131 }
4132
4134}
4135
4136/************************************************************************/
4140{
4141 struct resource_type *presource;
4142
4143 if (p->id < 0 || p->id > MAX_EXTRA_TYPES) {
4144 log_error("Bad resource %d.", p->id);
4145 return;
4146 }
4147
4148 presource = resource_type_init(extra_by_number(p->id));
4149
4151 presource->output[o] = p->output[o];
4153}
4154
4155/************************************************************************/
4159{
4160 struct extra_type *pextra = extra_by_number(p->id);
4161 int i;
4162 bool cbase;
4163 bool croad;
4164 bool cres;
4165
4166 fc_assert_ret_msg(NULL != pextra, "Bad extra %d.", p->id);
4167
4168 names_set(&pextra->name, NULL, p->name, p->rule_name);
4169
4170 pextra->category = p->category;
4171
4172 pextra->causes = 0;
4173 for (i = 0; i < EC_COUNT; i++) {
4174 if (BV_ISSET(p->causes, i)) {
4175 pextra->causes |= (1 << i);
4176 }
4177 }
4178
4179 pextra->rmcauses = 0;
4180 for (i = 0; i < ERM_COUNT; i++) {
4181 if (BV_ISSET(p->rmcauses, i)) {
4182 pextra->rmcauses |= (1 << i);
4183 }
4184 }
4185
4186 if (pextra->causes == 0) {
4188 } else {
4189 for (i = 0; i < EC_COUNT; i++) {
4190 if (is_extra_caused_by(pextra, i)) {
4191 extra_to_caused_by_list(pextra, i);
4192 }
4193 }
4194 }
4195
4196 cbase = is_extra_caused_by(pextra, EC_BASE);
4197 croad = is_extra_caused_by(pextra, EC_ROAD);
4199 if (cbase) {
4200 /* Index is one less than size of list when this base is already added. */
4202 }
4203 if (croad) {
4204 /* Index is one less than size of list when this road is already added. */
4206 }
4207 if (!cbase && !croad && !cres) {
4210 }
4211
4212 for (i = 0; i < ERM_COUNT; i++) {
4213 if (is_extra_removed_by(pextra, i)) {
4214 extra_to_removed_by_list(pextra, i);
4215 }
4216 }
4217
4219 sz_strlcpy(pextra->act_gfx_alt, p->act_gfx_alt);
4221 sz_strlcpy(pextra->rmact_gfx, p->rmact_gfx);
4224 sz_strlcpy(pextra->graphic_str, p->graphic_str);
4225 sz_strlcpy(pextra->graphic_alt, p->graphic_alt);
4226
4227 for (i = 0; i < p->reqs_count; i++) {
4228 requirement_vector_append(&pextra->reqs, p->reqs[i]);
4229 }
4230 fc_assert(pextra->reqs.size == p->reqs_count);
4231
4232 for (i = 0; i < p->rmreqs_count; i++) {
4234 }
4235 fc_assert(pextra->rmreqs.size == p->rmreqs_count);
4236
4238 for (i = 0; i < p->appearance_reqs_count; i++) {
4240 }
4242
4244 for (i = 0; i < p->disappearance_reqs_count; i++) {
4246 }
4248
4249 pextra->visibility_req = p->visibility_req;
4250 pextra->buildable = p->buildable;
4251 pextra->generated = p->generated;
4252 pextra->build_time = p->build_time;
4254 pextra->removal_time = p->removal_time;
4256 pextra->infracost = p->infracost;
4257 pextra->defense_bonus = p->defense_bonus;
4258
4259 if (pextra->defense_bonus != 0) {
4260 if (extra_has_flag(pextra, EF_NATURAL_DEFENSE)) {
4262 } else {
4264 }
4265 }
4266
4268
4269 pextra->eus = p->eus;
4270 if (pextra->eus == EUS_HIDDEN) {
4272 }
4273
4274 pextra->native_to = p->native_to;
4275
4276 pextra->flags = p->flags;
4277 if (pextra->no_aggr_near_city >= 0) {
4279 }
4280 if (extra_has_flag(pextra, EF_CAUSE_ZOC)) {
4282 }
4283
4284 pextra->hidden_by = p->hidden_by;
4285 pextra->bridged_over = p->bridged_over;
4286 pextra->conflicts = p->conflicts;
4287
4289
4291}
4292
4293/************************************************************************/
4297{
4298 const char *flagname;
4299 const char *helptxt;
4300
4302 "Bad user flag %d.", p->id);
4303
4304 if (p->name[0] == '\0') {
4305 flagname = NULL;
4306 } else {
4307 flagname = p->name;
4308 }
4309
4310 if (p->helptxt[0] == '\0') {
4311 helptxt = NULL;
4312 } else {
4313 helptxt = p->helptxt;
4314 }
4315
4316 set_user_extra_flag_name(p->id, flagname, helptxt);
4317}
4318
4319/************************************************************************/
4323{
4324 struct base_type *pbase = base_by_number(p->id);
4325
4326 fc_assert_ret_msg(NULL != pbase, "Bad base %d.", p->id);
4327
4328 pbase->gui_type = p->gui_type;
4329 pbase->border_sq = p->border_sq;
4330 pbase->vision_main_sq = p->vision_main_sq;
4331 pbase->vision_invis_sq = p->vision_invis_sq;
4332 pbase->vision_subs_sq = p->vision_subs_sq;
4333
4337 }
4338}
4339
4340/************************************************************************/
4344{
4345 int i;
4346 struct road_type *proad = road_by_number(p->id);
4347
4348 fc_assert_ret_msg(NULL != proad, "Bad road %d.", p->id);
4349
4350 proad->gui_type = p->gui_type;
4351
4352 for (i = 0; i < p->first_reqs_count; i++) {
4353 requirement_vector_append(&proad->first_reqs, p->first_reqs[i]);
4354 }
4355 fc_assert(proad->first_reqs.size == p->first_reqs_count);
4356
4357 proad->move_cost = p->move_cost;
4358 proad->move_mode = p->move_mode;
4359
4361 proad->tile_incr_const[o] = p->tile_incr_const[o];
4362 proad->tile_incr[o] = p->tile_incr[o];
4363 proad->tile_bonus[o] = p->tile_bonus[o];
4365
4366 proad->compat = p->compat;
4367 proad->integrates = p->integrates;
4368 proad->flags = p->flags;
4369}
4370
4371/************************************************************************/
4375{
4376 struct goods_type *pgood = goods_by_number(p->id);
4377 int i;
4378
4379 fc_assert_ret_msg(NULL != pgood, "Bad goods %d.", p->id);
4380
4381 names_set(&pgood->name, NULL, p->name, p->rule_name);
4382
4383 for (i = 0; i < p->reqs_count; i++) {
4385 }
4386 fc_assert(pgood->reqs.size == p->reqs_count);
4387
4388 pgood->from_pct = p->from_pct;
4389 pgood->to_pct = p->to_pct;
4390 pgood->onetime_pct = p->onetime_pct;
4391 pgood->flags = p->flags;
4392
4393 PACKET_STRVEC_EXTRACT(pgood->helptext, p->helptext);
4394}
4395
4396/************************************************************************/
4400{
4401 struct action *act;
4402
4403 if (!action_id_exists(p->id)) {
4404 /* Action id out of range */
4405 log_error("handle_ruleset_action() the action id %d is out of range.",
4406 p->id);
4407
4408 return;
4409 }
4410
4411 act = action_by_number(p->id);
4412
4413 sz_strlcpy(act->ui_name, p->ui_name);
4414 act->quiet = p->quiet;
4415
4416 act->result = p->result;
4417 act->sub_results = p->sub_results;
4419
4420 act->actor_kind = p->act_kind;
4421 act->target_kind = p->tgt_kind;
4422 act->sub_target_kind = p->sub_tgt_kind;
4423
4424 act->min_distance = p->min_distance;
4425 act->max_distance = p->max_distance;
4426 act->blocked_by = p->blocked_by;
4427}
4428
4429/************************************************************************/
4432void
4434{
4435 struct action_enabler *enabler;
4436 int i;
4437
4439 /* Non existing action */
4440 log_error("handle_ruleset_action_enabler() the action %d "
4441 "doesn't exist.",
4442 p->enabled_action);
4443
4444 return;
4445 }
4446
4448
4449 enabler->action = p->enabled_action;
4450
4451 for (i = 0; i < p->actor_reqs_count; i++) {
4452 requirement_vector_append(&enabler->actor_reqs, p->actor_reqs[i]);
4453 }
4454 fc_assert(enabler->actor_reqs.size == p->actor_reqs_count);
4455
4456 for (i = 0; i < p->target_reqs_count; i++) {
4457 requirement_vector_append(&enabler->target_reqs, p->target_reqs[i]);
4458 }
4459 fc_assert(enabler->target_reqs.size == p->target_reqs_count);
4460
4462}
4463
4464/************************************************************************/
4468{
4470 int i;
4471
4473
4474 auto_perf->cause = p->cause;
4475
4476 for (i = 0; i < p->reqs_count; i++) {
4478 }
4479 fc_assert(auto_perf->reqs.size == p->reqs_count);
4480
4481 for (i = 0; i < p->alternatives_count; i++) {
4482 auto_perf->alternatives[i] = p->alternatives[i];
4483 }
4484}
4485
4486/************************************************************************/
4490{
4492 int i;
4493
4494 fc_assert_ret_msg(NULL != pdis, "Bad disaster %d.", p->id);
4495
4496 names_set(&pdis->name, NULL, p->name, p->rule_name);
4497
4498 for (i = 0; i < p->reqs_count; i++) {
4499 requirement_vector_append(&pdis->reqs, p->reqs[i]);
4500 }
4501 fc_assert(pdis->reqs.size == p->reqs_count);
4502
4503 pdis->frequency = p->frequency;
4504
4505 pdis->effects = p->effects;
4506}
4507
4508/************************************************************************/
4512{
4514
4515 fc_assert_ret_msg(NULL != pach, "Bad achievement %d.", p->id);
4516
4517 names_set(&pach->name, NULL, p->name, p->rule_name);
4518
4519 pach->type = p->type;
4520 pach->unique = p->unique;
4521 pach->value = p->value;
4522}
4523
4524/************************************************************************/
4528{
4530
4531 if (pset != NULL) {
4532 pset->trade_pct = p->trade_pct;
4533 pset->cancelling = p->cancelling;
4534 pset->bonus_type = p->bonus_type;
4535 }
4536}
4537
4538/************************************************************************/
4542 (const struct packet_ruleset_terrain_control *p)
4543{
4544 /* Since terrain_control is the same as packet_ruleset_terrain_control
4545 * we can just copy the data directly. */
4546 terrain_control = *p;
4547 /* terrain_control.move_fragments likely changed */
4549}
4550
4551/************************************************************************/
4555 (const struct packet_ruleset_nation_sets *packet)
4556{
4557 int i;
4558
4559 for (i = 0; i < packet->nsets; i++) {
4560 struct nation_set *pset =
4561 nation_set_new(packet->names[i], packet->rule_names[i],
4562 packet->descriptions[i]);
4563
4564 if (pset == NULL) {
4565 break;
4566 } else {
4568 }
4569 }
4570}
4571
4572/************************************************************************/
4576 (const struct packet_ruleset_nation_groups *packet)
4577{
4578 int i;
4579
4580 for (i = 0; i < packet->ngroups; i++) {
4581 struct nation_group *pgroup;
4582
4583 pgroup = nation_group_new(packet->groups[i]);
4584
4585 if (pgroup != NULL) {
4587 pgroup->hidden = packet->hidden[i];
4588 } else {
4589 break;
4590 }
4591 }
4592}
4593
4594/************************************************************************/
4598{
4599 struct nation_type *pnation = nation_by_number(packet->id);
4600 int i;
4601
4602 fc_assert_ret_msg(NULL != pnation, "Bad nation %d.", packet->id);
4603
4604 if (packet->translation_domain[0] != '\0') {
4605 size_t len = strlen(packet->translation_domain) + 1;
4606 pnation->translation_domain = fc_malloc(len);
4608 } else {
4609 pnation->translation_domain = NULL;
4610 }
4611 names_set(&pnation->adjective, pnation->translation_domain,
4612 packet->adjective, packet->rule_name);
4613 name_set(&pnation->noun_plural, pnation->translation_domain, packet->noun_plural);
4614 sz_strlcpy(pnation->flag_graphic_str, packet->graphic_str);
4615 sz_strlcpy(pnation->flag_graphic_alt, packet->graphic_alt);
4616 pnation->style = style_by_number(packet->style);
4617 for (i = 0; i < packet->leader_count; i++) {
4618 (void) nation_leader_new(pnation, packet->leader_name[i],
4619 packet->leader_is_male[i]);
4620 }
4621
4622 /* set later by PACKET_NATION_AVAILABILITY */
4623 pnation->client.is_pickable = FALSE;
4624 pnation->is_playable = packet->is_playable;
4625 pnation->barb_type = packet->barbarian_type;
4626
4627 if ('\0' != packet->legend[0]) {
4628 pnation->legend = fc_strdup(nation_legend_translation(pnation, packet->legend));
4629 } else {
4630 pnation->legend = fc_strdup("");
4631 }
4632
4633 for (i = 0; i < packet->nsets; i++) {
4634 struct nation_set *pset = nation_set_by_number(packet->sets[i]);
4635
4636 if (NULL != pset) {
4637 nation_set_list_append(pnation->sets, pset);
4638 } else {
4639 log_error("handle_ruleset_nation() \"%s\" have unknown set %d.",
4640 nation_rule_name(pnation), packet->sets[i]);
4641 }
4642 }
4643
4644 for (i = 0; i < packet->ngroups; i++) {
4646
4647 if (NULL != pgroup) {
4649 } else {
4650 log_error("handle_ruleset_nation() \"%s\" have unknown group %d.",
4651 nation_rule_name(pnation), packet->groups[i]);
4652 }
4653 }
4654
4655 /* init_government may be NULL */
4657 for (i = 0; i < MAX_NUM_TECH_LIST; i++) {
4658 if (i < packet->init_techs_count) {
4659 pnation->init_techs[i] = packet->init_techs[i];
4660 } else {
4661 pnation->init_techs[i] = A_LAST;
4662 }
4663 }
4664 for (i = 0; i < MAX_NUM_UNIT_LIST; i++) {
4665 if (i < packet->init_units_count) {
4666 pnation->init_units[i] = utype_by_number(packet->init_units[i]);
4667 } else {
4668 /* TODO: should init_units be initialized in common/nation.c? */
4669 pnation->init_units[i] = utype_by_number(U_LAST);
4670 }
4671 }
4672 for (i = 0; i < MAX_NUM_BUILDING_LIST; i++) {
4673 if (i < packet->init_buildings_count) {
4674 pnation->init_buildings[i] = packet->init_buildings[i];
4675 } else {
4676 pnation->init_buildings[i] = B_LAST;
4677 }
4678 }
4679
4681}
4682
4683/************************************************************************/
4687void handle_nation_availability(int ncount, const bool *is_pickable,
4688 bool nationset_change)
4689{
4690 int i;
4691
4692 fc_assert_action(ncount == nation_count(),
4693 ncount = MIN(ncount, nation_count()));
4694
4695 for (i = 0; i < ncount; i++) {
4696 nation_by_number(i)->client.is_pickable = is_pickable[i];
4697 }
4698
4699 races_update_pickable(nationset_change);
4700}
4701
4702/************************************************************************/
4706{
4707 struct nation_style *pstyle = style_by_number(p->id);
4708
4709 fc_assert_ret_msg(NULL != pstyle, "Bad style %d.", p->id);
4710
4711 names_set(&pstyle->name, NULL, p->name, p->rule_name);
4712}
4713
4714/************************************************************************/
4718{
4719 struct clause_info *info = clause_info_get(p->type);
4720 int i;
4721
4722 fc_assert_ret_msg(NULL != info, "Bad clause %d.", p->type);
4723
4724 info->enabled = p->enabled;
4725
4726 for (i = 0; i < p->giver_reqs_count; i++) {
4728 }
4729 fc_assert(info->giver_reqs.size == p->giver_reqs_count);
4730
4731 for (i = 0; i < p->receiver_reqs_count; i++) {
4733 }
4735}
4736
4737/************************************************************************/
4741{
4742 int id, j;
4743 struct citystyle *cs;
4744
4745 id = packet->style_id;
4747 "Bad citystyle %d.", id);
4748 cs = &city_styles[id];
4749
4750 for (j = 0; j < packet->reqs_count; j++) {
4751 requirement_vector_append(&cs->reqs, packet->reqs[j]);
4752 }
4753 fc_assert(cs->reqs.size == packet->reqs_count);
4754
4755 names_set(&cs->name, NULL, packet->name, packet->rule_name);
4756 sz_strlcpy(cs->graphic, packet->graphic);
4757 sz_strlcpy(cs->graphic_alt, packet->graphic_alt);
4758 sz_strlcpy(cs->citizens_graphic, packet->citizens_graphic);
4759
4761}
4762
4763/************************************************************************/
4767{
4768 int id, j;
4769 struct music_style *pmus;
4770
4771 id = packet->id;
4773 "Bad music_style %d.", id);
4774
4776
4777 for (j = 0; j < packet->reqs_count; j++) {
4778 requirement_vector_append(&pmus->reqs, packet->reqs[j]);
4779 }
4780 fc_assert(pmus->reqs.size == packet->reqs_count);
4781
4782 sz_strlcpy(pmus->music_peaceful, packet->music_peaceful);
4783 sz_strlcpy(pmus->music_combat, packet->music_combat);
4784}
4785
4786/************************************************************************/
4790{
4791 int i;
4792
4793 /* Must set num_specialist_types before iterating over them. */
4795
4796 fc_assert_ret(packet->veteran_levels > 0);
4797
4799 game.veteran->levels = packet->veteran_levels;
4800
4801 for (i = 0; i < MAX_NUM_TECH_LIST; i++) {
4802 if (i < packet->global_init_techs_count) {
4804 } else {
4806 }
4807 }
4808 for (i = 0; i < MAX_NUM_BUILDING_LIST; i++) {
4809 if (i < packet->global_init_buildings_count) {
4811 } else {
4813 }
4814 }
4815
4816 for (i = 0; i < packet->veteran_levels; i++) {
4818 packet->power_fact[i], packet->move_bonus[i],
4819 packet->base_raise_chance[i],
4820 packet->work_raise_chance[i]);
4821 }
4822
4825 packet->background_green,
4826 packet->background_blue);
4827
4829}
4830
4831/************************************************************************/
4835{
4836 int j;
4837 struct specialist *s = specialist_by_number(p->id);
4838
4839 fc_assert_ret_msg(NULL != s, "Bad specialist %d.", p->id);
4840
4841 names_set(&s->name, NULL, p->plural_name, p->rule_name);
4843
4846
4847 for (j = 0; j < p->reqs_count; j++) {
4849 }
4850 fc_assert(s->reqs.size == p->reqs_count);
4851
4853
4855}
4856
4857/************************************************************************/
4860void handle_city_name_suggestion_info(int unit_id, const char *name)
4861{
4862 struct unit *punit = player_unit_by_number(client_player(), unit_id);
4863
4864 if (!can_client_issue_orders()) {
4865 return;
4866 }
4867
4868 if (punit) {
4870 bool other_asking = FALSE;
4871
4873 if (other->client.asking_city_name) {
4875 }
4878
4879 if (!other_asking) {
4881 }
4882 } else {
4884 unit_id, tile_index(unit_tile(punit)),
4885 0, name);
4886 }
4887 }
4888}
4889
4890/************************************************************************/
4896void handle_unit_action_answer(int actor_id, int target_id, int cost,
4897 action_id action_type,
4898 int request_kind)
4899{
4900 struct city *pcity = game_city_by_number(target_id);
4901 struct unit *punit = game_unit_by_number(target_id);
4902 struct unit *pactor = player_unit_by_number(client_player(), actor_id);
4903 struct action *paction = action_by_number(action_type);
4904
4905 if (ACTION_NONE != action_type
4906 && !action_id_exists(action_type)) {
4907 /* Non existing action */
4908 log_error("handle_unit_action_answer() the action %d doesn't exist.",
4909 action_type);
4910
4911 if (request_kind == REQEST_PLAYER_INITIATED) {
4915 }
4916
4917 return;
4918 }
4919
4920 if (!pactor) {
4921 log_debug("Bad actor %d.", actor_id);
4922
4923 if (request_kind == REQEST_PLAYER_INITIATED) {
4926 }
4927
4928 return;
4929 }
4930
4931 switch ((enum gen_action)action_type) {
4933 if (punit && client.conn.playing
4935 if (request_kind == REQEST_PLAYER_INITIATED) {
4936 /* Focus on the unit so the player knows where it is */
4938
4940 } else {
4941 /* Not in use (yet). */
4942 log_error("Unimplemented: received background unit bribe cost.");
4943 }
4944 } else {
4945 log_debug("Bad target %d.", target_id);
4946 if (request_kind == REQEST_PLAYER_INITIATED) {
4950 }
4951 }
4952 break;
4955 if (pcity && client.conn.playing
4957 if (request_kind == REQEST_PLAYER_INITIATED) {
4958 /* Focus on the unit so the player knows where it is */
4960
4962 } else {
4963 /* Not in use (yet). */
4964 log_error("Unimplemented: received background city incite cost.");
4965 }
4966 } else {
4967 log_debug("Bad target %d.", target_id);
4968 if (request_kind == REQEST_PLAYER_INITIATED) {
4972 }
4973 }
4974 break;
4976 if (pcity && client.conn.playing
4978 /* TODO: The bundled clients will have to start showing the upgrade
4979 * price sent from the server before it can be allowed to rely on
4980 * things the player can't see. (Example: it becomes legal to upgrade
4981 * a unit in a foreign city.) */
4982
4983 /* Getting unit upgrade cost from the server is currently only used by
4984 * Freeciv-web. */
4985 log_error("Received upgrade unit price but can't forward it.");
4986 }
4987 break;
4988 case ACTION_NONE:
4989 log_debug("Server didn't respond to query.");
4990 if (request_kind == REQEST_PLAYER_INITIATED) {
4994 }
4995 break;
4996 default:
4997 log_error("handle_unit_action_answer() invalid action_type (%d).",
4998 action_type);
4999 if (request_kind == REQEST_PLAYER_INITIATED) {
5003 }
5004 break;
5005 };
5006}
5007
5008/************************************************************************/
5013{
5015
5017 if (action_prob_possible(act_probs[act_id])) {
5018 /* An attack. */
5019 if (attack_action == ACTION_NONE) {
5020 /* No previous attack action found. */
5021 attack_action = act_id;
5022 } else {
5023 /* More than one legal attack action found. */
5024 return ACTION_NONE;
5025 }
5026 }
5029 if (action_prob_possible(act_probs[act_id])) {
5030 /* An interesting non attack action has been found. */
5031 return ACTION_NONE;
5032 }
5034
5035 return attack_action;
5036}
5037
5038/**********************************************************************/
5043 const struct act_prob *act_probs,
5044 struct unit *target_unit,
5045 struct city *target_city,
5046 struct tile *target_tile)
5047{
5049
5051
5053
5054 if (auto_action != ACTION_NONE) {
5055 /* No interesting actions except a single attack action has been
5056 * found. The player wants it performed without questions. */
5057
5058 /* The order requests below doesn't send additional details. */
5060
5061 /* Give the order. */
5063 case ATK_TILE:
5064 case ATK_UNITS:
5065 case ATK_EXTRAS:
5066 if (target_tile != NULL) {
5069 0, "");
5070 }
5071 break;
5072 case ATK_CITY:
5073 if (target_city != NULL) {
5076 0, "");
5077 }
5078 break;
5079 case ATK_UNIT:
5080 if (target_unit != NULL) {
5083 0, "");
5084 }
5085 break;
5086 case ATK_SELF:
5089 0, "");
5090 break;
5091 case ATK_COUNT:
5093 break;
5094 }
5095
5096 /* Clean up. */
5098 } else {
5099 /* This should be done in the foreground */
5101 }
5102}
5103
5104/************************************************************************/
5111{
5113
5114 struct tile *target_tile = index_to_tile(&(wld.map), packet->target_tile_id);
5115 struct extra_type *target_extra = packet->target_extra_id == EXTRA_NONE ?
5119
5120 const struct act_prob *act_probs = packet->action_probabilities;
5121
5122 int request_kind = packet->request_kind;
5123 bool valid = FALSE;
5124
5125 /* The dead can't act */
5127 /* At least one action must be possible */
5128 action_iterate(act) {
5129 if (action_prob_possible(act_probs[act])) {
5130 valid = TRUE;
5131 break;
5132 }
5134 }
5135
5136 switch (request_kind) {
5138 if (valid) {
5139 /* The player can select an action and should be informed. */
5140
5141 /* Show the client specific action dialog */
5145 act_probs);
5146 } else {
5147 /* Nothing to do. */
5151 }
5152 break;
5154 /* This was a background action selection dialog refresh. */
5155
5156 if (actor_unit != NULL
5158 /* The situation may have changed. */
5162 act_probs);
5163 }
5164 break;
5166 if (actor_unit != NULL) {
5169 }
5170 break;
5171 default:
5172 log_warn("Unknown request_kind %d in reply", request_kind);
5173 break;
5174 }
5175}
5176
5177/************************************************************************/
5180void handle_city_sabotage_list(int actor_id, int city_id,
5181 bv_imprs improvements,
5182 action_id act_id,
5183 int request_kind)
5184{
5185 struct city *pcity = game_city_by_number(city_id);
5186 struct unit *pactor = player_unit_by_number(client_player(), actor_id);
5187 struct action *paction = action_by_number(act_id);
5188
5189 if (!pactor) {
5190 log_debug("Bad diplomat %d.", actor_id);
5191
5192 if (request_kind == REQEST_PLAYER_INITIATED) {
5195 }
5196
5197 return;
5198 }
5199
5200 if (!pcity) {
5201 log_debug("Bad city %d.", city_id);
5202
5203 if (request_kind == REQEST_PLAYER_INITIATED) {
5207 }
5208
5209 return;
5210 }
5211
5213 improvement_iterate(pimprove) {
5214 update_improvement_from_packet(pcity, pimprove,
5215 BV_ISSET(improvements,
5216 improvement_index(pimprove)));
5218
5219 if (request_kind == REQEST_PLAYER_INITIATED) {
5220 /* Focus on the unit so the player knows where it is */
5222
5224 } else {
5225 /* Not in use (yet). */
5226 log_error("Unimplemented: received background city building list.");
5227 }
5228 } else {
5229 log_debug("Can't issue orders");
5230 if (request_kind == REQEST_PLAYER_INITIATED) {
5233 }
5234 }
5235}
5236
5237/************************************************************************/
5246
5247/************************************************************************/
5251{
5252 if (client_has_player()
5253 && packet->player_id == player_number(client_player())) {
5254 if (packet->winner) {
5255 start_menu_music("music_victory", NULL);
5256 } else {
5257 start_menu_music("music_defeat", NULL);
5258 }
5259 }
5261}
5262
5263/************************************************************************/
5267 (const struct packet_player_attribute_chunk *packet)
5268{
5269 if (!client_has_player()) {
5270 return;
5271 }
5272
5274
5275 if (packet->offset + packet->chunk_length == packet->total_length) {
5276 /* We successful received the last chunk. The attribute block is
5277 now complete. */
5279 }
5280}
5281
5282/************************************************************************/
5286{
5288
5292 client.last_processed_request_id_seen);
5294 request_id_of_currently_handled_packet);
5295
5296 log_debug("start processing packet %d",
5298}
5299
5300/************************************************************************/
5319
5320/************************************************************************/
5324 int packet_type, int size)
5325{
5326 fc_assert(pc == &client.conn);
5327 log_debug("incoming packet={type=%d, size=%d}", packet_type, size);
5328}
5329
5330/************************************************************************/
5334 int packet_type, int size,
5335 int request_id)
5336{
5337 fc_assert(pc == &client.conn);
5338 log_debug("outgoing packet={type=%d, size=%d, request_id=%d}",
5340
5342}
5343
5344/************************************************************************/
5348{
5349 log_debug("handle_freeze_client");
5350
5352}
5353
5354/************************************************************************/
5358{
5359 log_debug("handle_thaw_client");
5360
5363}
5364
5365/************************************************************************/
5369{
5371}
5372
5373/************************************************************************/
5377{
5378 log_verbose("server shutdown");
5379}
5380
5381/************************************************************************/
5385{
5386 recv_ruleset_effect(packet);
5387}
5388
5389/************************************************************************/
5395void handle_edit_object_created(int tag, int id)
5396{
5398}
5399
5400/************************************************************************/
5404{
5405 struct tile *ptile = index_to_tile(&(wld.map), packet->id);
5406 bool changed = FALSE;
5407
5408 /* Check. */
5409 if (NULL == ptile) {
5410 log_error("%s(): invalid tile index %d.", __FUNCTION__, packet->id);
5411 return;
5412 }
5413
5414 /* Handle. */
5415 if (packet->removal) {
5416 changed = map_startpos_remove(ptile);
5417 } else {
5418 if (NULL != map_startpos_get(ptile)) {
5419 changed = FALSE;
5420 } else {
5421 map_startpos_new(ptile);
5422 changed = TRUE;
5423 }
5424 }
5425
5426 /* Notify. */
5427 if (changed && can_client_change_view()) {
5429 if (packet->removal) {
5431 packet->id, TRUE);
5432 } else {
5433 editgui_notify_object_created(packet->tag, packet->id);
5434 }
5435 }
5436}
5437
5438/************************************************************************/
5442 packet)
5443{
5444 struct tile *ptile = index_to_tile(&(wld.map), packet->id);
5445 struct startpos *psp;
5446
5447 /* Check. */
5448 if (NULL == ptile) {
5449 log_error("%s(): invalid tile index %d.", __FUNCTION__, packet->id);
5450 return;
5451 }
5452
5453 psp = map_startpos_get(ptile);
5454 if (NULL == psp) {
5455 log_error("%s(): no start position at (%d, %d)",
5456 __FUNCTION__, TILE_XY(ptile));
5457 return;
5458 }
5459
5460 /* Handle. */
5461 if (startpos_unpack(psp, packet) && can_client_change_view()) {
5462 /* Notify. */
5465 FALSE);
5466 }
5467}
5468
5469/************************************************************************/
5473{
5474 game.client.fog_of_war = enabled;
5475
5476 menus_update();
5477}
5478
5479/************************************************************************/
5482void handle_vote_remove(int vote_no)
5483{
5486}
5487
5488/************************************************************************/
5491void handle_vote_update(int vote_no, int yes, int no, int abstain,
5492 int num_voters)
5493{
5494 struct voteinfo *vi;
5495
5497
5499 "Got packet_vote_update for non-existent vote %d!",
5500 vote_no);
5501
5502 vi->yes = yes;
5503 vi->no = no;
5504 vi->abstain = abstain;
5505 vi->num_voters = num_voters;
5506
5508}
5509
5510/************************************************************************/
5513void handle_vote_new(const struct packet_vote_new *packet)
5514{
5516 "Got a packet_vote_new for already existing "
5517 "vote %d!", packet->vote_no);
5518
5520 packet->user,
5521 packet->desc,
5522 packet->percent_required,
5523 packet->flags);
5525}
5526
5527/************************************************************************/
5531{
5532 struct voteinfo *vi;
5533
5535
5537 "Got packet_vote_resolve for non-existent vote %d!",
5538 vote_no);
5539
5540 vi->resolved = TRUE;
5541 vi->passed = passed;
5542
5544}
5545
5546/************************************************************************/
5549void handle_play_music(const char *tag)
5550{
5551 play_single_track(tag);
5552}
5553
5554/************************************************************************/
5557void handle_popup_image(const char *tag)
5558{
5559 popup_image(tag);
5560}
5561
5562/************************************************************************/
5565void handle_diplomacy_init_meeting(int counterpart, int initiated_from)
5566{
5567 client_init_meeting(counterpart, initiated_from);
5568}
5569
5570/************************************************************************/
5573void handle_diplomacy_accept_treaty(int counterpart, bool I_accepted,
5574 bool other_accepted)
5575{
5576 client_recv_accept_treaty(counterpart, I_accepted, other_accepted);
5577}
5578
5579/************************************************************************/
5582void handle_diplomacy_cancel_meeting(int counterpart, int initiated_from)
5583{
5584 client_recv_cancel_meeting(counterpart, initiated_from);
5585}
5586
5587/************************************************************************/
5590void handle_diplomacy_create_clause(int counterpart, int giver,
5591 enum clause_type type, int value)
5592{
5593 client_recv_create_clause(counterpart, giver, type, value);
5594}
5595
5596/************************************************************************/
5599void handle_diplomacy_remove_clause(int counterpart, int giver,
5600 enum clause_type type, int value)
5601{
5602 client_recv_remove_clause(counterpart, giver, type, value);
5603}
5604
5605/**********************************************************************/
5610{
5613
5614 names_set(&curr->name, NULL, packet->name, packet->rule_name);
5615 curr->checkpoint = packet->checkpoint;
5616 curr->type = packet->behavior;
5617 curr->target = packet->type;
5618 curr->def = packet->def;
5619
5621 || curr->target != CTGT_CITY) {
5622 return;
5623 }
5624
5625 PACKET_STRVEC_EXTRACT(curr->helptext, packet->helptext);
5627}
5628
5629/**********************************************************************/
5633{
5634 int i;
5635 int counters_count;
5636 struct city *pcity = game_city_by_number(packet->city);
5637
5638 if (NULL == pcity) {
5639 return;
5640 }
5641
5643 if (counters_count != packet->count) {
5644 return;
5645 }
5646
5647 for (i = 0; i < counters_count; i++) {
5648 pcity->counter_values[i] = packet->counters[i];
5649 }
5650
5651 if (pcity->tile != NULL) {
5652 /* City's location known */
5654 }
5655
5657}
5658
5659/**********************************************************************/
5663{
5664 options_sync_reply(serial);
5665}
struct achievement * achievement_by_number(int id)
struct action_auto_perf * action_auto_perf_slot_number(const int num)
Definition actions.c:6421
bool action_prob_possible(const struct act_prob probability)
Definition actions.c:5821
void actions_rs_pre_san_gen(void)
Definition actions.c:1654
void action_enabler_add(struct action_enabler *enabler)
Definition actions.c:2282
struct action_enabler * action_enabler_new(void)
Definition actions.c:2236
bool action_id_exists(const action_id act_id)
Definition actions.c:1829
static struct action * action_by_number(action_id act_id)
Definition actions.h:635
#define action_array_iterate(_act_array_, _act_id_)
Definition actions.h:497
#define action_id_requires_details(act_id)
Definition actions.h:673
#define action_array_iterate_end
Definition actions.h:509
#define action_iterate_end
Definition actions.h:465
#define action_iterate(_act_)
Definition actions.h:461
#define action_id_get_target_kind(act_id)
Definition actions.h:652
#define ACTION_NONE
Definition actions.h:311
void agents_unit_changed(struct unit *punit)
Definition agents.c:511
void agents_city_remove(struct city *pcity)
Definition agents.c:640
void agents_thaw_hint(void)
Definition agents.c:440
void agents_tile_remove(struct tile *ptile)
Definition agents.c:667
void agents_city_new(struct city *pcity)
Definition agents.c:614
void agents_start_turn(void)
Definition agents.c:474
void agents_tile_changed(struct tile *ptile)
Definition agents.c:691
void agents_unit_new(struct unit *punit)
Definition agents.c:536
void agents_unit_remove(struct unit *punit)
Definition agents.c:562
void agents_processing_started(void)
Definition agents.c:413
void agents_tile_new(struct tile *ptile)
Definition agents.c:715
void agents_processing_finished(void)
Definition agents.c:422
void agents_new_turn(void)
Definition agents.c:483
void agents_city_changed(struct city *pcity)
Definition agents.c:588
void agents_game_joined(void)
Definition agents.c:449
void agents_freeze_hint(void)
Definition agents.c:431
void agents_before_new_turn(void)
Definition agents.c:466
void attribute_restore(void)
Definition attribute.c:355
void audio_restart(const char *soundset_name, const char *musicset_name)
Definition audio.c:376
void audio_play_sound(const char *const tag, const char *const alt_tag, const char *const alt_tag2)
Definition audio.c:528
void base_type_init(struct extra_type *pextra, int idx)
Definition base.c:117
struct extra_type * base_extra_get(const struct base_type *pbase)
Definition base.c:101
struct base_type * base_by_number(const Base_type_id id)
Definition base.c:76
bool territory_claiming_base(const struct base_type *pbase)
Definition base.c:158
void dbv_set(struct dbv *pdbv, int bit)
Definition bitvector.c:144
void dbv_clr(struct dbv *pdbv, int bit)
Definition bitvector.c:167
#define BV_SET_VAL(bv, bit, val)
Definition bitvector.h:91
#define BV_SET(bv, bit)
Definition bitvector.h:81
#define BV_ARE_EQUAL(vec1, vec2)
Definition bitvector.h:113
#define BV_ISSET(bv, bit)
Definition bitvector.h:78
#define BV_CLR(bv, bit)
Definition bitvector.h:86
bool has_capability(const char *cap, const char *capstr)
Definition capability.c:77
const char *const our_capability
Definition capstr.c:32
void output_window_append(const struct ft_color color, const char *featured_text)
void output_window_printf(const struct ft_color color, const char *format,...)
void citizens_nation_set(struct city *pcity, const struct player_slot *pslot, citizens count)
Definition citizens.c:145
citizens citizens_count(const struct city *pcity)
Definition citizens.c:162
void citizens_init(struct city *pcity)
Definition citizens.c:32
void city_map_radius_sq_set(struct city *pcity, int radius_sq)
Definition city.c:148
void city_name_set(struct city *pcity, const char *new_name)
Definition city.c:1145
void city_styles_alloc(int num)
Definition city.c:3396
const char * city_name_get(const struct city *pcity)
Definition city.c:1137
void city_production_caravan_shields_init(void)
Definition city.c:1778
void city_remove_improvement(struct city *pcity, const struct impr_type *pimprove)
Definition city.c:3371
void city_size_add(struct city *pcity, int add)
Definition city.c:1164
void free_city_map_index(void)
Definition city.c:609
bool city_unhappy(const struct city *pcity)
Definition city.c:1626
struct city * create_city_virtual(struct player *pplayer, struct tile *ptile, const char *name)
Definition city.c:3430
bool city_happy(const struct city *pcity)
Definition city.c:1614
void city_size_set(struct city *pcity, citizens size)
Definition city.c:1180
void city_add_improvement(struct city *pcity, const struct impr_type *pimprove)
Definition city.c:3357
int city_map_radius_sq_get(const struct city *pcity)
Definition city.c:137
void destroy_city_virtual(struct city *pcity)
Definition city.c:3516
void city_rally_point_receive(const struct packet_city_rally_point *packet, struct city *pcity)
Definition city.c:3641
static const struct city struct citystyle * city_styles
Definition city.c:84
#define city_list_iterate(citylist, pcity)
Definition city.h:508
#define city_tile(_pcity_)
Definition city.h:564
static citizens city_size_get(const struct city *pcity)
Definition city.h:569
#define city_tile_iterate_skip_free_worked(_nmap, _radius_sq, _city_tile, _tile, _index, _x, _y)
Definition city.h:214
@ CITIZEN_LAST
Definition city.h:272
@ CITIZEN_ANGRY
Definition city.h:271
@ CITIZEN_HAPPY
Definition city.h:268
@ CITIZEN_CONTENT
Definition city.h:269
@ CITIZEN_UNHAPPY
Definition city.h:270
#define output_type_iterate(output)
Definition city.h:845
#define city_owner(_pcity_)
Definition city.h:563
#define city_tile_iterate_skip_free_worked_end
Definition city.h:222
#define city_list_iterate_end
Definition city.h:510
#define I_NEVER
Definition city.h:247
@ FEELING_FINAL
Definition city.h:284
@ FEELING_LAST
Definition city.h:285
#define output_type_iterate_end
Definition city.h:851
void generate_citydlg_dimensions(void)
void popup_city_dialog(struct city *pcity)
void refresh_city_dialog(struct city *pcity)
void city_report_dialog_update_city(struct city *pcity)
void city_report_dialog_update(void)
char music_set_name[512]
void start_turn_change_wait(void)
bool client_is_global_observer(void)
void client_remove_cli_conn(struct connection *pconn)
bool client_is_observer(void)
void stop_turn_change_wait(void)
void set_server_busy(bool busy)
void user_ended_turn(void)
struct civclient client
bool auto_connect
enum client_states client_state(void)
void set_seconds_to_turndone(double seconds)
char sound_set_name[512]
bool can_client_issue_orders(void)
bool client_has_player(void)
void set_client_state(enum client_states newstate)
bool can_client_change_view(void)
#define client_player()
@ C_S_PREPARING
Definition client_main.h:46
@ C_S_RUNNING
Definition client_main.h:47
@ C_S_OVER
Definition client_main.h:48
enum known_type client_tile_get_known(const struct tile *ptile)
Definition climap.c:36
void create_event(struct tile *ptile, enum event_type event, const struct ft_color color, const char *format,...)
Definition climisc.c:1092
void client_player_init(struct player *pplayer)
Definition climisc.c:1372
void client_remove_city(struct city *pcity)
Definition climisc.c:134
void client_player_maps_reset(void)
Definition climisc.c:1383
void client_remove_unit(struct unit *punit)
Definition climisc.c:72
void unit_focus_set_status(struct player *pplayer)
Definition climisc.c:1362
void handle_event(const char *featured_text, struct tile *ptile, enum event_type event, int turn, int phase, int conn_id)
Definition climisc.c:967
void client_recv_remove_clause(int counterpart, int giver, enum clause_type type, int value)
Definition clitreaty.c:131
void client_recv_create_clause(int counterpart, int giver, enum clause_type type, int value)
Definition clitreaty.c:105
void client_recv_accept_treaty(int counterpart, bool I_accepted, bool other_accepted)
Definition clitreaty.c:59
void client_recv_cancel_meeting(int counterpart, int initiated_from)
Definition clitreaty.c:83
void client_init_meeting(int counterpart, int initiated_from)
Definition clitreaty.c:33
static void city_changed(int city_id)
Definition cma_core.c:448
char * incite_cost
Definition comments.c:75
void send_client_wants_hack(const char *filename)
int get_next_request_id(int old_request_id)
Definition connection.c:530
void conn_set_capability(struct connection *pconn, const char *capability)
Definition connection.c:661
struct connection * conn_by_number(int id)
Definition connection.c:421
#define conn_list_iterate(connlist, pconn)
Definition connection.h:108
#define conn_list_iterate_end
Definition connection.h:110
void do_move_unit(struct unit *punit, struct unit *target_unit)
Definition control.c:2802
bool unit_is_in_focus(const struct unit *punit)
Definition control.c:388
void action_selection_no_longer_in_progress(const int old_actor_id)
Definition control.c:1051
struct unit * get_focus_unit_on_tile(const struct tile *ptile)
Definition control.c:396
void action_decision_request(struct unit *actor_unit)
Definition control.c:1110
void set_units_in_combat(struct unit *pattacker, struct unit *pdefender)
Definition control.c:1032
void clear_hover_state(void)
Definition control.c:328
void unit_focus_set(struct unit *punit)
Definition control.c:506
bool should_ask_server_for_actions(const struct unit *punit)
Definition control.c:339
struct unit_list * get_units_in_focus(void)
Definition control.c:177
void request_do_action(action_id action, int actor_id, int target_id, int sub_tgt, const char *name)
Definition control.c:1730
void unit_focus_urgent(struct unit *punit)
Definition control.c:207
void unit_change_battlegroup(struct unit *punit, int battlegroup)
Definition control.c:255
bool non_ai_unit_focus
Definition control.c:125
void action_decision_clear_want(const int old_actor_id)
Definition control.c:1080
int get_num_units_in_focus(void)
Definition control.c:185
void unit_register_battlegroup(struct unit *punit)
Definition control.c:275
void unit_focus_update(void)
Definition control.c:789
void auto_center_on_focus_unit(void)
Definition control.c:434
void request_new_unit_activity(struct unit *punit, enum unit_activity act)
Definition control.c:1929
void action_selection_next_in_focus(const int old_actor_id)
Definition control.c:1092
int counters_get_city_counters_count(void)
Definition counters.c:74
struct counter * counter_by_id(int id)
Definition counters.c:82
void attach_city_counter(struct counter *counter)
Definition counters.c:94
struct unit struct city struct unit * target_unit
Definition dialogs_g.h:56
popup_action_selection
Definition dialogs_g.h:55
struct unit * actor_unit
Definition dialogs_g.h:55
struct unit struct city struct unit struct tile struct extra_type const struct act_prob *act_probs int actor_unit_id popup_bribe_dialog
Definition dialogs_g.h:73
const char * caption
Definition dialogs_g.h:37
const char const char * headline
Definition dialogs_g.h:38
popup_notify_dialog
Definition dialogs_g.h:37
struct unit struct city struct unit struct tile * target_tile
Definition dialogs_g.h:57
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:74
struct unit struct city * target_city
Definition dialogs_g.h:56
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 int cost
Definition dialogs_g.h:74
struct unit struct city struct unit struct tile struct extra_type * target_extra
Definition dialogs_g.h:57
struct clause_info * clause_info_get(enum clause_type type)
Definition diptreaty.c:276
struct disaster_type * disaster_by_number(Disaster_type_id id)
Definition disaster.c:87
editgui_notify_object_changed
Definition editgui_g.h:27
int int id
Definition editgui_g.h:28
bool editor_is_active(void)
Definition editor.c:347
void editor_ruleset_changed(void)
Definition editor.c:181
@ OBJTYPE_PLAYER
Definition editor.h:30
@ OBJTYPE_UNIT
Definition editor.h:28
@ OBJTYPE_STARTPOS
Definition editor.h:27
@ OBJTYPE_GAME
Definition editor.h:31
@ OBJTYPE_CITY
Definition editor.h:29
@ OBJTYPE_TILE
Definition editor.h:26
void recv_ruleset_effect(const struct packet_ruleset_effect *packet)
Definition effects.c:591
struct @21::@22 reqs
enum event_type event
Definition events.c:81
const char * get_event_tag(enum event_type event)
Definition events.c:276
struct player * extra_owner(const struct tile *ptile)
Definition extras.c:1114
void set_user_extra_flag_name(enum extra_flag_id id, const char *name, const char *helptxt)
Definition extras.c:933
struct extra_type_list * extra_type_list_of_zoccers(void)
Definition extras.c:267
bool extra_has_flag(const struct extra_type *pextra, enum extra_flag_id flag)
Definition extras.c:861
struct extra_type_list * extra_type_list_by_cause(enum extra_cause cause)
Definition extras.c:249
void extra_to_caused_by_list(struct extra_type *pextra, enum extra_cause cause)
Definition extras.c:312
struct extra_type * extra_by_number(int id)
Definition extras.c:183
struct extra_type_list * extra_type_list_of_terr_claimers(void)
Definition extras.c:275
bool is_extra_removed_by(const struct extra_type *pextra, enum extra_rmcause rmcause)
Definition extras.c:353
struct extra_type_list * extra_type_list_of_unit_hiders(void)
Definition extras.c:259
#define extra_type_iterate(_p)
Definition extras.h:315
static void extra_to_removed_by_list(struct extra_type *pextra, enum extra_rmcause rmcause)
Definition extras.h:214
#define extra_type_iterate_end
Definition extras.h:321
#define is_extra_caused_by(e, c)
Definition extras.h:203
#define extra_index(_e_)
Definition extras.h:183
#define EXTRA_NONE
Definition extras.h:85
#define EF_LAST_USER_FLAG
Definition extras.h:82
#define MAX_DISASTER_TYPES
Definition fc_types.h:52
#define MAX_GRANARY_INIS
Definition fc_types.h:72
#define MAX_NUM_BUILDING_LIST
Definition fc_types.h:46
int Tech_type_id
Definition fc_types.h:377
#define EC_NATURAL_DEFENSIVE
Definition fc_types.h:1116
#define EC_SPECIAL
Definition fc_types.h:1114
int action_id
Definition fc_types.h:389
#define SP_MAX
Definition fc_types.h:409
#define EC_NONE
Definition fc_types.h:1113
#define EC_NOT_AGGRESSIVE
Definition fc_types.h:1117
#define EC_DEFENSIVE
Definition fc_types.h:1115
#define IF_LAST_USER_FLAG
Definition fc_types.h:677
#define MAX_NUM_UNIT_LIST
Definition fc_types.h:45
#define MAX_EXTRA_TYPES
Definition fc_types.h:50
@ CTGT_CITY
Definition fc_types.h:126
#define MAX_ACHIEVEMENT_TYPES
Definition fc_types.h:53
#define MAX_NUM_TECH_LIST
Definition fc_types.h:44
@ O_SHIELD
Definition fc_types.h:101
@ O_FOOD
Definition fc_types.h:101
@ O_SCIENCE
Definition fc_types.h:101
@ O_GOLD
Definition fc_types.h:101
#define MAX_LEN_CITYNAME
Definition fc_types.h:67
#define MAX_COUNTERS
Definition fc_types.h:106
#define UCL_LAST
Definition fc_types.h:417
#define IDENTITY_NUMBER_ZERO
Definition fc_types.h:92
#define _(String)
Definition fcintl.h:67
const struct ft_color ftc_client
struct civ_game game
Definition game.c:62
void game_ruleset_init(void)
Definition game.c:512
bool is_player_phase(const struct player *pplayer, int phase)
Definition game.c:707
int current_turn_timeout(void)
Definition game.c:848
void game_ruleset_free(void)
Definition game.c:561
struct world wld
Definition game.c:63
struct unit * game_unit_by_number(int id)
Definition game.c:116
struct city * game_city_by_number(int id)
Definition game.c:107
void init_client_goto(void)
Definition goto.c:152
struct ruler_title * government_ruler_title_new(struct government *pgovern, const struct nation_type *pnation, const char *ruler_male_title, const char *ruler_female_title)
Definition government.c:325
struct government * government_by_number(const Government_type_id gov)
Definition government.c:103
struct government * government_of_player(const struct player *pplayer)
Definition government.c:114
void governments_alloc(int num)
Definition government.c:529
Government_type_id government_number(const struct government *pgovern)
Definition government.c:91
int action_selection_target_extra(void)
int action_selection_target_tile(void)
int action_selection_actor_unit(void)
void action_selection_close(void)
int action_selection_target_city(void)
void action_selection_refresh(struct unit *actor_unit, struct city *target_city, struct unit *target_unit, struct tile *target_tile, struct extra_type *target_extra, const struct act_prob *act_probs)
void popup_sabotage_dialog(struct unit *actor, struct city *pcity, const struct action *paction)
int action_selection_target_unit(void)
void popup_incite_dialog(struct unit *actor, struct city *pcity, int cost, const struct action *paction)
bool city_dialog_is_open(struct city *pcity)
Definition citydlg.c:587
void popdown_all_city_dialogs(void)
Definition citydlg.c:607
void refresh_unit_city_dialogs(struct unit *punit)
Definition citydlg.c:546
void server_connect(void)
Definition connectdlg.c:60
void close_connection_dialog(void)
Definition connectdlg.c:52
void races_update_pickable(bool nationset_change)
Definition dialogs.c:731
void show_tech_gained_dialog(Tech_type_id tech)
Definition dialogs.c:1524
void popdown_races_dialog(void)
Definition dialogs.c:1230
void popup_connect_msg(const char *headline, const char *message)
Definition dialogs.c:239
bool handmade_scenario_warning(void)
Definition dialogs.c:1573
void races_toggles_set_sensitive(void)
Definition dialogs.c:1245
void popup_combat_info(int attacker_unit_id, int defender_unit_id, int attacker_hp, int defender_hp, bool make_att_veteran, bool make_def_veteran)
Definition dialogs.c:1583
void popup_image(const char *tag)
Definition dialogs.c:1636
void editgui_notify_object_created(int tag, int id)
Definition editgui.c:1924
void editgui_refresh(void)
Definition editgui.c:1798
static GtkWidget * source
Definition gotodlg.c:58
enum gui_type get_gui_type(void)
Definition gui_main.c:2077
void update_infra_dialog(void)
Definition infradlg.c:138
void close_intel_dialog(struct player *p)
Definition inteldlg.c:223
void update_intel_dialog(struct player *p)
Definition inteldlg.c:462
void popup_newcity_dialog(struct unit *punit, const char *suggestname)
Definition mapctrl.c:197
void update_info_label(void)
Definition mapview.c:138
void start_turn(void)
Definition mapview.c:805
void update_unit_info_label(struct unit_list *punits)
Definition mapview.c:275
void update_city_descriptions(void)
Definition mapview.c:488
void update_start_page(void)
Definition pages.c:1675
void science_report_dialog_popup(bool raise)
Definition repodlgs.c:716
void endgame_report_dialog_start(const struct packet_endgame_report *packet)
Definition repodlgs.c:1983
GType type
Definition repodlgs.c:1313
void science_report_dialog_redraw(void)
Definition repodlgs.c:761
void popup_musicset_suggestion_dialog(void)
void popup_soundset_suggestion_dialog(void)
void refresh_spaceship_dialog(struct player *pplayer)
void popup_tileset_suggestion_dialog(void)
Definition tileset_dlg.c:58
void voteinfo_gui_update(void)
void conn_list_dialog_update(void)
void boot_help_texts(void)
Definition helpdata.c:768
void idex_register_unit(struct world *iworld, struct unit *punit)
Definition idex.c:82
void idex_unregister_city(struct world *iworld, struct city *pcity)
Definition idex.c:97
void idex_register_city(struct world *iworld, struct city *pcity)
Definition idex.c:67
struct impr_type * improvement_by_number(const Impr_type_id id)
const char * improvement_rule_name(const struct impr_type *pimprove)
bool is_improvement_visible(const struct impr_type *pimprove)
Impr_type_id improvement_index(const struct impr_type *pimprove)
void improvement_feature_cache_init(void)
Definition improvement.c:92
void set_user_impr_flag_name(enum impr_flag_id id, const char *name, const char *helptxt)
Impr_type_id improvement_count(void)
#define improvement_iterate_end
#define improvement_iterate(_p)
#define B_LAST
Definition improvement.h:42
const char * name
Definition inputfile.c:127
#define fc_assert_msg(condition, message,...)
Definition log.h:181
#define fc_assert_ret(condition)
Definition log.h:191
#define log_packet
Definition log.h:137
#define log_warn(message,...)
Definition log.h:105
#define log_verbose(message,...)
Definition log.h:109
#define fc_assert(condition)
Definition log.h:176
#define fc_assert_ret_msg(condition, message,...)
Definition log.h:205
#define fc_assert_ret_val(condition, val)
Definition log.h:194
#define fc_assert_action(condition, action)
Definition log.h:187
#define log_debug(message,...)
Definition log.h:115
#define log_normal(message,...)
Definition log.h:107
@ LOG_NORMAL
Definition log.h:32
#define log_error(message,...)
Definition log.h:103
struct startpos * map_startpos_get(const struct tile *ptile)
Definition map.c:1883
int startpos_number(const struct startpos *psp)
Definition map.c:1633
void map_free(struct civ_map *fmap)
Definition map.c:530
int sq_map_distance(const struct tile *tile0, const struct tile *tile1)
Definition map.c:641
struct startpos * map_startpos_new(struct tile *ptile)
Definition map.c:1866
void map_init_topology(struct civ_map *nmap)
Definition map.c:303
void main_map_allocate(void)
Definition map.c:519
struct tile * index_to_tile(const struct civ_map *imap, int mindex)
Definition map.c:456
bool map_startpos_remove(struct tile *ptile)
Definition map.c:1899
bool same_pos(const struct tile *tile1, const struct tile *tile2)
Definition map.c:940
bool startpos_unpack(struct startpos *psp, const struct packet_edit_startpos_full *packet)
Definition map.c:1726
struct terrain_misc terrain_control
Definition map.c:69
bool map_is_empty(void)
Definition map.c:149
#define whole_map_iterate(_map, _tile)
Definition map.h:545
#define whole_map_iterate_end
Definition map.h:554
void upgrade_canvas_clipboard(void)
void update_turn_done_button_state(void)
struct city * city_workers_display
void put_nuke_mushroom_pixmaps(struct tile *ptile)
void update_map_canvas_visible(void)
bool tile_visible_mapcanvas(struct tile *ptile)
enum topo_comp_lvl tileset_map_topo_compatible(int topology_id, struct tileset *tset, int *tset_topo)
void refresh_city_mapcanvas(struct city *pcity, struct tile *ptile, bool full_refresh, bool write_to_screen)
void mapdeco_init(void)
void center_tile_mapcanvas(const struct tile *ptile)
void link_marks_decrease_turn_counters(void)
void update_city_description(struct city *pcity)
const char * describe_topology(int topo)
void refresh_tile_mapcanvas(struct tile *ptile, bool full_refresh, bool write_to_screen)
void refresh_unit_mapcanvas(struct unit *punit, struct tile *ptile, bool full_refresh, bool write_to_screen)
void decrease_unit_hp_smooth(struct unit *punit0, int hp0, struct unit *punit1, int hp1)
@ TOPO_INCOMP_HARD
#define fc_calloc(n, esz)
Definition mem.h:38
#define FC_FREE(ptr)
Definition mem.h:41
#define fc_strdup(str)
Definition mem.h:43
#define fc_malloc(sz)
Definition mem.h:34
void menus_update(void)
void meswin_clear_older(int turn, int phase)
int utype_unknown_move_cost(const struct unit_type *utype)
Definition movement.c:105
void init_move_fragments(void)
Definition movement.c:959
Multiplier_type_id multiplier_count(void)
Definition multipliers.c:88
struct multiplier * multiplier_by_number(Multiplier_type_id id)
Definition multipliers.c:57
Multiplier_type_id multiplier_index(const struct multiplier *pmul)
Definition multipliers.c:80
#define multipliers_iterate(_mul_)
Definition multipliers.h:61
#define multipliers_iterate_end
Definition multipliers.h:67
void play_single_track(const char *const tag)
Definition music.c:116
void start_menu_music(const char *const tag, char *const alt_tag)
Definition music.c:98
void start_style_music(void)
Definition music.c:44
static void name_set(struct name_translation *ptrans, const char *domain, const char *vernacular_name)
static void names_set(struct name_translation *ptrans, const char *domain, const char *vernacular_name, const char *rule_name)
const char * nation_rule_name(const struct nation_type *pnation)
Definition nation.c:138
int nation_group_index(const struct nation_group *pgroup)
Definition nation.c:943
Nation_type_id nation_count(void)
Definition nation.c:507
struct nation_group * nation_group_new(const char *name)
Definition nation.c:960
struct nation_type * nation_of_unit(const struct unit *punit)
Definition nation.c:463
struct nation_set * nation_set_new(const char *set_name, const char *set_rule_name, const char *set_description)
Definition nation.c:716
struct nation_type * nation_by_number(const Nation_type_id nation)
Definition nation.c:475
int nation_set_index(const struct nation_set *pset)
Definition nation.c:699
struct nation_type * nation_of_city(const struct city *pcity)
Definition nation.c:454
struct nation_set * nation_set_by_number(int id)
Definition nation.c:762
struct nation_group * nation_group_by_number(int id)
Definition nation.c:1004
struct nation_leader * nation_leader_new(struct nation_type *pnation, const char *name, bool is_male)
Definition nation.c:239
void nations_alloc(int num)
Definition nation.c:622
const char * nation_legend_translation(const struct nation_type *pnation, const char *legend)
Definition nation.c:299
void resend_desired_settable_options(void)
Definition options.c:5768
const char * tileset_name_for_topology(int topology_id)
Definition options.c:6580
void options_sync_reply(int serial)
Definition options.c:6130
struct client_options gui_options
Definition options.c:72
void calculate_overview_dimensions(void)
void generic_handle_player_attribute_chunk(struct player *pplayer, const struct packet_player_attribute_chunk *chunk)
Definition packets.c:690
#define PACKET_STRVEC_EXTRACT(strvec, str)
Definition packets.h:191
#define REQEST_PLAYER_INITIATED
Definition packets.h:63
@ UNIT_INFO_CITY_PRESENT
Definition packets.h:69
@ UNIT_INFO_CITY_SUPPORTED
Definition packets.h:68
int dsend_packet_spaceship_place(struct connection *pc, enum spaceship_place_type type, int num)
int send_packet_conn_pong(struct connection *pc)
int dsend_packet_unit_get_actions(struct connection *pc, int actor_unit_id, int target_unit_id, int target_tile_id, int target_extra_id, int request_kind)
int dsend_packet_player_change_government(struct connection *pc, Government_type_id government)
int send_packet_client_info(struct connection *pc, const struct packet_client_info *packet)
packet_type
void handle_ruleset_game(const struct packet_ruleset_game *packet)
Definition packhand.c:4789
void handle_player_diplstate(const struct packet_player_diplstate *packet)
Definition packhand.c:2784
static action_id auto_attack_act(const struct act_prob *act_probs)
Definition packhand.c:5012
void handle_ruleset_nation_sets(const struct packet_ruleset_nation_sets *packet)
Definition packhand.c:4555
void handle_ruleset_nation(const struct packet_ruleset_nation *packet)
Definition packhand.c:4597
void handle_city_name_suggestion_info(int unit_id, const char *name)
Definition packhand.c:4860
void handle_sync_serial_reply(int serial)
Definition packhand.c:5662
static struct unit * unpackage_short_unit(const struct packet_unit_short_info *packet)
Definition packhand.c:363
void handle_nuke_tile_info(int tile)
Definition packhand.c:545
void handle_unknown_research(int id)
Definition packhand.c:2754
const action_id auto_attack_blockers[]
Definition packhand.c:162
void handle_ruleset_government_ruler_title(const struct packet_ruleset_government_ruler_title *packet)
Definition packhand.c:4017
void handle_city_info(const struct packet_city_info *packet)
Definition packhand.c:650
void handle_end_turn(void)
Definition packhand.c:1490
static struct unit * unpackage_unit(const struct packet_unit_info *packet)
Definition packhand.c:264
char * caption
Definition packhand.c:129
enum event_type event
Definition packhand.c:128
void handle_conn_info(const struct packet_conn_info *pinfo)
Definition packhand.c:2885
void handle_vote_remove(int vote_no)
Definition packhand.c:5482
void handle_investigate_finished(const struct packet_investigate_finished *packet)
Definition packhand.c:2145
void handle_page_msg_part(const char *lines)
Definition packhand.c:1620
void handle_unit_combat_info(const struct packet_unit_combat_info *packet)
Definition packhand.c:568
void handle_ruleset_style(const struct packet_ruleset_style *p)
Definition packhand.c:4705
void handle_unit_remove(int unit_id)
Definition packhand.c:491
void handle_vote_update(int vote_no, int yes, int no, int abstain, int num_voters)
Definition packhand.c:5491
static int last_turn
Definition packhand.c:137
void handle_ruleset_multiplier(const struct packet_ruleset_multiplier *p)
Definition packhand.c:3959
void handle_player_info(const struct packet_player_info *pinfo)
Definition packhand.c:2433
void handle_ruleset_extra(const struct packet_ruleset_extra *p)
Definition packhand.c:4158
void handle_ruleset_action_auto(const struct packet_ruleset_action_auto *p)
Definition packhand.c:4467
void handle_map_info(const struct packet_map_info *packet)
Definition packhand.c:2223
void handle_ruleset_unit_bonus(const struct packet_ruleset_unit_bonus *p)
Definition packhand.c:3672
void handle_start_phase(int phase)
Definition packhand.c:1417
void start_revolution(void)
Definition packhand.c:2377
void handle_timeout_info(float seconds_to_phasedone, float last_turn_change_time)
Definition packhand.c:2347
void handle_ruleset_terrain_control(const struct packet_ruleset_terrain_control *p)
Definition packhand.c:4542
static struct @229 page_msg_report
const action_id auto_attack_actions[]
Definition packhand.c:145
void handle_play_music(const char *tag)
Definition packhand.c:5549
static struct @228 invisible
void handle_investigate_started(const struct packet_investigate_started *packet)
Definition packhand.c:2121
void handle_edit_object_created(int tag, int id)
Definition packhand.c:5395
int parts
Definition packhand.c:132
void handle_conn_ping(void)
Definition packhand.c:5368
void handle_ruleset_tech_class(const struct packet_ruleset_tech_class *p)
Definition packhand.c:3844
void handle_diplomacy_init_meeting(int counterpart, int initiated_from)
Definition packhand.c:5565
void handle_ruleset_control(const struct packet_ruleset_control *packet)
Definition packhand.c:3403
void handle_end_phase(void)
Definition packhand.c:1406
void handle_ruleset_counter(const struct packet_ruleset_counter *packet)
Definition packhand.c:5609
void handle_server_info(const char *version_label, int major_version, int minor_version, int patch_version, int emerg_version)
Definition packhand.c:1573
void handle_ruleset_nation_groups(const struct packet_ruleset_nation_groups *packet)
Definition packhand.c:4576
void handle_ruleset_effect(const struct packet_ruleset_effect *packet)
Definition packhand.c:5384
void handle_new_year(int year, int fragments, int turn)
Definition packhand.c:1357
char * headline
Definition packhand.c:130
void handle_research_info(const struct packet_research_info *packet)
Definition packhand.c:2670
void handle_ruleset_goods(const struct packet_ruleset_goods *p)
Definition packhand.c:4374
void handle_unit_info(const struct packet_unit_info *packet)
Definition packhand.c:1646
void handle_ruleset_city(const struct packet_ruleset_city *packet)
Definition packhand.c:4740
void handle_ruleset_unit_class(const struct packet_ruleset_unit_class *p)
Definition packhand.c:3581
void handle_ruleset_government(const struct packet_ruleset_government *p)
Definition packhand.c:3987
void handle_ruleset_terrain_flag(const struct packet_ruleset_terrain_flag *p)
Definition packhand.c:4114
void handle_connect_msg(const char *message)
Definition packhand.c:1564
#define REQEST_BACKGROUND_REFRESH
Definition packhand.c:140
void handle_rulesets_ready(void)
Definition packhand.c:3527
void handle_tile_info(const struct packet_tile_info *packet)
Definition packhand.c:3115
void handle_ruleset_action(const struct packet_ruleset_action *p)
Definition packhand.c:4399
static void action_decision_handle(struct unit *punit)
Definition packhand.c:1662
void handle_achievement_info(int id, bool gained, bool first)
Definition packhand.c:3014
void handle_scenario_description(const char *description)
Definition packhand.c:3391
void play_sound_for_event(enum event_type type)
Definition packhand.c:1517
void handle_edit_startpos(const struct packet_edit_startpos *packet)
Definition packhand.c:5403
void handle_processing_finished(void)
Definition packhand.c:5303
static int unpack_tech_req(const enum tech_req r_num, const int reqs_size, const struct requirement *reqs, struct advance *a, int i)
Definition packhand.c:3749
void handle_diplomacy_cancel_meeting(int counterpart, int initiated_from)
Definition packhand.c:5582
void handle_city_short_info(const struct packet_city_short_info *packet)
Definition packhand.c:1158
void handle_edit_fogofwar_state(bool enabled)
Definition packhand.c:5472
void handle_popup_image(const char *tag)
Definition packhand.c:5557
void handle_diplomacy_create_clause(int counterpart, int giver, enum clause_type type, int value)
Definition packhand.c:5590
void handle_endgame_player(const struct packet_endgame_player *packet)
Definition packhand.c:5250
void handle_ruleset_resource(const struct packet_ruleset_resource *p)
Definition packhand.c:4139
void handle_unit_action_answer(int actor_id, int target_id, int cost, action_id action_type, int request_kind)
Definition packhand.c:4896
void handle_ruleset_tech(const struct packet_ruleset_tech *p)
Definition packhand.c:3779
void handle_team_name_info(int team_id, const char *team_name)
Definition packhand.c:553
void handle_thaw_client(void)
Definition packhand.c:5357
void handle_calendar_info(const struct packet_calendar_info *pcalendar)
Definition packhand.c:2339
void packhand_free(void)
Definition packhand.c:218
void set_government_choice(struct government *government)
Definition packhand.c:2364
void handle_city_rally_point(const struct packet_city_rally_point *packet)
Definition packhand.c:1007
void handle_ruleset_disaster(const struct packet_ruleset_disaster *p)
Definition packhand.c:4489
static bool handle_unit_packet_common(struct unit *packet_unit)
Definition packhand.c:1700
void handle_ruleset_unit_class_flag(const struct packet_ruleset_unit_class_flag *p)
Definition packhand.c:3717
void handle_server_join_reply(bool you_can_join, const char *message, const char *capability, const char *challenge_file, int conn_id)
Definition packhand.c:400
void handle_ruleset_summary(const struct packet_ruleset_summary *packet)
Definition packhand.c:3499
void handle_set_topology(int topology_id, int wrap_id)
Definition packhand.c:2200
void handle_ruleset_impr_flag(const struct packet_ruleset_impr_flag *p)
Definition packhand.c:3933
void handle_page_msg(const char *caption, const char *headline, enum event_type event, int len, int parts)
Definition packhand.c:1589
void handle_city_update_counters(const struct packet_city_update_counters *packet)
Definition packhand.c:5632
void handle_edit_startpos_full(const struct packet_edit_startpos_full *packet)
Definition packhand.c:5441
void handle_conn_ping_info(int connections, const int *conn_id, const float *ping_time)
Definition packhand.c:2991
void handle_diplomacy_remove_clause(int counterpart, int giver, enum clause_type type, int value)
Definition packhand.c:5599
static bool spaceship_autoplace(struct player *pplayer, struct player_spaceship *ship)
Definition packhand.c:3051
void handle_player_remove(int playerno)
Definition packhand.c:2388
void handle_processing_started(void)
Definition packhand.c:5285
void handle_begin_turn(void)
Definition packhand.c:1476
void handle_endgame_report(const struct packet_endgame_report *packet)
Definition packhand.c:5241
void handle_early_chat_msg(const struct packet_early_chat_msg *packet)
Definition packhand.c:1550
void handle_ruleset_clause(const struct packet_ruleset_clause *p)
Definition packhand.c:4717
void handle_ruleset_road(const struct packet_ruleset_road *p)
Definition packhand.c:4343
void handle_unit_actions(const struct packet_unit_actions *packet)
Definition packhand.c:5110
void handle_ruleset_music(const struct packet_ruleset_music *packet)
Definition packhand.c:4766
void handle_ruleset_base(const struct packet_ruleset_base *p)
Definition packhand.c:4322
void notify_about_incoming_packet(struct connection *pc, int packet_type, int size)
Definition packhand.c:5323
void handle_freeze_client(void)
Definition packhand.c:5347
void handle_city_remove(int city_id)
Definition packhand.c:468
void handle_chat_msg(const struct packet_chat_msg *packet)
Definition packhand.c:1530
static void city_packet_common(struct city *pcity, struct tile *pcenter, struct player *powner, struct tile_list *worked_tiles, bool is_new, bool popup, bool investigate)
Definition packhand.c:1021
void handle_trade_route_info(const struct packet_trade_route_info *packet)
Definition packhand.c:1123
void handle_player_attribute_chunk(const struct packet_player_attribute_chunk *packet)
Definition packhand.c:5267
void handle_vote_new(const struct packet_vote_new *packet)
Definition packhand.c:5513
static void packhand_init(void)
Definition packhand.c:239
void handle_scenario_info(const struct packet_scenario_info *packet)
Definition packhand.c:3370
void handle_ruleset_extra_flag(const struct packet_ruleset_extra_flag *p)
Definition packhand.c:4296
char * lines
Definition packhand.c:131
void notify_about_outgoing_packet(struct connection *pc, int packet_type, int size, int request_id)
Definition packhand.c:5333
#define VALIDATE(_count, _maximum, _string)
const char forced_tileset_name[]
struct city_list * cities
Definition packhand.c:119
void handle_ruleset_tech_flag(const struct packet_ruleset_tech_flag *p)
Definition packhand.c:3857
void handle_nation_availability(int ncount, const bool *is_pickable, bool nationset_change)
Definition packhand.c:4687
void handle_spaceship_info(const struct packet_spaceship_info *p)
Definition packhand.c:3070
void handle_ruleset_specialist(const struct packet_ruleset_specialist *p)
Definition packhand.c:4834
void handle_unit_short_info(const struct packet_unit_short_info *packet)
Definition packhand.c:2152
void handle_diplomacy_accept_treaty(int counterpart, bool I_accepted, bool other_accepted)
Definition packhand.c:5573
void handle_ruleset_unit_flag(const struct packet_ruleset_unit_flag *p)
Definition packhand.c:3692
void handle_city_nationalities(const struct packet_city_nationalities *packet)
Definition packhand.c:987
void handle_server_shutdown(void)
Definition packhand.c:5376
void handle_ruleset_building(const struct packet_ruleset_building *p)
Definition packhand.c:3882
static bool update_improvement_from_packet(struct city *pcity, struct impr_type *pimprove, bool have_impr)
Definition packhand.c:628
void handle_ruleset_unit(const struct packet_ruleset_unit *p)
Definition packhand.c:3599
void handle_ruleset_terrain(const struct packet_ruleset_terrain *p)
Definition packhand.c:4031
static void action_decision_maybe_auto(struct unit *actor_unit, const struct act_prob *act_probs, struct unit *target_unit, struct city *target_city, struct tile *target_tile)
Definition packhand.c:5042
#define REQEST_BACKGROUND_FAST_AUTO_ATTACK
Definition packhand.c:142
void handle_city_sabotage_list(int actor_id, int city_id, bv_imprs improvements, action_id act_id, int request_kind)
Definition packhand.c:5180
void handle_ruleset_action_enabler(const struct packet_ruleset_action_enabler *p)
Definition packhand.c:4433
void handle_ruleset_achievement(const struct packet_ruleset_achievement *p)
Definition packhand.c:4511
void handle_game_info(const struct packet_game_info *pinfo)
Definition packhand.c:2263
struct player * placeholder
Definition packhand.c:120
void handle_vote_resolve(int vote_no, bool passed)
Definition packhand.c:5530
void handle_worker_task(const struct packet_worker_task *packet)
Definition packhand.c:1300
void handle_ruleset_description_part(const struct packet_ruleset_description_part *packet)
Definition packhand.c:3517
void handle_ruleset_trade(const struct packet_ruleset_trade *p)
Definition packhand.c:4527
int len
Definition packhand.c:127
void set_client_page(enum client_pages page)
enum client_pages get_client_page(void)
bool player_slot_is_used(const struct player_slot *pslot)
Definition player.c:448
struct unit * player_unit_by_number(const struct player *pplayer, int unit_id)
Definition player.c:1229
struct player * player_new(struct player_slot *pslot)
Definition player.c:493
struct player * player_by_number(const int player_id)
Definition player.c:849
int player_count(void)
Definition player.c:817
struct player_slot * player_slot_by_number(int player_id)
Definition player.c:463
int player_number(const struct player *pplayer)
Definition player.c:837
const char * player_name(const struct player *pplayer)
Definition player.c:895
void player_set_color(struct player *pplayer, const struct rgbcolor *prgbcolor)
Definition player.c:648
int player_index(const struct player *pplayer)
Definition player.c:829
bool player_set_nation(struct player *pplayer, struct nation_type *pnation)
Definition player.c:861
struct player_diplstate * player_diplstate_get(const struct player *plr1, const struct player *plr2)
Definition player.c:324
bool can_player_see_units_in_city(const struct player *pplayer, const struct city *pcity)
Definition player.c:1133
struct player * player_slot_get_player(const struct player_slot *pslot)
Definition player.c:437
bool can_player_see_city_internals(const struct player *pplayer, const struct city *pcity)
Definition player.c:1149
void player_destroy(struct player *pplayer)
Definition player.c:756
#define players_iterate_end
Definition player.h:537
#define players_iterate(_pplayer)
Definition player.h:532
#define ANON_USER_NAME
Definition player.h:48
#define is_ai(plr)
Definition player.h:230
#define ANON_PLAYER_NAME
Definition player.h:43
#define is_human(plr)
Definition player.h:229
void players_dialog_update(void)
#define fc_rand(_size)
Definition rand.h:56
void multipliers_dialog_update(void)
const struct packet_endgame_player *packet void science_report_dialog_update(void)
void economy_report_dialog_update(void)
void units_report_dialog_update(void)
endgame_report_dialog_player
Definition repodlgs_g.h:33
struct universal universal_by_number(const enum universals_n kind, const int value)
bool are_universals_equal(const struct universal *psource1, const struct universal *psource2)
enum tech_state research_invention_set(struct research *presearch, Tech_type_id tech, enum tech_state value)
Definition research.c:637
struct research * research_by_number(int number)
Definition research.c:118
struct research * research_get(const struct player *pplayer)
Definition research.c:128
void research_update(struct research *presearch)
Definition research.c:501
#define research_players_iterate(_presearch, _pplayer)
Definition research.h:166
#define research_players_iterate_end
Definition research.h:170
void rgbcolor_destroy(struct rgbcolor *prgbcolor)
Definition rgbcolor.c:74
struct rgbcolor * rgbcolor_new(int r, int g, int b)
Definition rgbcolor.c:34
void road_integrators_cache_init(void)
Definition road.c:111
struct road_type * road_by_number(Road_type_id id)
Definition road.c:58
void road_type_init(struct extra_type *pextra, int idx)
Definition road.c:93
void script_client_signal_emit(const char *signal_name,...)
static struct connection connections[MAX_NUM_CONNECTIONS]
Definition sernet.c:94
#define ARRAY_SIZE(x)
Definition shared.h:85
#define MIN(x, y)
Definition shared.h:55
#define MAX(x, y)
Definition shared.h:54
bool next_spaceship_component(struct player *pplayer, struct player_spaceship *ship, struct spaceship_component *fill)
Definition spaceship.c:130
struct specialist * specialist_by_number(const Specialist_type_id id)
Definition specialist.c:100
#define specialist_type_iterate_end
Definition specialist.h:79
#define specialist_type_iterate(sp)
Definition specialist.h:73
#define DEFAULT_SPECIALIST
Definition specialist.h:43
size_t size
Definition specvec.h:72
#define strvec_iterate(psv, str)
#define strvec_iterate_end
struct player * first
bool actor_consuming_always
Definition actions.h:395
int max_distance
Definition actions.h:378
bool quiet
Definition actions.h:385
enum action_sub_target_kind sub_target_kind
Definition actions.h:370
enum action_result result
Definition actions.h:365
char ui_name[MAX_LEN_NAME]
Definition actions.h:381
bv_action_sub_results sub_results
Definition actions.h:366
enum action_actor_kind actor_kind
Definition actions.h:368
bv_actions blocked_by
Definition actions.h:389
enum action_target_kind target_kind
Definition actions.h:369
int min_distance
Definition actions.h:378
struct requirement_vector research_reqs
Definition tech.h:137
struct tech_class * tclass
Definition tech.h:130
double cost
Definition tech.h:150
struct advance * require[AR_SIZE]
Definition tech.h:132
struct name_translation name
Definition tech.h:126
struct strvec * helptext
Definition tech.h:140
bv_tech_flags flags
Definition tech.h:139
int num_reqs
Definition tech.h:156
char graphic_str[MAX_LEN_NAME]
Definition tech.h:128
char graphic_alt[MAX_LEN_NAME]
Definition tech.h:129
int turn
Definition city.h:246
Definition city.h:320
struct worker_task_list * task_reqs
Definition city.h:412
int turn_last_built
Definition city.h:387
int surplus[O_LAST]
Definition city.h:355
enum city_wl_cancel_behavior wlcb
Definition city.h:404
int food_stock
Definition city.h:367
struct built_status built[B_LAST]
Definition city.h:394
struct player * original
Definition city.h:324
int history
Definition city.h:410
int * counter_values
Definition city.h:408
int pollution
Definition city.h:369
bool did_sell
Definition city.h:380
int id
Definition city.h:326
int last_turns_shield_surplus
Definition city.h:392
enum capital_type capital
Definition city.h:328
int disbanded_shields
Definition city.h:391
int waste[O_LAST]
Definition city.h:356
struct unit_list * info_units_present
Definition city.h:474
bv_city_options city_options
Definition city.h:403
int city_radius_sq
Definition city.h:375
bool was_happy
Definition city.h:381
struct player * owner
Definition city.h:323
enum city_acquire_type acquire_t
Definition city.h:329
int turn_founded
Definition city.h:386
int airlift
Definition city.h:378
int citizen_base[O_LAST]
Definition city.h:359
int caravan_shields
Definition city.h:390
bool did_buy
Definition city.h:379
struct unit_list * info_units_supported
Definition city.h:473
char * name
Definition city.h:321
struct trade_route_list * routes
Definition city.h:344
bool occupied
Definition city.h:460
int usage[O_LAST]
Definition city.h:360
struct worklist worklist
Definition city.h:401
struct universal production
Definition city.h:396
int walls
Definition city.h:461
bool happy
Definition city.h:462
struct unit_list * collecting_info_units_supported
Definition city.h:477
int steal
Definition city.h:414
int unhappy_penalty[O_LAST]
Definition city.h:357
unsigned char first_citizen_index
Definition city.h:483
int before_change_shields
Definition city.h:389
int culture
Definition city.h:465
int style
Definition city.h:327
bool had_famine
Definition city.h:382
struct unit_list * collecting_info_units_present
Definition city.h:478
int buy_cost
Definition city.h:466
citizens feel[CITIZEN_LAST][FEELING_LAST]
Definition city.h:333
citizens specialists[SP_MAX]
Definition city.h:336
struct tile * tile
Definition city.h:322
int shield_stock
Definition city.h:368
int prod[O_LAST]
Definition city.h:358
int city_image
Definition city.h:464
struct universal changed_from
Definition city.h:399
bool unhappy
Definition city.h:463
struct unit_list * units_supported
Definition city.h:406
int illness_trade
Definition city.h:370
struct city::@17::@20 client
bool fog_of_war
Definition game.h:121
struct rgbcolor * plr_bg_color
Definition game.h:103
struct packet_scenario_description scenario_desc
Definition game.h:88
struct packet_ruleset_control control
Definition game.h:83
char * ruleset_summary
Definition game.h:84
struct conn_list * est_connections
Definition game.h:97
int global_init_techs[MAX_NUM_TECH_LIST]
Definition game.h:110
struct packet_game_info info
Definition game.h:89
bool ruleset_ready
Definition game.h:119
int global_init_buildings[MAX_NUM_BUILDING_LIST]
Definition game.h:111
struct packet_scenario_info scenario
Definition game.h:87
char * ruleset_description
Definition game.h:85
struct conn_list * all_connections
Definition game.h:96
bool ruleset_init
Definition game.h:118
struct civ_game::@30 rgame
struct packet_timeout_info tinfo
Definition game.h:91
struct veteran_system * veteran
Definition game.h:101
struct packet_calendar_info calendar
Definition game.h:90
struct government * default_government
Definition game.h:93
struct civ_game::@31::@34 client
struct government * government_during_revolution
Definition game.h:94
int xsize
Definition map_types.h:78
int ysize
Definition map_types.h:78
int north_latitude
Definition map_types.h:79
Continent_id num_continents
Definition map_types.h:81
int south_latitude
Definition map_types.h:80
int topology_id
Definition map_types.h:72
int wrap_id
Definition map_types.h:73
struct connection conn
Definition client_main.h:96
struct requirement_vector receiver_reqs
Definition diptreaty.h:59
struct requirement_vector giver_reqs
Definition diptreaty.h:58
bool enabled
Definition diptreaty.h:57
bool sound_bell_at_new_turn
Definition options.h:150
bool autoaccept_tileset_suggestion
Definition options.h:183
bool autoaccept_musicset_suggestion
Definition options.h:185
bool draw_city_names
Definition options.h:196
bool draw_city_productions
Definition options.h:198
bool popup_new_cities
Definition options.h:167
bool draw_city_trade_routes
Definition options.h:200
bool wakeup_focus
Definition options.h:159
bool autoaccept_soundset_suggestion
Definition options.h:184
bool ask_city_name
Definition options.h:166
bool draw_city_growth
Definition options.h:197
bool ai_manual_turn_done
Definition options.h:154
int smooth_combat_step_msec
Definition options.h:153
bool draw_full_citybar
Definition options.h:216
bool auto_center_on_combat
Definition options.h:157
bool popup_attack_actions
Definition options.h:169
enum unit_type_flag_id flag
Definition unittype.h:467
enum combat_bonus_type type
Definition unittype.h:468
bool established
Definition connection.h:140
struct player * playing
Definition connection.h:151
int request_id_of_currently_handled_packet
Definition connection.h:193
struct connection::@58::@63 client
enum cmdlevel access_level
Definition connection.h:177
bool observer
Definition connection.h:147
char username[MAX_LEN_NAME]
Definition connection.h:164
char capability[MAX_LEN_CAPSTR]
Definition connection.h:171
int last_processed_request_id_seen
Definition connection.h:190
double ping_time
Definition connection.h:161
bv_unit_classes native_to
Definition extras.h:130
char rmact_gfx[MAX_LEN_NAME]
Definition extras.h:102
bv_extras conflicts
Definition extras.h:133
uint8_t rmcauses
Definition extras.h:95
char act_gfx_alt[MAX_LEN_NAME]
Definition extras.h:100
struct requirement_vector appearance_reqs
Definition extras.h:108
struct strvec * helptext
Definition extras.h:149
bv_extra_flags flags
Definition extras.h:132
char rmact_gfx_alt[MAX_LEN_NAME]
Definition extras.h:103
uint16_t causes
Definition extras.h:94
bv_extras bridged_over
Definition extras.h:135
struct extra_type::@25 data
int removal_time
Definition extras.h:120
char rmact_gfx_alt2[MAX_LEN_NAME]
Definition extras.h:104
int build_time_factor
Definition extras.h:119
struct requirement_vector disappearance_reqs
Definition extras.h:109
bool generated
Definition extras.h:117
int special_idx
Definition extras.h:153
struct requirement_vector rmreqs
Definition extras.h:107
Tech_type_id visibility_req
Definition extras.h:139
enum extra_category category
Definition extras.h:93
char graphic_alt[MAX_LEN_NAME]
Definition extras.h:98
char activity_gfx[MAX_LEN_NAME]
Definition extras.h:99
int disappearance_chance
Definition extras.h:126
int removal_time_factor
Definition extras.h:121
char act_gfx_alt2[MAX_LEN_NAME]
Definition extras.h:101
struct requirement_vector reqs
Definition extras.h:106
bool buildable
Definition extras.h:116
enum extra_unit_seen_type eus
Definition extras.h:128
int defense_bonus
Definition extras.h:124
int appearance_chance
Definition extras.h:125
char graphic_str[MAX_LEN_NAME]
Definition extras.h:97
int build_time
Definition extras.h:118
int infracost
Definition extras.h:122
int no_aggr_near_city
Definition extras.h:137
bv_extras hidden_by
Definition extras.h:134
struct name_translation name
Definition extras.h:90
struct strvec * helptext
Definition government.h:65
struct requirement_vector reqs
Definition government.h:62
char graphic_alt[MAX_LEN_NAME]
Definition government.h:58
Government_type_id item_number
Definition government.h:53
char sound_alt2[MAX_LEN_NAME]
Definition government.h:61
struct name_translation name
Definition government.h:54
char sound_str[MAX_LEN_NAME]
Definition government.h:59
char graphic_str[MAX_LEN_NAME]
Definition government.h:57
char sound_alt[MAX_LEN_NAME]
Definition government.h:60
int build_cost
Definition improvement.h:60
char graphic_str[MAX_LEN_NAME]
Definition improvement.h:55
char graphic_alt2[MAX_LEN_NAME]
Definition improvement.h:57
enum impr_genus_id genus
Definition improvement.h:63
char graphic_alt[MAX_LEN_NAME]
Definition improvement.h:56
struct requirement_vector obsolete_by
Definition improvement.h:59
char soundtag_alt[MAX_LEN_NAME]
Definition improvement.h:67
char soundtag_alt2[MAX_LEN_NAME]
Definition improvement.h:68
struct requirement_vector reqs
Definition improvement.h:58
struct strvec * helptext
Definition improvement.h:65
struct name_translation name
Definition improvement.h:52
bv_impr_flags flags
Definition improvement.h:64
char soundtag[MAX_LEN_NAME]
Definition improvement.h:66
struct requirement_vector reqs
Definition multipliers.h:42
struct strvec * helptext
Definition multipliers.h:43
int minimum_turns
Definition multipliers.h:41
struct name_translation name
Definition multipliers.h:33
int init_buildings[MAX_NUM_BUILDING_LIST]
Definition nation.h:123
struct nation_group_list * groups
Definition nation.h:116
struct name_translation noun_plural
Definition nation.h:102
struct nation_set_list * sets
Definition nation.h:113
char flag_graphic_str[MAX_LEN_NAME]
Definition nation.h:103
struct name_translation adjective
Definition nation.h:101
char flag_graphic_alt[MAX_LEN_NAME]
Definition nation.h:104
struct government * init_government
Definition nation.h:124
bool is_pickable
Definition nation.h:161
struct unit_type * init_units[MAX_NUM_UNIT_LIST]
Definition nation.h:125
char * legend
Definition nation.h:107
enum barbarian_type barb_type
Definition nation.h:110
struct nation_type::@51::@54 client
char * translation_domain
Definition nation.h:100
struct nation_style * style
Definition nation.h:106
int init_techs[MAX_NUM_TECH_LIST]
Definition nation.h:122
bool is_playable
Definition nation.h:109
char message[MAX_LEN_MSG]
enum event_type event
int last_turns_shield_surplus
int usage[O_LAST]
int ppl_content[FEELING_LAST]
bv_city_options city_options
enum capital_type capital
int surplus[O_LAST]
enum city_acquire_type acquire_type
int ppl_unhappy[FEELING_LAST]
int citizen_base[O_LAST]
enum city_wl_cancel_behavior wl_cb
int specialists[SP_MAX]
int ppl_angry[FEELING_LAST]
bv_imprs improvements
struct worklist worklist
char name[MAX_LEN_CITYNAME]
int ppl_happy[FEELING_LAST]
int prod[O_LAST]
int unhappy_penalty[O_LAST]
int waste[O_LAST]
int nation_id[MAX_CITY_NATIONALITIES]
int nation_citizens[MAX_CITY_NATIONALITIES]
enum capital_type capital
char name[MAX_LEN_CITYNAME]
int counters[MAX_COUNTERS]
enum event_type event
char message[MAX_LEN_MSG]
Government_type_id government_during_revolution_id
enum ai_level skill_level
enum phase_mode_type phase_mode
enum victory_condition_type victory_conditions
Government_type_id default_government_id
enum diplstate_type type
char inventions[A_LAST+1]
char rule_name[MAX_LEN_NAME]
enum achievement_type type
char name[MAX_LEN_NAME]
action_id alternatives[MAX_NUM_ACTIONS]
struct requirement reqs[MAX_NUM_REQS]
enum action_auto_perf_cause cause
struct requirement actor_reqs[MAX_NUM_REQS]
struct requirement target_reqs[MAX_NUM_REQS]
enum action_sub_target_kind sub_tgt_kind
enum action_actor_kind act_kind
bv_action_sub_results sub_results
char ui_name[MAX_LEN_NAME]
enum action_target_kind tgt_kind
enum action_result result
enum base_gui_type gui_type
char helptext[MAX_LEN_PACKET]
struct requirement obs_reqs[MAX_NUM_REQS]
char soundtag_alt[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
enum impr_genus_id genus
char name[MAX_LEN_NAME]
char soundtag[MAX_LEN_NAME]
char soundtag_alt2[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char graphic_alt2[MAX_LEN_NAME]
char graphic_str[MAX_LEN_NAME]
char graphic_alt[MAX_LEN_NAME]
char citizens_graphic[MAX_LEN_NAME]
char name[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char graphic_alt[MAX_LEN_NAME]
char graphic[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
enum clause_type type
struct requirement receiver_reqs[MAX_NUM_REQS]
struct requirement giver_reqs[MAX_NUM_REQS]
char preferred_soundset[MAX_LEN_NAME]
char preferred_tileset[MAX_LEN_NAME]
char preferred_musicset[MAX_LEN_NAME]
enum counter_target type
char name[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char helptext[MAX_LEN_PACKET]
enum counter_behavior behavior
char text[MAX_LEN_CONTENT]
char rule_name[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
bv_disaster_effects effects
char name[MAX_LEN_NAME]
char helptxt[MAX_LEN_PACKET]
char name[MAX_LEN_NAME]
bv_unit_classes native_to
char rmact_gfx_alt2[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
char graphic_alt[MAX_LEN_NAME]
char act_gfx_alt2[MAX_LEN_NAME]
struct requirement disappearance_reqs[MAX_NUM_REQS]
bv_extra_flags flags
char act_gfx_alt[MAX_LEN_NAME]
char activity_gfx[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
enum extra_unit_seen_type eus
struct requirement appearance_reqs[MAX_NUM_REQS]
char name[MAX_LEN_NAME]
char graphic_str[MAX_LEN_NAME]
char rmact_gfx_alt[MAX_LEN_NAME]
char rmact_gfx[MAX_LEN_NAME]
struct requirement rmreqs[MAX_NUM_REQS]
char helptext[MAX_LEN_PACKET]
int work_raise_chance[MAX_VET_LEVELS]
int base_raise_chance[MAX_VET_LEVELS]
int global_init_techs[MAX_NUM_TECH_LIST]
int move_bonus[MAX_VET_LEVELS]
char veteran_name[MAX_VET_LEVELS][MAX_LEN_NAME]
Impr_type_id global_init_buildings[MAX_NUM_BUILDING_LIST]
int power_fact[MAX_VET_LEVELS]
char helptext[MAX_LEN_PACKET]
bv_goods_flags flags
char name[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
char sound_alt[MAX_LEN_NAME]
char graphic_alt[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char name[MAX_LEN_NAME]
Government_type_id id
char sound_str[MAX_LEN_NAME]
char graphic_str[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
char helptext[MAX_LEN_PACKET]
char sound_alt2[MAX_LEN_NAME]
char name[MAX_LEN_NAME]
char helptxt[MAX_LEN_PACKET]
char name[MAX_LEN_NAME]
Multiplier_type_id id
struct requirement reqs[MAX_NUM_REQS]
char rule_name[MAX_LEN_NAME]
char helptext[MAX_LEN_PACKET]
char music_combat[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
char music_peaceful[MAX_LEN_NAME]
char groups[MAX_NUM_NATION_GROUPS][MAX_LEN_NAME]
bool hidden[MAX_NUM_NATION_GROUPS]
char rule_names[MAX_NUM_NATION_SETS][MAX_LEN_NAME]
char names[MAX_NUM_NATION_SETS][MAX_LEN_NAME]
char descriptions[MAX_NUM_NATION_SETS][MAX_LEN_MSG]
int init_techs[MAX_NUM_TECH_LIST]
char leader_name[MAX_NUM_LEADERS][MAX_LEN_NAME]
char noun_plural[MAX_LEN_NAME]
char adjective[MAX_LEN_NAME]
Impr_type_id init_buildings[MAX_NUM_BUILDING_LIST]
Unit_type_id init_units[MAX_NUM_UNIT_LIST]
bool leader_is_male[MAX_NUM_LEADERS]
char translation_domain[MAX_LEN_NAME]
char graphic_str[MAX_LEN_NAME]
Government_type_id init_government_id
int groups[MAX_NUM_NATION_GROUPS]
enum barbarian_type barbarian_type
int sets[MAX_NUM_NATION_SETS]
char graphic_alt[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char legend[MAX_LEN_MSG]
bv_road_flags flags
int tile_incr_const[O_LAST]
enum road_gui_type gui_type
bv_max_extras integrates
enum road_compat compat
enum road_move_mode move_mode
int tile_bonus[O_LAST]
int tile_incr[O_LAST]
struct requirement first_reqs[MAX_NUM_REQS]
char rule_name[MAX_LEN_NAME]
char graphic_alt[MAX_LEN_NAME]
struct requirement reqs[MAX_NUM_REQS]
Specialist_type_id id
char helptext[MAX_LEN_PACKET]
char short_name[MAX_LEN_NAME]
char graphic_str[MAX_LEN_NAME]
char plural_name[MAX_LEN_NAME]
char name[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char text[MAX_LEN_CONTENT]
char name[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char name[MAX_LEN_NAME]
char helptxt[MAX_LEN_PACKET]
char name[MAX_LEN_NAME]
struct requirement research_reqs[MAX_NUM_REQS]
char graphic_str[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
char graphic_alt[MAX_LEN_NAME]
bv_tech_flags flags
char helptext[MAX_LEN_PACKET]
char name[MAX_LEN_NAME]
char helptxt[MAX_LEN_PACKET]
int extra_removal_times[MAX_EXTRA_TYPES]
Terrain_type_id transform_result
int resource_freq[MAX_EXTRA_TYPES]
char helptext[MAX_LEN_PACKET]
Resource_type_id resources[MAX_EXTRA_TYPES]
bv_terrain_flags flags
char graphic_str[MAX_LEN_NAME]
bv_unit_classes native_to
Terrain_type_id cultivate_result
Terrain_type_id plant_result
char name[MAX_LEN_NAME]
int road_output_incr_pct[O_LAST]
char graphic_alt[MAX_LEN_NAME]
char graphic_alt2[MAX_LEN_NAME]
char rule_name[MAX_LEN_NAME]
enum trade_route_illegal_cancelling cancelling
enum trade_route_bonus_type bonus_type
enum combat_bonus_type type
enum unit_type_flag_id flag
char helptxt[MAX_LEN_PACKET]
char rule_name[MAX_LEN_NAME]
bv_unit_class_flags flags
char name[MAX_LEN_NAME]
char helptext[MAX_LEN_PACKET]
char name[MAX_LEN_NAME]
char helptxt[MAX_LEN_PACKET]
char graphic_alt[MAX_LEN_NAME]
enum vision_layer vlayer
enum transp_def_type tp_defense
char rule_name[MAX_LEN_NAME]
int power_fact[MAX_VET_LEVELS]
char name[MAX_LEN_NAME]
char graphic_alt2[MAX_LEN_NAME]
char graphic_str[MAX_LEN_NAME]
char sound_fight_alt[MAX_LEN_NAME]
bv_unit_classes disembarks
bv_unit_classes cargo
bv_unit_type_flags flags
char sound_move_alt[MAX_LEN_NAME]
bv_unit_classes targets
struct requirement build_reqs[MAX_NUM_REQS]
int base_raise_chance[MAX_VET_LEVELS]
int work_raise_chance[MAX_VET_LEVELS]
char sound_fight[MAX_LEN_NAME]
bv_unit_classes embarks
char veteran_name[MAX_VET_LEVELS][MAX_LEN_NAME]
char sound_move[MAX_LEN_NAME]
char helptext[MAX_LEN_PACKET]
bv_unit_type_roles roles
int move_bonus[MAX_VET_LEVELS]
char description[MAX_LEN_CONTENT]
char authors[MAX_LEN_PACKET/3]
bv_spaceship_structure structure
Resource_type_id resource
enum known_type known
char label[MAX_LEN_MAP_LABEL]
Continent_id continent
Definition packets_gen.h:99
Terrain_type_id terrain
char spec_sprite[MAX_LEN_NAME]
enum route_direction direction
struct act_prob action_probabilities[MAX_NUM_ACTIONS]
int upkeep[O_LAST]
enum action_decision action_decision_want
struct unit_order orders[MAX_LEN_ROUTE]
enum unit_activity activity
Unit_type_id type
enum unit_activity changed_from
enum direction8 facing
enum server_side_agent ssa_controller
enum direction8 facing
char user[MAX_LEN_NAME]
enum unit_activity activity
enum ai_level skill_level
Definition player.h:114
enum barbarian_type barbarian_type
Definition player.h:120
int science_cost
Definition player.h:117
int love[MAX_NUM_PLAYER_SLOTS]
Definition player.h:122
int infra_points
Definition player.h:65
enum spaceship_state state
Definition spaceship.h:108
struct city_list * cities
Definition player.h:279
struct player_ai ai_common
Definition player.h:286
bv_plr_flags flags
Definition player.h:290
struct dbv tile_vision[V_COUNT]
Definition player.h:357
int primary_capital_id
Definition player.h:273
bool is_male
Definition player.h:255
int wonders[B_LAST]
Definition player.h:303
struct government * target_government
Definition player.h:257
int autoselect_weight
Definition player.h:297
char username[MAX_LEN_NAME]
Definition player.h:250
bool is_connected
Definition player.h:294
int revolution_finishes
Definition player.h:271
int nturns_idle
Definition player.h:263
struct government * government
Definition player.h:256
struct dbv tile_known
Definition player.h:308
int turns_alive
Definition player.h:264
bool was_created
Definition player.h:292
int tech_upkeep
Definition player.h:361
struct unit_list * units
Definition player.h:280
struct conn_list * connections
Definition player.h:296
bool is_alive
Definition player.h:266
bv_player real_embassy
Definition player.h:275
struct player::@70::@73 client
struct player_economic economic
Definition player.h:282
int culture
Definition player.h:365
struct player_spaceship spaceship
Definition player.h:284
char name[MAX_LEN_NAME]
Definition player.h:249
bv_player gives_shared_vision
Definition player.h:300
enum mood_type mood
Definition player.h:359
struct player_score score
Definition player.h:281
struct multiplier_value multipliers[MAX_NUM_MULTIPLIERS]
Definition player.h:312
bool color_changeable
Definition player.h:363
int music_style
Definition player.h:278
struct nation_style * style
Definition player.h:277
bool phase_done
Definition player.h:261
bv_player gives_shared_tiles
Definition player.h:302
bool is_ready
Definition player.h:260
int history
Definition player.h:314
struct rgbcolor * rgb
Definition player.h:310
bool unassigned_user
Definition player.h:251
int output[O_LAST]
Definition terrain.h:49
int g
Definition rgbcolor.h:34
int b
Definition rgbcolor.h:34
int r
Definition rgbcolor.h:34
struct requirement_vector reqs
Definition specialist.h:38
char graphic_alt[MAX_LEN_NAME]
Definition specialist.h:36
struct strvec * helptext
Definition specialist.h:40
char graphic_str[MAX_LEN_NAME]
Definition specialist.h:35
struct name_translation name
Definition specialist.h:31
struct name_translation abbreviation
Definition specialist.h:32
Definition map.c:41
struct terrain * cultivate_result
Definition terrain.h:215
int placing_time
Definition terrain.h:227
struct extra_type ** resources
Definition terrain.h:204
struct strvec * helptext
Definition terrain.h:263
char graphic_alt2[MAX_LEN_NAME]
Definition terrain.h:189
bv_terrain_flags flags
Definition terrain.h:259
int * resource_freq
Definition terrain.h:205
bv_unit_classes native_to
Definition terrain.h:257
int road_time
Definition terrain.h:213
struct name_translation name
Definition terrain.h:184
int plant_time
Definition terrain.h:219
struct terrain * plant_result
Definition terrain.h:218
int irrigation_food_incr
Definition terrain.h:221
int defense_bonus
Definition terrain.h:200
int cultivate_time
Definition terrain.h:216
int movement_cost
Definition terrain.h:199
const struct unit_type * animal
Definition terrain.h:237
int pillage_time
Definition terrain.h:232
int output[O_LAST]
Definition terrain.h:202
int transform_time
Definition terrain.h:231
char graphic_alt[MAX_LEN_NAME]
Definition terrain.h:188
int mining_time
Definition terrain.h:225
struct rgbcolor * rgb
Definition terrain.h:261
char graphic_str[MAX_LEN_NAME]
Definition terrain.h:187
enum terrain_class tclass
Definition terrain.h:197
int road_output_incr_pct[O_LAST]
Definition terrain.h:211
int extra_removal_times[MAX_EXTRA_TYPES]
Definition terrain.h:235
struct terrain * transform_result
Definition terrain.h:229
int irrigation_time
Definition terrain.h:222
int base_time
Definition terrain.h:212
int mining_shield_incr
Definition terrain.h:224
Definition tile.h:50
char * spec_sprite
Definition tile.h:66
char * label
Definition tile.h:65
bv_extras extras
Definition tile.h:55
struct unit_list * units
Definition tile.h:58
struct player * extras_owner
Definition tile.h:63
int infra_turns
Definition tile.h:62
struct extra_type * placing
Definition tile.h:61
Continent_id continent
Definition tile.h:54
int hp_loss_pct
Definition unittype.h:155
int non_native_def_pct
Definition unittype.h:156
int min_speed
Definition unittype.h:154
struct name_translation name
Definition unittype.h:151
struct strvec * helptext
Definition unittype.h:159
bv_unit_class_flags flags
Definition unittype.h:157
enum unit_orders order
Definition unit.h:93
int action
Definition unit.h:100
int transport_capacity
Definition unittype.h:523
struct unit_type::@87 adv
struct unit_class * uclass
Definition unittype.h:556
int pop_cost
Definition unittype.h:513
struct requirement_vector build_reqs
Definition unittype.h:520
int defense_strength
Definition unittype.h:516
bv_unit_classes cargo
Definition unittype.h:558
int firepower
Definition unittype.h:525
int paratroopers_range
Definition unittype.h:541
char graphic_alt[MAX_LEN_NAME]
Definition unittype.h:506
bool worker
Definition unittype.h:575
char sound_move_alt[MAX_LEN_NAME]
Definition unittype.h:509
int build_cost
Definition unittype.h:512
int convert_time
Definition unittype.h:531
int city_size
Definition unittype.h:550
struct veteran_system * veteran
Definition unittype.h:544
const struct unit_type * obsoleted_by
Definition unittype.h:529
int vision_radius_sq
Definition unittype.h:522
int move_rate
Definition unittype.h:517
bv_unit_classes targets
Definition unittype.h:561
enum vision_layer vlayer
Definition unittype.h:569
struct strvec * helptext
Definition unittype.h:571
int bombard_rate
Definition unittype.h:547
char graphic_str[MAX_LEN_NAME]
Definition unittype.h:505
int city_slots
Definition unittype.h:552
char sound_move[MAX_LEN_NAME]
Definition unittype.h:508
char sound_fight_alt[MAX_LEN_NAME]
Definition unittype.h:511
struct name_translation name
Definition unittype.h:502
bv_unit_type_roles roles
Definition unittype.h:535
enum transp_def_type tp_defense
Definition unittype.h:554
int upkeep[O_LAST]
Definition unittype.h:538
char graphic_alt2[MAX_LEN_NAME]
Definition unittype.h:507
bv_unit_classes disembarks
Definition unittype.h:567
const struct unit_type * converted_to
Definition unittype.h:530
bv_unit_type_flags flags
Definition unittype.h:534
char sound_fight[MAX_LEN_NAME]
Definition unittype.h:510
bv_unit_classes embarks
Definition unittype.h:564
int attack_strength
Definition unittype.h:515
int happy_cost
Definition unittype.h:537
struct combat_bonus_list * bonuses
Definition unittype.h:526
Definition unit.h:138
int length
Definition unit.h:195
int upkeep[O_LAST]
Definition unit.h:148
bool has_orders
Definition unit.h:193
struct unit::@80 orders
bool occupied
Definition unit.h:219
enum action_decision action_decision_want
Definition unit.h:202
int battlegroup
Definition unit.h:191
enum unit_activity activity
Definition unit.h:157
int moves_left
Definition unit.h:150
struct unit::@81::@83 client
int id
Definition unit.h:145
bool moved
Definition unit.h:173
int index
Definition unit.h:195
bool vigilant
Definition unit.h:197
int hp
Definition unit.h:151
int fuel
Definition unit.h:153
struct extra_type * changed_from_target
Definition unit.h:170
int current_form_turn
Definition unit.h:208
bool stay
Definition unit.h:205
bool colored
Definition unit.h:222
enum direction8 facing
Definition unit.h:142
bool asking_city_name
Definition unit.h:225
struct extra_type * activity_target
Definition unit.h:164
int activity_count
Definition unit.h:162
struct unit_order * list
Definition unit.h:198
enum unit_activity changed_from
Definition unit.h:168
struct player * nationality
Definition unit.h:144
int transported_by
Definition unit.h:216
bool repeat
Definition unit.h:196
int homecity
Definition unit.h:146
bool paradropped
Definition unit.h:174
bool done_moving
Definition unit.h:181
int birth_turn
Definition unit.h:207
struct goods_type * carrying
Definition unit.h:186
struct tile * goto_tile
Definition unit.h:155
struct tile * action_decision_tile
Definition unit.h:203
const struct unit_type * utype
Definition unit.h:139
int veteran
Definition unit.h:152
int changed_from_count
Definition unit.h:169
enum unit_focus_status focus_status
Definition unit.h:214
enum server_side_agent ssa_controller
Definition unit.h:172
enum universals_n kind
Definition fc_types.h:902
int yes
Definition voteinfo.h:36
int num_voters
Definition voteinfo.h:39
bool passed
Definition voteinfo.h:41
int abstain
Definition voteinfo.h:38
int vote_no
Definition voteinfo.h:31
int no
Definition voteinfo.h:37
struct civ_map map
struct nation_style * style_by_number(int id)
Definition style.c:88
void styles_alloc(int count)
Definition style.c:36
struct music_style * music_style_by_number(int id)
Definition style.c:171
void music_styles_alloc(int count)
Definition style.c:133
int fc_snprintf(char *str, size_t n, const char *format,...)
Definition support.c:974
size_t fc_strlcpy(char *dest, const char *src, size_t n)
Definition support.c:791
size_t fc_strlcat(char *dest, const char *src, size_t n)
Definition support.c:836
#define sz_strlcpy(dest, src)
Definition support.h:195
#define TRUE
Definition support.h:46
#define FALSE
Definition support.h:47
#define fc_strncmp(_s1_, _s2_, _len_)
Definition support.h:160
int team_count(void)
Definition team.c:375
struct team_slot * team_slot_by_number(int team_id)
Definition team.c:175
bool team_add_player(struct player *pplayer, struct team *pteam)
Definition team.c:467
struct team * team_new(struct team_slot *tslot)
Definition team.c:317
void team_slot_set_defined_name(struct team_slot *tslot, const char *team_name)
Definition team.c:288
struct advance * advance_by_number(const Tech_type_id atype)
Definition tech.c:107
void set_user_tech_flag_name(enum tech_flag_id id, const char *name, const char *helptxt)
Definition tech.c:394
struct tech_class * tech_class_by_number(const int idx)
Definition tech.c:320
Tech_type_id advance_number(const struct advance *padvance)
Definition tech.c:98
#define A_FUTURE
Definition tech.h:46
#define A_NEVER
Definition tech.h:51
#define advance_index_iterate_end
Definition tech.h:248
tech_req
Definition tech.h:110
@ AR_TWO
Definition tech.h:112
@ AR_ROOT
Definition tech.h:113
@ AR_ONE
Definition tech.h:111
static Tech_type_id advance_count(void)
Definition tech.h:170
#define A_NONE
Definition tech.h:43
#define A_UNKNOWN
Definition tech.h:49
#define A_LAST
Definition tech.h:45
#define advance_index_iterate(_start, _index)
Definition tech.h:244
Terrain_type_id terrain_count(void)
Definition terrain.c:118
struct terrain * terrain_by_number(const Terrain_type_id type)
Definition terrain.c:156
const char * terrain_rule_name(const struct terrain *pterrain)
Definition terrain.c:247
struct resource_type * resource_type_init(struct extra_type *pextra)
Definition terrain.c:272
void set_user_terrain_flag_name(enum terrain_flag_id id, const char *name, const char *helptxt)
Definition terrain.c:788
#define MAX_NUM_TERRAINS
Definition terrain.h:64
void tile_set_terrain(struct tile *ptile, struct terrain *pterrain)
Definition tile.c:124
void tile_set_owner(struct tile *ptile, struct player *pplayer, struct tile *claimer)
Definition tile.c:69
bool tile_set_label(struct tile *ptile, const char *label)
Definition tile.c:1095
void tile_set_resource(struct tile *ptile, struct extra_type *presource)
Definition tile.c:349
struct city * tile_city(const struct tile *ptile)
Definition tile.c:83
void tile_set_worked(struct tile *ptile, struct city *pcity)
Definition tile.c:106
#define tile_index(_pt_)
Definition tile.h:88
#define tile_worked(_tile)
Definition tile.h:118
#define tile_resource(_tile)
Definition tile.h:102
known_type
Definition tile.h:35
@ TILE_KNOWN_UNSEEN
Definition tile.h:37
@ TILE_UNKNOWN
Definition tile.h:36
@ TILE_KNOWN_SEEN
Definition tile.h:38
#define tile_list_iterate(tile_list, ptile)
Definition tile.h:73
#define tile_terrain(_tile)
Definition tile.h:114
#define TILE_XY(ptile)
Definition tile.h:43
#define tile_list_iterate_end
Definition tile.h:75
#define tile_owner(_tile)
Definition tile.h:96
void tileset_setup_unit_type(struct tileset *t, struct unit_type *ut)
Definition tilespec.c:3806
void tileset_setup_government(struct tileset *t, struct government *gov)
Definition tilespec.c:4420
void tileset_setup_specialist_type_default_set(struct tileset *t, Specialist_type_id id)
Definition tilespec.c:2891
void tileset_setup_tile_type(struct tileset *t, const struct terrain *pterrain)
Definition tilespec.c:4154
void tileset_player_init(struct tileset *t, struct player *pplayer)
Definition tilespec.c:7372
bool unit_drawn_with_city_outline(const struct unit *punit, bool check_focus)
Definition tilespec.c:5512
void tileset_setup_impr_type(struct tileset *t, struct impr_type *pimprove)
Definition tilespec.c:3840
void tileset_background_init(struct tileset *t)
Definition tilespec.c:7452
void tileset_setup_tech_type(struct tileset *t, struct advance *padvance)
Definition tilespec.c:3856
void tileset_setup_city_tiles(struct tileset *t, int style)
Definition tilespec.c:6455
void tilespec_reread_frozen_refresh(const char *tname)
Definition tilespec.c:1545
void tileset_setup_extra(struct tileset *t, struct extra_type *pextra)
Definition tilespec.c:3875
const char * tileset_basename(const struct tileset *t)
Definition tilespec.c:704
void finish_loading_sprites(struct tileset *t)
Definition tilespec.c:3612
const char * tileset_name_get(struct tileset *t)
Definition tilespec.c:7523
void tileset_error(enum log_level level, const char *tset_name, const char *format,...)
Definition tilespec.c:624
bool tilespec_reread(const char *new_tileset_name, bool game_fully_initialized, float scale)
Definition tilespec.c:1355
void tileset_setup_nation_flag(struct tileset *t, struct nation_type *nation)
Definition tilespec.c:4435
void tileset_ruleset_reset(struct tileset *t)
Definition tilespec.c:7487
#define MAX_NUM_CITIZEN_SPRITES
Definition tilespec.h:197
#define NUM_WALL_TYPES
Definition tilespec.h:359
int city_num_trade_routes(const struct city *pcity)
struct trade_route_settings * trade_route_settings_by_type(enum trade_route_type type)
struct goods_type * goods_by_number(Goods_type_id id)
bool unit_transport_load(struct unit *pcargo, struct unit *ptrans, bool force)
Definition unit.c:2378
struct unit * unit_transport_get(const struct unit *pcargo)
Definition unit.c:2449
bool unit_transport_unload(struct unit *pcargo)
Definition unit.c:2398
struct unit * unit_virtual_create(struct player *pplayer, struct city *pcity, const struct unit_type *punittype, int veteran_level)
Definition unit.c:1632
void unit_virtual_destroy(struct unit *punit)
Definition unit.c:1737
void unit_tile_set(struct unit *punit, struct tile *ptile)
Definition unit.c:1263
bool unit_transported(const struct unit *pcargo)
Definition unit.c:2433
struct unit_list * unit_transport_cargo(const struct unit *ptrans)
Definition unit.c:2459
#define unit_tile(_pu)
Definition unit.h:397
@ FOCUS_AVAIL
Definition unit.h:53
@ FOCUS_WAIT
Definition unit.h:53
@ ORDER_PERFORM_ACTION
Definition unit.h:47
#define unit_owner(_pu)
Definition unit.h:396
#define unit_list_iterate(unitlist, punit)
Definition unitlist.h:31
#define unit_list_iterate_end
Definition unitlist.h:33
void set_unit_class_caches(struct unit_class *pclass)
Definition unittype.c:2756
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:1569
const char * unit_rule_name(const struct unit *punit)
Definition unittype.c:1587
void set_unit_move_type(struct unit_class *puclass)
Definition unittype.c:2924
void set_unit_type_caches(struct unit_type *ptype)
Definition unittype.c:2815
struct unit_class * uclass_by_number(const Unit_Class_id id)
Definition unittype.c:2477
void veteran_system_definition(struct veteran_system *vsystem, int level, const char *vlist_name, int vlist_power, int vlist_move, int vlist_raise, int vlist_wraise)
Definition unittype.c:2685
struct unit_type * utype_by_number(const Unit_type_id id)
Definition unittype.c:112
void unit_type_action_cache_set(struct unit_type *ptype)
Definition unittype.c:915
void set_user_unit_class_flag_name(enum unit_class_flag_id id, const char *name, const char *helptxt)
Definition unittype.c:1812
struct veteran_system * veteran_system_new(int count)
Definition unittype.c:2654
bool utype_can_do_action(const struct unit_type *putype, const action_id act_id)
Definition unittype.c:371
void set_user_unit_type_flag_name(enum unit_type_flag_id id, const char *name, const char *helptxt)
Definition unittype.c:1876
#define UCF_LAST_USER_FLAG
Definition unittype.h:127
#define unit_class_iterate(_p)
Definition unittype.h:908
#define UTYF_LAST_USER_FLAG
Definition unittype.h:331
#define unit_type_iterate(_p)
Definition unittype.h:855
#define U_LAST
Definition unittype.h:40
#define unit_class_iterate_end
Definition unittype.h:915
#define unit_type_iterate_end
Definition unittype.h:862
void update_queue_processing_finished(int request_id)
void update_queue_processing_started(int request_id)
void unit_select_dialog_update(void)
#define vision_layer_iterate(v)
Definition vision.h:77
#define vision_layer_iterate_end
Definition vision.h:80
void voteinfo_queue_delayed_remove(int vote_no)
Definition voteinfo.c:53
struct voteinfo * voteinfo_queue_find(int vote_no)
Definition voteinfo.c:150
void voteinfo_queue_add(int vote_no, const char *user, const char *desc, int percent_required, int flags)
Definition voteinfo.c:123
bool worker_task_is_sane(struct worker_task *ptask)
Definition workertask.c:40
#define worker_task_list_iterate(tasklist, ptask)
Definition workertask.h:33
#define worker_task_list_iterate_end
Definition workertask.h:35
void worklist_copy(struct worklist *dst, const struct worklist *src)
Definition worklist.c:112
void worklist_init(struct worklist *pwl)
Definition worklist.c:38