forked from github/server
race special attack spells use name instead of id.
This commit is contained in:
parent
594683d077
commit
2e897bfbf7
3 changed files with 22 additions and 18 deletions
|
@ -1587,12 +1587,11 @@ 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)
|
||||||
{
|
{
|
||||||
spell *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;
|
||||||
|
|
||||||
sp = find_spellbyid((spellid_t)(a->data.iparam));
|
|
||||||
/* 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);
|
((cspell_f)sp->sp_function)(fi, sp->level, power, sp);
|
||||||
|
|
|
@ -45,7 +45,7 @@ typedef struct att {
|
||||||
int type;
|
int type;
|
||||||
union {
|
union {
|
||||||
const char * dice;
|
const char * dice;
|
||||||
int iparam;
|
const spell * sp;
|
||||||
} data;
|
} data;
|
||||||
int flags;
|
int flags;
|
||||||
} att;
|
} att;
|
||||||
|
|
|
@ -64,6 +64,24 @@ xml_readtext(xmlNodePtr node, struct locale ** lang, xmlChar **text)
|
||||||
*text = xmlNodeListGetString(node->doc, node->children, 1);
|
*text = xmlNodeListGetString(node->doc, node->children, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const spell *
|
||||||
|
xml_spell(xmlNode * node, const char * name)
|
||||||
|
{
|
||||||
|
const spell * sp = NULL;
|
||||||
|
xmlChar * property = xmlGetProp(node, BAD_CAST name);
|
||||||
|
if (property!=NULL) {
|
||||||
|
int i = atoi((const char *)property);
|
||||||
|
if (i>0) {
|
||||||
|
sp = find_spellbyid((spellid_t)i);
|
||||||
|
}
|
||||||
|
if (sp==NULL) {
|
||||||
|
sp = find_spell(M_NONE, (const char *)property);
|
||||||
|
}
|
||||||
|
assert(sp);
|
||||||
|
xmlFree(property);
|
||||||
|
}
|
||||||
|
return sp;
|
||||||
|
}
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
xml_to_locale(const xmlChar * xmlStr)
|
xml_to_locale(const xmlChar * xmlStr)
|
||||||
|
@ -1325,20 +1343,7 @@ parse_races(xmlDocPtr doc)
|
||||||
assert(rc->precombatspell==NULL || !"precombatspell is already initialized");
|
assert(rc->precombatspell==NULL || !"precombatspell is already initialized");
|
||||||
for (k=0;k!=result->nodesetval->nodeNr;++k) {
|
for (k=0;k!=result->nodesetval->nodeNr;++k) {
|
||||||
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
||||||
xmlChar * property = xmlGetProp(node, BAD_CAST "spell");
|
rc->precombatspell = xml_spell(node, "spell");
|
||||||
if (property!=NULL) {
|
|
||||||
const spell * sp = NULL;
|
|
||||||
int i = atoi((const char *)property);
|
|
||||||
if (i>0) {
|
|
||||||
sp = find_spellbyid((spellid_t)i);
|
|
||||||
}
|
|
||||||
if (sp==NULL) {
|
|
||||||
sp = find_spell(M_NONE, (const char *)property);
|
|
||||||
}
|
|
||||||
assert(sp);
|
|
||||||
rc->precombatspell = sp;
|
|
||||||
xmlFree(property);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
xmlXPathFreeObject(result);
|
xmlXPathFreeObject(result);
|
||||||
|
|
||||||
|
@ -1354,7 +1359,7 @@ parse_races(xmlDocPtr doc)
|
||||||
a->data.dice = strdup((const char*)property);
|
a->data.dice = strdup((const char*)property);
|
||||||
xmlFree(property);
|
xmlFree(property);
|
||||||
} else {
|
} else {
|
||||||
a->data.iparam = xml_ivalue(node, "spell", 0);
|
a->data.sp = xml_spell(node, "spell");
|
||||||
}
|
}
|
||||||
a->type = xml_ivalue(node, "type", 0);
|
a->type = xml_ivalue(node, "type", 0);
|
||||||
a->flags = xml_ivalue(node, "flags", 0);
|
a->flags = xml_ivalue(node, "flags", 0);
|
||||||
|
|
Loading…
Reference in a new issue