some caster/mage changes issues (transfer aura is hard).

This commit is contained in:
Enno Rehling 2018-11-17 22:28:55 +01:00
parent 270646d9c3
commit b6110c5b22
2 changed files with 22 additions and 17 deletions

View file

@ -1262,8 +1262,8 @@ bool fumble(region * r, unit * u, const spell * sp, int cast_grade)
} }
/* CHAOSPATZERCHANCE 10 : +10% Chance zu Patzern */ /* CHAOSPATZERCHANCE 10 : +10% Chance zu Patzern */
mage = get_mage_depr(u); mage = get_mage(u);
if (mage->magietyp == M_DRAIG) { if (mage && mage->magietyp == M_DRAIG) {
fumble_chance += CHAOSPATZERCHANCE; fumble_chance += CHAOSPATZERCHANCE;
} }
if (is_cursed(u->attribs, &ct_magicboost)) { if (is_cursed(u->attribs, &ct_magicboost)) {

View file

@ -706,11 +706,13 @@ static int sp_transferaura(castorder * co)
{ {
int aura, gain, multi = 2; int aura, gain, multi = 2;
unit *caster = co_get_caster(co); unit *caster = co_get_caster(co);
unit *mage = co_get_magician(co);
int cast_level = co->level; int cast_level = co->level;
spellparameter *pa = co->par; spellparameter *pa = co->par;
unit *u; unit *u;
sc_mage *scm_dst, *scm_src = get_mage(caster); sc_mage *scm_dst, *scm_src = get_mage(mage);
assert(scm_src);
/* wenn kein Ziel gefunden, Zauber abbrechen */ /* wenn kein Ziel gefunden, Zauber abbrechen */
if (pa->param[0]->flag == TARGET_NOTFOUND) if (pa->param[0]->flag == TARGET_NOTFOUND)
return 0; return 0;
@ -5384,6 +5386,7 @@ int sp_fetchastral(castorder * co)
ro = u->region; ro = u->region;
} }
assert(ro);
cast_level = co->level; /* at least one unit could have been teleported */ cast_level = co->level; /* at least one unit could have been teleported */
if (is_cursed(ro->attribs, &ct_astralblock)) { if (is_cursed(ro->attribs, &ct_astralblock)) {
ADDMSG(&mage->faction->msgs, msg_feedback(mage, co->order, ADDMSG(&mage->faction->msgs, msg_feedback(mage, co->order,
@ -5658,8 +5661,9 @@ int sp_disruptastral(castorder * co)
int c = rng_int() % inhab_regions; int c = rng_int() % inhab_regions;
/* Zufaellige Zielregion suchen */ /* Zufaellige Zielregion suchen */
while (c-- != 0) while (c-- != 0) {
trl2 = trl2->next; trl2 = trl2->next;
}
tr = trl2->data; tr = trl2->data;
if (!is_magic_resistant(mage, u, 0) && can_survive(u, tr)) { if (!is_magic_resistant(mage, u, 0) && can_survive(u, tr)) {
@ -5766,7 +5770,8 @@ int sp_permtransfer(castorder * co)
{ {
int aura, i; int aura, i;
unit *tu; unit *tu;
unit *mage = co_get_caster(co); unit *caster = co_get_caster(co);
unit *mage = co_get_magician(co);
int cast_level = co->level; int cast_level = co->level;
spellparameter *pa = co->par; spellparameter *pa = co->par;
const spell *sp = co->sp; const spell *sp = co->sp;
@ -5787,7 +5792,7 @@ int sp_permtransfer(castorder * co)
if (!is_mage(tu)) { if (!is_mage(tu)) {
/* sprintf(buf, "%s in %s: 'ZAUBER %s': Einheit ist kein Magier." /* sprintf(buf, "%s in %s: 'ZAUBER %s': Einheit ist kein Magier."
, unitname(mage), regionname(mage->region, mage->faction),sa->strings[0]); */ , unitname(mage), regionname(mage->region, mage->faction),sa->strings[0]); */
cmistake(mage, co->order, 214, MSG_MAGIC); cmistake(caster, co->order, 214, MSG_MAGIC);
return 0; return 0;
} }
@ -5804,10 +5809,9 @@ int sp_permtransfer(castorder * co)
change_maxspellpoints(tu, aura / 3); change_maxspellpoints(tu, aura / 3);
} }
msg = msg = msg_message("sp_permtransfer_effect", "mage target amount", mage, tu, aura);
msg_message("sp_permtransfer_effect", "mage target amount", mage, tu, aura); add_message(&caster->faction->msgs, msg);
add_message(&mage->faction->msgs, msg); if (tu->faction != caster->faction) {
if (tu->faction != mage->faction) {
add_message(&tu->faction->msgs, msg); add_message(&tu->faction->msgs, msg);
} }
msg_release(msg); msg_release(msg);
@ -5908,7 +5912,8 @@ int sp_stealaura(castorder * co)
{ {
int taura; int taura;
unit *u; unit *u;
unit *mage = co_get_caster(co); unit *mage = co_get_magician(co);
unit *caster = co_get_caster(co);
int cast_level = co->level; int cast_level = co->level;
double power = co->force; double power = co->force;
spellparameter *pa = co->par; spellparameter *pa = co->par;
@ -5921,8 +5926,8 @@ int sp_stealaura(castorder * co)
u = pa->param[0]->data.u; u = pa->param[0]->data.u;
if (!get_mage_depr(u)) { if (!get_mage_depr(u)) {
ADDMSG(&mage->faction->msgs, msg_message("stealaura_fail", "unit target", ADDMSG(&caster->faction->msgs, msg_message("stealaura_fail", "unit target",
mage, u)); caster, u));
ADDMSG(&u->faction->msgs, msg_message("stealaura_fail_detect", "unit", u)); ADDMSG(&u->faction->msgs, msg_message("stealaura_fail_detect", "unit", u));
return 0; return 0;
} }
@ -5934,16 +5939,16 @@ int sp_stealaura(castorder * co)
get_mage_depr(mage)->spellpoints += taura; get_mage_depr(mage)->spellpoints += taura;
/* sprintf(buf, "%s entzieht %s %d Aura.", unitname(mage), unitname(u), /* sprintf(buf, "%s entzieht %s %d Aura.", unitname(mage), unitname(u),
taura); */ taura); */
ADDMSG(&mage->faction->msgs, msg_message("stealaura_success", ADDMSG(&caster->faction->msgs, msg_message("stealaura_success",
"mage target aura", mage, u, taura)); "mage target aura", caster, u, taura));
/* sprintf(buf, "%s fuehlt seine magischen Kraefte schwinden und verliert %d " /* sprintf(buf, "%s fuehlt seine magischen Kraefte schwinden und verliert %d "
"Aura.", unitname(u), taura); */ "Aura.", unitname(u), taura); */
ADDMSG(&u->faction->msgs, msg_message("stealaura_detect", "unit aura", u, ADDMSG(&u->faction->msgs, msg_message("stealaura_detect", "unit aura", u,
taura)); taura));
} }
else { else {
ADDMSG(&mage->faction->msgs, msg_message("stealaura_fail", "unit target", ADDMSG(&caster->faction->msgs, msg_message("stealaura_fail", "unit target",
mage, u)); caster, u));
ADDMSG(&u->faction->msgs, msg_message("stealaura_fail_detect", "unit", u)); ADDMSG(&u->faction->msgs, msg_message("stealaura_fail_detect", "unit", u));
} }
return cast_level; return cast_level;