"Dämonen gehen an die Bauern"
- fixed recruit/release of demons.
This commit is contained in:
Enno Rehling 2008-02-04 23:14:50 +00:00
parent 7dc301596e
commit 3a56a1127c
3 changed files with 28 additions and 15 deletions

View file

@ -290,7 +290,7 @@ any_recruiters(const struct race * rc, int qty)
static int static int
peasant_recruiters(const struct race * rc, int qty) peasant_recruiters(const struct race * rc, int qty)
{ {
if (rc->ec_flags & ECF_REC_UNLIMITED) return -1; if (rc->ec_flags & ECF_REC_ETHEREAL) return -1;
if (rc->ec_flags & ECF_REC_HORSES) return -1; if (rc->ec_flags & ECF_REC_HORSES) return -1;
if (rc==new_race[RC_URUK]) return qty; if (rc==new_race[RC_URUK]) return qty;
return qty * 2; return qty * 2;
@ -299,7 +299,7 @@ peasant_recruiters(const struct race * rc, int qty)
static int static int
horse_recruiters(const struct race * rc, int qty) horse_recruiters(const struct race * rc, int qty)
{ {
if (rc->ec_flags & ECF_REC_UNLIMITED) return -1; if (rc->ec_flags & ECF_REC_ETHEREAL) return -1;
if (rc->ec_flags & ECF_REC_HORSES) return qty * 2; if (rc->ec_flags & ECF_REC_HORSES) return qty * 2;
return -1; return -1;
} }
@ -424,7 +424,11 @@ expandrecruit(region * r, request * recruitorders)
/* no limit: */ /* no limit: */
recruits = select_recruitment(&recruitorders, any_recruiters, &orc_total); recruits = select_recruitment(&recruitorders, any_recruiters, &orc_total);
if (recruits) { if (recruits) {
do_recruiting(recruits, INT_MAX); int recruited, peasants = rpeasants(r);
recruited = do_recruiting(recruits, INT_MAX);
if (recruited>0) {
rsetpeasants(r, peasants - recruited/2);
}
free_recruitments(recruits); free_recruitments(recruits);
} }

View file

@ -228,13 +228,14 @@ destroyfaction(faction * f)
distribute_items(u); distribute_items(u);
if (!fval(r->terrain, SEA_REGION) && !!playerrace(u->race)) { if (!fval(r->terrain, SEA_REGION) && !!playerrace(u->race)) {
const race * rc = u->race; const race * rc = u->race;
int p = rpeasants(u->region);
int m = rmoney(u->region); int m = rmoney(u->region);
if ((rc->ec_flags & ECF_REC_ETHEREAL)==0) {
int p = rpeasants(u->region);
int h = rhorses(u->region); int h = rhorses(u->region);
/* Personen gehen nur an die Bauern, wenn sie auch von dort /* Personen gehen nur an die Bauern, wenn sie auch von dort
* stammen */ * stammen */
if ((rc->ec_flags & ECF_REC_UNLIMITED)==0) {
if (rc->ec_flags & ECF_REC_HORSES) { /* Zentauren an die Pferde */ if (rc->ec_flags & ECF_REC_HORSES) { /* Zentauren an die Pferde */
h += u->number; h += u->number;
} else if (rc == new_race[RC_URUK]){ /* Orks zählen nur zur Hälfte */ } else if (rc == new_race[RC_URUK]){ /* Orks zählen nur zur Hälfte */
@ -242,11 +243,11 @@ destroyfaction(faction * f)
} else { } else {
p += u->number; p += u->number;
} }
}
m += get_money(u);
h += get_item(u, I_HORSE); h += get_item(u, I_HORSE);
rsetpeasants(r, p); rsetpeasants(r, p);
rsethorses(r, h); rsethorses(r, h);
}
m += get_money(u);
rsetmoney(r, m); rsetmoney(r, m);
} }

View file

@ -870,11 +870,19 @@ transfermen(unit * u, unit * u2, int n)
} }
} }
else if (r->land) { else if (r->land) {
if ((u->race->ec_flags & ECF_REC_UNLIMITED)==0) { if ((u->race->ec_flags & ECF_REC_ETHEREAL)==0) {
if(u->race != new_race[RC_URUK]) { const race * rc = u->race;
rsetpeasants(r, rpeasants(r) + n); if (rc->ec_flags & ECF_REC_HORSES) { /* Zentauren an die Pferde */
int h = rhorses(r) + u->number;
rsethorses(r, h);
} else { } else {
rsetpeasants(r, rpeasants(r) + n/2); int p = rpeasants(r);
if (rc == new_race[RC_URUK]){ /* Orks zählen nur zur Hälfte */
p += u->number/2;
} else {
p += u->number;
}
rsetpeasants(r, p);
} }
} }
} }