forked from github/server
Merge pull request #240 from badgerman/feature/bug-2069-familiar-races
bug 2069: familiar races
This commit is contained in:
commit
78857d8aa3
4 changed files with 21 additions and 14 deletions
|
@ -158,6 +158,7 @@ static race *rc_find_i(const char *name)
|
||||||
}
|
}
|
||||||
if (!rc && strcmp(name, "uruk") == 0) {
|
if (!rc && strcmp(name, "uruk") == 0) {
|
||||||
rc = rc_find_i("orc");
|
rc = rc_find_i("orc");
|
||||||
|
log_warning("a reference was made to the retired race '%s', returning '%s'.", name, rc->_name);
|
||||||
}
|
}
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,7 +146,6 @@ extern "C" {
|
||||||
int flags;
|
int flags;
|
||||||
int battle_flags;
|
int battle_flags;
|
||||||
int ec_flags;
|
int ec_flags;
|
||||||
race_t oldfamiliars[MAXMAGIETYP];
|
|
||||||
struct att attack[RACE_ATTACKS];
|
struct att attack[RACE_ATTACKS];
|
||||||
signed char bonus[MAXSKILLS];
|
signed char bonus[MAXSKILLS];
|
||||||
|
|
||||||
|
|
|
@ -1613,7 +1613,7 @@ static int parse_races(xmlDocPtr doc)
|
||||||
xmlNodePtr node = nodes->nodeTab[i];
|
xmlNodePtr node = nodes->nodeTab[i];
|
||||||
xmlNodePtr child;
|
xmlNodePtr child;
|
||||||
xmlChar *propValue;
|
xmlChar *propValue;
|
||||||
race *rc;
|
race *rc, *frc = 0;
|
||||||
xmlXPathObjectPtr result;
|
xmlXPathObjectPtr result;
|
||||||
int k, study_speed_base, attacks;
|
int k, study_speed_base, attacks;
|
||||||
struct att *attack;
|
struct att *attack;
|
||||||
|
@ -1810,21 +1810,27 @@ static int parse_races(xmlDocPtr doc)
|
||||||
/* reading eressea/races/race/familiar */
|
/* reading eressea/races/race/familiar */
|
||||||
xpath->node = node;
|
xpath->node = node;
|
||||||
result = xmlXPathEvalExpression(BAD_CAST "familiar", xpath);
|
result = xmlXPathEvalExpression(BAD_CAST "familiar", xpath);
|
||||||
for (k = 0; k != result->nodesetval->nodeNr; ++k) {
|
if (result->nodesetval->nodeNr > MAXMAGIETYP) {
|
||||||
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
log_error("race %s has %d potential familiars", rc->_name, result->nodesetval->nodeNr);
|
||||||
race *frc;
|
}
|
||||||
|
for (k = 0; k != MAXMAGIETYP; ++k) {
|
||||||
|
if (k < result->nodesetval->nodeNr) {
|
||||||
|
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
||||||
|
|
||||||
propValue = xmlGetProp(node, BAD_CAST "race");
|
propValue = xmlGetProp(node, BAD_CAST "race");
|
||||||
assert(propValue != NULL);
|
assert(propValue != NULL);
|
||||||
frc = rc_get_or_create((const char *)propValue);
|
frc = rc_get_or_create((const char *)propValue);
|
||||||
if (xml_bvalue(node, "default", false)) {
|
if (xml_bvalue(node, "default", false)) {
|
||||||
rc->familiars[k] = rc->familiars[0];
|
rc->familiars[k] = rc->familiars[0];
|
||||||
rc->familiars[0] = frc;
|
rc->familiars[0] = frc;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
rc->familiars[k] = frc;
|
||||||
|
}
|
||||||
|
xmlFree(propValue);
|
||||||
|
} else {
|
||||||
rc->familiars[k] = frc;
|
rc->familiars[k] = frc;
|
||||||
}
|
}
|
||||||
xmlFree(propValue);
|
|
||||||
}
|
}
|
||||||
xmlXPathFreeObject(result);
|
xmlXPathFreeObject(result);
|
||||||
|
|
||||||
|
|
|
@ -480,6 +480,7 @@ static const race *select_familiar(const race * magerace, magic_t magiegebiet)
|
||||||
assert(magerace->familiars[0]);
|
assert(magerace->familiars[0]);
|
||||||
if (rnd >= 70) {
|
if (rnd >= 70) {
|
||||||
retval = magerace->familiars[magiegebiet];
|
retval = magerace->familiars[magiegebiet];
|
||||||
|
assert(retval);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
retval = magerace->familiars[0];
|
retval = magerace->familiars[0];
|
||||||
|
|
Loading…
Reference in a new issue