- Neue Orkrasse RC_URUK

Muss getestet werden. Langsameres Lernen nicht drin.
This commit is contained in:
Christian Schlittchen 2002-02-10 16:04:39 +00:00
parent f1fc6dce4f
commit 0a0474df52
12 changed files with 118 additions and 29 deletions

View file

@ -245,7 +245,7 @@ expandrecruit(region * r, request * recruitorders)
{ {
/* Rekrutierung */ /* Rekrutierung */
int i, n, p = rpeasants(r), h = rhorses(r); int i, n, p = rpeasants(r), h = rhorses(r), uruks = 0;
int rfrac = p / RECRUITFRACTION; int rfrac = p / RECRUITFRACTION;
unit * u; unit * u;
@ -266,7 +266,7 @@ expandrecruit(region * r, request * recruitorders)
if (h <= 0) continue; if (h <= 0) continue;
} else if ((rc->ec_flags & ECF_REC_ETHEREAL) == 0) { } else if ((rc->ec_flags & ECF_REC_ETHEREAL) == 0) {
/* recruit from peasants if any space left */ /* recruit from peasants if any space left */
if (n >= rfrac) continue; if (n - (uruks+1)/2 >= rfrac) continue;
} }
} }
if (recruitcost) { if (recruitcost) {
@ -276,7 +276,10 @@ expandrecruit(region * r, request * recruitorders)
if ((rc->ec_flags & ECF_REC_UNLIMITED)==0) { if ((rc->ec_flags & ECF_REC_UNLIMITED)==0) {
if (rc->ec_flags & ECF_REC_HORSES) h--; /* use a horse */ if (rc->ec_flags & ECF_REC_HORSES) h--; /* use a horse */
else { else {
if ((rc->ec_flags & ECF_REC_ETHEREAL)==0) p--; /* use a peasant */ if ((rc->ec_flags & ECF_REC_ETHEREAL)==0) {
p--; /* use a peasant */
if(rc == new_race[RC_URUK]) uruks++;
}
n++; n++;
} }
} }
@ -286,7 +289,7 @@ expandrecruit(region * r, request * recruitorders)
} }
assert(p>=0 && h>=0); assert(p>=0 && h>=0);
rsetpeasants(r, p); rsetpeasants(r, p+uruks/2);
rsethorses(r, h); rsethorses(r, h);
free(oa); free(oa);
@ -295,7 +298,7 @@ expandrecruit(region * r, request * recruitorders)
if (u->n >= 0) { if (u->n >= 0) {
if (u->number) if (u->number)
u->hp += u->n * unit_max_hp(u); u->hp += u->n * unit_max_hp(u);
if (u->race == new_race[RC_ORC]) { if (u->race == new_race[RC_URUK]) {
change_skill(u, SK_SWORD, skill_level(1) * u->n); change_skill(u, SK_SWORD, skill_level(1) * u->n);
change_skill(u, SK_SPEAR, skill_level(1) * u->n); change_skill(u, SK_SPEAR, skill_level(1) * u->n);
} }
@ -365,12 +368,17 @@ recruit(region * r, unit * u, strlist * S,
return; return;
} }
#if RACE_ADJUSTMENTS
if (fval(r, RF_ORCIFIED) && u->faction->race != new_race[RC_URUK] &&
#else
if (fval(r, RF_ORCIFIED) && u->faction->race != new_race[RC_ORC] && if (fval(r, RF_ORCIFIED) && u->faction->race != new_race[RC_ORC] &&
#endif
!(u->faction->race->ec_flags & ECF_REC_HORSES)) { !(u->faction->race->ec_flags & ECF_REC_HORSES)) {
cmistake(u, S->s, 238, MSG_EVENT); cmistake(u, S->s, 238, MSG_EVENT);
return; return;
} }
recruitcost = u->faction->race->recruitcost; recruitcost = u->faction->race->recruitcost;
if (recruitcost) { if (recruitcost) {
pl = getplane(r); pl = getplane(r);
@ -537,6 +545,11 @@ givemen(int n, unit * u, unit * u2, const char * cmd)
return; return;
} else if (u == u2) { } else if (u == u2) {
error = 10; error = 10;
#if RACE_ADJUSTMENTS
} else if (u->race == new_race[RC_URUK]) {
/* Uruks/Snotlings können nicht an Bauern übergeben werden. */
error = 307;
#endif
} else if ((u && unit_has_cursed_item(u)) || (u2 && unit_has_cursed_item(u2))) { } else if ((u && unit_has_cursed_item(u)) || (u2 && unit_has_cursed_item(u2))) {
error = 78; error = 78;
} else if (fval(u, FL_LOCKED) || fval(u, FL_HUNGER) || is_cursed(u->attribs, C_SLAVE, 0)) { } else if (fval(u, FL_LOCKED) || fval(u, FL_HUNGER) || is_cursed(u->attribs, C_SLAVE, 0)) {

View file

@ -1075,6 +1075,8 @@ randomevents(void)
drown(r); drown(r);
} }
#if RACE_ADJUSTMENTS
/* Orks vermehren sich */ /* Orks vermehren sich */
for (r = regions; r; r = r->next) { for (r = regions; r; r = r->next) {
@ -1129,6 +1131,7 @@ randomevents(void)
} }
} }
} }
#endif
/* Talente von Dämonen verschieben sich und Dämonen fressen Bauern */ /* Talente von Dämonen verschieben sich und Dämonen fressen Bauern */

View file

@ -1324,8 +1324,6 @@ describe(FILE * F, region * r, int partial, faction * f)
} }
} }
extern const int wagetable[6][3];
void void
statistics(FILE * F, region * r, faction * f) statistics(FILE * F, region * r, faction * f)
{ {

View file

@ -132,7 +132,7 @@ setstealth(unit * u, strlist * S)
if (u->race == new_race[RC_DAEMON]) { if (u->race == new_race[RC_DAEMON]) {
race_t allowed[] = { RC_DWARF, RC_ELF, RC_ORC, RC_GOBLIN, RC_HUMAN, race_t allowed[] = { RC_DWARF, RC_ELF, RC_ORC, RC_GOBLIN, RC_HUMAN,
RC_TROLL, RC_DAEMON, RC_INSECT, RC_HALFLING, RC_CAT, RC_AQUARIAN, RC_TROLL, RC_DAEMON, RC_INSECT, RC_HALFLING, RC_CAT, RC_AQUARIAN,
NORACE }; RC_URUK, NORACE };
int i; int i;
for (i=0;allowed[i]!=NORACE;++i) if (new_race[allowed[i]]==trace) break; for (i=0;allowed[i]!=NORACE;++i) if (new_race[allowed[i]]==trace) break;
if (new_race[allowed[i]]==trace) { if (new_race[allowed[i]]==trace) {

View file

@ -682,10 +682,21 @@ weapon_skill(const weapon_type * wtype, const unit * u, boolean attacking)
skill = effskill(u, SK_WEAPONLESS); skill = effskill(u, SK_WEAPONLESS);
if (skill==0) { if (skill==0) {
/* wenn kein waffenloser kampf, dann den rassen-defaultwert */ /* wenn kein waffenloser kampf, dann den rassen-defaultwert */
if (attacking) { if(u->race == new_race[RC_URUK]) {
skill = u->race->at_default; int sword = effskill(u, SK_SWORD);
int spear = effskill(u, SK_SPEAR);
skill = max(sword, spear) - 3;
if (attacking) {
skill = max(skill, u->race->at_default);
} else {
skill = max(skill, u->race->df_default);
}
} else { } else {
skill = u->race->df_default; if (attacking) {
skill = u->race->at_default;
} else {
skill = u->race->df_default;
}
} }
} else { } else {
/* der rassen-defaultwert kann höher sein als der Talentwert von /* der rassen-defaultwert kann höher sein als der Talentwert von

View file

@ -2764,7 +2764,8 @@ wage(const region *r, const unit *u, boolean img)
if (b) esize = buildingeffsize(b, img); if (b) esize = buildingeffsize(b, img);
if (u) { if (u) {
wage = wagetable[esize][old_race(u->race) == RC_ORC]; /* TODO: Snotling! */
wage = wagetable[esize][u->race == new_race[RC_ORC] || u->race == new_race[RC_URUK]];
if (fspecial(u->faction, FS_URBAN)) { if (fspecial(u->faction, FS_URBAN)) {
wage += wagetable[esize][3]; wage += wagetable[esize][3];
} }

View file

@ -616,34 +616,35 @@ enum {
RC_HALFLING, RC_HALFLING,
RC_CAT, RC_CAT,
RC_AQUARIAN, RC_AQUARIAN,
RC_URUK,
RC_UNDEAD, /* 11 - Untoter */ RC_UNDEAD, /* 12 - Untoter */
RC_ILLUSION, RC_ILLUSION,
RC_FIREDRAGON, RC_FIREDRAGON,
RC_DRAGON, RC_DRAGON,
RC_WYRM, RC_WYRM,
RC_TREEMAN, RC_TREEMAN,
RC_BIRTHDAYDRAGON, /* 17 - Katzendrache*/ RC_BIRTHDAYDRAGON, /* 18 - Katzendrache*/
RC_DRACOID, RC_DRACOID,
RC_SPECIAL, RC_SPECIAL,
RC_SPELL, RC_SPELL,
RC_IRONGOLEM, /* 21 - Eisengolem */ RC_IRONGOLEM, /* 22 - Eisengolem */
RC_STONEGOLEM, RC_STONEGOLEM,
RC_SHADOW, RC_SHADOW,
RC_SHADOWLORD, RC_SHADOWLORD,
RC_IRONKEEPER, /* 25 - Bergwächter */ RC_IRONKEEPER, /* 26 - Bergwächter */
RC_ALP, RC_ALP,
RC_TOAD, /* 27 - Kröte */ RC_TOAD, /* 28 - Kröte */
RC_HIRNTOETER, RC_HIRNTOETER,
RC_PEASANT, RC_PEASANT,
RC_WOLF, /* 30 */ RC_WOLF, /* 31 */
RC_HOUSECAT, RC_HOUSECAT,
RC_TUNNELWORM, RC_TUNNELWORM,
@ -654,7 +655,7 @@ enum {
RC_UNICORN, RC_UNICORN,
RC_WARG, RC_WARG,
RC_WRAITH, RC_WRAITH,
RC_IMP, /* 40 */ RC_IMP, /* 41 */
RC_DREAMCAT, RC_DREAMCAT,
RC_FEY, RC_FEY,
RC_OWL, RC_OWL,
@ -664,7 +665,7 @@ enum {
RC_OCEANTURTLE, RC_OCEANTURTLE,
RC_KRAKEN, RC_KRAKEN,
RC_SEASERPENT, RC_SEASERPENT,
RC_SHADOWKNIGHT, /* 50 */ RC_SHADOWKNIGHT, /* 51 */
RC_CENTAUR, RC_CENTAUR,
@ -675,10 +676,11 @@ enum {
RC_GHOUL, RC_GHOUL,
RC_GHOUL_LORD, RC_GHOUL_LORD,
RC_MUS_SPIRIT, /* 58 */ RC_MUS_SPIRIT, /* 59 */
RC_GNOME, /* 59 */ RC_GNOME, /* 60 */
RC_TEMPLATE, /* 60 */ RC_TEMPLATE, /* 61 */
RC_CLONE, /* 61 */ RC_CLONE, /* 62 */
MAXRACES, MAXRACES,
NORACE = (race_t) - 1 NORACE = (race_t) - 1

View file

@ -155,7 +155,7 @@ const struct race_syn race_synonyms[] = {
/* required for old_race, do not change order! */ /* required for old_race, do not change order! */
static const char * oldracenames[MAXRACES] = { static const char * oldracenames[MAXRACES] = {
"dwarf", "elf", "orc", "goblin", "human", "troll", "demon", "insect", "halfling", "cat", "aquarian", "dwarf", "elf", "orc", "goblin", "human", "troll", "demon", "insect", "halfling", "cat", "aquarian", "uruk"
"undead", "illusion", "undead", "illusion",
"young dragon", "dragon", "wyrm", "ent", "catdragon", "dracoid", "young dragon", "dragon", "wyrm", "ent", "catdragon", "dracoid",
"special", "spell", "special", "spell",
@ -208,6 +208,7 @@ give_starting_equipment(struct region *r, struct unit *u)
set_show_item(u->faction, I_FEENSTIEFEL); set_show_item(u->faction, I_FEENSTIEFEL);
break; break;
case RC_ORC: case RC_ORC:
case RC_URUK:
set_level(u, SK_SPEAR, 4); set_level(u, SK_SPEAR, 4);
set_level(u, SK_SWORD, 4); set_level(u, SK_SWORD, 4);
set_level(u, SK_CROSSBOW, 4); set_level(u, SK_CROSSBOW, 4);

View file

@ -4287,7 +4287,7 @@
<text locale="en">"$unit($unit) in $region($region): '$command' - options ZIP and BZIP2 can only be switched, not turned off."</text> <text locale="en">"$unit($unit) in $region($region): '$command' - options ZIP and BZIP2 can only be switched, not turned off."</text>
</message> </message>
<message name="error305"> <message name="error306">
<type> <type>
<arg name="unit" type="unit"></arg> <arg name="unit" type="unit"></arg>
<arg name="region" type="region"></arg> <arg name="region" type="region"></arg>
@ -4300,6 +4300,19 @@
</locale> </locale>
</message> </message>
<message name="error307">
<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' - Orks sind keine Bauern."</text>
</nr>
</locale>
</message>
<message name="drown_on_ship"> <message name="drown_on_ship">
<type> <type>
<arg name="unit" type="unit"></arg> <arg name="unit" type="unit"></arg>

View file

@ -1861,6 +1861,12 @@
<string name="Orks"> <string name="Orks">
<text locale="de">Orks</text> <text locale="de">Orks</text>
</string> </string>
<string name="Uruk">
<text locale="de">Ork</text>
</string>
<string name="Uruks">
<text locale="de">Orks</text>
</string>
<string name="Riesenschildkröte"> <string name="Riesenschildkröte">
<text locale="de">Riesenschildkröte</text> <text locale="de">Riesenschildkröte</text>
</string> </string>
@ -2013,6 +2019,12 @@
<string name="rc_orc"> <string name="rc_orc">
<text locale="de">Ork</text> <text locale="de">Ork</text>
</string> </string>
<string name="rc_uruk_p">
<text locale="de">Orks</text>
</string>
<string name="rc_uruk">
<text locale="de">Ork</text>
</string>
<string name="rc_zombie"> <string name="rc_zombie">
<text locale="de">Zombie</text> <text locale="de">Zombie</text>
</string> </string>

View file

@ -1691,8 +1691,14 @@
<text locale="en">orc</text> <text locale="en">orc</text>
</string> </string>
<string name="Orks"> <string name="Orks">
<text locale="en">orcs</text>
</string>
<string name="Uruk">
<text locale="en">orc</text> <text locale="en">orc</text>
</string> </string>
<string name="Uruks">
<text locale="en">orcs</text>
</string>
<string name="Riesenschildkröte"> <string name="Riesenschildkröte">
<text locale="en">giant turtle</text> <text locale="en">giant turtle</text>
</string> </string>

View file

@ -1093,7 +1093,7 @@
<familiar race="eagle"></familiar> <familiar race="eagle"></familiar>
<familiar race="imp"></familiar> <familiar race="imp"></familiar>
</race> </race>
<race name="goblin" magres="-0.050000" maxaura="1.000000" regaura="1.000000" recruitcost="40" maintenance="10" weight="1000" speed="1.000000" hp="16" ac="0" damage="1d5" unarmedattack="-2" unarmeddefense="0" attackmodifier="0" defensemodifier="0" playerrace walk giveitem giveperson giveunit getitem equipment> <race name="goblin" magres="-0.050000" maxaura="1.000000" regaura="1.000000" recruitcost="40" maintenance="10" weight="900" speed="1.000000" hp="16" ac="0" damage="1d5" unarmedattack="-2" unarmeddefense="0" attackmodifier="0" defensemodifier="0" playerrace walk giveitem giveperson giveunit getitem equipment>
<ai splitsize="10000" attackrandom moverandom learn></ai> <ai splitsize="10000" attackrandom moverandom learn></ai>
<function name="initfamiliar" value="oldfamiliars"></function> <function name="initfamiliar" value="oldfamiliars"></function>
<skill name="sk_alchemy" modifier="1"></skill> <skill name="sk_alchemy" modifier="1"></skill>
@ -1173,7 +1173,7 @@
<familiar race="unicorn"></familiar> <familiar race="unicorn"></familiar>
<familiar race="imp"></familiar> <familiar race="imp"></familiar>
</race> </race>
<race name="dwarf" magres="0.050000" maxaura="1.000000" regaura="0.500000" recruitcost="90" 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> <race name="dwarf" magres="0.050000" maxaura="1.000000" regaura="0.500000" recruitcost="110" 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> <ai splitsize="10000" attackrandom moverandom learn></ai>
<skill name="sk_mining" modifier="2"></skill> <skill name="sk_mining" modifier="2"></skill>
<skill name="sk_bow" modifier="-1"></skill> <skill name="sk_bow" modifier="-1"></skill>
@ -1204,4 +1204,33 @@
<familiar race="wolf"></familiar> <familiar race="wolf"></familiar>
<familiar race="rat"></familiar> <familiar race="rat"></familiar>
</race> </race>
<race name="uruk" magres="-0.050000" maxaura="1.000000" regaura="1.000000" recruitcost="70" 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>
</races> </races>