new mail addresses

gcc-4.2: MAX() and MIN()
This commit is contained in:
Enno Rehling 2008-08-18 10:11:51 +00:00
parent 8a2fe52291
commit 9e529a50ae
43 changed files with 323 additions and 334 deletions

View file

@ -13,8 +13,9 @@ if ! $(HAVE_LUA) {
}
if ! $(CPU) {
CPU = pentium2 ;
ARCH = -march=$(CPU) -mtune=$(CPU) -mmmx -mieee-fp ;
CPU = prescott ;
ARCH = -march=$(CPU) -mmmx -mieee-fp ;
ARCH += -mtune=$(CPU) ;
}
if $(DISTCC_HOSTS) {

View file

@ -276,40 +276,32 @@ cr_output_curses(FILE * F, const faction * viewer, const void * obj, typ_t typ)
static int
cr_unit(variant var, char * buffer, const void * userdata)
{
const faction * report = (const faction*)userdata;
unit * u = (unit *)var.v;
sprintf(buffer, "%d", u?u->no:-1);
unused(report);
return 0;
}
static int
cr_ship(variant var, char * buffer, const void * userdata)
{
const faction * report = (const faction*)userdata;
ship * u = (ship *)var.v;
sprintf(buffer, "%d", u?u->no:-1);
unused(report);
return 0;
}
static int
cr_building(variant var, char * buffer, const void * userdata)
{
const faction * report = (const faction*)userdata;
building * u = (building *)var.v;
sprintf(buffer, "%d", u?u->no:-1);
unused(report);
return 0;
}
static int
cr_faction(variant var, char * buffer, const void * userdata)
{
const faction * report = (const faction*)userdata;
faction * f = (faction *)var.v;
sprintf(buffer, "%d", f?f->no:-1);
unused(report);
return 0;
}

View file

@ -353,10 +353,10 @@ do_recruiting(recruitment * recruits, int available)
if (rc==new_race[RC_URUK]) multi = 1;
number = min(req->qty, get / multi);
number = MIN(req->qty, get / multi);
if (rc->recruitcost) {
int afford = get_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, number*rc->recruitcost) / rc->recruitcost;
number = min(number, afford);
number = MIN(number, afford);
use_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, rc->recruitcost*number);
}
if (u->number+number>UNIT_MAXSIZE) {
@ -548,7 +548,7 @@ recruit(unit * u, struct order * ord, request ** recruitorders)
}
if (recruitcost>0) {
int pooled = get_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, recruitcost * n);
n = min(n, pooled / recruitcost);
n = MIN(n, pooled / recruitcost);
}
u->wants = n;
@ -1120,7 +1120,7 @@ recruit_archetype(unit * u, order * ord)
if (a!=NULL) {
maxsize -= a->data.i;
}
n = min(maxsize/arch->size, n);
n = MIN(maxsize/arch->size, n);
if (n<=0) {
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "recruit_capacity_exhausted", "building", u->building));
/* TODO: error message */
@ -1427,11 +1427,11 @@ allocate_resource(unit * u, const resource_type * rtype, int want)
/* nun ist amount die Gesamtproduktion der Einheit (in punkten) */
/* mit Flinkfingerring verzehnfacht sich die Produktion */
amount += skill * min(u->number, get_item(u,I_RING_OF_NIMBLEFINGER)) * 9;
amount += skill * MIN(u->number, get_item(u,I_RING_OF_NIMBLEFINGER)) * 9;
/* Schaffenstrunk: */
if ((dm = get_effect(u, oldpotiontype[P_DOMORE])) != 0) {
dm = min(dm, u->number);
dm = MIN(dm, u->number);
change_effect(u, oldpotiontype[P_DOMORE], -dm);
amount += dm * skill; /* dm Personen produzieren doppelt */
}
@ -1538,7 +1538,7 @@ leveled_allocation(const resource_type * rtype, region * r, allocation * alist)
}
need = norders;
avail = min(avail, norders);
avail = MIN(avail, norders);
if (need>0) {
int use = 0;
for (al=alist;al;al=al->next) if (!fval(al, AFL_DONE)) {
@ -1552,7 +1552,7 @@ leveled_allocation(const resource_type * rtype, region * r, allocation * alist)
use += x;
norders -= want;
need -= x;
al->get = min(al->want, al->get+(int)(x/al->save));
al->get = MIN(al->want, al->get+(int)(x/al->save));
}
}
if (use) {
@ -1584,7 +1584,7 @@ attrib_allocation(const resource_type * rtype, region * r, allocation * alist)
if (avail < 0) avail = 0;
}
avail = min(avail, norders);
avail = MIN(avail, norders);
for (al=alist;al;al=al->next) {
if (avail > 0) {
int want = required(al->want, al->save);
@ -1594,7 +1594,7 @@ attrib_allocation(const resource_type * rtype, region * r, allocation * alist)
++x;
avail -= x;
norders -= want;
al->get = min(al->want, (int)(x/al->save));
al->get = MIN(al->want, (int)(x/al->save));
if (rdata->produce) {
int use = required(al->get, al->save);
if (use) rdata->produce(r, rtype, use);
@ -2021,7 +2021,7 @@ buy(unit * u, request ** buyorders, struct order * ord)
k -= a->data.i;
}
n = min(n, k);
n = MIN(n, k);
if (!n) {
cmistake(u, ord, 102, MSG_COMMERCE);
@ -2305,7 +2305,7 @@ static boolean
/* Ein Händler kann nur 10 Güter pro Talentpunkt verkaufen. */
n = min(n, u->number * 10 * eff_skill(u, SK_TRADE, r));
n = MIN(n, u->number * 10 * eff_skill(u, SK_TRADE, r));
if (!n) {
cmistake(u, ord, 54, MSG_COMMERCE);
@ -2334,11 +2334,11 @@ static boolean
for (o=*sellorders;o;o=o->next) {
if (o->type.ltype==ltype && o->unit->faction == u->faction) {
int fpool = o->qty - get_pooled(o->unit, itype->rtype, GET_RESERVE, INT_MAX);
available -= max(0, fpool);
available -= MAX(0, fpool);
}
}
n = min(n, available);
n = MIN(n, available);
if (n <= 0) {
cmistake(u, ord, 264, MSG_COMMERCE);
@ -2362,7 +2362,7 @@ static boolean
k -= a->data.i;
}
n = min(n, k);
n = MIN(n, k);
assert(n>=0);
/* die Menge der verkauften Güter merken */
a->data.i += n;
@ -2415,7 +2415,7 @@ expandstealing(region * r, request * stealorders)
n = 10;
}
if (n > 0) {
n = min(n, oa[i].unit->wants);
n = MIN(n, oa[i].unit->wants);
use_pooled(u, r_silver, GET_ALL, n);
oa[i].unit->n = n;
change_money(oa[i].unit, n);
@ -2469,8 +2469,8 @@ plant(region *r, unit *u, int raw)
return;
}
n = min(skill*u->number, n);
n = min(raw, n);
n = MIN(skill*u->number, n);
n = MIN(raw, n);
/* Für jedes Kraut Talent*10% Erfolgschance. */
for(i = n; i>0; i--) {
if (rng_int()%10 < skill) planted++;
@ -2518,14 +2518,14 @@ planttrees(region *r, unit *u, int raw)
}
/* wenn eine Anzahl angegeben wurde, nur soviel verbrauchen */
raw = min(raw, skill*u->number);
raw = MIN(raw, skill*u->number);
n = get_pooled(u, rtype, GET_DEFAULT, raw);
if (n==0) {
ADDMSG(&u->faction->msgs,
msg_feedback(u, u->thisorder, "resource_missing", "missing", rtype));
return;
}
n = min(raw, n);
n = MIN(raw, n);
/* Für jeden Samen Talent*10% Erfolgschance. */
for(i = n; i>0; i--) {
@ -2582,7 +2582,7 @@ breedtrees(region *r, unit *u, int raw)
}
/* wenn eine Anzahl angegeben wurde, nur soviel verbrauchen */
raw = min(skill*u->number, raw);
raw = MIN(skill*u->number, raw);
n = get_pooled(u, rtype, GET_DEFAULT, raw);
/* Samen prüfen */
if (n==0) {
@ -2590,7 +2590,7 @@ breedtrees(region *r, unit *u, int raw)
msg_feedback(u, u->thisorder, "resource_missing", "missing", rtype));
return;
}
n = min(raw, n);
n = MIN(raw, n);
/* Für jeden Samen Talent*5% Erfolgschance. */
for(i = n; i>0; i--) {
@ -2623,7 +2623,7 @@ breedhorses(region *r, unit *u)
cmistake(u, u->thisorder, 107, MSG_PRODUCE);
return;
}
n = min(u->number * eff_skill(u, SK_HORSE_TRAINING, r), get_item(u, I_HORSE));
n = MIN(u->number * eff_skill(u, SK_HORSE_TRAINING, r), get_item(u, I_HORSE));
for (c = 0; c < n; c++) {
if (rng_int() % 100 < eff_skill(u, SK_HORSE_TRAINING, r)) {
@ -2848,7 +2848,7 @@ steal_cmd(unit * u, struct order * ord, request ** stealorders)
}
}
i = min(u->number, get_item(u,I_RING_OF_NIMBLEFINGER));
i = MIN(u->number, get_item(u,I_RING_OF_NIMBLEFINGER));
if (i > 0) {
n *= STEALINCOME * (u->number + i * 9);
} else {
@ -2869,7 +2869,7 @@ steal_cmd(unit * u, struct order * ord, request ** stealorders)
/* Nur soviel PRODUCEEXP wie auch tatsaechlich gemacht wurde */
produceexp(u, SK_STEALTH, min(n, u->number));
produceexp(u, SK_STEALTH, MIN(n, u->number));
}
/* ------------------------------------------------------------- */
@ -2894,7 +2894,7 @@ expandentertainment(region * r)
entertaining -= o->qty;
/* Nur soviel PRODUCEEXP wie auch tatsächlich gemacht wurde */
produceexp(u, SK_ENTERTAINMENT, min(u->n, u->number));
produceexp(u, SK_ENTERTAINMENT, MIN(u->n, u->number));
add_income(u, IC_ENTERTAIN, o->qty, u->n);
fset(u, UFL_LONGACTION|UFL_NOTMOVING);
}
@ -2945,7 +2945,7 @@ entertain_cmd(unit * u, struct order * ord)
skip_token();
max_e = getuint();
if (max_e != 0) {
u->wants = min(u->wants,max_e);
u->wants = MIN(u->wants,max_e);
}
o = nextentertainer++;
o->unit = u;
@ -2997,7 +2997,7 @@ expandwork(region * r, request * work_begin, request * work_end)
/* Der Rest wird von den Bauern verdient. n ist das uebriggebliebene
* Geld. */
earnings = min(n, rpeasants(r) * p_wage) + verdienst;
earnings = MIN(n, rpeasants(r) * p_wage) + verdienst;
/* Mehr oder weniger durch Trank "Riesengrass" oder "Faulobstschnaps" */
rsetmoney(r, rmoney(r) + earnings);
@ -3097,9 +3097,9 @@ tax_cmd(unit * u, struct order * ord, request ** taxorders)
if (max == 0) max = INT_MAX;
if (!playerrace(u->race)) {
u->wants = min(income(u), max);
u->wants = MIN(income(u), max);
} else {
u->wants = min(n * eff_skill(u, SK_TAXING, r) * 20, max);
u->wants = MIN(n * eff_skill(u, SK_TAXING, r) * 20, max);
}
u2 = is_guarded(r, u, GUARD_TAX);

View file

@ -87,7 +87,7 @@ give_item(int want, const item_type * itype, unit * src, unit * dest, struct ord
assert(itype!=NULL);
n = get_pooled(src, item2resource(itype), GET_DEFAULT, want);
n = min(want, n);
n = MIN(want, n);
if (dest && src->faction != dest->faction && src->faction->age < GiveRestriction()) {
if (ord!=NULL) {
ADDMSG(&src->faction->msgs, msg_feedback(src, ord, "giverestriction",

View file

@ -202,7 +202,7 @@ get_food(region *r)
* food from the peasants */
if (owner!=NULL && (get_alliance(owner, u->faction) & HELP_MONEY)) {
int rm = rmoney(r);
int use = min(rm, need);
int use = MIN(rm, need);
rsetmoney(r, rm-use);
need -= use;
}
@ -214,7 +214,7 @@ get_food(region *r)
for (v = r->units; need && v; v = v->next) {
if (v->faction == u->faction && help_money(v)) {
int give = get_money(v) - lifestyle(v);
give = min(need, give);
give = MIN(need, give);
if (give>0) {
change_money(v, -give);
change_money(u, give);
@ -231,7 +231,7 @@ get_food(region *r)
int need = lifestyle(u);
faction * f = u->faction;
need -= max(0, get_money(u));
need -= MAX(0, get_money(u));
if (need > 0) {
unit *v;
@ -239,7 +239,7 @@ get_food(region *r)
for (v = r->units; need && v; v = v->next) {
if (v->faction != f && alliedunit(v, f, HELP_MONEY) && help_money(v)) {
int give = get_money(v) - lifestyle(v);
give = min(need, give);
give = MIN(need, give);
if (give>0) {
change_money(v, -give);
@ -289,7 +289,7 @@ get_food(region *r)
}
if (donor != NULL) {
int blut = get_effect(donor, pt_blood);
blut = min(blut, hungry);
blut = MIN(blut, hungry);
change_effect(donor, pt_blood, -blut);
hungry -= blut;
}
@ -320,7 +320,7 @@ get_food(region *r)
/* 3. Von den überlebenden das Geld abziehen: */
for (u = r->units; u; u = u->next) {
int need = min(get_money(u), lifestyle(u));
int need = MIN(get_money(u), lifestyle(u));
change_money(u, -need);
}
}
@ -382,7 +382,7 @@ live(region * r)
}
/* bestes Talent raussuchen */
if (sb!=NULL) {
int weeks = min(effect, u->number);
int weeks = MIN(effect, u->number);
reduce_skill(u, sb, weeks);
ADDMSG(&u->faction->msgs, msg_message("dumbeffect",
"unit weeks skill", u, weeks, (skill_t)sb->id));
@ -439,7 +439,7 @@ calculate_emigration(region *r)
int max_emigration = MAX_EMIGRATION(rp2-maxp2);
if (max_emigration>0) {
max_emigration = min(max_emigration, max_immigrants);
max_emigration = MIN(max_emigration, max_immigrants);
r->land->newpeasants += max_emigration;
rc->land->newpeasants -= max_emigration;
max_immigrants -= max_emigration;
@ -499,7 +499,7 @@ peasants(region * r)
/* Alle werden satt, oder halt soviele für die es auch Geld gibt */
satiated = min(peasants, money / maintenance_cost(NULL));
satiated = MIN(peasants, money / maintenance_cost(NULL));
rsetmoney(r, money - satiated * maintenance_cost(NULL));
/* Von denjenigen, die nicht satt geworden sind, verhungert der
@ -508,7 +508,7 @@ peasants(region * r)
/* Es verhungert maximal die unterernährten Bevölkerung. */
n = min(peasants - satiated, rpeasants(r));
n = MIN(peasants - satiated, rpeasants(r));
dead += (int)(0.5F + n * PEASANT_STARVATION_CHANCE);
if (dead > 0) {
@ -590,7 +590,7 @@ horses(region * r)
/* Logistisches Wachstum, Optimum bei halbem Maximalbesatz. */
maxhorses = maxworkingpeasants(r)/10;
maxhorses = max(0, maxhorses);
maxhorses = MAX(0, maxhorses);
horses = rhorses(r);
if (horses > 0) {
if (is_cursed(r->attribs, C_CURSED_BY_THE_GODS, 0)) {
@ -620,7 +620,7 @@ horses(region * r)
if (r2 && fval(r2->terrain, WALK_INTO)) {
int pt = (rhorses(r) * HORSEMOVE)/100;
pt = (int)normalvariate(pt, pt/4.0);
pt = max(0, pt);
pt = MAX(0, pt);
if (fval(r2, RF_MIGRATION))
rsethorses(r2, rhorses(r2) + pt);
else {
@ -666,7 +666,7 @@ trees(region * r, const int current_season, const int last_weeks_season)
a = a_find(r->attribs, &at_germs);
if(a && last_weeks_season == SEASON_SPRING) {
/* ungekeimte Samen bleiben erhalten, Sprößlinge wachsen */
sprout = min(a->data.sa[1], rtrees(r, 1));
sprout = MIN(a->data.sa[1], rtrees(r, 1));
/* aus dem gesamt Sprößlingepool abziehen */
rsettrees(r, 1, rtrees(r, 1) - sprout);
/* zu den Bäumen hinzufügen */
@ -686,7 +686,7 @@ trees(region * r, const int current_season, const int last_weeks_season)
/* Grundchance 1.0% */
seedchance = (int)(FORESTGROWTH * RESOURCE_QUANTITY);
/* Jeder Elf in der Region erhöht die Chance um 0.0008%. */
seedchance += (min(elves, (production(r)*MAXPEASANTS_PER_AREA)/8)) * 8;
seedchance += (MIN(elves, (production(r)*MAXPEASANTS_PER_AREA)/8)) * 8;
grownup_trees = rtrees(r, 2);
seeds = 0;
@ -738,7 +738,7 @@ trees(region * r, const int current_season, const int last_weeks_season)
/* Raubbau abfangen, es dürfen nie mehr Samen wachsen, als aktuell
* in der Region sind */
seeds = min(a->data.sa[0], rtrees(r, 0));
seeds = MIN(a->data.sa[0], rtrees(r, 0));
sprout = 0;
for(i=0;i<seeds;i++) {
@ -757,7 +757,7 @@ trees(region * r, const int current_season, const int last_weeks_season)
* der Region entfernt werden können, da Jungbäume in der gleichen
* Runde nachwachsen, wir also nicht mehr zwischen diesjährigen und
* 'alten' Jungbäumen unterscheiden könnten */
sprout = min(a->data.sa[1], rtrees(r, 1));
sprout = MIN(a->data.sa[1], rtrees(r, 1));
grownup_trees = 0;
for(i=0;i<sprout;i++) {
@ -844,7 +844,7 @@ demographics(void)
for (r = regions; r; r = r->next) {
if (r->land && r->land->newpeasants) {
int rp = rpeasants(r) + r->land->newpeasants;
rsetpeasants(r, max(0, rp));
rsetpeasants(r, MAX(0, rp));
}
}
@ -1089,7 +1089,7 @@ parse_restart(void)
puts(" - beseitige Spieler, die sich nach der Anmeldung nicht "
"gemeldet haben...");
age = calloc(max(4,turn+1), sizeof(int));
age = calloc(MAX(4,turn+1), sizeof(int));
for (f = factions; f; f = f->next) if (!is_monsters(f)) {
if (RemoveNMRNewbie() && !fval(f, FFL_NOIDLEOUT)) {
if (f->age>=0 && f->age <= turn) ++age[f->age];
@ -2386,7 +2386,7 @@ combatspell_cmd(unit * u, struct order * ord)
if (findparam(s, u->faction->locale) == P_LEVEL) {
/* Merken, setzen kommt erst später */
level = getint();
level = max(0, level);
level = MAX(0, level);
s = getstrtoken();
}
@ -2943,8 +2943,8 @@ age_building(building * b)
}
} else if (mage!=NULL) {
int sk = effskill(mage, SK_MAGIC);
c->duration = max(c->duration, sk/2);
c->vigour = max(c->vigour, sk);
c->duration = MAX(c->duration, sk/2);
c->vigour = MAX(c->vigour, sk);
}
}
}
@ -2969,12 +2969,12 @@ ageing(void)
/* Goliathwasser */
int i = get_effect(u, oldpotiontype[P_STRONG]);
if (i > 0){
change_effect(u, oldpotiontype[P_STRONG], -1 * min(u->number, i));
change_effect(u, oldpotiontype[P_STRONG], -1 * MIN(u->number, i));
}
/* Berserkerblut*/
i = get_effect(u, oldpotiontype[P_BERSERK]);
if (i > 0){
change_effect(u, oldpotiontype[P_BERSERK], -1 * min(u->number, i));
change_effect(u, oldpotiontype[P_BERSERK], -1 * MIN(u->number, i));
}
if (is_cursed(u->attribs, C_OLDRACE, 0)){
@ -3325,9 +3325,9 @@ monthly_healing(void)
p *= heal_factor(u->race);
if (u->hp < umhp) {
#ifdef NEW_DAEMONHUNGER_RULE
double maxheal = max(u->number, umhp/20.0);
double maxheal = MAX(u->number, umhp/20.0);
#else
double maxheal = max(u->number, umhp/10.0);
double maxheal = MAX(u->number, umhp/10.0);
#endif
int addhp;
struct building * b = inside_building(u);
@ -3344,7 +3344,7 @@ monthly_healing(void)
if (maxheal>0.0 && chance(maxheal)) ++addhp;
/* Aufaddieren der geheilten HP. */
u->hp = min(u->hp + addhp, umhp);
u->hp = MIN(u->hp + addhp, umhp);
/* soll man an negativer regeneration sterben können? */
assert(u->hp > 0);
@ -3502,7 +3502,7 @@ claim_cmd(unit * u, struct order * ord)
if (itype!=NULL) {
item ** iclaim = i_find(&u->faction->items, itype);
if (iclaim!=NULL && *iclaim!=NULL) {
n = min(n, (*iclaim)->number);
n = MIN(n, (*iclaim)->number);
i_change(iclaim, itype, -n);
i_change(&u->items, itype, n);
}

View file

@ -84,7 +84,7 @@ reduce_weight(unit * u)
int weight = 0;
if (horses > 0) {
horses = min(horses, (u->number*2));
horses = MIN(horses, (u->number*2));
change_resource(u, oldresourcetype[R_HORSE], - horses);
}
@ -96,7 +96,7 @@ reduce_weight(unit * u)
if (weight>capacity) {
if (itype->weight>=10 && itype->rtype->wtype==0 && itype->rtype->atype==0) {
if (itype->capacity < itype->weight) {
int reduce = min(itm->number, -((capacity-weight)/itype->weight));
int reduce = MIN(itm->number, -((capacity-weight)/itype->weight));
give_item(reduce, itm->type, u, NULL, NULL);
weight -= reduce * itype->weight;
}
@ -110,7 +110,7 @@ reduce_weight(unit * u)
const item_type * itype = itm->type;
weight += itm->number*itype->weight;
if (itype->capacity < itype->weight) {
int reduce = min(itm->number, -((capacity-weight)/itype->weight));
int reduce = MIN(itm->number, -((capacity-weight)/itype->weight));
give_item(reduce, itm->type, u, NULL, NULL);
weight -= reduce * itype->weight;
}
@ -608,7 +608,7 @@ eaten_by_monster(unit * u)
if (n > 0) {
n = lovar(n);
n = min(rpeasants(u->region), n);
n = MIN(rpeasants(u->region), n);
if (n > 0) {
deathcounts(u->region, n);
@ -634,7 +634,7 @@ absorbed_by_monster(unit * u)
if(n > 0) {
n = lovar(n);
n = min(rpeasants(u->region), n);
n = MIN(rpeasants(u->region), n);
if (n > 0){
rsetpeasants(u->region, rpeasants(u->region) - n);
scale_number(u, u->number + n);
@ -650,7 +650,7 @@ scareaway(region * r, int anzahl)
int n, p, diff = 0, emigrants[MAXDIRECTIONS];
direction_t d;
anzahl = min(max(1, anzahl),rpeasants(r));
anzahl = MIN(MAX(1, anzahl),rpeasants(r));
/* Wandern am Ende der Woche (normal) oder wegen Monster. Die
* Wanderung wird erst am Ende von demographics () ausgefuehrt.
@ -662,7 +662,7 @@ scareaway(region * r, int anzahl)
p = rpeasants(r);
assert(p >= 0 && anzahl >= 0);
for (n = min(p, anzahl); n; n--) {
for (n = MIN(p, anzahl); n; n--) {
direction_t dir = (direction_t)(rng_int() % MAXDIRECTIONS);
region * rc = rconnect(r, dir);
@ -698,7 +698,7 @@ scared_by_monster(unit * u)
if(n > 0) {
n = lovar(n);
n = min(rpeasants(u->region), n);
n = MIN(rpeasants(u->region), n);
if(n > 0) {
n = scareaway(u->region, n);
if(n > 0) {

View file

@ -1160,7 +1160,7 @@ rotting_herbs(void)
if (fval(itm->type, ITF_HERB)) {
double nv = normalvariate(k, k/4);
int inv = (int)nv;
int delta = min(n, inv);
int delta = MIN(n, inv);
if (i_change(itmp, itm->type, -delta)==NULL) {
continue;
}
@ -1207,7 +1207,7 @@ randomevents(void)
a_remove(&r->attribs, a);
ADDMSG(&r->msgs, msg_message("orcified", "region", r));
} else {
a->data.i -= max(10,a->data.i/10);
a->data.i -= MAX(10,a->data.i/10);
if (a->data.i <= 0) a_remove(&r->attribs, a);
}
}
@ -1244,7 +1244,7 @@ randomevents(void)
while (*blist) {
building * b = *blist;
if (fval(b->type, BTF_DECAY) && !buildingowner(r, b)) {
b->size -= max(1, (b->size * 20) / 100);
b->size -= MAX(1, (b->size * 20) / 100);
if (b->size == 0) {
remove_building(blist, r->buildings);
}

View file

@ -139,7 +139,7 @@ spy_cmd(unit * u, struct order * ord)
* Für jeden Talentpunkt, den das Spionagetalent das Tarnungstalent
* des Opfers übersteigt, erhöht sich dieses um 5%*/
spy = eff_skill(u, SK_SPY, r) - eff_skill(target, SK_STEALTH, r);
spychance = 0.1 + max(spy*0.05, 0.0);
spychance = 0.1 + MAX(spy*0.05, 0.0);
if (chance(spychance)) {
produceexp(u, SK_SPY, u->number);
@ -154,7 +154,7 @@ spy_cmd(unit * u, struct order * ord)
- (effskill(u, SK_STEALTH) + eff_skill(u, SK_SPY, r)/2);
if (invisible(u, target) >= u->number) {
observe = min(observe, 0);
observe = MIN(observe, 0);
}
/* Anschließend wird - unabhängig vom Erfolg - gewürfelt, ob der
@ -392,7 +392,7 @@ crew_skill(region * r, faction * f, ship * sh, skill_t sk)
for (u=r->units;u;u=u->next) {
if (u->ship == sh && u->faction == f) {
int s = eff_skill(u, sk, r);
value = max(s, value);
value = MAX(s, value);
}
}
return value;

View file

@ -159,7 +159,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
* steigen.
*
* n ist die Anzahl zusätzlich gelernter Tage. n darf max. die Differenz
* von schon gelernten Tagen zum max(30 Tage pro Mann) betragen. */
* von schon gelernten Tagen zum MAX(30 Tage pro Mann) betragen. */
if (magic_lowskill(student)){
cmistake(teacher, teacher->thisorder, 292, MSG_EVENT);
@ -173,7 +173,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
n -= teach->value;
}
n = min(n, nteaching);
n = MIN(n, nteaching);
if (n != 0) {
struct building * b = inside_building(teacher);
@ -196,7 +196,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
&& student->building && student->building->type == bt_find("academy"))
{
int j = study_cost(student, sk);
j = max(50, j * 2);
j = MAX(50, j * 2);
/* kann Einheit das zahlen? */
if (get_pooled(student, oldresourcetype[R_SILVER], GET_DEFAULT, j) >= j) {
/* Jeder Schüler zusätzlich +10 Tage wenn in Uni. */
@ -236,7 +236,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
* die Talentänderung (enno).
*/
nteaching = max(0, nteaching - student->number * 30);
nteaching = MAX(0, nteaching - student->number * 30);
}
return n;
@ -274,7 +274,7 @@ teach_cmd(unit * u, struct order * ord)
teaching = u->number * 30 * TEACHNUMBER;
if ((i = get_effect(u, oldpotiontype[P_FOOL])) > 0) { /* Trank "Dumpfbackenbrot" */
i = min(i, u->number * TEACHNUMBER);
i = MIN(i, u->number * TEACHNUMBER);
/* Trank wirkt pro Schüler, nicht pro Lehrer */
teaching -= i * 30;
change_effect(u, oldpotiontype[P_FOOL], -i);
@ -532,7 +532,7 @@ learn_cmd(unit * u, order * ord)
const struct building_type * btype = b?b->type:NULL;
if (btype == bt_find("academy")) {
studycost = max(50, studycost * 2);
studycost = MAX(50, studycost * 2);
}
}
@ -608,11 +608,11 @@ learn_cmd(unit * u, order * ord)
if (studycost) {
int cost = studycost * u->number;
money = get_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, cost);
money = min(money, cost);
money = MIN(money, cost);
}
if (money < studycost * u->number) {
studycost = p; /* Ohne Univertreurung */
money = min(money, studycost);
money = MIN(money, studycost);
if (p>0 && money < studycost * u->number) {
cmistake(u, ord, 65, MSG_EVENT);
multi = money / (double)(studycost * u->number);
@ -631,12 +631,12 @@ learn_cmd(unit * u, order * ord)
}
if (get_effect(u, oldpotiontype[P_WISE])) {
l = min(u->number, get_effect(u, oldpotiontype[P_WISE]));
l = MIN(u->number, get_effect(u, oldpotiontype[P_WISE]));
teach->value += l * 10;
change_effect(u, oldpotiontype[P_WISE], -l);
}
if (get_effect(u, oldpotiontype[P_FOOL])) {
l = min(u->number, get_effect(u, oldpotiontype[P_FOOL]));
l = MIN(u->number, get_effect(u, oldpotiontype[P_FOOL]));
teach->value -= l * 30;
change_effect(u, oldpotiontype[P_FOOL], -l);
}
@ -651,7 +651,7 @@ learn_cmd(unit * u, order * ord)
teach->value += u->number * 5 * (l+1);
} else {
teach->value -= u->number * 5 * (l+1);
teach->value = max(0, teach->value);
teach->value = MAX(0, teach->value);
}
}
#endif /* KARMA_MODULE */

View file

@ -99,7 +99,7 @@ attack_catapult(const troop * at, const struct weapon_type * wtype, int * casual
}
enemies = count_enemies(b, af, FIGHT_ROW, FIGHT_ROW, SELECT_ADVANCE);
enemies = min(enemies, CATAPULT_ATTACKS);
enemies = MIN(enemies, CATAPULT_ATTACKS);
if (enemies==0) {
return true; /* allow further attacks */
}

View file

@ -67,7 +67,7 @@ use_manacrystal(struct unit * u, const struct item_type * itype, int amount, str
}
for (i=0;i!=amount;++i) {
sp += max(25, max_spellpoints(u->region, u)/2);
sp += MAX(25, max_spellpoints(u->region, u)/2);
change_spellpoints(u, sp);
}

View file

@ -72,11 +72,11 @@ herbsearch(region * r, unit * u, int max)
return;
}
if (max) max = min(max, rherbs(r));
if (max) max = MIN(max, rherbs(r));
else max = rherbs(r);
herbsfound = ntimespprob(eff_skill(u, SK_HERBALISM, r) * u->number,
(double)rherbs(r)/100.0F, -0.01F);
herbsfound = min(herbsfound, max);
herbsfound = MIN(herbsfound, max);
rsetherbs(r, rherbs(r)-herbsfound);
if (herbsfound) {
@ -128,7 +128,7 @@ use_potion(unit * u, const item_type * itype, int amount, struct order *ord)
} else if (ptype==oldpotiontype[P_HEAL]) {
return EUNUSABLE;
} else if (ptype==oldpotiontype[P_HEILWASSER]) {
u->hp = min(unit_max_hp(u) * u->number, u->hp + 400 * amount);
u->hp = MIN(unit_max_hp(u) * u->number, u->hp + 400 * amount);
} else if (ptype==oldpotiontype[P_PEOPLE]) {
region * r = u->region;
attrib * a = (attrib*)a_find(r->attribs, &at_peasantluck);
@ -144,7 +144,7 @@ use_potion(unit * u, const item_type * itype, int amount, struct order *ord)
amount=1;
} else if (ptype==oldpotiontype[P_MACHT]) {
/* Verfünffacht die HP von max. 10 Personen in der Einheit */
u->hp += min(u->number, 10*amount) * unit_max_hp(u) * 4;
u->hp += MIN(u->number, 10*amount) * unit_max_hp(u) * 4;
} else {
change_effect(u, ptype, 10*amount);
}

View file

@ -94,7 +94,6 @@ alliance_kick(const tnode * tnext, void * data, struct order * ord)
unit * u = (unit*)data;
faction * f = findfaction(getid());
attrib * a;
unused(tnext);
if (f==NULL || f->alliance!=u->faction->alliance) {
/* does not belong to our alliance */

View file

@ -216,7 +216,7 @@ armedmen(const unit * u, boolean siege_weapons)
/* if (effskill(u, wtype->skill) >= wtype->minskill) n += itm->number; */
if (n>u->number) break;
}
n = min(n, u->number);
n = MIN(n, u->number);
}
}
return n;
@ -442,7 +442,7 @@ get_row(const side * s, int row, const side * vs)
/* every entry in the size[] array means someone trying to defend us.
* 'retreat' is the number of rows falling.
*/
result = max(FIRST_ROW, row - retreat);
result = MAX(FIRST_ROW, row - retreat);
return result;
}
@ -576,11 +576,11 @@ weapon_skill(const weapon_type * wtype, const unit * u, boolean attacking)
if(u->race == new_race[RC_URUK]) {
int sword = effskill(u, SK_MELEE);
int spear = effskill(u, SK_SPEAR);
skill = max(sword, spear) - 3;
skill = MAX(sword, spear) - 3;
if (attacking) {
skill = max(skill, u->race->at_default);
skill = MAX(skill, u->race->at_default);
} else {
skill = max(skill, u->race->df_default);
skill = MAX(skill, u->race->df_default);
}
} else {
if (attacking) {
@ -734,7 +734,7 @@ select_magicarmor(troop t)
int geschuetzt = 0;
int ma = 0;
geschuetzt = min(get_item(u, I_TROLLBELT), u->number);
geschuetzt = MIN(get_item(u, I_TROLLBELT), u->number);
if (geschuetzt > t.index) /* unser Kandidat wird geschuetzt */
ma += 1;
@ -1016,8 +1016,8 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile)
}
#endif /* KARMA_MODULE */
kritchance = max(kritchance, 0.005);
kritchance = min(0.9, kritchance);
kritchance = MAX(kritchance, 0.005);
kritchance = MIN(0.9, kritchance);
while (chance(kritchance)) {
if (bdebug) {
@ -1040,7 +1040,7 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile)
}
/* Skilldifferenzbonus */
da += max(0, (sk-sd)/DAMAGE_QUOTIENT);
da += MAX(0, (sk-sd)/DAMAGE_QUOTIENT);
}
@ -1063,13 +1063,13 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile)
}
if (res > 0) {
da = (int) (max(da * res, 0));
da = (int) (MAX(da * res, 0));
}
/* gegen Magie wirkt nur natürliche und magische Rüstung */
ar = an+am;
}
rda = max(da - ar,0);
rda = MAX(da - ar,0);
if ((du->race->battle_flags & BF_INV_NONMAGIC) && !magic) rda = 0;
else {
@ -1094,7 +1094,7 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile)
}
/* gibt Rüstung +effect für duration Treffer */
if (meffect->typ == SHIELD_ARMOR) {
rda = max(rda - meffect->effect, 0);
rda = MAX(rda - meffect->effect, 0);
meffect->duration--;
}
}
@ -1294,7 +1294,7 @@ select_enemy(fighter * af, int minrow, int maxrow, int select)
minrow = FIGHT_ROW;
maxrow = BEHIND_ROW;
}
minrow = max(minrow, FIGHT_ROW);
minrow = MAX(minrow, FIGHT_ROW);
enemies = count_enemies(b, af, minrow, maxrow, select);
@ -1367,7 +1367,7 @@ select_opponent(battle * b, troop at, int mindist, int maxdist)
* them */
dt = select_enemy(at.fighter, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE);
} else {
mindist = max(mindist, FIGHT_ROW);
mindist = MAX(mindist, FIGHT_ROW);
dt = select_enemy(at.fighter, mindist, maxdist, SELECT_ADVANCE);
}
@ -1479,7 +1479,7 @@ do_combatmagic(battle *b, combatmagic_t was)
}
level = eff_spelllevel(mage, sp, level, 1);
if (sl > 0) level = min(sl, level);
if (sl > 0) level = MIN(sl, level);
if (level < 0) {
report_failed_spell(b, mage, sp);
free_order(ord);
@ -1561,7 +1561,7 @@ do_combatspell(troop at)
}
level = eff_spelllevel(mage, sp, fi->magic, 1);
if ((sl = get_combatspelllevel(mage, 1)) > 0) level = min(level, sl);
if ((sl = get_combatspelllevel(mage, 1)) > 0) level = MIN(level, sl);
if (fumble(r, mage, sp, sp->level) == true) {
report_failed_spell(b, mage, sp);
@ -1825,7 +1825,7 @@ dazzle(battle *b, troop *td)
void
damage_building(battle *b, building *bldg, int damage_abs)
{
bldg->size = max(1, bldg->size-damage_abs);
bldg->size = MAX(1, bldg->size-damage_abs);
/* Wenn Burg, dann gucken, ob die Leute alle noch in das Gebäude passen. */
@ -2085,7 +2085,7 @@ do_regenerate(fighter *af)
while(ta.index--) {
af->person[ta.index].hp += effskill(au, SK_STAMINA);
af->person[ta.index].hp = min(unit_max_hp(au), af->person[ta.index].hp);
af->person[ta.index].hp = MIN(unit_max_hp(au), af->person[ta.index].hp);
}
}
@ -2118,9 +2118,9 @@ fleechance(unit * u)
if (u->race == new_race[RC_HALFLING]) {
c += 0.20;
c = min(c, 0.90);
c = MIN(c, 0.90);
} else {
c = min(c, 0.75);
c = MIN(c, 0.75);
}
if (a!=NULL) c += a->data.flt;
@ -2189,7 +2189,7 @@ loot_items(fighter * corpse)
float lootfactor = dead/(float)u->number; /* only loot the dead! */
int maxloot = (int)(itm->number*lootfactor);
if (maxloot>0) {
int i = min(10, maxloot);
int i = MIN(10, maxloot);
for (; i != 0; --i) {
int loot = maxloot/i;
@ -2264,7 +2264,7 @@ static void
battle_effects(battle * b, int dead_players)
{
region * r = b->region;
int dead_peasants = min(rpeasants(r), (int)(dead_players*PopulationDamage()));
int dead_peasants = MIN(rpeasants(r), (int)(dead_players*PopulationDamage()));
deathcounts(r, dead_peasants + dead_players);
chaoscounts(r, dead_peasants / 2);
rsetpeasants(r, rpeasants(r) - dead_peasants);
@ -2805,7 +2805,7 @@ print_stats(battle * b)
for (s=b->sides;s!=b->sides+b->nsides;++s) {
if (cv_size(&s->leader.fighters)) {
b->max_tactics = max(b->max_tactics, s->leader.value);
b->max_tactics = MAX(b->max_tactics, s->leader.value);
}
}
@ -2948,7 +2948,7 @@ make_fighter(battle * b, unit * u, side * s1, boolean attack)
/* change_effect wird in ageing gemacht */
/* Effekte von Artefakten */
strongmen = min(fig->unit->number, get_item(u, I_TROLLBELT));
strongmen = MIN(fig->unit->number, get_item(u, I_TROLLBELT));
#if KARMA_MODULE
for (a = a_find(u->attribs, &at_prayer_effect); a && a->type==&at_prayer_effect; a = a->next) {
@ -3125,7 +3125,7 @@ make_fighter(battle * b, unit * u, side * s1, boolean attack)
else
p_bonus += 3;
} while(rnd >= 97);
bonus = max(p_bonus, bonus);
bonus = MAX(p_bonus, bonus);
}
t += bonus;
}
@ -3241,7 +3241,7 @@ make_battle(region * r)
for (bf=b->factions;bf;bf=bf->next) {
faction * f = bf->faction;
max_fac_no = max(max_fac_no, f->no);
max_fac_no = MAX(max_fac_no, f->no);
freset(f, FFL_MARK);
}
return b;
@ -3284,7 +3284,7 @@ free_battle(battle * b)
bfaction * bf = b->factions;
faction * f = bf->faction;
b->factions = bf->next;
max_fac_no = max(max_fac_no, f->no);
max_fac_no = MAX(max_fac_no, f->no);
free(bf);
}
@ -3542,7 +3542,7 @@ flee(const troop dt)
/* Regeländerung: Man muß das Tier nicht reiten können,
* um es vom Schlachtfeld mitzunehmen, ist ja nur
* eine Region weit. * */
keep = min(1, itm->number);
keep = MIN(1, itm->number);
/* da ist das weight des tiers mit drin */
carry += itype->capacity - itype->weight;
} else if (itm->type->weight <= 0) {
@ -3881,7 +3881,7 @@ battle_flee(battle * b)
troop dt;
int runners = 0;
/* Flucht nicht bei mehr als 600 HP. Damit Wyrme tötbar bleiben. */
int runhp = min(600,(int)(0.9+unit_max_hp(u)*hpflee(u->status)));
int runhp = MIN(600,(int)(0.9+unit_max_hp(u)*hpflee(u->status)));
if (fval(u->race, RCF_UNDEAD) || u->race == new_race[RC_SHADOWKNIGHT]) continue;
dt.fighter = fig;
@ -3918,7 +3918,7 @@ battle_flee(battle * b)
if (fig->person[dt.index].flags & FL_PANICED) {
ispaniced = EFFECT_PANIC_SPELL;
}
if (chance(min(fleechance(u)+ispaniced, 0.90))) {
if (chance(MIN(fleechance(u)+ispaniced, 0.90))) {
++runners;
flee(dt);
}

View file

@ -190,7 +190,7 @@ bin_r_str_buf(struct storage * store, char * result, size_t size)
result[0] = 0;
} else {
len = (size_t)i;
rd = min(len, size);
rd = MIN(len, size);
fread(result, sizeof(char), rd, file(store));
if (rd<len) {
fseek(file(store), (long)(len-rd), SEEK_CUR);

View file

@ -99,7 +99,7 @@ get_borders_i(const region * r1, const region * r2)
int key = reg_hashkey(r1);
int k2 = reg_hashkey(r2);
key = min(k2, key) % BORDER_MAXHASH;
key = MIN(k2, key) % BORDER_MAXHASH;
bp = &borders[key];
while (*bp) {
border * b = *bp;
@ -452,7 +452,7 @@ b_nameroad(const border * b, const region * r, const struct faction * f, int gfl
return LOC(f->locale, mkname("border", "an_incomplete_road"));
}
} else {
int percent = max(1, 100*local/r->terrain->max_road);
int percent = MAX(1, 100*local/r->terrain->max_road);
if (local) {
snprintf(buffer, sizeof(buffer), LOC(f->locale, mkname("border", "a_road_percent")), percent);
} else {

View file

@ -223,9 +223,9 @@ siege_cmd(unit * u, order * ord)
/* schaden durch katapulte */
d = i_get(u->items, it_catapult);
d = min(u->number, d);
d = MIN(u->number, d);
pooled = get_pooled(u, it_catapultammo->rtype, GET_DEFAULT, d);
d = min(pooled, d);
d = MIN(pooled, d);
if (eff_skill(u, SK_CATAPULT, r) >= 1) {
katapultiere = d;
d *= eff_skill(u, SK_CATAPULT, r);
@ -251,11 +251,11 @@ siege_cmd(unit * u, order * ord)
* einheiten wieder abgesucht werden muessen! */
usetsiege(u, b);
b->besieged += max(bewaffnete, katapultiere);
b->besieged += MAX(bewaffnete, katapultiere);
/* definitiver schaden eingeschraenkt */
d = min(d, b->size - 1);
d = MIN(d, b->size - 1);
/* meldung, schaden anrichten */
if (d && !curse_active(get_curse(b->attribs, magicwalls_ct))) {
@ -311,11 +311,11 @@ destroy_road(unit *u, int nmax, struct order * ord)
cmistake(u, ord, 71, MSG_PRODUCE);
} else {
short road = rroad(r, d);
n = min(n, road);
n = MIN(n, road);
if (n!=0) {
region * r2 = rconnect(r,d);
int willdo = eff_skill(u, SK_ROAD_BUILDING, r)*u->number;
willdo = min(willdo, n);
willdo = MIN(willdo, n);
if (willdo==0) {
/* TODO: error message */
}
@ -502,7 +502,7 @@ build_road(region * r, unit * u, int size, direction_t d)
return;
}
if (size>0) left = min(size, left);
if (size>0) left = MIN(size, left);
/* baumaximum anhand der rohstoffe */
if (u->race == new_race[RC_STONEGOLEM]){
n = u->number * GOLEM_STONE;
@ -513,14 +513,14 @@ build_road(region * r, unit * u, int size, direction_t d)
return;
}
}
left = min(n, left);
left = MIN(n, left);
/* n = maximum by skill. try to maximize it */
n = u->number * eff_skill(u, SK_ROAD_BUILDING, r);
if (n < left) {
item * itm = *i_find(&u->items, olditemtype[I_RING_OF_NIMBLEFINGER]);
if (itm!=NULL && itm->number>0) {
int rings = min(u->number, itm->number);
int rings = MIN(u->number, itm->number);
n = n * (9*rings+u->number) / u->number;
}
}
@ -529,15 +529,15 @@ build_road(region * r, unit * u, int size, direction_t d)
if (dm != 0) {
int sk = eff_skill(u, SK_ROAD_BUILDING, r);
int todo = (left - n + sk - 1) / sk;
todo = min(todo, u->number);
dm = min(dm, todo);
todo = MIN(todo, u->number);
dm = MIN(dm, todo);
change_effect(u, oldpotiontype[P_DOMORE], -dm);
n += dm * sk;
} /* Auswirkung Schaffenstrunk */
}
/* make minimum of possible and available: */
n = min(left, n);
n = MIN(left, n);
/* n is now modified by several special effects, so we have to
* minimize it again to make sure the road will not grow beyond
@ -553,7 +553,7 @@ build_road(region * r, unit * u, int size, direction_t d)
} else {
use_pooled(u, oldresourcetype[R_STONE], GET_DEFAULT, n);
/* Nur soviel PRODUCEEXP wie auch tatsaechlich gemacht wurde */
produceexp(u, SK_ROAD_BUILDING, min(n, u->number));
produceexp(u, SK_ROAD_BUILDING, MIN(n, u->number));
}
ADDMSG(&u->faction->msgs, msg_message("buildroad",
"region unit size", r, u, n));
@ -632,7 +632,7 @@ build(unit * u, const construction * ctype, int completed, int want)
if (dm != 0) {
/* Auswirkung Schaffenstrunk */
dm = min(dm, u->number);
dm = MIN(dm, u->number);
change_effect(u, oldpotiontype[P_DOMORE], -dm);
skills += dm * effsk;
}
@ -687,17 +687,17 @@ build(unit * u, const construction * ctype, int completed, int want)
item * itm = *i_find(&u->items, olditemtype[I_RING_OF_NIMBLEFINGER]);
if (itm!=NULL) i = itm->number;
if (i>0) {
int rings = min(u->number, i);
int rings = MIN(u->number, i);
n = n * (9*rings+u->number) / u->number;
}
}
if (want>0) {
n = min(want, n);
n = MIN(want, n);
}
if (type->maxsize>0) {
n = min(type->maxsize-completed, n);
n = MIN(type->maxsize-completed, n);
if (type->improvement==NULL) {
want = n;
}
@ -752,7 +752,7 @@ build(unit * u, const construction * ctype, int completed, int want)
completed = completed + n;
}
/* Nur soviel PRODUCEEXP wie auch tatsaechlich gemacht wurde */
produceexp(u, ctype->skill, min(made, u->number));
produceexp(u, ctype->skill, MIN(made, u->number));
return made;
}
@ -789,7 +789,7 @@ maxbuild(const unit * u, const construction * cons)
if (have<need) {
return 0;
}
else maximum = min(maximum, have/need);
else maximum = MIN(maximum, have/need);
}
return maximum;
}
@ -977,7 +977,7 @@ build_ship(unit * u, ship * sh, int want)
}
if (sh->damage && can) {
int repair = min(sh->damage, can * DAMAGE_SCALE);
int repair = MIN(sh->damage, can * DAMAGE_SCALE);
n += repair / DAMAGE_SCALE;
if (repair % DAMAGE_SCALE) ++n;
sh->damage = sh->damage - repair;
@ -1016,7 +1016,7 @@ create_ship(region * r, unit * u, const struct ship_type * newtype, int want, or
cmistake(u, ord, 88, MSG_PRODUCE);
return;
}
if (want>0) want = min(want, msize);
if (want>0) want = MIN(want, msize);
else want = msize;
sh = new_ship(newtype, u->faction->locale, r);
@ -1070,7 +1070,7 @@ continue_ship(region * r, unit * u, int want)
cmistake(u, u->thisorder, 88, MSG_PRODUCE);
return;
}
if (want > 0) want = min(want, msize);
if (want > 0) want = MIN(want, msize);
else want = msize;
build_ship(u, sh, want);

View file

@ -144,18 +144,18 @@ bt_register(building_type * type)
int
buildingcapacity(const building * b)
{
if (b->type->capacity>=0) {
if (b->type->capacity>=0) {
if (b->type->maxcapacity>=0) {
return min(b->type->maxcapacity, b->size * b->type->capacity);
return MIN(b->type->maxcapacity, b->size * b->type->capacity);
}
return b->size * b->type->capacity;
}
return b->size * b->type->capacity;
}
if (b->size>=b->type->maxsize) {
if (b->type->maxcapacity>=0) {
return b->type->maxcapacity;
}
}
return 0;
return 0;
}
attrib_type at_building_generic_type = {

View file

@ -134,7 +134,7 @@ curse_age(attrib * a)
} else if (c_flags(c) & CURSE_NOAGE) {
c->duration = 1;
} else if (c->duration!=INT_MAX) {
c->duration = max(0, c->duration-1);
c->duration = MAX(0, c->duration-1);
}
return c->duration;
}
@ -314,7 +314,7 @@ ct_find(const char *c)
if (strcmp(c, ctl->type->cname)==0) {
return ctl->type;
} else {
size_t k = min(strlen(c), strlen(ctl->type->cname));
size_t k = MIN(strlen(c), strlen(ctl->type->cname));
if (!strncasecmp(c, ctl->type->cname, k)) {
return ctl->type;
}
@ -468,7 +468,7 @@ get_cursedmen(unit *u, curse *c)
cursedmen = cc->cursedmen;
}
return min(u->number, cursedmen);
return MIN(u->number, cursedmen);
}
/* setzt die Anzahl der betroffenen Personen auf cursedmen */
@ -548,7 +548,7 @@ create_curse(unit *magician, attrib **ap, const curse_type *ct, double vigour,
/* es gibt schon eins diese Typs */
if (c && ct->mergeflags != NO_MERGE) {
if(ct->mergeflags & M_DURATION){
c->duration = max(c->duration, duration);
c->duration = MAX(c->duration, duration);
}
if(ct->mergeflags & M_SUMDURATION){
c->duration += duration;
@ -557,10 +557,10 @@ create_curse(unit *magician, attrib **ap, const curse_type *ct, double vigour,
c->effect.i += effect.i;
}
if(ct->mergeflags & M_MAXEFFECT){
c->effect.i = max(c->effect.i, effect.i);
c->effect.i = MAX(c->effect.i, effect.i);
}
if(ct->mergeflags & M_VIGOUR){
c->vigour = max(vigour, c->vigour);
c->vigour = MAX(vigour, c->vigour);
}
if(ct->mergeflags & M_VIGOUR_ADD){
c->vigour = vigour + c->vigour;

View file

@ -1833,7 +1833,7 @@ maxworkingpeasants(const struct region * r)
{
int i = production(r) * MAXPEASANTS_PER_AREA
- ((rtrees(r,2)+rtrees(r,1)/2) * TREESIZE);
return max(i, 0);
return MAX(i, 0);
}
unit_list *
@ -1886,8 +1886,8 @@ lighthouse_range(const building * b, const faction * f)
if (c > buildingcapacity(b)) break;
if (f==NULL || u->faction == f) {
int sk = eff_skill(u, SK_PERCEPTION, r) / 3;
d = max(d, sk);
d = min(maxd, d);
d = MAX(d, sk);
d = MIN(maxd, d);
if (d==maxd) break;
}
} else if (c) break; /* first unit that's no longer in the house ends the search */
@ -2578,7 +2578,7 @@ plagues(region * r, boolean ismagic)
/* Seuchenwahrscheinlichkeit in % */
if (!ismagic) {
double mwp = max(maxworkingpeasants(r), 1);
double mwp = MAX(maxworkingpeasants(r), 1);
double prob = pow(rpeasants(r) / (mwp * wage(r, NULL, NULL) * 0.13), 4.0)
* PLAGUE_CHANCE;
@ -2670,7 +2670,7 @@ default_wage(const region *r, const faction * f, const race * rc)
/* Godcurse: Income -10 */
if (curse_active(get_curse(r->attribs, ct_find("godcursezone")))) {
wage = max(0,wage-10);
wage = MAX(0,wage-10);
}
/* Bei einer Dürre verdient man nur noch ein Viertel */

View file

@ -52,7 +52,7 @@ new_group(faction * f, const char * name, int gid)
while (*gp) gp = &(*gp)->next;
*gp = g;
maxgid = max(gid, maxgid);
maxgid = MAX(gid, maxgid);
g->name = strdup(name);
g->gid = gid;

View file

@ -751,7 +751,7 @@ heal(unit * user, int effect)
{
int req = unit_max_hp(user) * user->number - user->hp;
if (req>0) {
req = min(req, effect);
req = MIN(req, effect);
effect -= req;
user->hp += req;
}

View file

@ -401,7 +401,7 @@ sacrifice_cmd(unit * u, struct order * ord)
cmistake(u, ord, 253, MSG_EVENT);
return 0;
}
n = min(get_spellpoints(u), min(max_spellpoints(u->region, u), n));
n = MIN(get_spellpoints(u), min(max_spellpoints(u->region, u), n));
if(n <= 0) {
cmistake(u, ord, 254, MSG_EVENT);
return 0;

View file

@ -534,7 +534,7 @@ get_combatspelllevel(const unit *u, int nr)
assert(nr < MAXCOMBATSPELLS);
if (m) {
int level = eff_skill(u, SK_MAGIC, u->region);
return min(m->combatspells[nr].level, level);
return MIN(m->combatspells[nr].level, level);
}
return -1;
}
@ -664,7 +664,7 @@ change_spellpoints(unit * u, int mp)
if (!m) return 0;
/* verhindere negative Magiepunkte */
sp = max(m->spellpoints + mp, 0);
sp = MAX(m->spellpoints + mp, 0);
m->spellpoints = sp;
return sp;
@ -723,7 +723,7 @@ max_spellpoints(const region * r, const unit * u)
n = get_curseeffect(u->attribs, C_AURA, 0);
if (n>0) msp = (msp*n)/100;
return max((int)msp, 0);
return MAX((int)msp, 0);
}
int
@ -759,7 +759,7 @@ countspells(unit *u, int step)
count = m->spellcount + step;
/* negative Werte abfangen. */
m->spellcount = max(0,count);
m->spellcount = MAX(0,count);
return m->spellcount;
}
@ -847,7 +847,7 @@ eff_spelllevel(unit *u, const spell * sp, int cast_level, int range)
* gewünschten gebildet */
} else if (sp->components[k].cost == SPC_LEVEL) {
costtyp = SPC_LEVEL;
cast_level = min(cast_level, maxlevel);
cast_level = MIN(cast_level, maxlevel);
/* bei Typ Linear müssen die Kosten in Höhe der Stufe vorhanden
* sein, ansonsten schlägt der Spruch fehl */
} else if (sp->components[k].cost == SPC_LINEAR) {
@ -859,7 +859,7 @@ eff_spelllevel(unit *u, const spell * sp, int cast_level, int range)
/* Ein Spruch mit Fixkosten wird immer mit der Stufe des Spruchs und
* nicht auf der Stufe des Magiers gezaubert */
if (costtyp == SPC_FIX) {
cast_level = min(cast_level, sp->level);
cast_level = MIN(cast_level, sp->level);
}
return cast_level;
@ -1061,7 +1061,7 @@ spellpower(region * r, unit * u, const spell * sp, int cast_level, struct order
force = force * MagicPower();
return max(force, 0);
return MAX(force, 0);
}
/* ------------------------------------------------------------- */
@ -1220,8 +1220,8 @@ target_resists_magic(unit *magician, void *obj, int objtyp, int t_bonus)
break;
}
probability = max(0.02, probability + t_bonus*0.01);
probability = min(0.98, probability);
probability = MAX(0.02, probability + t_bonus*0.01);
probability = MIN(0.98, probability);
/* gibt true, wenn die Zufallszahl kleiner als die chance ist und
* false, wenn sie gleich oder größer ist, dh je größer die
@ -1355,7 +1355,7 @@ do_fumble(castorder *co)
case 2:
/* temporärer Stufenverlust */
duration = max(rng_int()%level/2, 2);
duration = MAX(rng_int()%level/2, 2);
effect.i = -(level/2);
c = create_curse(u, &u->attribs, ct_find("skillmod"), (float)level, duration,
effect, 1);
@ -1469,15 +1469,15 @@ regeneration_magiepunkte(void)
/* maximal Differenz bis Maximale-Aura regenerieren
* mindestens 1 Aura pro Monat */
reg_aura = max(1,reg_aura);
reg_aura = min((auramax - aura), reg_aura);
reg_aura = MAX(1,reg_aura);
reg_aura = MIN((auramax - aura), reg_aura);
aura += (int)reg_aura;
ADDMSG(&u->faction->msgs, msg_message(
"regenaura", "unit region amount",
u, r, (int)reg_aura));
}
set_spellpoints(u, min(aura, auramax));
set_spellpoints(u, MIN(aura, auramax));
/* Zum letzten Mal Spruchliste aktualisieren */
updatespelllist(u);
@ -2473,7 +2473,7 @@ cast_cmd(unit * u, order * ord)
/* für Syntax ' STUFE x REGION y z ' */
if (findparam(s, u->faction->locale) == P_LEVEL) {
int p = getint();
level = min(p, level);
level = MIN(p, level);
if (level < 1) {
/* Fehler "Das macht wenig Sinn" */
cmistake(u, ord, 10, MSG_MAGIC);
@ -2499,7 +2499,7 @@ cast_cmd(unit * u, order * ord)
* hier nach REGION nochmal auf STUFE prüfen */
if (findparam(s, u->faction->locale) == P_LEVEL) {
int p = getint();
level = min(p, level);
level = MIN(p, level);
if (level < 1) {
/* Fehler "Das macht wenig Sinn" */
cmistake(u, ord, 10, MSG_MAGIC);
@ -2622,7 +2622,7 @@ cast_cmd(unit * u, order * ord)
* löschen, zaubern kann er noch */
range *= 2;
set_order(&mage->thisorder, NULL);
level = min(level, eff_skill(mage, SK_MAGIC, mage->region)/2);
level = MIN(level, eff_skill(mage, SK_MAGIC, mage->region)/2);
familiar = u;
}
}

View file

@ -272,11 +272,11 @@ ridingcapacity(unit * u)
* tragen nichts (siehe walkingcapacity). Ein Wagen zählt nur, wenn er
* von zwei Pferden gezogen wird */
animals = min(animals, effskill(u, SK_RIDING) * u->number * 2);
animals = MIN(animals, effskill(u, SK_RIDING) * u->number * 2);
if (fval(u->race, RCF_HORSE)) animals += u->number;
/* maximal diese Pferde können zum Ziehen benutzt werden */
vehicles = min(animals / HORSESNEEDED, vehicles);
vehicles = MIN(animals / HORSESNEEDED, vehicles);
return vehicles * vcap + animals * acap;
}
@ -294,7 +294,7 @@ walkingcapacity(const struct unit * u)
/* Das Gewicht, welches die Pferde tragen, plus das Gewicht, welches
* die Leute tragen */
pferde_fuer_wagen = min(animals, effskill(u, SK_RIDING) * u->number * 4);
pferde_fuer_wagen = MIN(animals, effskill(u, SK_RIDING) * u->number * 4);
if (fval(u->race, RCF_HORSE)) {
animals += u->number;
people = 0;
@ -303,7 +303,7 @@ walkingcapacity(const struct unit * u)
}
/* maximal diese Pferde können zum Ziehen benutzt werden */
wagen_mit_pferden = min(vehicles, pferde_fuer_wagen / HORSESNEEDED);
wagen_mit_pferden = MIN(vehicles, pferde_fuer_wagen / HORSESNEEDED);
n = wagen_mit_pferden * vcap;
@ -313,7 +313,7 @@ walkingcapacity(const struct unit * u)
wagen_ohne_pferde = vehicles - wagen_mit_pferden;
/* Genug Trolle, um die Restwagen zu ziehen? */
wagen_mit_trollen = min(u->number / 4, wagen_ohne_pferde);
wagen_mit_trollen = MIN(u->number / 4, wagen_ohne_pferde);
/* Wagenkapazität hinzuzählen */
n += wagen_mit_trollen * vcap;
@ -331,7 +331,7 @@ walkingcapacity(const struct unit * u)
}
/* change_effect wird in ageing gemacht */
tmp = get_item(u, I_TROLLBELT);
n += min(people, tmp) * (STRENGTHMULTIPLIER-1) * personcapacity(u);
n += MIN(people, tmp) * (STRENGTHMULTIPLIER-1) * personcapacity(u);
return n;
}
@ -359,7 +359,7 @@ canwalk(unit * u)
maxwagen = effskill(u, SK_RIDING) * u->number * 2;
if (u->race == new_race[RC_TROLL]) {
maxwagen = max(maxwagen, u->number / 4);
maxwagen = MAX(maxwagen, u->number / 4);
}
maxpferde = effskill(u, SK_RIDING) * u->number * 4 + u->number;
@ -843,7 +843,7 @@ bewegung_blockiert_von(unit * reisender, region * r)
if (!contact && guard) {
double prob = 0.3; /* 30% base chance */
prob += 0.1 * (perception - eff_stealth(reisender, r));
prob += 0.1 * min(guard->number, get_item(guard, I_AMULET_OF_TRUE_SEEING));
prob += 0.1 * MIN(guard->number, get_item(guard, I_AMULET_OF_TRUE_SEEING));
if (chance(prob)) {
return guard;
@ -1836,7 +1836,7 @@ sail(unit * u, order * ord, boolean move_on_land, region_list **routep)
const luxury_type * ltype = resource2luxury(itm->type->rtype);
if (ltype!=NULL && itm->number>0) {
int st = itm->number * effskill(hafenmeister, SK_TRADE) / 50;
st = min(itm->number, st);
st = MIN(itm->number, st);
if (st > 0) {
i_change(&u2->items, itm->type, -st);

View file

@ -418,9 +418,9 @@ abkz(const char *s, char * buf, size_t buflen, size_t maxchars)
}
}
/* Buchstaben pro Teilkürzel = max(1,max/AnzWort) */
/* Buchstaben pro Teilkürzel = MAX(1,max/AnzWort) */
bpt = max(1, maxchars / c);
bpt = MAX(1, maxchars / c);
/* Einzelne Wörter anspringen und jeweils die ersten BpT kopieren */

View file

@ -180,7 +180,7 @@ get_pooled(const unit * u, const resource_type * rtype, unsigned int mode, int c
if ((mode & GET_SLACK) && (mode & GET_RESERVE)) use = have;
else {
int reserve = get_reservation(u, rtype);
int slack = max(0, have-reserve);
int slack = MAX(0, have-reserve);
if (mode & GET_RESERVE) use = have-slack;
else if (mode & GET_SLACK) use = slack;
}
@ -216,17 +216,17 @@ use_pooled(unit * u, const resource_type * rtype, unsigned int mode, int count)
}
if ((mode & GET_SLACK) && (mode & GET_RESERVE)) {
n = min(use, have);
n = MIN(use, have);
} else {
int reserve = get_reservation(u, rtype);
int slack = max(0, have-reserve);
int slack = MAX(0, have-reserve);
if (mode & GET_RESERVE) {
n = have-slack;
n = min(use, n);
n = MIN(use, n);
change_reservation(u, rtype, -n);
}
else if (mode & GET_SLACK) {
n = min(use, slack);
n = MIN(use, slack);
}
}
if (n>0) {

View file

@ -1202,7 +1202,7 @@ terraform_region(region * r, const terrain_type * terrain)
if (!fval(r, RF_CHAOTIC)) {
int peasants;
peasants = (maxworkingpeasants(r) * (20+dice_rand("6d10")))/100;
rsetpeasants(r, max(100, peasants));
rsetpeasants(r, MAX(100, peasants));
rsetmoney(r, rpeasants(r) * ((wage(r, NULL, NULL)+1) + rng_int() % 5));
}
}

View file

@ -61,6 +61,7 @@ struct message;
struct message_list;
struct rawmaterial;
struct donation;
struct item;
typedef struct land_region {
char *name;

View file

@ -203,8 +203,8 @@ update_nmrs(void)
int nmr = turn-f->lastorders+1;
if (nmr<0 || nmr>NMRTimeout()) {
log_error(("faction %s has %d NMRS\n", factionid(f), nmr));
nmr = max(0, nmr);
nmr = min(nmr, NMRTimeout());
nmr = MAX(0, nmr);
nmr = MIN(nmr, NMRTimeout());
}
++nmrs[nmr];
}
@ -833,7 +833,7 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
oldeff = sv->old + get_modifier(u, sv->id, sv->old, u->region, false);
}
oldeff = max(0, oldeff);
oldeff = MAX(0, oldeff);
diff = effsk - oldeff;
if (diff != 0) {

View file

@ -1303,7 +1303,7 @@ invisible(const unit *target, const unit * viewer)
else {
int hidden = get_item(target, I_RING_OF_INVISIBILITY) + 100 * get_item(target, I_SPHERE_OF_INVISIBILITY);
if (hidden) {
hidden = min(hidden, target->number);
hidden = MIN(hidden, target->number);
if (viewer) hidden -= get_item(viewer, I_AMULET_OF_TRUE_SEEING);
}
return hidden;

View file

@ -218,8 +218,8 @@ tagbegin(xml_stack *stack)
monster * m = calloc(sizeof(monster), 1);
m->race = rc_find(xml_value(tag, "race"));
m->chance = xml_fvalue(tag, "chance");
m->avgsize = max(1, xml_ivalue(tag, "size"));
m->maxunits = min(1, xml_ivalue(tag, "maxunits"));
m->avgsize = MAX(1, xml_ivalue(tag, "size"));
m->maxunits = MIN(1, xml_ivalue(tag, "maxunits"));
if (m->race) {
if (xml_bvalue(tag, "boss")) {

View file

@ -23,7 +23,7 @@
/* util includes */
#include <util/rng.h>
#define age_chance(a,b,p) (max(0,a-b)*p)
#define age_chance(a,b,p) (MAX(0,a-b)*p)
#define DRAGONAGE 27
#define WYRMAGE 68

View file

@ -31,7 +31,7 @@
#define UNDEAD_BREAKUP 25 /* chance dafuer */
#define UNDEAD_BREAKUP_FRACTION (25+rng_int()%70) /* anteil der weg geht */
#define age_chance(a,b,p) (max(0,a-b)*p)
#define age_chance(a,b,p) (MAX(0,a-b)*p)
void
age_undead(unit *u)
@ -61,7 +61,7 @@ void
age_skeleton(unit *u)
{
if (is_monsters(u->faction) && rng_int()%100 < age_chance(u->age, 27, 1)) {
int n = max(1,u->number/2);
int n = MAX(1,u->number/2);
double q = (double) u->hp / (double) (unit_max_hp(u) * u->number);
u->race = new_race[RC_SKELETON_LORD];
u->irace = new_race[RC_SKELETON_LORD];
@ -74,7 +74,7 @@ void
age_zombie(unit *u)
{
if (is_monsters(u->faction) && rng_int()%100 < age_chance(u->age, 27, 1)) {
int n = max(1,u->number/2);
int n = MAX(1,u->number/2);
double q = (double) u->hp / (double) (unit_max_hp(u) * u->number);
u->race = new_race[RC_ZOMBIE_LORD];
u->irace = new_race[RC_ZOMBIE_LORD];
@ -87,7 +87,7 @@ void
age_ghoul(unit *u)
{
if (is_monsters(u->faction) && rng_int()%100 < age_chance(u->age, 27, 1)) {
int n = max(1,u->number/2);
int n = MAX(1,u->number/2);
double q = (double) u->hp / (double) (unit_max_hp(u) * u->number);
u->race = new_race[RC_GHOUL_LORD];
u->irace = new_race[RC_GHOUL_LORD];

View file

@ -286,14 +286,14 @@ sp_combatrosthauch(fighter * fi, int level, double power, spell * sp)
if (df->alive==0) continue;
if (force<=0) break;
/* da n min(force, x), sollte force maximal auf 0 sinken */
/* da n MIN(force, x), sollte force maximal auf 0 sinken */
assert(force >= 0);
if (df->weapons) {
int w;
for (w=0;df->weapons[w].type!=NULL;++w) {
weapon * wp = df->weapons;
int n = min(force, wp->used);
int n = MIN(force, wp->used);
if (n) {
requirement * mat = wp->type->itype->construction->materials;
boolean iron = false;
@ -841,7 +841,7 @@ sp_shadowknights(fighter * fi, int level, double power, spell * sp)
region *r = b->region;
unit *mage = fi->unit;
attrib *a;
int force = max(1, (int)get_force(power, 3));
int force = MAX(1, (int)get_force(power, 3));
message * msg;
unused(sp);
@ -933,7 +933,7 @@ sp_chaosrow(fighter * fi, int level, double power, spell * sp)
if (df->alive==0) continue;
if (power<=0.0) break;
/* force sollte wegen des max(0,x) nicht unter 0 fallen können */
/* force sollte wegen des MAX(0,x) nicht unter 0 fallen können */
if (is_magic_resistant(mage, df->unit, 0)) continue;
@ -967,7 +967,7 @@ sp_chaosrow(fighter * fi, int level, double power, spell * sp)
}
k+=df->alive;
}
power = max(0, power-n);
power = MAX(0, power-n);
}
cv_kill(fgs);
free(fgs);
@ -1066,12 +1066,12 @@ sp_hero(fighter * fi, int level, double power, spell * sp)
switch(sp->id) {
case SPL_HERO:
df_bonus = (int)(power/5);
force = max(1, lovar(get_force(power, 4)));
force = MAX(1, lovar(get_force(power, 4)));
break;
default:
df_bonus = 1;
force = max(1, (int)power);
force = MAX(1, (int)power);
}
allies = count_allies(fi->side, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE);
@ -1115,7 +1115,7 @@ sp_berserk(fighter * fi, int level, double power, spell * sp)
switch(sp->id) {
case SPL_BERSERK:
case SPL_BLOODTHIRST:
at_bonus = max(1,level/3);
at_bonus = MAX(1,level/3);
df_malus = 2;
force = (int)get_force(power,2);
break;
@ -1165,7 +1165,7 @@ sp_frighten(fighter * fi, int level, double power, spell * sp)
int targets = 0;
message * m;
at_malus = max(1,level - 4);
at_malus = MAX(1,level - 4);
df_malus = 2;
force = (int)get_force(power, 2);
@ -1427,7 +1427,7 @@ sp_fumbleshield(fighter * fi, int level, double power, spell * sp)
case SPL_CERRDOR_FUMBLESHIELD:
case SPL_TYBIED_FUMBLESHIELD:
duration = 100;
effect = max(1, 25-level);
effect = MAX(1, 25-level);
break;
default:
@ -1473,7 +1473,7 @@ sp_reanimate(fighter * fi, int level, double power, spell * sp)
}
healable = count_healable(b, fi);
healable = (int)min(k, healable);
healable = (int)MIN(k, healable);
while (healable--) {
fighter * tf = select_corpse(b, fi);
if (tf!=NULL && tf->side->casualties > 0
@ -1521,7 +1521,7 @@ sp_keeploot(fighter * fi, int level, double power, spell * sp)
message_all(b, m);
msg_release(m);
b->keeploot = (int)max(25, b->keeploot + 5*power);
b->keeploot = (int)MAX(25, b->keeploot + 5*power);
return level;
}
@ -1551,10 +1551,10 @@ heal_fighters(cvector *fgs, int * power, boolean heal_monsters)
if (rest>n) ++wound;
if (wound > 0 && wound < hp) {
int heal = min(healhp, wound);
int heal = MIN(healhp, wound);
assert(heal>=0);
df->person[n].hp += heal;
healhp = max(0, healhp - heal);
healhp = MAX(0, healhp - heal);
++healed;
if (healhp<=0) break;
}
@ -1678,7 +1678,7 @@ sp_undeadhero(fighter * fi, int level, double power, spell * sp)
cv_kill(fgs);
free(fgs);
level = min(level, undead);
level = MIN(level, undead);
if (undead == 0) {
msg = msg_message("summonundead_effect_0", "mage region", mage, mage->region);
} else {

View file

@ -149,7 +149,7 @@ magicanalyse_region(region *r, unit *mage, double force)
* mehr als 100% probability und damit immer ein Erfolg. */
probability = curse_chance(c, force);
mon = c->duration + (rng_int()%10) - 5;
mon = max(1, mon);
mon = MAX(1, mon);
found = true;
if (chance(probability)) { /* Analyse geglückt */
@ -190,7 +190,7 @@ magicanalyse_unit(unit *u, unit *mage, double force)
* mehr als 100% probability und damit immer ein Erfolg. */
probability = curse_chance(c, force);
mon = c->duration + (rng_int()%10) - 5;
mon = max(1,mon);
mon = MAX(1,mon);
if (chance(probability)) { /* Analyse geglückt */
if (c_flags(c) & CURSE_NOAGE) {
@ -231,7 +231,7 @@ magicanalyse_building(building *b, unit *mage, double force)
* mehr als 100% probability und damit immer ein Erfolg. */
probability = curse_chance(c, force);
mon = c->duration + (rng_int()%10) - 5;
mon = max(1,mon);
mon = MAX(1,mon);
if (chance(probability)) { /* Analyse geglückt */
if (c_flags(c) & CURSE_NOAGE) {
@ -272,7 +272,7 @@ magicanalyse_ship(ship *sh, unit *mage, double force)
* mehr als 100% probability und damit immer ein Erfolg. */
probability = curse_chance(c, force);
mon = c->duration + (rng_int()%10) - 5;
mon = max(1,mon);
mon = MAX(1,mon);
if (chance(probability)) { /* Analyse geglückt */
if (c_flags(c) & CURSE_NOAGE) {
@ -701,7 +701,7 @@ sp_destroy_magic(castorder *co)
mage, mage->region, co->order));
}
return max(succ, 1);
return MAX(succ, 1);
}
/* ------------------------------------------------------------- */
@ -764,7 +764,7 @@ sp_transferaura(castorder *co)
return 0;
}
gain = min(aura, scm_src->spellpoints) / multi;
gain = MIN(aura, scm_src->spellpoints) / multi;
scm_src->spellpoints -= gain*multi;
scm_dst->spellpoints += gain;
@ -902,7 +902,7 @@ sp_summonent(castorder *co)
return 0;
}
ents = (int)min(power*power, rtrees(r,2));
ents = (int)MIN(power*power, rtrees(r,2));
u = create_unit(r, mage->faction, ents, new_race[RC_TREEMAN], 0, NULL, mage);
@ -1296,7 +1296,7 @@ sp_rosthauch(castorder *co)
for (;iweapon!=NULL;iweapon=iweapon->next) {
item ** ip = i_find(&u->items, iweapon->type);
if (*ip) {
int i = min((*ip)->number, force);
int i = MIN((*ip)->number, force);
if (iweapon->chance<1.0) {
i = (int)(i*iweapon->chance);
}
@ -1332,7 +1332,7 @@ sp_rosthauch(castorder *co)
* ungünstigsten Fall kann pro Stufe nur eine Waffe verzaubert werden,
* darum wird hier nur für alle Fälle in denen noch weniger Waffen
* betroffen wurden ein Kostennachlass gegeben */
return min(success, cast_level);
return MIN(success, cast_level);
}
@ -1364,7 +1364,7 @@ sp_kaelteschutz(castorder *co)
unit *mage = co->magician.u;
int cast_level = co->level;
double force = co->force;
int duration = max(cast_level, (int)force) + 1;
int duration = MAX(cast_level, (int)force) + 1;
spellparameter *pa = co->par;
variant effect;
@ -2091,8 +2091,8 @@ sp_drought(castorder *co)
*/
c = get_curse(r->attribs, ct_find("drought"));
if (c) {
c->vigour = max(c->vigour, power);
c->duration = max(c->duration, (int)power);
c->vigour = MAX(c->vigour, power);
c->duration = MAX(c->duration, (int)power);
} else {
variant effect;
/* Baeume und Pferde sterben */
@ -2280,8 +2280,8 @@ sp_earthquake(castorder *co)
if (burg->size != 0 && !is_cursed(burg->attribs, C_MAGICWALLS, 0)) {
/* Magieresistenz */
if (!target_resists_magic(mage, burg, TYP_BUILDING, 0)) {
kaputt = min(10 * cast_level, burg->size / 4);
kaputt = max(kaputt, 1);
kaputt = MIN(10 * cast_level, burg->size / 4);
kaputt = MAX(kaputt, 1);
burg->size -= kaputt;
if (burg->size == 0) {
/* TODO: sollten die Insassen nicht Schaden nehmen? */
@ -2448,7 +2448,7 @@ sp_forest_fire(castorder *co)
* das Zaubern. Patzer werden warscheinlicher.
* Jeder Zauber muss erst gegen den Wiederstand des Fluchs gezaubert
* werden und schwächt dessen Antimagiewiederstand um 1.
* Wirkt max(Stufe(Magier) - Stufe(Ziel), rand(3)) Wochen
* Wirkt MAX(Stufe(Magier) - Stufe(Ziel), rand(3)) Wochen
* Patzer:
* Magier wird selbst betroffen
*
@ -2476,7 +2476,7 @@ sp_fumblecurse(castorder *co)
rx = rng_int()%3;
sx = cast_level - effskill(target, SK_MAGIC);
duration = max(sx, rx) + 1;
duration = MAX(sx, rx) + 1;
effect.i = (int)(force/2);
c = create_curse(mage, &target->attribs, ct_find("fumble"),
@ -2815,7 +2815,7 @@ wall_move(const border * b, struct unit * u, struct region * from, struct region
wall_data * fd = (wall_data*)b->data.v;
if (!routing && fd->active) {
int hp = dice(3, fd->force) * u->number;
hp = min (u->hp, hp);
hp = MIN(u->hp, hp);
u->hp -= hp;
if (u->hp) {
ADDMSG(&u->faction->msgs, msg_message("firewall_damage",
@ -2887,8 +2887,8 @@ sp_firewall(castorder *co)
fd->countdown = cast_level+1;
} else {
fd = (wall_data*)b->data.v;
fd->force = (int)max(fd->force, force/2+0.5);
fd->countdown = max(fd->countdown, cast_level+1);
fd->force = (int)MAX(fd->force, force/2+0.5);
fd->countdown = MAX(fd->countdown, cast_level+1);
}
/* melden, 1x pro Partei */
@ -3113,7 +3113,7 @@ sp_unholypower(castorder *co)
* Rüstung wirkt nicht
* Patzer:
* Magier gerät in den Staub und verliert zufällige Zahl von HP bis
* auf max(hp,2)
* auf MAX(hp,2)
* Besonderheiten:
* Nicht als curse implementiert, was schlecht ist - man kann dadurch
* kein dispell machen. Wegen fix unter Zeitdruck erstmal nicht zu
@ -3588,7 +3588,7 @@ sp_summonundead(castorder *co)
return 0;
}
undead = min(deathcount(r), 2 + lovar(force));
undead = MIN(deathcount(r), 2 + lovar(force));
if (cast_level <= 8) {
race = new_race[RC_SKELETON];
@ -3633,7 +3633,7 @@ sp_auraleak(castorder *co)
int cast_level = co->level;
message * msg;
lost = min(0.95, cast_level * 0.05);
lost = MIN(0.95, cast_level * 0.05);
for(u = r->units; u; u = u->next) {
if (is_mage(u)) {
@ -3993,8 +3993,8 @@ sp_raisepeasantmob(castorder *co)
anteil.i = 6 + (rng_int()%4);
n = rpeasants(r) * anteil.i / 10;
n = max(0, n);
n = min(n, rpeasants(r));
n = MAX(0, n);
n = MIN(n, rpeasants(r));
if (n <= 0) {
report_failure(mage, co->order);
@ -4218,12 +4218,12 @@ sp_recruit(castorder *co)
* Bauer, nur die Kosten steigen. */
n = (int)((pow(force, 1.6) * 100)/f->race->recruitcost);
if (f->race==new_race[RC_URUK]) {
n = min(2*maxp, n);
n = max(n, 1);
n = MIN(2*maxp, n);
n = MAX(n, 1);
rsetpeasants(r, maxp - (n+1) / 2);
} else {
n = min(maxp, n);
n = max(n, 1);
n = MIN(maxp, n);
n = MAX(n, 1);
rsetpeasants(r, maxp - n);
}
@ -4265,12 +4265,12 @@ sp_bigrecruit(castorder *co)
n = (int)force + lovar((force * force * 1000)/f->race->recruitcost);
if (f->race==new_race[RC_URUK]) {
n = min(2*maxp, n);
n = max(n, 1);
n = MIN(2*maxp, n);
n = MAX(n, 1);
rsetpeasants(r, maxp - (n+1) / 2);
} else {
n = min(maxp, n);
n = max(n, 1);
n = MIN(maxp, n);
n = MAX(n, 1);
rsetpeasants(r, maxp - n);
}
@ -4351,7 +4351,7 @@ sp_pump(castorder *co)
* Betört eine Einheit, so das sie ihm den größten Teil ihres Bargelds
* und 50% ihres Besitzes schenkt. Sie behält jedoch immer soviel, wie
* sie zum überleben braucht. Wirkt gegen Magieresistenz.
* min(Stufe*1000$, u->money - maintenace)
* MIN(Stufe*1000$, u->money - maintenace)
* Von jedem Item wird 50% abgerundet ermittelt und übergeben. Dazu
* kommt Itemzahl%2 mit 50% chance
*
@ -4387,15 +4387,15 @@ sp_seduce(castorder *co)
item * itm = *itmp;
int loot;
if (itm->type==i_silver) {
loot = min(cast_level * 1000, get_money(target) - (maintenance_cost(target)));
loot = max(loot, 0);
loot = MIN(cast_level * 1000, get_money(target) - (maintenance_cost(target)));
loot = MAX(loot, 0);
} else {
loot = itm->number/2;
if (itm->number % 2) {
loot += rng_int() % 2;
}
if (loot > 0) {
loot = (int)min(loot, force * 5);
loot = (int)MIN(loot, force * 5);
}
}
if (loot>0) {
@ -4508,7 +4508,7 @@ sp_headache(castorder *co)
}
if (smax!=NULL) {
/* wirkt auf maximal 10 Personen */
int change = min(10, target->number) * (rng_int()%2+1) / target->number;
int change = MIN(10, target->number) * (rng_int()%2+1) / target->number;
reduce_skill(target, smax, change);
}
set_order(&target->thisorder, NULL);
@ -4553,7 +4553,7 @@ sp_raisepeasants(castorder *co)
ADDMSG(&mage->faction->msgs, msg_feedback(mage, co->order, "error_nopeasants", ""));
return 0;
}
bauern = (int)min(rpeasants(r), power*250);
bauern = (int)MIN(rpeasants(r), power*250);
rsetpeasants(r, rpeasants(r) - bauern);
u2 = create_unit(r, mage->faction, bauern, new_race[RC_PEASANT], 0, LOC(mage->faction->locale, "furious_mob"), mage);
@ -4720,7 +4720,7 @@ sp_puttorest(castorder *co)
message * seen = msg_message("puttorest", "mage", mage);
message * unseen = msg_message("puttorest", "mage", NULL);
laid_to_rest = max(laid_to_rest, dead);
laid_to_rest = MAX(laid_to_rest, dead);
deathcounts(r, -laid_to_rest);
@ -4943,7 +4943,7 @@ sp_baddreams(castorder *co)
/* wirkt erst in der Folgerunde, soll mindestens eine Runde wirken,
* also duration+2 */
duration = (int)max(1, power/2); /* Stufe 1 macht sonst mist */
duration = (int)MAX(1, power/2); /* Stufe 1 macht sonst mist */
duration = 2 + rng_int()%duration;
/* Nichts machen als ein entsprechendes Attribut in die Region legen. */
@ -4983,7 +4983,7 @@ sp_gooddreams(castorder *co)
/* wirkt erst in der Folgerunde, soll mindestens eine Runde wirken,
* also duration+2 */
duration = (int)max(1, power/2); /* Stufe 1 macht sonst mist */
duration = (int)MAX(1, power/2); /* Stufe 1 macht sonst mist */
duration = 2 + rng_int()%duration;
effect.i = 1;
c = create_curse(mage, &r->attribs, ct_find("gbdream"), power, duration, effect, 0);
@ -5116,7 +5116,7 @@ sp_sweetdreams(castorder *co)
cmistake(mage, co->order, 40, MSG_EVENT);
continue;
}
men = min(opfer, u->number);
men = MIN(opfer, u->number);
opfer -= men;
/* Nichts machen als ein entsprechendes Attribut an die Einheit legen. */
@ -5293,7 +5293,7 @@ sp_resist_magic_bonus(castorder *co)
continue;
*/
m = min(u->number,victims);
m = MIN(u->number,victims);
victims -= m;
resistbonus.i = 20;
@ -5310,8 +5310,8 @@ sp_resist_magic_bonus(castorder *co)
msg_release(msg);
}
cast_level = min(cast_level, (int)(cast_level*(victims+4)/maxvictims));
return max(cast_level, 1);
cast_level = MIN(cast_level, (int)(cast_level*(victims+4)/maxvictims));
return MAX(cast_level, 1);
}
/** spell 'Astraler Weg'.
@ -6094,7 +6094,7 @@ sp_permtransfer(castorder *co)
return 0;
}
aura = min(get_spellpoints(mage)-spellcost(mage, sp), aura);
aura = MIN(get_spellpoints(mage)-spellcost(mage, sp), aura);
change_maxspellpoints(mage,-aura);
change_spellpoints(mage,-aura);
@ -6484,7 +6484,7 @@ sp_speed2(castorder *co)
spellparameter *pa = co->par;
maxmen = 2 * cast_level * cast_level;
dur = max(1, cast_level/2);
dur = MAX(1, cast_level/2);
for (n = 0; n < pa->length; n++) {
variant effect;
@ -6498,7 +6498,7 @@ sp_speed2(castorder *co)
u = pa->param[n]->data.u;
men = min(maxmen,u->number);
men = MIN(maxmen,u->number);
effect.i = 2;
create_curse(mage, &u->attribs, ct_find("speed"), force, dur, effect, men);
maxmen -= men;
@ -6508,7 +6508,7 @@ sp_speed2(castorder *co)
ADDMSG(&mage->faction->msgs, msg_message("speed_time_effect", "unit region amount", mage, mage->region, used));
/* Effektiv benötigten cast_level (mindestens 1) zurückgeben */
used = (int)sqrt(used/2);
return max(1, used);
return MAX(1, used);
}
/* ------------------------------------------------------------- */
@ -6592,7 +6592,7 @@ sp_q_antimagie(castorder *co)
"destroy_magic_noeffect", "unit region command",
mage, mage->region, co->order));
}
return max(succ, 1);
return MAX(succ, 1);
}
/* ------------------------------------------------------------- */
@ -6783,7 +6783,7 @@ sp_wdwpyramid(castorder *co)
ADDMSG(&mage->faction->msgs, msg_message("wdw_pyramidspell_notfound",
"unit region command mindist maxdist", mage, r, co->order,
max(1, minshowdist), maxshowdist));
MAX(1, minshowdist), maxshowdist));
}
return cast_level;

View file

@ -56,7 +56,7 @@ do_shock(unit *u, const char *reason)
if (u->number > 0) {
/* HP - Verlust */
u->hp = (unit_max_hp(u) * u->number)/10;
u->hp = max(1, u->hp);
u->hp = MAX(1, u->hp);
}
/* Aura - Verlust */

View file

@ -238,17 +238,18 @@ extern char * strdup(const char *s);
/**** ****
** min/max macros **
**** ****/
#ifndef NOMINMAX
#ifndef min
# define min(a,b) ((a) < (b) ? (a) : (b))
#ifndef MIN
# define MIN(a,b) ((a) < (b) ? (a) : (b))
#endif
#ifndef max
# define max(a,b) ((a) > (b) ? (a) : (b))
#ifndef MAX
# define MAX(a,b) ((a) > (b) ? (a) : (b))
#endif
#endif
#if defined (ghs) || defined (__GNUC__) || defined (__hpux) || defined (__sgi) || defined (__DECCXX) || defined (__KCC) || defined (__rational__) || defined (__USLC__) || defined (ACE_RM544)
#if defined (__GNUC__)
# define unused(a) /* unused: a */
#elif defined (ghs) || || defined (__hpux) || defined (__sgi) || defined (__DECCXX) || defined (__KCC) || defined (__rational__) || defined (__USLC__) || defined (ACE_RM544)
# define unused(a) do {/* null */} while (&a == 0)
#else /* ghs || __GNUC__ || ..... */
# define unused(a) (a)

View file

@ -90,14 +90,14 @@
<xi:include href="eressea/temple.xml"/>
<strings>
<string name="mailto">
<text locale="de">eressea-server@eressea.kn-bremen.de</text>
<text locale="en">eressea-server@eressea.kn-bremen.de</text>
<text locale="de">eressea-server@eressea.de</text>
<text locale="en">eressea-server@eressea.de</text>
</string>
<string name="newbie_info_1">
<text locale="de">Bitte denke daran, deine Befehle mit dem Betreff
ERESSEA BEFEHLE an eressea-server@eressea.kn-bremen.de zu senden.</text>
ERESSEA BEFEHLE an eressea-server@eressea.de zu senden.</text>
<text locale="en">Remember to send your orders to
eressea-server@eressea.kn-bremen.de with the subject ERESSEA ORDERS.</text>
eressea-server@eressea.de with the subject ERESSEA ORDERS.</text>
</string>
<string name="mailcmd">
<text locale="de">ERESSEA BEFEHLE</text>

View file

@ -1,57 +1,52 @@
Willkommen beim Eressea-Testspiel.
Vorweg: Dieses ist NICHT deine zukünftige Eressea-Partei. Es ist ein
Vorweg: Dieses ist NICHT deine zukünftige Eressea-Partei. Es ist ein
Tutorial. Um sicherzustellen, das neue Spieler in Eressea ein gewisses
Grundverständnis der Anleitung mitbringen, und nicht nach wochenlanger
Wartezeit über einen einfachen Fehler stolpern, schicken wir jeden neuen
Grundverständnis der Anleitung mitbringen, und nicht nach wochenlanger
Wartezeit über einen einfachen Fehler stolpern, schicken wir jeden neuen
Spieler in eine Probepartie, die 5 Runden dauert. Du kannst also mit dieser
Partei tun was Du möchtest, und etwas herumexperimentieren, ohne das das auf
Deine spätere Partei Auswirkungen hat. Einzig, das Du die 5 Runden
überlebst, verlangen wir von Dir.
Partei tun was Du möchtest, und etwas herumexperimentieren, ohne das das auf
Deine spätere Partei Auswirkungen hat. Einzig, das Du die 5 Runden
überlebst, verlangen wir von Dir.
Folgende Unterschiede gibt es zwischen diesem Testspiel und dem richtigen
Eressea:
* Email-Adresse für Züge
Testspiel: tutorial@eressea.upb.de
Eressea: eressea-server@eressea.upb.de
* Email-Adresse für Züge
Testspiel: tutorial@eressea.de
Eressea: eressea-server@eressea.de
* Zugabgaberhytmus:
Testspiel: 3x die Woche, Montag, Mittwoch und Samstag um 09:00 Uhr morgens
Eressea: 1x die Woche, Sonntags um 9:00 Uhr
* Spieldauer:
Testspiel: 5 Züge Minimum, Partei wird nach 10 Zügen gelöscht.
Testspiel: 5 Züge Minimum, Partei wird nach 10 Zügen gelöscht.
Eressea: unbegrenzt
Ein paar Tipps für den Anfang:
Ein paar Tipps für den Anfang:
Eressea ist ein komplexes Spiel mit einer Menge Regeln. Je besser Du sie
verstehst, desto besser wirst Du das Spiel spielen können. Nimm Dir die
Zeit, die Anleitung ausführlich zu lesen. Du findest sie unter
http://eressea.upb.de/rules/. Wenn Du allgemeine Fragen hast, kannst Du auch
auf unserem Forum vorbeischauen, das du unter http://eressea.upb.de/forum/
findest.
verstehst, desto besser wirst Du das Spiel spielen können. Nimm Dir die
Zeit, die Anleitung ausführlich zu lesen. Du findest sie unter
http://wiki.eressea.de/de/. Wenn Du allgemeine Fragen hast, kannst Du auch
auf unserem Forum vorbeischauen, das du auf
http://www.pbem-spiele.de/forum/viewforum.php?f=16 findest.
Eressea ist ein textuelles Spiel. Laß Dich nicht davon einschüchtern, das Du
Befehle lernen mußt - so viele sind es nicht, und die meisten sind sehr
Eressea ist ein textuelles Spiel. Laß Dich nicht davon einschüchtern, das Du
Befehle lernen mußt - so viele sind es nicht, und die meisten sind sehr
intuitiv. Vieles in Eressea passiert in deiner Phantasie, und das
spannendste am Spiel sind die anderen Spieler und die Diplomatie mit ihnen.
Die beiden anderen Dateien in dieser Mail enthalten den Report in zwei
verschiedenen Formaten. Die Datei mit der Endung .nr ist eine normale
Textdatei, und sie enthält deinen ersten Report in menschenlesbarer Form. Du
Textdatei, und sie enthält deinen ersten Report in menschenlesbarer Form. Du
kannst sie mit jedem Texteditor (zum Beispiel Notepad) lesen. Die zweite
Datei mit der Endung .cr enthält den Report in einer Form, die von
Datei mit der Endung .cr enthält den Report in einer Form, die von
Eressea-Software gelesen werden kann, wie zum Beispiel Magellan, das Du
unter http://eressea.upb.de/magellan/ findest. Ob Du lieber mit der
Textversion oder mit einem Programm spielst, ist Dir überlassen.
unter http://magellan.log-out.net/ findest. Ob Du lieber mit der
Textversion oder mit einem Programm spielst, ist Dir überlassen.
Solltest Du Fragen haben, die du mit der Anleitung nicht beantworten kannst,
kannst du eine Mail an die Adresse eressea-help@eressea.kn-bremen.de
schicken. Dort hilft man Dir gerne mit Fragen aller Art. Oder Du siehst Dir
mal die Beispielzüge unter http://www.webfeed.de/eressea/ an.
Viel Spaß mit Eressea wünscht Dir auf jeden Fall
Viel Spaß mit Eressea wünscht Dir auf jeden Fall
das Eressea-Team.

View file

@ -10,8 +10,8 @@ game shortly.
The tutorial differs from Eressea in a few very important points:
* Email-Address to send your turns to:
Tutorial: tutorial@eressea.upb.de
Eressea: eressea-server@eressea.upb.de
Tutorial: tutorial@eressea.de
Eressea: eressea-server@eressea.de
* Frequency:
Tutorial: 3x per Week, Monday, Wednesday and Saturday before 9 am CET.
@ -40,7 +40,7 @@ because the translation of the human-readable report is currently a work in
progress. That's why we recommend using the file with the .cr extension
instead. It is a format that is understood by most Eressea-tools, notably
the very good Magellan client. It is available at
http://eressea.upb.de/magellan/.
http://magellan.log-out.net/.
If you have any questions that the documentation does not answer, you can
send them to eressea-help@eressea.kn-bremen.de, and get an answer from a

View file

@ -13,7 +13,7 @@ loadscript("default.lua")
function change_locales()
-- local localechange = { }
local localechange = { en = { "won" } }
local localechange = { de = { "bb" } }
for loc, flist in pairs(localechange) do
for index, name in pairs(flist) do

View file

@ -96,8 +96,8 @@ convert_resources(void)
rawmaterial * rmstone = rm_get(r, rm_stones.rtype);
int oldiron;
int oldlaen = MAXLAENPERTURN * min(r->age, 100) / 2;
int oldstone = terrain[rterrain(r)].quarries * max(0, r->age - INIT_STONE);
int oldlaen = MAXLAENPERTURN * MIN(r->age, 100) / 2;
int oldstone = terrain[rterrain(r)].quarries * MAX(0, r->age - INIT_STONE);
int iron = a->data.sa[0];
int laen = a->data.sa[1];
int stone, level;
@ -127,7 +127,7 @@ convert_resources(void)
/** IRON **/
if (r_isglacier(r) || r->terrain==T_ICEBERG) {
oldiron = GLIRONPERTURN * min(r->age, 100) / 2;
oldiron = GLIRONPERTURN * MIN(r->age, 100) / 2;
} else {
oldiron = IRONPERTURN * r->age;
}
@ -136,7 +136,7 @@ convert_resources(void)
}
if (terrain[r->terrain].rawmaterials[i].type) {
base = terrain[r->terrain].rawmaterials[i].base;
iron = max(0, (int)(oldiron * ironmulti - iron ));
iron = MAX(0, (int)(oldiron * ironmulti - iron ));
level = 1;
base = (int)(terrain[r->terrain].rawmaterials[i].base*(1+level*terrain[r->terrain].rawmaterials[i].divisor));
while (iron >= base) {
@ -163,7 +163,7 @@ convert_resources(void)
if (terrain[r->terrain].rawmaterials[i].type == &rm_laen) break;
}
if (terrain[r->terrain].rawmaterials[i].type) {
laen = max(0, (int)(oldlaen * laenmulti - laen));
laen = MAX(0, (int)(oldlaen * laenmulti - laen));
level = 1;
base = (int)(terrain[r->terrain].rawmaterials[i].base*(1+level*terrain[r->terrain].rawmaterials[i].divisor));
while (laen >= base) {