forked from github/server
snotling
- gib bauern verboten - lernt nur bis T8 (+/-)
This commit is contained in:
parent
0a0474df52
commit
94b2f4f2de
10 changed files with 83 additions and 52 deletions
|
@ -546,7 +546,7 @@ givemen(int n, unit * u, unit * u2, const char * cmd)
|
|||
} else if (u == u2) {
|
||||
error = 10;
|
||||
#if RACE_ADJUSTMENTS
|
||||
} else if (u->race == new_race[RC_URUK]) {
|
||||
} else if (u->race == new_race[RC_URUK] || u->race == new_race[RC_SNOT]) {
|
||||
/* Uruks/Snotlings können nicht an Bauern übergeben werden. */
|
||||
error = 307;
|
||||
#endif
|
||||
|
|
|
@ -132,11 +132,6 @@ teach_unit(unit * teacher, unit * student, int teaching, skill_t sk, boolean rep
|
|||
{
|
||||
attrib * a;
|
||||
int n;
|
||||
#ifdef RANDOMIZED_LEARNING
|
||||
#ifdef SKILLMODIFIESLEARNING
|
||||
int smod, lmod, learning;
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* learning sind die Tage, die sie schon durch andere Lehrer zugute
|
||||
* geschrieben bekommen haben. Total darf dies nicht über 30 Tage pro Mann
|
||||
|
@ -150,23 +145,7 @@ teach_unit(unit * teacher, unit * student, int teaching, skill_t sk, boolean rep
|
|||
return 0;
|
||||
}
|
||||
|
||||
#ifdef RANDOMIZED_LEARNING
|
||||
#ifdef SKILLMODIFIESLEARNING
|
||||
smod = rc_skillmod(student->race, student->region, sk);
|
||||
lmod = 5 * smod;
|
||||
if(smod < 0) {
|
||||
lmod -= 5;
|
||||
} else if(smod > 0) {
|
||||
lmod += 5;
|
||||
}
|
||||
learning = max(0, 30 + lmod);
|
||||
n = student->number * dice(2, learning);
|
||||
#else
|
||||
n = student->number * dice(2,30);
|
||||
#endif
|
||||
#else
|
||||
n = student->number * 30;
|
||||
#endif
|
||||
a = a_find(student->attribs, &at_learning);
|
||||
if (a!=NULL) n -= a->data.i;
|
||||
|
||||
|
@ -193,7 +172,13 @@ teach_unit(unit * teacher, unit * student, int teaching, skill_t sk, boolean rep
|
|||
/* Jeder Schüler zusätzlich +10 Tage wenn in Uni. */
|
||||
a->data.i += (n / 30) * 10; /* learning erhöhen */
|
||||
/* Lehrer zusätzlich +1 Tag pro Schüler. */
|
||||
set_skill(teacher, sk, get_skill(teacher, sk) + (n / 30));
|
||||
#if SKILLPOINTS
|
||||
change_skill(teacher, sk, n / 30);
|
||||
#else
|
||||
if (learn_skill(teacher, sk, n / 30)) {
|
||||
change_skill(teacher, sk, teacher->number);
|
||||
}
|
||||
#endif
|
||||
} /* sonst nehmen sie nicht am Unterricht teil */
|
||||
}
|
||||
/* Teaching ist die Anzahl Leute, denen man noch was beibringen kann. Da
|
||||
|
@ -310,7 +295,7 @@ teach(region * r, unit * u)
|
|||
if (igetkeyword(student->thisorder, student->faction->locale) == K_STUDY) {
|
||||
/* Input ist nun von student->thisorder !! */
|
||||
sk = getskill(student->faction->locale);
|
||||
if (sk != NOSKILL && eff_skill(u, sk, r) > eff_skill(student, sk, r)) {
|
||||
if (sk != NOSKILL && eff_skill(u, sk, r) >= eff_skill(student, sk, r)+TEACHDIFFERENCE) {
|
||||
teaching -= teach_unit(u, student, teaching, sk, true);
|
||||
}
|
||||
}
|
||||
|
@ -445,11 +430,6 @@ learn(void)
|
|||
int i, l;
|
||||
int warrior_skill;
|
||||
int studycost;
|
||||
#ifdef RANDOMIZED_LEARNING
|
||||
#ifdef SKILLMODIFIESLEARNING
|
||||
int smod, lmod, learning;
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* lernen nach lehren */
|
||||
|
||||
|
@ -493,6 +473,13 @@ learn(void)
|
|||
cmistake(u, findorder(u, u->thisorder), 77, MSG_EVENT);
|
||||
continue;
|
||||
}
|
||||
/* snotlings können Talente nur bis T8 lernen */
|
||||
if (u->race == new_race[RC_SNOT]){
|
||||
if (get_level(u, i) >= 8){
|
||||
cmistake(u, findorder(u, u->thisorder), 308, MSG_EVENT);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
p = studycost = study_cost(u,i);
|
||||
a = a_find(u->attribs, &at_learning);
|
||||
|
@ -657,25 +644,15 @@ learn(void)
|
|||
}
|
||||
#endif
|
||||
|
||||
#ifdef RANDOMIZED_LEARNING
|
||||
#ifdef SKILLMODIFIESLEARNING
|
||||
smod = rc_skillmod(u->race, u->region, (skill_t)i);
|
||||
lmod = 5 * smod;
|
||||
if(smod < 0) {
|
||||
lmod -= 5;
|
||||
} else if(smod > 0) {
|
||||
lmod += 5;
|
||||
}
|
||||
learning = max(0, 30 + lmod);
|
||||
days = (int)((u->number * dice(2, learning) + a->data.i) * multi);
|
||||
#else
|
||||
days = (int)((u->number * dice(2, 30) + a->data.i) * multi);
|
||||
#endif
|
||||
#else
|
||||
days = (int)((u->number * 30 + a->data.i) * multi);
|
||||
#endif
|
||||
if (fval(u, FL_HUNGER)) days = days / 2;
|
||||
#if SKILLPOINTS
|
||||
change_skill(u, (skill_t)i, days);
|
||||
#else
|
||||
if (learn_skill(u, (skill_t)i, days)) {
|
||||
change_skill(u, (skill_t)i, u->number);
|
||||
}
|
||||
#endif
|
||||
if (a) {
|
||||
a_remove(&u->attribs, a);
|
||||
a = NULL;
|
||||
|
|
|
@ -2764,8 +2764,7 @@ wage(const region *r, const unit *u, boolean img)
|
|||
if (b) esize = buildingeffsize(b, img);
|
||||
|
||||
if (u) {
|
||||
/* TODO: Snotling! */
|
||||
wage = wagetable[esize][u->race == new_race[RC_ORC] || u->race == new_race[RC_URUK]];
|
||||
wage = wagetable[esize][u->race == new_race[RC_ORC] || u->race == new_race[RC_SNOT] || u->race == new_race[RC_URUK]];
|
||||
if (fspecial(u->faction, FS_URBAN)) {
|
||||
wage += wagetable[esize][3];
|
||||
}
|
||||
|
|
|
@ -617,6 +617,7 @@ enum {
|
|||
RC_CAT,
|
||||
RC_AQUARIAN,
|
||||
RC_URUK,
|
||||
RC_SNOT,
|
||||
|
||||
RC_UNDEAD, /* 12 - Untoter */
|
||||
RC_ILLUSION,
|
||||
|
|
|
@ -155,7 +155,7 @@ const struct race_syn race_synonyms[] = {
|
|||
|
||||
/* required for old_race, do not change order! */
|
||||
static const char * oldracenames[MAXRACES] = {
|
||||
"dwarf", "elf", "orc", "goblin", "human", "troll", "demon", "insect", "halfling", "cat", "aquarian", "uruk"
|
||||
"dwarf", "elf", "orc", "goblin", "human", "troll", "demon", "insect", "halfling", "cat", "aquarian", "uruk" "snotling"
|
||||
"undead", "illusion",
|
||||
"young dragon", "dragon", "wyrm", "ent", "catdragon", "dracoid",
|
||||
"special", "spell",
|
||||
|
|
|
@ -27,4 +27,4 @@
|
|||
#define SKILLPOINTS 1
|
||||
#define TEACHDIFFERENCE 1
|
||||
|
||||
#define PEASANT_ADJUSTMENT 0
|
||||
#define PEASANT_ADJUSTMENT 1
|
||||
|
|
|
@ -2529,7 +2529,7 @@ heal_all(void)
|
|||
#if PEASANT_ADJUSTMENT == 1
|
||||
|
||||
#define WEIGHT ((double)0.5)
|
||||
#define PLWEIGHT ((double)0.75)
|
||||
#define PLWEIGHT ((double)0.80)
|
||||
|
||||
static int
|
||||
peasant_adjustment(void)
|
||||
|
@ -2575,12 +2575,10 @@ peasant_adjustment(void)
|
|||
if(playerp * PLWEIGHT + rpeasants(r) > soll) {
|
||||
p_weg = (int)(min(((playerp * PLWEIGHT) + rpeasants(r)) - soll, rpeasants(r)));
|
||||
assert(p_weg >= 0);
|
||||
/*
|
||||
if (p_weg > 0){
|
||||
log_printf("BAUERN: war %d, minus %d, playerp %d\n",
|
||||
rpeasants(r), p_weg, playerp);
|
||||
}
|
||||
*/
|
||||
pool += p_weg;
|
||||
rsetpeasants(r, rpeasants(r) - p_weg);
|
||||
assert(rpeasants(r) >= 0);
|
||||
|
|
|
@ -4313,6 +4313,19 @@
|
|||
</locale>
|
||||
</message>
|
||||
|
||||
<message name="error308">
|
||||
<type>
|
||||
<arg name="unit" type="unit"></arg>
|
||||
<arg name="region" type="region"></arg>
|
||||
<arg name="command" type="string"></arg>
|
||||
</type>
|
||||
<locale name="de">
|
||||
<nr section="errors">
|
||||
<text>"$unit($unit) in $region($region): '$command' - Dieses Talent kann nicht höher gelernt werden."</text>
|
||||
</nr>
|
||||
</locale>
|
||||
</message>
|
||||
|
||||
<message name="drown_on_ship">
|
||||
<type>
|
||||
<arg name="unit" type="unit"></arg>
|
||||
|
|
|
@ -2781,6 +2781,19 @@
|
|||
</locale>
|
||||
</message>
|
||||
|
||||
<message name="error308">
|
||||
<type>
|
||||
<arg name="unit" type="unit"></arg>
|
||||
<arg name="region" type="region"></arg>
|
||||
<arg name="command" type="string"></arg>
|
||||
</type>
|
||||
<locale name="de">
|
||||
<nr section="errors">
|
||||
<text>"$unit($unit) in $region($region): '$command' - This skill couldn't learned higher."</text>
|
||||
</nr>
|
||||
</locale>
|
||||
</message>
|
||||
|
||||
<message name="mistake">
|
||||
<type>
|
||||
<arg name="unit" type="unit"></arg>
|
||||
|
|
|
@ -1118,6 +1118,36 @@
|
|||
<familiar race="rat"></familiar>
|
||||
<familiar race="imp"></familiar>
|
||||
</race>
|
||||
<race name="snotling" magres="-0.050000" maxaura="1.000000" regaura="1.000000" recruitcost="50" maintenance="10" weight="1000" speed="1.000000" hp="24" ac="0" damage="1d5" unarmedattack="-2" unarmeddefense="-2" attackmodifier="0" defensemodifier="0" playerrace walk giveitem giveperson giveunit getitem equipment>
|
||||
<ai splitsize="10000" attackrandom moverandom learn></ai>
|
||||
<skill name="sk_alchemy" modifier="1"></skill>
|
||||
<skill name="sk_mining" modifier="1"></skill>
|
||||
<skill name="sk_building" modifier="1"></skill>
|
||||
<skill name="sk_trade" modifier="-3"></skill>
|
||||
<skill name="sk_forestry" modifier="1"></skill>
|
||||
<skill name="sk_herbalism" modifier="-2"></skill>
|
||||
<skill name="sk_magic" modifier="-1"></skill>
|
||||
<skill name="sk_training" modifier="-1"></skill>
|
||||
<skill name="sk_armorer" modifier="1"></skill>
|
||||
<skill name="sk_shipcraft" modifier="-1"></skill>
|
||||
<skill name="sk_sailing" modifier="-1"></skill>
|
||||
<skill name="sk_espionage" modifier="-1"></skill>
|
||||
<skill name="sk_quarrying" modifier="1"></skill>
|
||||
<skill name="sk_tactics" modifier="1"></skill>
|
||||
<skill name="sk_entertainment" modifier="-2"></skill>
|
||||
<skill name="sk_weaponsmithing" modifier="2"></skill>
|
||||
<skill name="sk_cartmaking" modifier="-1"></skill>
|
||||
<skill name="sk_taxation" modifier="1"></skill>
|
||||
<skill name="sk_unarmed" modifier="-99"></skill>
|
||||
<attack type="1" damage="1d5"></attack>
|
||||
<familiar race="goblin" default></familiar>
|
||||
<familiar race="ghost"></familiar>
|
||||
<familiar race="imp"></familiar>
|
||||
<familiar race="rat"></familiar>
|
||||
<familiar race="wolf"></familiar>
|
||||
<familiar race="demon"></familiar>
|
||||
</race>
|
||||
|
||||
<race name="orc" magres="-0.050000" maxaura="1.000000" regaura="1.000000" recruitcost="50" maintenance="10" weight="1000" speed="1.000000" hp="24" ac="0" damage="1d5" unarmedattack="-2" unarmeddefense="-2" attackmodifier="0" defensemodifier="0" playerrace walk giveitem giveperson giveunit getitem equipment>
|
||||
<ai splitsize="10000" attackrandom moverandom learn></ai>
|
||||
<skill name="sk_alchemy" modifier="1"></skill>
|
||||
|
|
Loading…
Reference in a new issue