forked from github/server
New feature: learning speed
This commit is contained in:
parent
7b24248ac2
commit
d871101994
6 changed files with 27 additions and 25 deletions
|
@ -151,6 +151,14 @@ const attrib_type at_learning = {
|
||||||
ATF_UNIQUE
|
ATF_UNIQUE
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int
|
||||||
|
study_days(unit * student, skill_t sk)
|
||||||
|
{
|
||||||
|
int speed = 30 + student->race->study_speed_base;
|
||||||
|
if (student->race->study_speed) speed += student->race->study_speed[sk];
|
||||||
|
return student->number * speed;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
|
teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
|
||||||
boolean report, int * academy)
|
boolean report, int * academy)
|
||||||
|
@ -171,7 +179,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
n = student->number * 30;
|
n = study_days(student, sk);
|
||||||
a = a_find(student->attribs, &at_learning);
|
a = a_find(student->attribs, &at_learning);
|
||||||
if (a!=NULL) {
|
if (a!=NULL) {
|
||||||
teach = (teaching_info*)a->data.v;
|
teach = (teaching_info*)a->data.v;
|
||||||
|
|
|
@ -207,21 +207,6 @@ HelpMask(void)
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** specifies modes that are restricted to members of the same alliance.
|
|
||||||
* if this returns a non-zero value, then you cannot give those modes to a
|
|
||||||
* faction unless they are in the same alliance.
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
HelpMask(void)
|
|
||||||
{
|
|
||||||
static int help_mask = 0;
|
|
||||||
|
|
||||||
if (help_mask==0) {
|
|
||||||
help_mask = get_param_int(global.parameters, "rules.help.mask", HELP_ALL);
|
|
||||||
}
|
|
||||||
return help_mask;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
int
|
||||||
AllianceRestricted(void)
|
AllianceRestricted(void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -125,6 +125,8 @@ rc_new(const char * zName)
|
||||||
|
|
||||||
rc->attack[0].type = AT_COMBATSPELL;
|
rc->attack[0].type = AT_COMBATSPELL;
|
||||||
rc->attack[1].type = AT_NONE;
|
rc->attack[1].type = AT_NONE;
|
||||||
|
rc->speed = 0;
|
||||||
|
rc->study_speed_base = 0;
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -75,6 +75,8 @@ typedef struct race {
|
||||||
const spell * precombatspell;
|
const spell * precombatspell;
|
||||||
struct att attack[10];
|
struct att attack[10];
|
||||||
char bonus[MAXSKILLS];
|
char bonus[MAXSKILLS];
|
||||||
|
char study_speed_base;
|
||||||
|
signed char * study_speed; /* study-speed-bonus in points/turn (0=30 Tage) */
|
||||||
boolean __remove_me_nonplayer;
|
boolean __remove_me_nonplayer;
|
||||||
int flags;
|
int flags;
|
||||||
int battle_flags;
|
int battle_flags;
|
||||||
|
|
|
@ -1565,6 +1565,7 @@ parse_races(xmlDocPtr doc)
|
||||||
rc->speed = (float)xml_fvalue(node, "speed", 1.0F);
|
rc->speed = (float)xml_fvalue(node, "speed", 1.0F);
|
||||||
rc->hitpoints = xml_ivalue(node, "hp", 0);
|
rc->hitpoints = xml_ivalue(node, "hp", 0);
|
||||||
rc->armor = (char)xml_ivalue(node, "ac", 0);
|
rc->armor = (char)xml_ivalue(node, "ac", 0);
|
||||||
|
rc->study_speed_base = xml_ivalue(node, "studyspeed", 0);
|
||||||
|
|
||||||
rc->at_default = (char)xml_ivalue(node, "unarmedattack", -2);
|
rc->at_default = (char)xml_ivalue(node, "unarmedattack", -2);
|
||||||
rc->df_default = (char)xml_ivalue(node, "unarmeddefense", -2);
|
rc->df_default = (char)xml_ivalue(node, "unarmeddefense", -2);
|
||||||
|
@ -1626,18 +1627,22 @@ parse_races(xmlDocPtr doc)
|
||||||
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];
|
||||||
int mod = xml_ivalue(node, "modifier", 0);
|
int mod = xml_ivalue(node, "modifier", 0);
|
||||||
|
int speed = xml_ivalue(node, "speed", 0);
|
||||||
|
skill_t sk;
|
||||||
|
|
||||||
propValue = xmlGetProp(node, BAD_CAST "name");
|
propValue = xmlGetProp(node, BAD_CAST "name");
|
||||||
assert(propValue!=NULL);
|
assert(propValue!=NULL);
|
||||||
if (mod!=0) {
|
sk = sk_find((const char*)propValue);
|
||||||
skill_t sk = sk_find((const char*)propValue);
|
|
||||||
if (sk!=NOSKILL) {
|
if (sk!=NOSKILL) {
|
||||||
rc->bonus[sk] = (char)mod;
|
rc->bonus[sk] = (char)mod;
|
||||||
|
if (speed) {
|
||||||
|
if (!rc->study_speed) rc->study_speed = calloc(1, MAXSKILLS);
|
||||||
|
rc->study_speed[sk] = speed;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
log_error(("unknown skill '%s' in race '%s'\n",
|
log_error(("unknown skill '%s' in race '%s'\n",
|
||||||
(const char*)propValue, rc->_name[0]));
|
(const char*)propValue, rc->_name[0]));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
}
|
}
|
||||||
xmlXPathFreeObject(result);
|
xmlXPathFreeObject(result);
|
||||||
|
|
Loading…
Reference in a new issue