Freeciv-3.2
Loading...
Searching...
No Matches
combat.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 <math.h>
19
20/* utility */
21#include "bitvector.h"
22#include "rand.h"
23#include "log.h"
24
25/* common */
26#include "base.h"
27#include "game.h"
28#include "map.h"
29#include "movement.h"
30#include "packets.h"
31#include "unit.h"
32#include "unitlist.h"
33#include "unittype.h"
34
35#include "combat.h"
36
37/*******************************************************************/
44static bool can_player_attack_tile(const struct player *pplayer,
45 const struct tile *ptile)
46{
47 struct city *pcity = tile_city(ptile);
48
49 /* 1. Is there anyone there at all? */
50 if (!pcity && unit_list_size((ptile->units)) == 0) {
51 return FALSE;
52 }
53
54 /* 2. If there is a city there, can we attack it? */
55 if (pcity && !pplayers_at_war(city_owner(pcity), pplayer)) {
56 return FALSE;
57 }
58
59 /* 3. Are we allowed to attack _all_ units there? */
61 if (!pplayers_at_war(unit_owner(aunit), pplayer)) {
62 /* Enemy hiding behind a human/diplomatic shield */
63 return FALSE;
64 }
66
67 return TRUE;
68}
69
70/*******************************************************************/
73static bool is_unit_reachable_by_unit(const struct unit *defender,
74 const struct unit *attacker)
75{
76 struct unit_class *dclass = unit_class_get(defender);
77 const struct unit_type *atype = unit_type_get(attacker);
78
79 return BV_ISSET(atype->targets, uclass_index(dclass));
80}
81
82/*******************************************************************/
85bool is_unit_reachable_at(const struct unit *defender,
86 const struct unit *attacker,
87 const struct tile *location)
88{
89 if (NULL != tile_city(location)) {
90 return TRUE;
91 }
92
93 if (is_unit_reachable_by_unit(defender, attacker)) {
94 return TRUE;
95 }
96
97 if (tile_has_native_base(location, unit_type_get(defender))) {
98 return TRUE;
99 }
100
101 return FALSE;
102}
103
104/*******************************************************************/
123 const struct action *paction,
124 const struct unit *pdefender,
125 const struct tile *dest_tile)
126{
127 /* 1. Can we attack _anything_ ? */
128 if (paction == NULL) {
132 /* Needed because ACTION_NUKE_UNITS uses this when evaluating its
133 * hard requirements. */
136 return ATT_NON_ATTACK;
137 }
138 } else {
140 return ATT_NON_ATTACK;
141 }
142 }
143
144 /* 2. Can't attack with ground unit from ocean, except for marines */
145 if (paction == NULL) {
153 return ATT_NONNATIVE_SRC;
154 }
155 } else {
158 paction->id,
160 return ATT_NONNATIVE_SRC;
161 }
162 }
163
164 /* 3. Most units can not attack non-native terrain.
165 * Most ships can attack land tiles (shore bombardment) */
166 if (!is_native_tile(unit_type_get(punit), dest_tile)
168 return ATT_NONNATIVE_DST;
169 }
170
171 /* 4. Only fighters can attack planes, except in city or airbase attacks */
172 if (!is_unit_reachable_at(pdefender, punit, dest_tile)) {
173 return ATT_UNREACHABLE;
174 }
175
176 /* Unreachability check must remain the last check, as callers interpret
177 * ATT_UNREACHABLE as "ATT_OK except that unreachable." */
178
179 return ATT_OK;
180}
181
182/*******************************************************************/
187static enum unit_attack_result
189 const struct action *paction,
190 const struct tile *ptile)
191{
194
195 unit_list_iterate(ptile->units, aunit) {
196 /* HACK: we don't count transported units here. This prevents some
197 * bugs like a submarine carrying a cruise missile being invulnerable
198 * to other sea units. However from a gameplay perspective it's a hack,
199 * since players can load and unload their units manually to protect
200 * their transporters. */
201 if (!unit_transported(aunit)) {
202 enum unit_attack_result result;
203
205 aunit, ptile);
206 if (result == ATT_UNREACHABLE
208 /* Doesn't prevent us from attacking other units on the tile */
210 continue;
211 } else if (result != ATT_OK) {
212 return result;
213 }
215 }
217
218 /* If there are only unreachable, UTYF_NEVER_PROTECTS units, we still have
219 * to return ATT_UNREACHABLE. */
221}
222
223/*******************************************************************/
228static enum unit_attack_result
230 const struct action *paction,
231 const struct tile *ptile)
232{
233 enum unit_attack_result result = ATT_OK;
234
235 unit_list_iterate(ptile->units, aunit) {
236 /* HACK: we don't count transported units here. This prevents some
237 * bugs like a cargoplane carrying a land unit being vulnerable. */
238 if (!unit_transported(aunit)) {
240 aunit, ptile);
241 if (result == ATT_OK) {
242 return result;
243 }
244 }
246
247 /* That's result from check against last unit on tile, not first.
248 * Shouldn't matter. */
249 return result;
250}
251
252/*******************************************************************/
257 const struct action *paction,
258 const struct tile *ptile)
259{
262 } else {
264 }
265}
266
267/*******************************************************************/
272 const struct tile *ptile)
273{
274 /* Can unit wipe in general? */
276 return ATT_NON_ATTACK;
277 }
278
279 unit_list_iterate(ptile->units, target) {
280 if (get_total_defense_power(punit, target) > 0) {
281 return ATT_NOT_WIPABLE;
282 }
283
284 /* Can't wipe with ground unit from ocean, except for marines */
288 return ATT_NONNATIVE_SRC;
289 }
290
291 /* Most units can not wipe on non-native terrain.
292 * Most ships can wipe on land tiles (shore bombardment) */
295 return ATT_NONNATIVE_DST;
296 }
297
298 /* Only fighters can wipe planes, except in city or airbase attacks */
299 if (!is_unit_reachable_at(target, punit, ptile)) {
300 return ATT_UNREACHABLE;
301 }
303
304 return ATT_OK;
305}
306
307/*******************************************************************/
311bool can_unit_attack_tile(const struct unit *punit,
312 const struct action *paction,
313 const struct tile *dest_tile)
314{
315 return (can_player_attack_tile(unit_owner(punit), dest_tile)
317 == ATT_OK));
318}
319
320/*******************************************************************/
332double win_chance(int as, int ahp, int afp, int ds, int dhp, int dfp)
333{
334 /* number of rounds a unit can fight without dying */
335 int att_N_lose = (ahp + dfp - 1) / dfp;
336 int def_N_lose = (dhp + afp - 1) / afp;
337 /* Probability of losing one round */
338 double att_P_lose1 = (as + ds == 0) ? 0.5 : (double) ds / (as + ds);
339 double def_P_lose1 = 1 - att_P_lose1;
340
341 /*
342 This calculates
343
344 binomial_coeff(def_N_lose-1 + lr, lr)
345 * def_P_lose1^(def_N_lose-1)
346 * att_P_lose1^(lr)
347 * def_P_lose1
348
349 for each possible number of rounds lost (rl) by the winning unit.
350 rl is of course less than the number of rounds the winning unit
351 should lose to lose all it's hit points.
352 The probabilities are then summed.
353
354 To see this is correct consider the set of series for all valid fights.
355 These series are the type (win, lose, lose...). The possible lengths are
356 def_N_lose to def_N_lose+att_N_lose-1. A series is not valid unless it
357 contains def_N_lose wins, and one of the wins must be the last one, or
358 the series would be equivalent the a shorter series (the attacker would
359 have won one or more fights previously).
360 So since the last fight is a win we disregard it while calculating. Now
361 a series contains def_N_lose-1 wins. So for each possible length of a
362 series we find the probability of every valid series and then sum.
363 For a specific length (a "lr") every series have the probability
364 def_P_lose1^(def_N_lose-1) * att_P_lose1^(lr)
365 and then getting from that to the real series requires a win, ie factor
366 def_N_lose. The number of series with length (def_N_lose-1 + lr) and
367 "lr" lost fights is
368 binomial_coeff(def_N_lose-1 + lr, lr)
369 And by multiplying we get the formula on the top of this code block.
370 Adding the cumulative probability for each valid length then gives the
371 total probability.
372
373 We clearly have all valid series this way. To see that we have counted
374 none twice note that would require a series with a smaller series inbedded.
375 But since the smaller series already included def_N_lose wins, and the
376 larger series ends with a win, it would have too many wins and therefore
377 cannot exist.
378
379 In practice each binomial coefficient for a series length can be calculated
380 from the previous. In the coefficient (n, k) n is increased and k is
381 unchanged.
382 The "* def_P_lose1" is multiplied on the sum afterwards.
383
384 (lots of talk for so little code)
385 */
386
387 double binom_save = pow(def_P_lose1, (double)(def_N_lose - 1));
388 double accum_prob = binom_save; /* lr = 0 */
389
390 int lr; /* the number of Lost Rounds by the attacker */
391 for (lr = 1; lr < att_N_lose; lr++) {
392 /* update the coefficient */
393 int n = lr + def_N_lose - 1;
394 binom_save *= n;
395 binom_save /= lr;
397 /* use it for this lr */
399 }
400 /* Every element of the sum needs a factor for the very last fight round */
402
403 return accum_prob;
404}
405
406/*******************************************************************/
410 const struct unit *attacker,
411 const struct unit *defender,
412 int *att_fp, int *def_fp)
413{
414 struct city *pcity = tile_city(unit_tile(defender));
415 const struct unit_type *att_type;
416 const struct unit_type *def_type;
417 struct tile *att_tile;
418
419 att_type = unit_type_get(attacker);
420 def_type = unit_type_get(defender);
421
422 *att_fp = att_type->firepower;
423 *def_fp = def_type->firepower;
424
425 /* Check CityBuster flag */
426 if (unit_has_type_flag(attacker, UTYF_CITYBUSTER) && pcity) {
427 *att_fp *= 2;
428 }
429
430 /*
431 * UTYF_BADWALLATTACKER reduces the firepower of the attacking unit to
432 * badwallattacker firepower if an EFT_DEFEND_BONUS applies
433 * (such as a land unit attacking a city with city walls).
434 */
436 && get_unittype_bonus(unit_owner(defender), unit_tile(defender),
437 att_type, NULL,
438 EFT_DEFEND_BONUS) > 0) {
440 }
441
442 /* pearl harbour - defender's firepower is reduced,
443 * attacker's is multiplied by two */
445 && tile_city(unit_tile(defender))) {
446 *att_fp *= 2;
448 }
449
450 /*
451 * When attacked by fighters, helicopters have their firepower
452 * reduced to low firepower bonus.
453 */
457 }
458
459 att_tile = unit_tile(attacker);
460
461 /* In land bombardment both units have their firepower reduced.
462 * Land bombardment is always towards tile not native for attacker.
463 * It's initiated either from a tile not native to defender (Ocean for Land unit)
464 * or from a tile where attacker is despite non-native terrain (city, transport) */
466 && !is_native_tile(att_type, unit_tile(defender))
471 }
472}
473
474/*******************************************************************/
478double unit_win_chance(const struct civ_map *nmap,
479 const struct unit *attacker,
480 const struct unit *defender,
481 const struct action *paction)
482{
483 int def_power = get_total_defense_power(attacker, defender);
484 int att_power = get_total_attack_power(attacker, defender, paction);
485 double chance;
486 int def_fp, att_fp;
487
488 get_modified_firepower(nmap, attacker, defender, &att_fp, &def_fp);
489
490 chance = win_chance(att_power, attacker->hp, att_fp,
491 def_power, defender->hp, def_fp);
492
493 return chance;
494}
495
496/*******************************************************************/
501struct city *sdi_try_defend(const struct civ_map *nmap,
502 const struct player *owner,
503 const struct tile *ptile)
504{
505 square_iterate(nmap, ptile, 2, ptile1) {
506 struct city *pcity = tile_city(ptile1);
507
508 if (pcity
509 && fc_rand(100)
511 &(const struct req_context) {
512 .player = city_owner(pcity),
513 .city = pcity,
514 .tile = ptile,
515 },
517 return pcity;
518 }
520
521 return NULL;
522}
523
524/*******************************************************************/
527bool is_tired_attack(int moves_left)
528{
529 return game.info.tired_attack && moves_left < SINGLE_MOVE;
530}
531
532/*******************************************************************/
540
541/*******************************************************************/
546 int veteran, int moves_left)
547{
548 int power;
549 const struct veteran_level *vlevel;
550
552
555
556 power = punittype->attack_strength * POWER_FACTOR
557 * vlevel->power_fact / 100;
558
559 if (is_tired_attack(moves_left)) {
560 power = (power * moves_left) / SINGLE_MOVE;
561 }
562
563 return power;
564}
565
566/*******************************************************************/
570{
571 const struct veteran_level *vlevel;
572 const struct unit_type *ptype;
573
575
579
580 return ptype->defense_strength * POWER_FACTOR
581 * vlevel->power_fact / 100;
582}
583
584/*******************************************************************/
589static int get_defense_power(const struct unit *punit)
590{
592 struct tile *ptile = unit_tile(punit);
594
596 db = 100 + tile_terrain(ptile)->defense_bonus;
597 power = (power * db) / 100;
598 }
599
600 if (!is_native_tile_to_class(pclass, ptile)) {
601 power = power * pclass->non_native_def_pct / 100;
602 }
603
604 return power;
605}
606
607/*******************************************************************/
610int get_total_attack_power(const struct unit *attacker,
611 const struct unit *defender,
612 const struct action *paction)
613{
614 int mod;
615 int attackpower = get_attack_power(attacker);
616 struct tile *deftile = unit_tile(defender);
617 struct city *pcity = tile_city(deftile);
618
619 /* Note: get_unit_bonus() would use the tile unit is on,
620 * but we want defending tile. */
621 mod = 100 + get_target_bonus_effects(NULL,
622 &(const struct req_context) {
623 .player = unit_owner(attacker),
624 .city = pcity,
625 .tile = deftile,
626 .unit = attacker,
627 .unittype = unit_type_get(attacker),
628 .action = paction,
629 },
631
632 return attackpower * mod / 100;
633}
634
635/*******************************************************************/
646 const struct unit *def,
647 const struct player *def_player,
648 const struct tile *ptile,
649 int defensepower)
650{
651 const struct city *pcity = tile_city(ptile);
652 const struct unit_type *def_type = unit_type_get(def);
653
655
656 if (NULL != att_type) {
657 int scramble_bonus = 0;
659
660 if (pcity) {
661 scramble_bonus = def_type->cache.scramble_coeff[utype_index(att_type)];
662 }
663
664 if (scramble_bonus) {
665 /* Use type-specific city bonus,
666 * already multiplied on common type-specific bonus */
669 } else {
670 /* Use city defense effect */
671 int defense_multiplier_pct = 100
672 + def_type->cache.defense_mp_bonuses_pct[utype_index(att_type)];
673 int mod = 100 + get_unittype_bonus(def_player, ptile,
675
676 /* This applies even if pcity is NULL. */
678 defensepower = MAX(0, defensepower * mod / 100);
679 }
680
683 + 100 * combat_bonus_against(att_type->bonuses, def_type,
685
687 }
688
689 defensepower +=
691
693 * (100
695 &(const struct req_context) {
696 .player = unit_owner(def),
697 .city = pcity,
698 .tile = ptile,
699 .unit = def,
700 .unittype = unit_type_get(def),
701 },
702 NULL,
704
705 return defensepower;
706}
707
708/*******************************************************************/
713 const struct unit_type *att_type,
714 const struct unit_type *def_type,
715 struct player *def_player,
716 struct tile *ptile,
717 bool fortified, int veteran)
718{
719 int defensepower = def_type->defense_strength;
720 int db;
721 const struct veteran_level *vlevel;
722 struct unit_class *defclass;
723 struct unit *vdef;
724 int def;
725
727
728 if (!can_exist_at_tile(nmap, def_type, ptile)) {
729 /* Ground units on ship doesn't defend. */
730 return 0;
731 }
732
735
737
739 unit_tile_set(vdef, ptile);
740 if (fortified) {
741 vdef->activity = ACTIVITY_FORTIFIED;
742 }
743
746 db += tile_terrain(ptile)->defense_bonus / (100 / POWER_FACTOR);
747 }
748 defensepower *= db;
749 defensepower *= vlevel->power_fact / 100;
750 if (!is_native_tile_to_class(defclass, ptile)) {
751 defensepower = defensepower * defclass->non_native_def_pct / 100;
752 }
753
755 ptile, defensepower);
756
758
759 return def;
760}
761
762/*******************************************************************/
767int get_total_defense_power(const struct unit *attacker,
768 const struct unit *defender)
769{
770 return defense_multiplication(unit_type_get(attacker),
771 defender,
772 unit_owner(defender), unit_tile(defender),
773 get_defense_power(defender));
774}
775
776/*******************************************************************/
781int get_fortified_defense_power(const struct unit *attacker,
782 struct unit *defender)
783{
784 const struct unit_type *att_type = NULL;
786 int def;
787 const struct unit_type *utype;
788
789 if (attacker != NULL) {
790 att_type = unit_type_get(attacker);
791 }
792
793 real_act = defender->activity;
794
795 utype = unit_type_get(defender);
797 defender->activity = ACTIVITY_FORTIFIED;
798 }
799
800 def = defense_multiplication(att_type, defender,
801 unit_owner(defender), unit_tile(defender),
802 get_defense_power(defender));
803
804 defender->activity = real_act;
805
806 return def;
807}
808
809/*******************************************************************/
814static int get_defense_rating(const struct civ_map *nmap,
815 const struct unit *attacker,
816 const struct unit *defender)
817{
818 int afp, dfp;
819 int rating = get_total_defense_power(attacker, defender);
820
821 get_modified_firepower(nmap, attacker, defender, &afp, &dfp);
822
823 /* How many rounds the defender will last */
824 rating *= (defender->hp + afp-1)/afp;
825
826 rating *= dfp;
827
828 return rating;
829}
830
831/*******************************************************************/
836struct unit *get_defender(const struct civ_map *nmap,
837 const struct unit *attacker,
838 const struct tile *ptile,
839 const struct action *paction)
840{
841 struct unit *bestdef = NULL;
842 int bestvalue = -99, best_cost = 0, rating_of_best = 0;
843
844 /* Simply call unit_win_chance() with all the possible defenders in turn, and
845 * take the best one. It currently uses build cost as a tiebreaker in
846 * case 2 units are identical, but this is crude as build cost does not
847 * necessarily have anything to do with the value of a unit. This function
848 * could be improved to take the value of the unit into account. It would
849 * also be nice if the function was a bit more fuzzy about prioritizing,
850 * making it able to fx choose a 1a/9d unit over a 10a/10d unit. It should
851 * also be able to spare units without full hp's to some extent, as these
852 * could be more valuable later. */
853 unit_list_iterate(ptile->units, defender) {
854 /* We used to skip over allied units, but the logic for that is
855 * complicated and is now handled elsewhere. */
856 if (unit_can_defend_here(nmap, defender)
857 && (unit_attack_unit_at_tile_result(attacker, NULL, defender, ptile)
858 == ATT_OK)) {
859 bool change = FALSE;
860 int build_cost = unit_build_shield_cost_base(defender);
861 int defense_rating = get_defense_rating(nmap, attacker, defender);
862 /* This will make units roughly evenly good defenders look alike. */
863 int unit_def
864 = (int) (100000 * (1 - unit_win_chance(nmap, attacker,
865 defender, paction)));
866
867 fc_assert_action(0 <= unit_def, continue);
868
869 if (unit_has_type_flag(defender, UTYF_GAMELOSS)
870 && !is_stack_vulnerable(unit_tile(defender))) {
871 unit_def = -1; /* Then always use leader as last defender. */
872 /* FIXME: Multiple gameloss units with varying defense value
873 * not handled. */
874 }
875
876 if (unit_def > bestvalue) {
877 change = TRUE;
878 } else if (unit_def == bestvalue) {
879 if (build_cost < best_cost) {
880 change = TRUE;
881 } else if (build_cost == best_cost) {
883 change = TRUE;
884 }
885 }
886 }
887
888 if (change) {
890 bestdef = defender;
891 best_cost = build_cost;
893 }
894 }
896
897 return bestdef;
898}
899
900/*******************************************************************/
906struct unit *get_attacker(const struct civ_map *nmap,
907 const struct unit *defender,
908 const struct tile *ptile)
909{
910 struct unit *bestatt = 0;
911 int bestvalue = -1, unit_a, best_cost = 0;
912
913 unit_list_iterate(ptile->units, attacker) {
914 int build_cost = unit_build_shield_cost_base(attacker);
915
916 if (pplayers_allied(unit_owner(defender), unit_owner(attacker))) {
917 return NULL;
918 }
919 unit_a = (int) (100000 * (unit_win_chance(nmap, attacker,
920 defender, NULL)));
921 if (unit_a > bestvalue
922 || (unit_a == bestvalue && build_cost < best_cost)) {
924 bestatt = attacker;
925 best_cost = build_cost;
926 }
928
929 return bestatt;
930}
931
932/**********************************************************************/
943 const struct unit *pvictim,
944 const struct tile *tgt_tile,
945 const struct action *paction)
946{
949
952 /* I can't confirm if we won't deny that we weren't involved.
953 * (Won't defend against its owner.) */
954 continue;
955 }
956
957 if (punit == pvictim
959 /* The victim unit is defenseless unless it's a SuperSpy.
960 * Rationalization: A regular diplomat don't mind being bribed. A
961 * SuperSpy is high enough up the chain that accepting a bribe is
962 * against their own interests. */
963 continue;
964 }
965
968 /* A UTYF_SUPERSPY unit may not actually be a spy, but a superboss
969 * which we cannot allow puny diplomats from getting the better
970 * of. UTYF_SUPERSPY vs UTYF_SUPERSPY in a diplomatic contest always
971 * kills the attacker. */
972
973 /* The unit can't defend in a diplomatic battle. */
974 continue;
975 }
976
977 /* The first potential defender found is chosen. No priority is given
978 * to the best defender. */
979 return punit;
981
982 /* No diplomatic defender found. */
983 return NULL;
984}
985
986/*******************************************************************/
989bool is_stack_vulnerable(const struct tile *ptile)
990{
991 return (game.info.killstack
993 && NULL == tile_city(ptile));
994}
995
996/*******************************************************************/
1003 const struct unit_type *enemy,
1005{
1006 int value = 0;
1007
1009 if (pbonus->type == type && utype_has_flag(enemy, pbonus->flag)) {
1010 value += pbonus->value;
1011 }
1013
1014 return value;
1015}
1016
1017/*******************************************************************/
1021{
1022 const struct unit_type *utype = unit_type_get(punit);
1023 int base_bombard_rate = utype->bombard_rate;
1024
1026 int rate = (base_bombard_rate * punit->hp) / utype->hp;
1027
1028 return MAX(rate, 1);
1029 }
1030
1031 return base_bombard_rate;
1032}
#define n
Definition astring.c:77
#define BV_ISSET(bv, bit)
Definition bitvector.h:78
#define city_owner(_pcity_)
Definition city.h:563
static struct fc_sockaddr_list * list
Definition clinet.c:102
double unit_win_chance(const struct civ_map *nmap, const struct unit *attacker, const struct unit *defender, const struct action *paction)
Definition combat.c:478
bool is_unit_reachable_at(const struct unit *defender, const struct unit *attacker, const struct tile *location)
Definition combat.c:85
bool is_stack_vulnerable(const struct tile *ptile)
Definition combat.c:989
int get_virtual_defense_power(const struct civ_map *nmap, const struct unit_type *att_type, const struct unit_type *def_type, struct player *def_player, struct tile *ptile, bool fortified, int veteran)
Definition combat.c:712
static enum unit_attack_result unit_attack_any_at_tile_result(const struct unit *punit, const struct action *paction, const struct tile *ptile)
Definition combat.c:229
int get_attack_power(const struct unit *punit)
Definition combat.c:535
int unit_bombard_rate(struct unit *punit)
Definition combat.c:1020
int combat_bonus_against(const struct combat_bonus_list *list, const struct unit_type *enemy, enum combat_bonus_type type)
Definition combat.c:1002
int get_fortified_defense_power(const struct unit *attacker, struct unit *defender)
Definition combat.c:781
enum unit_attack_result unit_attack_units_at_tile_result(const struct unit *punit, const struct action *paction, const struct tile *ptile)
Definition combat.c:256
static int get_defense_rating(const struct civ_map *nmap, const struct unit *attacker, const struct unit *defender)
Definition combat.c:814
struct unit * get_attacker(const struct civ_map *nmap, const struct unit *defender, const struct tile *ptile)
Definition combat.c:906
int base_get_attack_power(const struct unit_type *punittype, int veteran, int moves_left)
Definition combat.c:545
struct city * sdi_try_defend(const struct civ_map *nmap, const struct player *owner, const struct tile *ptile)
Definition combat.c:501
int get_total_defense_power(const struct unit *attacker, const struct unit *defender)
Definition combat.c:767
int get_total_attack_power(const struct unit *attacker, const struct unit *defender, const struct action *paction)
Definition combat.c:610
enum unit_attack_result unit_attack_unit_at_tile_result(const struct unit *punit, const struct action *paction, const struct unit *pdefender, const struct tile *dest_tile)
Definition combat.c:122
static enum unit_attack_result unit_attack_all_at_tile_result(const struct unit *punit, const struct action *paction, const struct tile *ptile)
Definition combat.c:188
static int get_defense_power(const struct unit *punit)
Definition combat.c:589
bool is_tired_attack(int moves_left)
Definition combat.c:527
static int defense_multiplication(const struct unit_type *att_type, const struct unit *def, const struct player *def_player, const struct tile *ptile, int defensepower)
Definition combat.c:645
double win_chance(int as, int ahp, int afp, int ds, int dhp, int dfp)
Definition combat.c:332
enum unit_attack_result unit_wipe_units_at_tile_result(const struct unit *punit, const struct tile *ptile)
Definition combat.c:271
struct unit * get_defender(const struct civ_map *nmap, const struct unit *attacker, const struct tile *ptile, const struct action *paction)
Definition combat.c:836
struct unit * get_diplomatic_defender(const struct unit *act_unit, const struct unit *pvictim, const struct tile *tgt_tile, const struct action *paction)
Definition combat.c:942
bool can_unit_attack_tile(const struct unit *punit, const struct action *paction, const struct tile *dest_tile)
Definition combat.c:311
int base_get_defense_power(const struct unit *punit)
Definition combat.c:569
void get_modified_firepower(const struct civ_map *nmap, const struct unit *attacker, const struct unit *defender, int *att_fp, int *def_fp)
Definition combat.c:409
static bool can_player_attack_tile(const struct player *pplayer, const struct tile *ptile)
Definition combat.c:44
static bool is_unit_reachable_by_unit(const struct unit *defender, const struct unit *attacker)
Definition combat.c:73
#define POWER_FACTOR
Definition combat.h:32
unit_attack_result
Definition combat.h:34
@ ATT_NOT_WIPABLE
Definition combat.h:40
@ ATT_NONNATIVE_DST
Definition combat.h:39
@ ATT_OK
Definition combat.h:35
@ ATT_NON_ATTACK
Definition combat.h:36
@ ATT_UNREACHABLE
Definition combat.h:37
@ ATT_NONNATIVE_SRC
Definition combat.h:38
char * incite_cost
Definition comments.c:75
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
int get_target_bonus_effects(struct effect_list *plist, const struct req_context *context, const struct player *other_player, enum effect_type effect_type)
Definition effects.c:748
int get_unittype_bonus(const struct player *pplayer, const struct tile *ptile, const struct unit_type *punittype, const struct action *paction, enum effect_type effect_type)
Definition effects.c:1035
struct civ_game game
Definition game.c:62
struct city * owner
Definition citydlg.c:226
GType type
Definition repodlgs.c:1313
#define fc_assert_ret_val(condition, val)
Definition log.h:194
#define fc_assert_action(condition, action)
Definition log.h:187
#define square_iterate(nmap, center_tile, radius, tile_itr)
Definition map.h:391
#define square_iterate_end
Definition map.h:394
bool can_exist_at_tile(const struct civ_map *nmap, const struct unit_type *utype, const struct tile *ptile)
Definition movement.c:290
bool is_native_tile(const struct unit_type *punittype, const struct tile *ptile)
Definition movement.c:331
bool can_attack_non_native_hard_reqs(const struct unit_type *utype)
Definition movement.c:204
bool unit_can_defend_here(const struct civ_map *nmap, const struct unit *punit)
Definition movement.c:174
#define SINGLE_MOVE
Definition movement.h:26
static bool is_native_tile_to_class(const struct unit_class *punitclass, const struct tile *ptile)
Definition movement.h:84
bool pplayers_at_war(const struct player *pplayer, const struct player *pplayer2)
Definition player.c:1388
bool pplayers_allied(const struct player *pplayer, const struct player *pplayer2)
Definition player.c:1405
#define fc_rand(_size)
Definition rand.h:56
#define MIN(x, y)
Definition shared.h:55
#define MAX(x, y)
Definition shared.h:54
Definition city.h:320
struct tile * tile
Definition city.h:322
struct packet_game_info info
Definition game.h:89
bool damage_reduces_bombard_rate
int low_firepower_pearl_harbour
int low_firepower_nonnat_bombard
int low_firepower_combat_bonus
int low_firepower_badwallattacker
Definition tile.h:50
struct unit_list * units
Definition tile.h:58
struct veteran_system * veteran
Definition unittype.h:544
int bombard_rate
Definition unittype.h:547
Definition unit.h:138
enum unit_activity activity
Definition unit.h:157
int moves_left
Definition unit.h:150
int hp
Definition unit.h:151
int veteran
Definition unit.h:152
#define TRUE
Definition support.h:46
#define FALSE
Definition support.h:47
bool tile_has_extra_flag(const struct tile *ptile, enum extra_flag_id flag)
Definition tile.c:886
int tile_extras_defense_bonus(const struct tile *ptile, const struct unit_type *punittype)
Definition tile.c:233
bool tile_has_native_base(const struct tile *ptile, const struct unit_type *punittype)
Definition tile.c:324
struct city * tile_city(const struct tile *ptile)
Definition tile.c:83
#define tile_terrain(_tile)
Definition tile.h:110
struct unit * unit_virtual_create(struct player *pplayer, struct city *pcity, const struct unit_type *punittype, int veteran_level)
Definition unit.c:1624
void unit_virtual_destroy(struct unit *punit)
Definition unit.c:1729
void unit_tile_set(struct unit *punit, struct tile *ptile)
Definition unit.c:1255
bool unit_transported(const struct unit *pcargo)
Definition unit.c:2425
#define unit_tile(_pu)
Definition unit.h:397
#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
const struct unit_type * unit_type_get(const struct unit *punit)
Definition unittype.c:123
bool utype_has_class_flag(const struct unit_type *ptype, enum unit_class_flag_id flag)
Definition unittype.c:1657
int unit_build_shield_cost_base(const struct unit *punit)
Definition unittype.c:1484
bool utype_can_do_act_when_ustate(const struct unit_type *punit_type, const action_id act_id, const enum ustate_prop prop, const bool is_there)
Definition unittype.c:955
struct unit_class * unit_class_get(const struct unit *punit)
Definition unittype.c:2499
bool utype_can_do_action_result(const struct unit_type *putype, enum action_result result)
Definition unittype.c:387
const struct veteran_level * utype_veteran_level(const struct unit_type *punittype, int level)
Definition unittype.c:2597
bool unit_has_type_flag(const struct unit *punit, enum unit_type_flag_id flag)
Definition unittype.c:190
Unit_type_id utype_index(const struct unit_type *punittype)
Definition unittype.c:91
bool utype_can_do_action(const struct unit_type *putype, const action_id act_id)
Definition unittype.c:371
static bool uclass_has_flag(const struct unit_class *punitclass, enum unit_class_flag_id flag)
Definition unittype.h:766
#define utype_class(_t_)
Definition unittype.h:749
#define combat_bonus_list_iterate_end
Definition unittype.h:482
#define combat_bonus_list_iterate(bonuslist, pbonus)
Definition unittype.h:480
static bool utype_has_flag(const struct unit_type *punittype, int flag)
Definition unittype.h:617
#define uclass_index(_c_)
Definition unittype.h:742