forked from github/server
eliminate more static cached configuration values
This commit is contained in:
parent
17068af332
commit
7bbf11c6b6
3 changed files with 28 additions and 66 deletions
|
@ -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) {
|
||||||
|
|
47
src/battle.c
47
src/battle.c
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue