tighten up some lookups.

This commit is contained in:
Enno Rehling 2016-10-03 20:27:36 +02:00
parent fbdf845cb9
commit 8f1a1fc8c3

View file

@ -1031,9 +1031,8 @@ cancast(unit * u, const spell * sp, int level, int range, struct order * ord)
double double
spellpower(region * r, unit * u, const spell * sp, int cast_level, struct order *ord) spellpower(region * r, unit * u, const spell * sp, int cast_level, struct order *ord)
{ {
curse *c;
double force = cast_level; double force = cast_level;
int elf_power; static int elf_power, config;
const struct resource_type *rtype; const struct resource_type *rtype;
if (sp == NULL) { if (sp == NULL) {
@ -1046,54 +1045,65 @@ spellpower(region * r, unit * u, const spell * sp, int cast_level, struct order
if (btype && btype->flags & BTF_MAGIC) ++force; if (btype && btype->flags & BTF_MAGIC) ++force;
} }
elf_power = config_get_int("rules.magic.elfpower", 0); if (config_changed(&config)) {
elf_power = config_get_int("rules.magic.elfpower", 0);
if (elf_power && u_race(u) == get_race(RC_ELF) && r_isforest(r)) { }
++force; if (elf_power) {
static int rc_cache;
static const race *rc_elf;
if (rc_changed(&rc_cache)) {
rc_elf = get_race(RC_ELF);
}
if (u_race(u) == rc_elf && r_isforest(r)) {
++force;
}
} }
rtype = rt_find("rop"); rtype = rt_find("rop");
if (rtype && i_get(u->items, rtype->itype) > 0) { if (rtype && i_get(u->items, rtype->itype) > 0) {
++force; ++force;
} }
/* Antimagie in der Zielregion */ if (r->attribs) {
c = get_curse(r->attribs, ct_find("antimagiczone")); curse *c;
if (curse_active(c)) {
unit *mage = c->magician; /* Antimagie in der Zielregion */
force -= curse_geteffect(c); c = get_curse(r->attribs, ct_find("antimagiczone"));
curse_changevigour(&r->attribs, c, -cast_level); if (curse_active(c)) {
cmistake(u, ord, 185, MSG_MAGIC); unit *mage = c->magician;
if (mage != NULL && mage->faction != NULL) { force -= curse_geteffect(c);
if (force > 0) { curse_changevigour(&r->attribs, c, -cast_level);
ADDMSG(&mage->faction->msgs, msg_message("reduce_spell", cmistake(u, ord, 185, MSG_MAGIC);
"self mage region", mage, u, r)); if (mage != NULL && mage->faction != NULL) {
if (force > 0) {
ADDMSG(&mage->faction->msgs, msg_message("reduce_spell",
"self mage region", mage, u, r));
}
else {
ADDMSG(&mage->faction->msgs, msg_message("block_spell",
"self mage region", mage, u, r));
}
} }
else { }
ADDMSG(&mage->faction->msgs, msg_message("block_spell",
"self mage region", mage, u, r)); /* Patzerfluch-Effekt: */
c = get_curse(r->attribs, ct_find("fumble"));
if (curse_active(c)) {
unit *mage = c->magician;
force -= curse_geteffect(c);
curse_changevigour(&u->attribs, c, -1);
cmistake(u, ord, 185, MSG_MAGIC);
if (mage != NULL && mage->faction != NULL) {
if (force > 0) {
ADDMSG(&mage->faction->msgs, msg_message("reduce_spell",
"self mage region", mage, u, r));
}
else {
ADDMSG(&mage->faction->msgs, msg_message("block_spell",
"self mage region", mage, u, r));
}
} }
} }
} }
/* Patzerfluch-Effekt: */
c = get_curse(r->attribs, ct_find("fumble"));
if (curse_active(c)) {
unit *mage = c->magician;
force -= curse_geteffect(c);
curse_changevigour(&u->attribs, c, -1);
cmistake(u, ord, 185, MSG_MAGIC);
if (mage != NULL && mage->faction != NULL) {
if (force > 0) {
ADDMSG(&mage->faction->msgs, msg_message("reduce_spell",
"self mage region", mage, u, r));
}
else {
ADDMSG(&mage->faction->msgs, msg_message("block_spell",
"self mage region", mage, u, r));
}
}
}
return _max(force, 0); return _max(force, 0);
} }
@ -2784,6 +2794,8 @@ void magic(void)
int rank; int rank;
castorder *co; castorder *co;
spellrank spellranks[MAX_SPELLRANK]; spellrank spellranks[MAX_SPELLRANK];
const race *rc_spell = get_race(RC_SPELL);
const race *rc_insect = get_race(RC_INSECT);
memset(spellranks, 0, sizeof(spellranks)); memset(spellranks, 0, sizeof(spellranks));
@ -2792,10 +2804,10 @@ void magic(void)
for (u = r->units; u; u = u->next) { for (u = r->units; u; u = u->next) {
order *ord; order *ord;
if (u->number <= 0 || u_race(u) == get_race(RC_SPELL)) if (u->number <= 0 || u_race(u) == rc_spell)
continue; continue;
if (u_race(u) == get_race(RC_INSECT) && r_insectstalled(r) && if (u_race(u) == rc_insect && r_insectstalled(r) &&
!is_cursed(u->attribs, C_KAELTESCHUTZ, 0)) !is_cursed(u->attribs, C_KAELTESCHUTZ, 0))
continue; continue;