forked from github/server
old eressea executable has problems with non-existing lua spells.
This commit is contained in:
parent
ef2e1c8da9
commit
a1de5d5701
3 changed files with 103 additions and 75 deletions
|
@ -1403,50 +1403,50 @@ report_failed_spell(battle * b, unit * mage, const spell * sp)
|
||||||
void
|
void
|
||||||
do_combatmagic(battle *b, combatmagic_t was)
|
do_combatmagic(battle *b, combatmagic_t was)
|
||||||
{
|
{
|
||||||
void **fi;
|
void **fi;
|
||||||
region *r = b->region;
|
region *r = b->region;
|
||||||
castorder *co;
|
castorder *co;
|
||||||
castorder *cll[MAX_SPELLRANK];
|
castorder *cll[MAX_SPELLRANK];
|
||||||
int level;
|
int level;
|
||||||
int spellrank;
|
int spellrank;
|
||||||
int sl;
|
int sl;
|
||||||
|
|
||||||
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
||||||
cll[spellrank] = (castorder*)NULL;
|
cll[spellrank] = (castorder*)NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (fi = b->fighters.begin; fi != b->fighters.end; ++fi) {
|
for (fi = b->fighters.begin; fi != b->fighters.end; ++fi) {
|
||||||
fighter * fig = *fi;
|
fighter * fig = *fi;
|
||||||
unit * mage = fig->unit;
|
unit * mage = fig->unit;
|
||||||
|
|
||||||
if (fig->alive <= 0) continue; /* fighter kann im Kampf getötet worden sein */
|
if (fig->alive <= 0) continue; /* fighter kann im Kampf getötet worden sein */
|
||||||
|
|
||||||
level = eff_skill(mage, SK_MAGIC, r);
|
level = eff_skill(mage, SK_MAGIC, r);
|
||||||
if (level > 0) {
|
if (level > 0) {
|
||||||
double power;
|
double power;
|
||||||
const spell *sp;
|
const spell *sp;
|
||||||
const struct locale * lang = mage->faction->locale;
|
const struct locale * lang = mage->faction->locale;
|
||||||
char cmd[128];
|
char cmd[128];
|
||||||
order * ord;
|
order * ord;
|
||||||
|
|
||||||
switch(was) {
|
switch(was) {
|
||||||
case DO_PRECOMBATSPELL:
|
case DO_PRECOMBATSPELL:
|
||||||
sp = get_combatspell(mage, 0);
|
sp = get_combatspell(mage, 0);
|
||||||
sl = get_combatspelllevel(mage, 0);
|
sl = get_combatspelllevel(mage, 0);
|
||||||
break;
|
break;
|
||||||
case DO_POSTCOMBATSPELL:
|
case DO_POSTCOMBATSPELL:
|
||||||
sp = get_combatspell(mage, 2);
|
sp = get_combatspell(mage, 2);
|
||||||
sl = get_combatspelllevel(mage, 2);
|
sl = get_combatspelllevel(mage, 2);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* Fehler! */
|
/* Fehler! */
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (sp == NULL)
|
if (sp == NULL)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
snprintf(cmd, 128, "%s \"%s\"",
|
snprintf(cmd, 128, "%s \"%s\"",
|
||||||
LOC(lang, keywords[K_CAST]), spell_name(sp, lang));
|
LOC(lang, keywords[K_CAST]), spell_name(sp, lang));
|
||||||
|
|
||||||
ord = parse_order(cmd, lang);
|
ord = parse_order(cmd, lang);
|
||||||
if (cancast(mage, sp, 1, 1, ord) == false) {
|
if (cancast(mage, sp, 1, 1, ord) == false) {
|
||||||
|
@ -1454,44 +1454,47 @@ do_combatmagic(battle *b, combatmagic_t was)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
level = eff_spelllevel(mage, sp, level, 1);
|
level = eff_spelllevel(mage, sp, level, 1);
|
||||||
if (sl > 0) level = min(sl, level);
|
if (sl > 0) level = min(sl, level);
|
||||||
if (level < 0) {
|
if (level < 0) {
|
||||||
report_failed_spell(b, mage, sp);
|
report_failed_spell(b, mage, sp);
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
power = spellpower(r, mage, sp, level, ord);
|
power = spellpower(r, mage, sp, level, ord);
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
if (power <= 0) { /* Effekt von Antimagie */
|
if (power <= 0) { /* Effekt von Antimagie */
|
||||||
report_failed_spell(b, mage, sp);
|
report_failed_spell(b, mage, sp);
|
||||||
pay_spell(mage, sp, level, 1);
|
pay_spell(mage, sp, level, 1);
|
||||||
} else if (fumble(r, mage, sp, sp->level) == true) {
|
} else if (fumble(r, mage, sp, sp->level) == true) {
|
||||||
report_failed_spell(b, mage, sp);
|
report_failed_spell(b, mage, sp);
|
||||||
pay_spell(mage, sp, level, 1);
|
pay_spell(mage, sp, level, 1);
|
||||||
} else {
|
} else {
|
||||||
co = new_castorder(fig, 0, sp, r, level, power, 0, 0, 0);
|
co = new_castorder(fig, 0, sp, r, level, power, 0, 0, 0);
|
||||||
add_castorder(&cll[(int)(sp->rank)], co);
|
add_castorder(&cll[(int)(sp->rank)], co);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
||||||
for (co = cll[spellrank]; co; co = co->next) {
|
for (co = cll[spellrank]; co; co = co->next) {
|
||||||
fighter * fig = co->magician.fig;
|
fighter * fig = co->magician.fig;
|
||||||
const spell * sp = co->sp;
|
const spell * sp = co->sp;
|
||||||
int level = co->level;
|
int level = co->level;
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
|
if (sp->sp_function==NULL) {
|
||||||
level = ((cspell_f)sp->sp_function)(fig, level, power, sp);
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
if (level > 0) {
|
} else {
|
||||||
pay_spell(fig->unit, sp, level, 1);
|
level = ((cspell_f)sp->sp_function)(fig, level, power, sp);
|
||||||
}
|
if (level > 0) {
|
||||||
}
|
pay_spell(fig->unit, sp, level, 1);
|
||||||
}
|
}
|
||||||
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
}
|
||||||
free_castorders(cll[spellrank]);
|
}
|
||||||
}
|
}
|
||||||
|
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
||||||
|
free_castorders(cll[spellrank]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1561,10 +1564,14 @@ do_combatspell(troop at, int row)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
level = ((cspell_f)sp->sp_function)(fi, level, power, sp);
|
if (sp->sp_function==NULL) {
|
||||||
if (level > 0) {
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
pay_spell(mage, sp, level, 1);
|
} else {
|
||||||
at.fighter->action_counter++;
|
level = ((cspell_f)sp->sp_function)(fi, level, power, sp);
|
||||||
|
if (level > 0) {
|
||||||
|
pay_spell(mage, sp, level, 1);
|
||||||
|
at.fighter->action_counter++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1577,14 +1584,18 @@ do_combatspell(troop at, int row)
|
||||||
static void
|
static void
|
||||||
do_extra_spell(troop at, const att *a)
|
do_extra_spell(troop at, const att *a)
|
||||||
{
|
{
|
||||||
const spell *sp = a->data.sp;
|
const spell *sp = a->data.sp;
|
||||||
fighter *fi = at.fighter;
|
fighter *fi = at.fighter;
|
||||||
unit *au = fi->unit;
|
unit *au = fi->unit;
|
||||||
int power;
|
int power;
|
||||||
|
|
||||||
/* nur bei Monstern können mehrere 'Magier' in einer Einheit sein */
|
/* nur bei Monstern können mehrere 'Magier' in einer Einheit sein */
|
||||||
power = sp->level * au->number;
|
power = sp->level * au->number;
|
||||||
((cspell_f)sp->sp_function)(fi, sp->level, power, sp);
|
if (sp->sp_function==NULL) {
|
||||||
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
|
} else {
|
||||||
|
((cspell_f)sp->sp_function)(fi, sp->level, power, sp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
|
|
@ -202,7 +202,6 @@ static int
|
||||||
read_mage(attrib * a, FILE * F)
|
read_mage(attrib * a, FILE * F)
|
||||||
{
|
{
|
||||||
int i, mtype;
|
int i, mtype;
|
||||||
boolean update = false;
|
|
||||||
sc_mage * mage = (sc_mage*)a->data.v;
|
sc_mage * mage = (sc_mage*)a->data.v;
|
||||||
char spname[64];
|
char spname[64];
|
||||||
|
|
||||||
|
@ -1355,7 +1354,11 @@ do_fumble(castorder *co)
|
||||||
case 5:
|
case 5:
|
||||||
case 6:
|
case 6:
|
||||||
/* Spruch gelingt, aber alle Magiepunkte weg */
|
/* Spruch gelingt, aber alle Magiepunkte weg */
|
||||||
((nspell_f)sp->sp_function)(co);
|
if (sp->sp_function==NULL) {
|
||||||
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
|
} else {
|
||||||
|
((nspell_f)sp->sp_function)(co);
|
||||||
|
}
|
||||||
set_spellpoints(u, 0);
|
set_spellpoints(u, 0);
|
||||||
ADDMSG(&u->faction->msgs, msg_message("patzer4", "unit region spell",
|
ADDMSG(&u->faction->msgs, msg_message("patzer4", "unit region spell",
|
||||||
u, r, sp));
|
u, r, sp));
|
||||||
|
@ -1366,7 +1369,11 @@ do_fumble(castorder *co)
|
||||||
case 9:
|
case 9:
|
||||||
default:
|
default:
|
||||||
/* Spruch gelingt, alle nachfolgenden Sprüche werden 2^4 so teuer */
|
/* Spruch gelingt, alle nachfolgenden Sprüche werden 2^4 so teuer */
|
||||||
((nspell_f)sp->sp_function)(co);
|
if (sp->sp_function==NULL) {
|
||||||
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
|
} else {
|
||||||
|
((nspell_f)sp->sp_function)(co);
|
||||||
|
}
|
||||||
ADDMSG(&u->faction->msgs, msg_message("patzer5", "unit region spell",
|
ADDMSG(&u->faction->msgs, msg_message("patzer5", "unit region spell",
|
||||||
u, r, sp));
|
u, r, sp));
|
||||||
countspells(u, 3);
|
countspells(u, 3);
|
||||||
|
@ -2758,7 +2765,12 @@ magic(void)
|
||||||
/* zuerst bezahlen, dann evt in do_fumble alle Aura verlieren */
|
/* zuerst bezahlen, dann evt in do_fumble alle Aura verlieren */
|
||||||
fumbled = true;
|
fumbled = true;
|
||||||
} else if (co->force>0) {
|
} else if (co->force>0) {
|
||||||
co->level = ((nspell_f)sp->sp_function)(co);
|
if (sp->sp_function==NULL) {
|
||||||
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
|
co->level = 0;
|
||||||
|
} else {
|
||||||
|
co->level = ((nspell_f)sp->sp_function)(co);
|
||||||
|
}
|
||||||
if (co->level <= 0) {
|
if (co->level <= 0) {
|
||||||
/* Kosten nur für real benötige Stufe berechnen */
|
/* Kosten nur für real benötige Stufe berechnen */
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -197,7 +197,12 @@ unit_castspell(unit& u, const char * name)
|
||||||
co->par = NULL;
|
co->par = NULL;
|
||||||
co->rt = u.region;
|
co->rt = u.region;
|
||||||
co->sp = sp;
|
co->sp = sp;
|
||||||
sp->sp_function(co);
|
if (sp->sp_function==NULL) {
|
||||||
|
log_error(("spell '%s' has no function.\n", sp->sname));
|
||||||
|
co->level = 0;
|
||||||
|
} else {
|
||||||
|
sp->sp_function(co);
|
||||||
|
}
|
||||||
free(co);
|
free(co);
|
||||||
}
|
}
|
||||||
slist=slist->next;
|
slist=slist->next;
|
||||||
|
|
Loading…
Reference in a new issue