forked from github/server
tighten up some lookups.
This commit is contained in:
parent
fbdf845cb9
commit
8f1a1fc8c3
1 changed files with 54 additions and 42 deletions
96
src/magic.c
96
src/magic.c
|
@ -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;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue