eliminate more static cached configuration values

This commit is contained in:
Enno Rehling 2015-11-22 15:14:50 +01:00
parent 17068af332
commit 7bbf11c6b6
3 changed files with 28 additions and 66 deletions

View file

@ -93,13 +93,11 @@ void herbsearch(unit * u, int max)
static int begin_potion(unit * u, const potion_type * ptype, struct order *ord) static int begin_potion(unit * u, const potion_type * ptype, struct order *ord)
{ {
static int rule_multipotion = -1; bool rule_multipotion;
assert(ptype != NULL); assert(ptype != NULL);
if (rule_multipotion < 0) { /* should we allow multiple different potions to be used the same turn? */
/* should we allow multiple different potions to be used the same turn? */ rule_multipotion = config_get_int("rules.magic.multipotion", 0) != 0;
rule_multipotion = config_get_int("rules.magic.multipotion", 0);
}
if (!rule_multipotion) { if (!rule_multipotion) {
const potion_type *use = ugetpotionuse(u); const potion_type *use = ugetpotionuse(u);
if (use != NULL && use != ptype) { if (use != NULL && use != ptype) {

View file

@ -664,23 +664,14 @@ weapon_skill(const weapon_type * wtype, const unit * u, bool attacking)
static int CavalrySkill(void) static int CavalrySkill(void)
{ {
static int skill = -1; return config_get_int("rules.cavalry.skill", 2);
if (skill < 0) {
skill = config_get_int("rules.cavalry.skill", 2);
}
return skill;
} }
#define BONUS_SKILL 1 #define BONUS_SKILL 1
#define BONUS_DAMAGE 2 #define BONUS_DAMAGE 2
static int CavalryBonus(const unit * u, troop enemy, int type) static int CavalryBonus(const unit * u, troop enemy, int type)
{ {
static int mode = -1; int mode = config_get_int("rules.cavalry.mode", 1);
if (mode < 0) {
mode = config_get_int("rules.cavalry.mode", 1);
}
if (mode == 0) { if (mode == 0) {
/* old rule, Eressea 1.0 compat */ /* old rule, Eressea 1.0 compat */
return (type == BONUS_SKILL) ? 2 : 0; return (type == BONUS_SKILL) ? 2 : 0;
@ -1006,9 +997,7 @@ const char *rel_dam(int dam, int hp)
static void vampirism(troop at, int damage) static void vampirism(troop at, int damage)
{ {
static int vampire = -1; int vampire = config_get_int("rules.combat.demon_vampire", 0);
if (vampire < 0)
vampire = config_get_int("rules.combat.demon_vampire", 0);
if (vampire > 0) { if (vampire > 0) {
int gain = damage / vampire; int gain = damage / vampire;
int chance = damage - vampire * gain; int chance = damage - vampire * gain;
@ -1079,7 +1068,6 @@ static int rc_specialdamage(const unit *au, const unit *du, const struct weapon_
} }
int calculate_armor(troop dt, const weapon_type *dwtype, const weapon_type *awtype, double *magres) { int calculate_armor(troop dt, const weapon_type *dwtype, const weapon_type *awtype, double *magres) {
static int rule_armor = -1;
fighter *df = dt.fighter; fighter *df = dt.fighter;
unit *du = df->unit; unit *du = df->unit;
int ar = 0, an, am; int ar = 0, an, am;
@ -1107,10 +1095,7 @@ int calculate_armor(troop dt, const weapon_type *dwtype, const weapon_type *awty
/* Momentan nur Trollgürtel und Werwolf-Eigenschaft */ /* Momentan nur Trollgürtel und Werwolf-Eigenschaft */
am = select_magicarmor(dt); am = select_magicarmor(dt);
if (rule_armor < 0) { if (config_get_int("rules.combat.nat_armor", 0) == 0) {
rule_armor = config_get_int("rules.combat.nat_armor", 0);
}
if (rule_armor == 0) {
/* natürliche Rüstung ist halbkumulativ */ /* natürliche Rüstung ist halbkumulativ */
if (ar > 0) { if (ar > 0) {
ar += an / 2; ar += an / 2;
@ -1939,10 +1924,7 @@ int skilldiff(troop at, troop dt, int dist)
} }
if (u_race(au) == get_race(RC_GOBLIN)) { if (u_race(au) == get_race(RC_GOBLIN)) {
static int goblin_bonus = -1; int goblin_bonus = config_get_int("rules.combat.goblinbonus", 10);
if (goblin_bonus < 0)
goblin_bonus =
config_get_int("rules.combat.goblinbonus", 10);
if (af->side->size[SUM_ROW] >= df->side->size[SUM_ROW] * goblin_bonus) { if (af->side->size[SUM_ROW] >= df->side->size[SUM_ROW] * goblin_bonus) {
skdiff += 1; skdiff += 1;
} }
@ -2140,10 +2122,7 @@ static int attacks_per_round(troop t)
static void make_heroes(battle * b) static void make_heroes(battle * b)
{ {
side *s; side *s;
static int hero_speed = 0; int hero_speed = config_get_int("rules.combat.herospeed", 10);
if (hero_speed == 0) {
hero_speed = config_get_int("rules.combat.herospeed", 10);
}
for (s = b->sides; s != b->sides + b->nsides; ++s) { for (s = b->sides; s != b->sides + b->nsides; ++s) {
fighter *fig; fighter *fig;
for (fig = s->fighters; fig; fig = fig->next) { for (fig = s->fighters; fig; fig = fig->next) {
@ -3213,16 +3192,12 @@ side * get_side(battle * b, const struct unit * u)
side * find_side(battle * b, const faction * f, const group * g, unsigned int flags, const faction * stealthfaction) side * find_side(battle * b, const faction * f, const group * g, unsigned int flags, const faction * stealthfaction)
{ {
side * s; side * s;
static int rule_anon_battle = -1; bool rule_anon_battle = config_get_int("rules.stealth.anon_battle", 1) != 0;
if (rule_anon_battle < 0) {
rule_anon_battle = config_get_int("rules.stealth.anon_battle", 1);
}
for (s = b->sides; s != b->sides + b->nsides; ++s) { for (s = b->sides; s != b->sides + b->nsides; ++s) {
if (s->faction == f && s->group == g) { if (s->faction == f && s->group == g) {
unsigned int s1flags = flags | SIDE_HASGUARDS; unsigned int s1flags = flags | SIDE_HASGUARDS;
unsigned int s2flags = s->flags | SIDE_HASGUARDS; unsigned int s2flags = s->flags | SIDE_HASGUARDS;
if (rule_anon_battle!=0 && s->stealthfaction != stealthfaction) { if (rule_anon_battle && s->stealthfaction != stealthfaction) {
continue; continue;
} }
if (s1flags == s2flags) { if (s1flags == s2flags) {
@ -3611,7 +3586,6 @@ battle *make_battle(region * r)
unit *u; unit *u;
bfaction *bf; bfaction *bf;
building * bld; building * bld;
static int max_fac_no = 0; /* need this only once */
/* Alle Mann raus aus der Burg! */ /* Alle Mann raus aus der Burg! */
for (bld = r->buildings; bld != NULL; bld = bld->next) for (bld = r->buildings; bld != NULL; bld = bld->next)
@ -3663,7 +3637,6 @@ battle *make_battle(region * r)
for (bf = b->factions; bf; bf = bf->next) { for (bf = b->factions; bf; bf = bf->next) {
faction *f = bf->faction; faction *f = bf->faction;
max_fac_no = _max(max_fac_no, f->no);
freset(f, FFL_MARK); freset(f, FFL_MARK);
} }
return b; return b;
@ -3709,17 +3682,13 @@ static void battle_free(battle * b) {
void free_battle(battle * b) void free_battle(battle * b)
{ {
int max_fac_no = 0;
if (bdebug) { if (bdebug) {
fclose(bdebug); fclose(bdebug);
} }
while (b->factions) { while (b->factions) {
bfaction *bf = b->factions; bfaction *bf = b->factions;
faction *f = bf->faction;
b->factions = bf->next; b->factions = bf->next;
max_fac_no = _max(max_fac_no, f->no);
free(bf); free(bf);
} }

View file

@ -320,33 +320,28 @@ static int lua_getresource(unit * u, const struct resource_type *rtype)
static bool lua_canuse_item(const unit * u, const struct item_type *itype) static bool lua_canuse_item(const unit * u, const struct item_type *itype)
{ {
static int function_exists = 1;
bool result = true; bool result = true;
lua_State *L = (lua_State *)global.vm_state;
const char *fname = "item_canuse";
if (function_exists) { lua_getglobal(L, fname);
lua_State *L = (lua_State *)global.vm_state; if (lua_isfunction(L, -1)) {
const char *fname = "item_canuse"; tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit");
tolua_pushstring(L, itype->rtype->_name);
lua_getglobal(L, fname); if (lua_pcall(L, 2, 1, 0) != 0) {
if (lua_isfunction(L, -1)) { const char *error = lua_tostring(L, -1);
tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); log_error("use(%s) calling '%s': %s.\n", unitname(u), fname, error);
tolua_pushstring(L, itype->rtype->_name);
if (lua_pcall(L, 2, 1, 0) != 0) {
const char *error = lua_tostring(L, -1);
log_error("get(%s) calling '%s': %s.\n", unitname(u), fname, error);
lua_pop(L, 1);
}
else {
result = lua_toboolean(L, -1);
lua_pop(L, 1);
}
}
else {
function_exists = 0;
log_error("get(%s) calling '%s': not a function.\n", unitname(u), fname);
lua_pop(L, 1); lua_pop(L, 1);
} }
else {
result = lua_toboolean(L, -1);
lua_pop(L, 1);
}
}
else {
log_error("use(%s) calling '%s': not a function.\n", unitname(u), fname);
lua_pop(L, 1);
} }
return result; return result;
} }