use STUDYDAYS consequently

This commit is contained in:
Steffen Mecke 2017-07-28 09:55:39 +02:00
parent 4fe72b5d28
commit 1edfb7ae8e
4 changed files with 17 additions and 14 deletions

View file

@ -958,6 +958,7 @@ void drain_exp(struct unit *u, int n)
skill *sv = unit_skill(u, sk);
if (sv) {
while (n > 0) {
/* FIXME STUDYDAYS */
if (n >= 30 * u->number) {
reduce_skill(u, sv, 1);
n -= 30;

View file

@ -153,6 +153,7 @@ int rc_skillmod(const struct race *rc, const region * r, skill_t sk)
int level_days(int level)
{
/* FIXME STUDYDAYS * ((level + 1) * level / 2); */
return 30 * ((level + 1) * level / 2);
}

View file

@ -176,13 +176,13 @@ const attrib_type at_learning = {
static int study_days(unit * student, skill_t sk)
{
int speed = 30;
int speed = STUDYDAYS;
if (u_race(student)->study_speed) {
speed += u_race(student)->study_speed[sk];
if (speed < 30) {
if (speed < STUDYDAYS) {
skill *sv = unit_skill(student, sk);
if (sv == 0) {
speed = 30;
speed = STUDYDAYS;
}
}
}
@ -209,7 +209,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
return 0;
}
n = 30 * student->number;
n = STUDYDAYS * student->number;
a = a_find(student->attribs, &at_learning);
if (a != NULL) {
teach = (teaching_info *)a->data.v;
@ -231,7 +231,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
* Student auch in unterschiedlichen Gebaeuden stehen duerfen */
if (academy_can_teach(teacher, student, sk)) {
/* Jeder Schueler zusaetzlich +10 Tage wenn in Uni. */
teach->value += (n / 30) * 10; /* learning erhoehen */
teach->value += (n / STUDYDAYS) * EXPERIENCEDAYS; /* learning erhoehen */
/* Lehrer zusaetzlich +1 Tag pro Schueler. */
if (academy) {
*academy += n;
@ -268,7 +268,7 @@ teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk,
* die Talentaenderung (enno).
*/
nteaching = MAX(0, nteaching - student->number * 30);
nteaching = MAX(0, nteaching - student->number * STUDYDAYS);
}
return n;
@ -301,14 +301,14 @@ int teach_cmd(unit * u, struct order *ord)
return 0;
}
teaching = u->number * 30 * TEACHNUMBER;
teaching = u->number * STUDYDAYS * TEACHNUMBER;
if ((i = get_effect(u, oldpotiontype[P_FOOL])) > 0) { /* Trank "Dumpfbackenbrot" */
i = MIN(i, u->number * TEACHNUMBER);
/* Trank wirkt pro Schueler, nicht pro Lehrer */
teaching -= i * 30;
teaching -= i * STUDYDAYS;
change_effect(u, oldpotiontype[P_FOOL], -i);
j = teaching / 30;
j = teaching / STUDYDAYS;
ADDMSG(&u->faction->msgs, msg_message("teachdumb", "teacher amount", u, j));
}
if (teaching == 0)
@ -747,12 +747,12 @@ int study_cmd(unit * u, order * ord)
if (get_effect(u, oldpotiontype[P_WISE])) {
l = MIN(u->number, get_effect(u, oldpotiontype[P_WISE]));
teach->value += l * 10;
teach->value += l * EXPERIENCEDAYS;
change_effect(u, oldpotiontype[P_WISE], -l);
}
if (get_effect(u, oldpotiontype[P_FOOL])) {
l = MIN(u->number, get_effect(u, oldpotiontype[P_FOOL]));
teach->value -= l * 30;
teach->value -= l * STUDYDAYS;
change_effect(u, oldpotiontype[P_FOOL], -l);
}
@ -761,11 +761,11 @@ int study_cmd(unit * u, order * ord)
/* p ist Kosten ohne Uni, studycost mit; wenn
* p!=studycost, ist die Einheit zwangsweise
* in einer Uni */
teach->value += u->number * 10;
teach->value += u->number * EXPERIENCEDAYS;
}
if (is_cursed(r->attribs, C_BADLEARN, 0)) {
teach->value -= u->number * 10;
teach->value -= u->number * EXPERIENCEDAYS;
}
multi *= study_speedup(u, sk, speed_rule);
@ -828,7 +828,7 @@ int study_cmd(unit * u, order * ord)
static int produceexp_days(void) {
static int config, rule;
if (config_changed(&config)) {
rule = config_get_int("study.produceexp", 10);
rule = config_get_int("study.produceexp", EXPERIENCEDAYS);
}
return rule;
}

View file

@ -39,6 +39,7 @@ extern "C" {
typedef void(*learn_fun)(struct unit *u, skill_t sk, int days);
#define STUDYDAYS 30
#define EXPERIENCEDAYS 10
void learn_skill(struct unit *u, skill_t sk, int days);
void produceexp(struct unit *u, skill_t sk, int n);