wrap ai.scare and at_scare in rc_set_param

This commit is contained in:
Enno Rehling 2017-02-05 19:26:07 +01:00
parent f2ed2c892a
commit 67414f29eb
3 changed files with 13 additions and 7 deletions

View file

@ -311,6 +311,11 @@ void rc_set_param(struct race *rc, const char *key, const char *value) {
if (strcmp(key, "recruit_multi") == 0) { if (strcmp(key, "recruit_multi") == 0) {
rc->recruit_multi = atof(value); rc->recruit_multi = atof(value);
} }
else if (strcmp(key, "ai.scare") == 0) {
attrib *a = a_new(&at_scare);
a->data.i = atoi(value);
a_add(&rc->attribs, a);
}
else if (strcmp(key, "migrants.formula") == 0) { else if (strcmp(key, "migrants.formula") == 0) {
if (value[0] == '1') { if (value[0] == '1') {
rc->flags |= RCF_MIGRANTS; rc->flags |= RCF_MIGRANTS;

View file

@ -96,6 +96,8 @@ static void test_rc_set_param(CuTest *tc) {
rc_set_param(rc, "migrants.formula", "1"); rc_set_param(rc, "migrants.formula", "1");
CuAssertIntEquals(tc, RCF_MIGRANTS, rc->flags&RCF_MIGRANTS); CuAssertIntEquals(tc, RCF_MIGRANTS, rc->flags&RCF_MIGRANTS);
CuAssertIntEquals(tc, MIGRANTS_LOG10, rc_migrants_formula(rc)); CuAssertIntEquals(tc, MIGRANTS_LOG10, rc_migrants_formula(rc));
rc_set_param(rc, "ai.scare", "400");
CuAssertIntEquals(tc, 400, rc_scare(rc));
test_cleanup(); test_cleanup();
} }

View file

@ -1575,13 +1575,12 @@ static int parse_spells(xmlDocPtr doc)
static void parse_ai(race * rc, xmlNodePtr node) static void parse_ai(race * rc, xmlNodePtr node)
{ {
int n; xmlChar *propValue;
n = xml_ivalue(node, "scare", 0); propValue = xmlGetProp(node, BAD_CAST "scare");
if (n>0) { if (propValue) {
attrib *a = a_new(&at_scare); rc_set_param(rc, "ai.scare", (const char *)propValue);
a->data.i = n; xmlFree(propValue);
a_add(&rc->attribs, a);
} }
rc->splitsize = xml_ivalue(node, "splitsize", 0); rc->splitsize = xml_ivalue(node, "splitsize", 0);
rc->aggression = (float)xml_fvalue(node, "aggression", 0.04); rc->aggression = (float)xml_fvalue(node, "aggression", 0.04);