forked from github/server
stop using MIN and MAX macros
This commit is contained in:
parent
0884fb1f1b
commit
9ee84445eb
2 changed files with 56 additions and 36 deletions
|
@ -16,7 +16,9 @@ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
**/
|
**/
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <kernel/config.h>
|
#include <kernel/config.h>
|
||||||
#include "building.h"
|
#include "building.h"
|
||||||
|
@ -150,10 +152,11 @@ building_type *bt_get_or_create(const char *name)
|
||||||
int buildingcapacity(const building * b)
|
int buildingcapacity(const building * b)
|
||||||
{
|
{
|
||||||
if (b->type->capacity >= 0) {
|
if (b->type->capacity >= 0) {
|
||||||
if (b->type->maxcapacity >= 0) {
|
int cap = b->size * b->type->capacity;
|
||||||
return MIN(b->type->maxcapacity, b->size * b->type->capacity);
|
if (b->type->maxcapacity > 0 && b->type->maxcapacity < cap) {
|
||||||
|
cap = b->type->maxcapacity;
|
||||||
}
|
}
|
||||||
return b->size * b->type->capacity;
|
return cap;
|
||||||
}
|
}
|
||||||
if (building_finished(b)) {
|
if (building_finished(b)) {
|
||||||
if (b->type->maxcapacity >= 0) {
|
if (b->type->maxcapacity >= 0) {
|
||||||
|
@ -313,9 +316,15 @@ int building_protection(const building_type * btype, int stage)
|
||||||
{
|
{
|
||||||
assert(btype->flags & BTF_FORTIFICATION);
|
assert(btype->flags & BTF_FORTIFICATION);
|
||||||
if (btype->maxsize < 0) {
|
if (btype->maxsize < 0) {
|
||||||
return castle_bonus[MIN(stage, 5)];
|
if (stage > 5) {
|
||||||
|
stage = 5;
|
||||||
}
|
}
|
||||||
return watch_bonus[MIN(stage, 2)];
|
return castle_bonus[stage];
|
||||||
|
}
|
||||||
|
if (stage > 2) {
|
||||||
|
stage = 2;
|
||||||
|
}
|
||||||
|
return watch_bonus[stage];
|
||||||
}
|
}
|
||||||
|
|
||||||
void write_building_reference(const struct building *b, struct storage *store)
|
void write_building_reference(const struct building *b, struct storage *store)
|
||||||
|
@ -682,7 +691,7 @@ default_wage(const region * r, const faction * f, const race * rc, int in_turn)
|
||||||
{
|
{
|
||||||
building *b = largestbuilding(r, cmp_wage, false);
|
building *b = largestbuilding(r, cmp_wage, false);
|
||||||
int esize = 0;
|
int esize = 0;
|
||||||
double wage;
|
int wage;
|
||||||
|
|
||||||
if (b != NULL) {
|
if (b != NULL) {
|
||||||
/* TODO: this reveals imaginary castles */
|
/* TODO: this reveals imaginary castles */
|
||||||
|
@ -715,25 +724,27 @@ default_wage(const region * r, const faction * f, const race * rc, int in_turn)
|
||||||
if (r->attribs) {
|
if (r->attribs) {
|
||||||
attrib *a;
|
attrib *a;
|
||||||
curse *c;
|
curse *c;
|
||||||
|
variant vm = frac_make(wage, 1);
|
||||||
|
|
||||||
/* Godcurse: Income -10 */
|
/* Godcurse: Income -10 */
|
||||||
c = get_curse(r->attribs, &ct_godcursezone);
|
c = get_curse(r->attribs, &ct_godcursezone);
|
||||||
if (c && curse_active(c)) {
|
if (c && curse_active(c)) {
|
||||||
wage = MAX(0, wage - 10);
|
wage = (wage < 10) ? 0 : (wage - 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Bei einer D<>rre verdient man nur noch ein Viertel */
|
/* Bei einer D<>rre verdient man nur noch ein Viertel */
|
||||||
c = get_curse(r->attribs, &ct_drought);
|
c = get_curse(r->attribs, &ct_drought);
|
||||||
if (c && curse_active(c)) {
|
if (c && curse_active(c)) {
|
||||||
wage /= curse_geteffect(c);
|
vm = frac_mul(vm, frac_make(1, curse_geteffect_int(c)));
|
||||||
}
|
}
|
||||||
|
|
||||||
a = a_find(r->attribs, &at_reduceproduction);
|
a = a_find(r->attribs, &at_reduceproduction);
|
||||||
if (a) {
|
if (a) {
|
||||||
wage = (wage * a->data.sa[0]) / 100;
|
vm = frac_mul(vm, frac_make(a->data.sa[0], 100));
|
||||||
}
|
}
|
||||||
|
wage = vm.sa[0] / vm.sa[1];
|
||||||
}
|
}
|
||||||
return (int)wage;
|
return wage;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
|
|
@ -9,7 +9,9 @@
|
||||||
This program may not be used, modified or distributed
|
This program may not be used, modified or distributed
|
||||||
without prior permission by the authors of Eressea.
|
without prior permission by the authors of Eressea.
|
||||||
*/
|
*/
|
||||||
|
#ifdef _MSC_VER
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
|
#endif
|
||||||
#include "combatspells.h"
|
#include "combatspells.h"
|
||||||
|
|
||||||
#include <spells/buildingcurse.h>
|
#include <spells/buildingcurse.h>
|
||||||
|
@ -45,6 +47,7 @@
|
||||||
|
|
||||||
/* libc includes */
|
/* libc includes */
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
#include <math.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
@ -131,8 +134,7 @@ int damage_spell(struct castorder * co, int dmg, int strength)
|
||||||
|
|
||||||
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW - 1, SELECT_ADVANCE);
|
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW - 1, SELECT_ADVANCE);
|
||||||
if (enemies == 0) {
|
if (enemies == 0) {
|
||||||
message *m =
|
m = msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
||||||
msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -171,8 +173,7 @@ int sp_petrify(struct castorder * co)
|
||||||
|
|
||||||
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE);
|
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE);
|
||||||
if (!enemies) {
|
if (!enemies) {
|
||||||
message *m =
|
m = msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
||||||
msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -218,8 +219,7 @@ int sp_stun(struct castorder * co)
|
||||||
|
|
||||||
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE);
|
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE);
|
||||||
if (!enemies) {
|
if (!enemies) {
|
||||||
message *m =
|
m = msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
||||||
msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -298,7 +298,8 @@ int sp_combatrosthauch(struct castorder * co)
|
||||||
|
|
||||||
for (w = 0; df->weapons[w].type != NULL; ++w) {
|
for (w = 0; df->weapons[w].type != NULL; ++w) {
|
||||||
weapon *wp = df->weapons;
|
weapon *wp = df->weapons;
|
||||||
int n = MIN(force, wp->used);
|
int n = force;
|
||||||
|
if (n < wp->used) n = wp->used;
|
||||||
if (n) {
|
if (n) {
|
||||||
requirement *mat = wp->type->itype->construction->materials;
|
requirement *mat = wp->type->itype->construction->materials;
|
||||||
bool iron = false;
|
bool iron = false;
|
||||||
|
@ -682,8 +683,7 @@ int sp_immolation(struct castorder * co)
|
||||||
force = 99999;
|
force = 99999;
|
||||||
|
|
||||||
if (!count_enemies(b, fi, FIGHT_ROW, AVOID_ROW, SELECT_ADVANCE | SELECT_FIND)) {
|
if (!count_enemies(b, fi, FIGHT_ROW, AVOID_ROW, SELECT_ADVANCE | SELECT_FIND)) {
|
||||||
message *m =
|
m = msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
||||||
msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -791,7 +791,7 @@ int sp_shadowknights(struct castorder * co)
|
||||||
region *r = b->region;
|
region *r = b->region;
|
||||||
unit *mage = fi->unit;
|
unit *mage = fi->unit;
|
||||||
attrib *a;
|
attrib *a;
|
||||||
int force = MAX(1, (int)get_force(power, 3));
|
int force = (int)fmax(1, get_force(power, 3));
|
||||||
message *msg;
|
message *msg;
|
||||||
|
|
||||||
u =
|
u =
|
||||||
|
@ -890,7 +890,6 @@ int sp_chaosrow(struct castorder * co)
|
||||||
continue;
|
continue;
|
||||||
if (power <= 0.0)
|
if (power <= 0.0)
|
||||||
break;
|
break;
|
||||||
/* force sollte wegen des MAX(0,x) nicht unter 0 fallen k<>nnen */
|
|
||||||
|
|
||||||
if (is_magic_resistant(mage, df->unit, 0))
|
if (is_magic_resistant(mage, df->unit, 0))
|
||||||
continue;
|
continue;
|
||||||
|
@ -925,7 +924,7 @@ int sp_chaosrow(struct castorder * co)
|
||||||
}
|
}
|
||||||
k += df->alive;
|
k += df->alive;
|
||||||
}
|
}
|
||||||
power = MAX(0, power - n);
|
power = fmax(0, power - n);
|
||||||
}
|
}
|
||||||
selist_free(fgs);
|
selist_free(fgs);
|
||||||
|
|
||||||
|
@ -1020,7 +1019,8 @@ int sp_hero(struct castorder * co)
|
||||||
message *m;
|
message *m;
|
||||||
|
|
||||||
df_bonus = (int)(power / 5);
|
df_bonus = (int)(power / 5);
|
||||||
force = MAX(1, lovar(get_force(power, 4)));
|
force = lovar(get_force(power, 4));
|
||||||
|
if (force < 1) force = 1;
|
||||||
|
|
||||||
allies =
|
allies =
|
||||||
count_allies(fi->side, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE, ALLY_ANY);
|
count_allies(fi->side, FIGHT_ROW, BEHIND_ROW, SELECT_ADVANCE, ALLY_ANY);
|
||||||
|
@ -1065,7 +1065,8 @@ int sp_berserk(struct castorder * co)
|
||||||
int targets = 0;
|
int targets = 0;
|
||||||
message *m;
|
message *m;
|
||||||
|
|
||||||
at_bonus = MAX(1, level / 3);
|
at_bonus = level / 3;
|
||||||
|
if (at_bonus < 1) at_bonus = 1;
|
||||||
df_malus = 2;
|
df_malus = 2;
|
||||||
force = (int)get_force(power, 2);
|
force = (int)get_force(power, 2);
|
||||||
|
|
||||||
|
@ -1114,14 +1115,14 @@ int sp_frighten(struct castorder * co)
|
||||||
int targets = 0;
|
int targets = 0;
|
||||||
message *m;
|
message *m;
|
||||||
|
|
||||||
at_malus = MAX(1, level - 4);
|
at_malus = level - 4;
|
||||||
|
if (at_malus < 1) at_malus = 1;
|
||||||
df_malus = 2;
|
df_malus = 2;
|
||||||
force = (int)get_force(power, 2);
|
force = (int)get_force(power, 2);
|
||||||
|
|
||||||
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW - 1, SELECT_ADVANCE);
|
enemies = count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW - 1, SELECT_ADVANCE);
|
||||||
if (!enemies) {
|
if (!enemies) {
|
||||||
message *m =
|
m = msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
||||||
msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1170,8 +1171,7 @@ int sp_tiredsoldiers(struct castorder * co)
|
||||||
|
|
||||||
if (!count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW,
|
if (!count_enemies(b, fi, FIGHT_ROW, BEHIND_ROW,
|
||||||
SELECT_ADVANCE | SELECT_FIND)) {
|
SELECT_ADVANCE | SELECT_FIND)) {
|
||||||
message *m =
|
m = msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
||||||
msg_message("spell_out_of_range", "mage spell", fi->unit, sp);
|
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1367,7 +1367,8 @@ int sp_fumbleshield(struct castorder * co)
|
||||||
|
|
||||||
/* der erste Zauber schl<68>gt mit 100% fehl */
|
/* der erste Zauber schl<68>gt mit 100% fehl */
|
||||||
duration = 100;
|
duration = 100;
|
||||||
effect = MAX(1, 25 - level);
|
effect = 25 - level;
|
||||||
|
if (effect < 1) effect = 1;
|
||||||
|
|
||||||
do_meffect(fi, SHIELD_BLOCK, effect, duration);
|
do_meffect(fi, SHIELD_BLOCK, effect, duration);
|
||||||
return level;
|
return level;
|
||||||
|
@ -1403,7 +1404,7 @@ int sp_reanimate(struct castorder * co)
|
||||||
unit *mage = fi->unit;
|
unit *mage = fi->unit;
|
||||||
int healable, j = 0;
|
int healable, j = 0;
|
||||||
double c = 0.50 + 0.02 * power;
|
double c = 0.50 + 0.02 * power;
|
||||||
double k = EFFECT_HEALING_SPELL * power;
|
int k = (int)(EFFECT_HEALING_SPELL * power);
|
||||||
bool use_item = has_ao_healing(mage);
|
bool use_item = has_ao_healing(mage);
|
||||||
message *msg;
|
message *msg;
|
||||||
|
|
||||||
|
@ -1413,7 +1414,9 @@ int sp_reanimate(struct castorder * co)
|
||||||
}
|
}
|
||||||
|
|
||||||
healable = count_healable(b, fi);
|
healable = count_healable(b, fi);
|
||||||
healable = (int)MIN(k, healable);
|
if (healable > k) {
|
||||||
|
healable = k;
|
||||||
|
}
|
||||||
while (healable--) {
|
while (healable--) {
|
||||||
fighter *tf = select_corpse(b, fi);
|
fighter *tf = select_corpse(b, fi);
|
||||||
if (tf != NULL && tf->side->casualties > 0
|
if (tf != NULL && tf->side->casualties > 0
|
||||||
|
@ -1466,7 +1469,7 @@ int sp_keeploot(struct castorder * co)
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
|
|
||||||
b->keeploot = (int)MAX(25, b->keeploot + 5 * power);
|
b->keeploot = (int)fmax(25, b->keeploot + 5 * power);
|
||||||
|
|
||||||
return level;
|
return level;
|
||||||
}
|
}
|
||||||
|
@ -1497,10 +1500,14 @@ static int heal_fighters(selist * fgs, int *power, bool heal_monsters)
|
||||||
++wound;
|
++wound;
|
||||||
|
|
||||||
if (wound > 0 && wound < hp) {
|
if (wound > 0 && wound < hp) {
|
||||||
int heal = MIN(healhp, wound);
|
int heal = healhp;
|
||||||
|
if (heal > wound) {
|
||||||
|
heal = wound;
|
||||||
|
}
|
||||||
assert(heal >= 0);
|
assert(heal >= 0);
|
||||||
df->person[n].hp += heal;
|
df->person[n].hp += heal;
|
||||||
healhp = MAX(0, healhp - heal);
|
healhp -= heal;
|
||||||
|
if (healhp < 0) healhp = 0;
|
||||||
++healed;
|
++healed;
|
||||||
if (healhp <= 0)
|
if (healhp <= 0)
|
||||||
break;
|
break;
|
||||||
|
@ -1653,7 +1660,9 @@ int sp_undeadhero(struct castorder * co)
|
||||||
}
|
}
|
||||||
selist_free(fgs);
|
selist_free(fgs);
|
||||||
|
|
||||||
level = MIN(level, undead);
|
if (level > undead) {
|
||||||
|
level = undead;
|
||||||
|
}
|
||||||
if (undead == 0) {
|
if (undead == 0) {
|
||||||
msg =
|
msg =
|
||||||
msg_message("summonundead_effect_0", "mage region", mage, mage->region);
|
msg_message("summonundead_effect_0", "mage region", mage, mage->region);
|
||||||
|
|
Loading…
Reference in a new issue