forked from github/server
some caster/mage changes issues (transfer aura is hard).
This commit is contained in:
parent
270646d9c3
commit
b6110c5b22
2 changed files with 22 additions and 17 deletions
|
@ -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)) {
|
||||||
|
|
35
src/spells.c
35
src/spells.c
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue