Drachen: kein eigenes Silber riechen, keine unsichtbaren Einheiten angreifen.

This commit is contained in:
Enno Rehling 2005-05-21 11:50:21 +00:00
parent 2fc718b983
commit 9b4ffd9e25
4 changed files with 29 additions and 26 deletions

View file

@ -116,13 +116,14 @@ get_money_for_dragon(region * r, unit * u, int wanted)
/* falls der drache launisch ist, oder das regionssilber knapp, greift er alle an */ /* falls der drache launisch ist, oder das regionssilber knapp, greift er alle an */
n = 0; n = 0;
for (u2 = r->units; u2; u2 = u2->next) { for (u2 = r->units; u2; u2 = u2->next) {
if (u2->faction != u->faction && get_money(u2)) { if (u2->faction != u->faction && cansee(u->faction, r, u2, 0)) {
if (getguard(u2) & GUARD_TAX) continue; int m = get_money(u2);
if (m==0 || (getguard(u2) & GUARD_TAX)) continue;
else { else {
order * ord = monster_attack(u, u2); order * ord = monster_attack(u, u2);
if (ord) { if (ord) {
addlist(&u->orders, ord); addlist(&u->orders, ord);
n += get_money(u2); n += m;
} }
} }
} }
@ -139,19 +140,22 @@ get_money_for_dragon(region * r, unit * u, int wanted)
} }
static int static int
money(region * r) all_money(region * r, faction * f)
{ {
unit *u; unit *u;
int m; int m;
m = rmoney(r); m = rmoney(r);
for (u = r->units; u; u = u->next) for (u = r->units; u; u = u->next) {
if (f!=u->faction) {
m += get_money(u); m += get_money(u);
}
}
return m; return m;
} }
static direction_t static direction_t
richest_neighbour(region * r, int absolut) richest_neighbour(region * r, faction * f, int absolut)
{ {
/* m - maximum an Geld, d - Richtung, i - index, t = Geld hier */ /* m - maximum an Geld, d - Richtung, i - index, t = Geld hier */
@ -161,9 +165,9 @@ richest_neighbour(region * r, int absolut)
direction_t d = NODIRECTION, i; direction_t d = NODIRECTION, i;
if (absolut == 1 || rpeasants(r) == 0) { if (absolut == 1 || rpeasants(r) == 0) {
m = (double) money(r); m = (double) all_money(r, f);
} else { } else {
m = (double) money(r) / (double) rpeasants(r); m = (double) all_money(r, f) / (double) rpeasants(r);
} }
/* finde die region mit dem meisten geld */ /* finde die region mit dem meisten geld */
@ -171,9 +175,9 @@ richest_neighbour(region * r, int absolut)
for (i = 0; i != MAXDIRECTIONS; i++) for (i = 0; i != MAXDIRECTIONS; i++)
if (rconnect(r, i) && rterrain(rconnect(r, i)) != T_OCEAN) { if (rconnect(r, i) && rterrain(rconnect(r, i)) != T_OCEAN) {
if (absolut == 1 || rpeasants(r) == 0) { if (absolut == 1 || rpeasants(r) == 0) {
t = (double) money(rconnect(r, i)); t = (double) all_money(rconnect(r, i), f);
} else { } else {
t = (double) money(rconnect(r, i)) / (double) rpeasants(r); t = (double) all_money(rconnect(r, i), f) / (double) rpeasants(r);
} }
if (t > m) { if (t > m) {
@ -304,7 +308,7 @@ monster_move(region * r, unit * u)
case RC_FIREDRAGON: case RC_FIREDRAGON:
case RC_DRAGON: case RC_DRAGON:
case RC_WYRM: case RC_WYRM:
d = richest_neighbour(r, 1); d = richest_neighbour(r, u->faction, 1);
break; break;
case RC_TREEMAN: case RC_TREEMAN:
d = treeman_neighbour(r); d = treeman_neighbour(r);
@ -333,7 +337,7 @@ monster_move(region * r, unit * u)
static int static int
dragon_affinity_value(region *r, unit *u) dragon_affinity_value(region *r, unit *u)
{ {
int m = count_all_money(r); int m = all_money(r, u->faction);
if(u->race == new_race[RC_FIREDRAGON]) { if(u->race == new_race[RC_FIREDRAGON]) {
return (int)(normalvariate(m,m/2)); return (int)(normalvariate(m,m/2));

View file

@ -552,18 +552,6 @@ resourcepath(void)
return strcat(strcpy(zText, basepath()), "/res"); return strcat(strcpy(zText, basepath()), "/res");
} }
int
count_all_money(const region * r)
{
const unit *u;
int m = rmoney(r);
for (u = r->units; u; u = u->next)
m += get_money(u);
return m;
}
int int
count_skill(faction * f, skill_t sk) count_skill(faction * f, skill_t sk)
{ {

View file

@ -907,7 +907,6 @@ extern int lighthouse_range(const struct building * b, const struct faction * f)
/* skills */ /* skills */
extern int max_skill(struct faction * f, skill_t sk); extern int max_skill(struct faction * f, skill_t sk);
extern int count_skill(struct faction * f, skill_t sk); extern int count_skill(struct faction * f, skill_t sk);
extern int count_all_money(const struct region * r);
/* direction, geography */ /* direction, geography */
extern const char *directions[]; extern const char *directions[];

View file

@ -171,6 +171,18 @@ SpecialFunction(region *r)
delwin(win); delwin(win);
} }
static int
count_all_money(const region * r)
{
const unit *u;
int m = rmoney(r);
for (u = r->units; u; u = u->next)
m += get_money(u);
return m;
}
char Tchar[MAXRACES] = "ZEOGMTDIHK~uifdwtbrsz"; char Tchar[MAXRACES] = "ZEOGMTDIHK~uifdwtbrsz";
void void