From 7bbf11c6b6e86eb15dbc0365324a4d4ed8fce98d Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sun, 22 Nov 2015 15:14:50 +0100 Subject: [PATCH] eliminate more static cached configuration values --- src/alchemy.c | 8 +++----- src/battle.c | 47 ++++++++--------------------------------------- src/helpers.c | 39 +++++++++++++++++---------------------- 3 files changed, 28 insertions(+), 66 deletions(-) diff --git a/src/alchemy.c b/src/alchemy.c index 406d39fd6..ace6a62dd 100644 --- a/src/alchemy.c +++ b/src/alchemy.c @@ -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 rule_multipotion = -1; + bool rule_multipotion; assert(ptype != NULL); - if (rule_multipotion < 0) { - /* should we allow multiple different potions to be used the same turn? */ - rule_multipotion = config_get_int("rules.magic.multipotion", 0); - } + /* should we allow multiple different potions to be used the same turn? */ + rule_multipotion = config_get_int("rules.magic.multipotion", 0) != 0; if (!rule_multipotion) { const potion_type *use = ugetpotionuse(u); if (use != NULL && use != ptype) { diff --git a/src/battle.c b/src/battle.c index 80c3c0583..a1e2572dc 100644 --- a/src/battle.c +++ b/src/battle.c @@ -664,23 +664,14 @@ weapon_skill(const weapon_type * wtype, const unit * u, bool attacking) static int CavalrySkill(void) { - static int skill = -1; - - if (skill < 0) { - skill = config_get_int("rules.cavalry.skill", 2); - } - return skill; + return config_get_int("rules.cavalry.skill", 2); } #define BONUS_SKILL 1 #define BONUS_DAMAGE 2 static int CavalryBonus(const unit * u, troop enemy, int type) { - static int mode = -1; - - if (mode < 0) { - mode = config_get_int("rules.cavalry.mode", 1); - } + int mode = config_get_int("rules.cavalry.mode", 1); if (mode == 0) { /* old rule, Eressea 1.0 compat */ 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 int vampire = -1; - if (vampire < 0) - vampire = config_get_int("rules.combat.demon_vampire", 0); + int vampire = config_get_int("rules.combat.demon_vampire", 0); if (vampire > 0) { int gain = damage / vampire; 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) { - static int rule_armor = -1; fighter *df = dt.fighter; unit *du = df->unit; 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 */ am = select_magicarmor(dt); - if (rule_armor < 0) { - rule_armor = config_get_int("rules.combat.nat_armor", 0); - } - if (rule_armor == 0) { + if (config_get_int("rules.combat.nat_armor", 0) == 0) { /* natürliche Rüstung ist halbkumulativ */ if (ar > 0) { ar += an / 2; @@ -1939,10 +1924,7 @@ int skilldiff(troop at, troop dt, int dist) } if (u_race(au) == get_race(RC_GOBLIN)) { - static int goblin_bonus = -1; - if (goblin_bonus < 0) - goblin_bonus = - config_get_int("rules.combat.goblinbonus", 10); + int goblin_bonus = config_get_int("rules.combat.goblinbonus", 10); if (af->side->size[SUM_ROW] >= df->side->size[SUM_ROW] * goblin_bonus) { skdiff += 1; } @@ -2140,10 +2122,7 @@ static int attacks_per_round(troop t) static void make_heroes(battle * b) { side *s; - static int hero_speed = 0; - if (hero_speed == 0) { - hero_speed = config_get_int("rules.combat.herospeed", 10); - } + int hero_speed = config_get_int("rules.combat.herospeed", 10); for (s = b->sides; s != b->sides + b->nsides; ++s) { fighter *fig; 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 * s; - static int rule_anon_battle = -1; - - if (rule_anon_battle < 0) { - rule_anon_battle = config_get_int("rules.stealth.anon_battle", 1); - } + bool rule_anon_battle = config_get_int("rules.stealth.anon_battle", 1) != 0; for (s = b->sides; s != b->sides + b->nsides; ++s) { if (s->faction == f && s->group == g) { unsigned int s1flags = 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; } if (s1flags == s2flags) { @@ -3611,7 +3586,6 @@ battle *make_battle(region * r) unit *u; bfaction *bf; building * bld; - static int max_fac_no = 0; /* need this only once */ /* Alle Mann raus aus der Burg! */ 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) { faction *f = bf->faction; - max_fac_no = _max(max_fac_no, f->no); freset(f, FFL_MARK); } return b; @@ -3709,17 +3682,13 @@ static void battle_free(battle * b) { void free_battle(battle * b) { - int max_fac_no = 0; - if (bdebug) { fclose(bdebug); } while (b->factions) { bfaction *bf = b->factions; - faction *f = bf->faction; b->factions = bf->next; - max_fac_no = _max(max_fac_no, f->no); free(bf); } diff --git a/src/helpers.c b/src/helpers.c index a81a91679..21483fa50 100644 --- a/src/helpers.c +++ b/src/helpers.c @@ -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 int function_exists = 1; bool result = true; + lua_State *L = (lua_State *)global.vm_state; + const char *fname = "item_canuse"; - if (function_exists) { - lua_State *L = (lua_State *)global.vm_state; - const char *fname = "item_canuse"; + lua_getglobal(L, fname); + if (lua_isfunction(L, -1)) { + tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); + tolua_pushstring(L, itype->rtype->_name); - lua_getglobal(L, fname); - if (lua_isfunction(L, -1)) { - tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); - 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); + if (lua_pcall(L, 2, 1, 0) != 0) { + const char *error = lua_tostring(L, -1); + log_error("use(%s) calling '%s': %s.\n", unitname(u), fname, error); 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; }