Fix bewachender Bauernmob

fix doppelt base36 nummer in Meldung
fix keine Erfahrungstage bei scheitern an Magieresistenz

Nicht getestet, da der source derzeit nicht kompiliert
This commit is contained in:
Katja Zedel 2002-03-01 19:32:25 +00:00
parent c41a989809
commit fbd5190b50
4 changed files with 20 additions and 9 deletions

View file

@ -2591,6 +2591,12 @@ bewache_an(void)
if (rterrain(r) != T_OCEAN) { if (rterrain(r) != T_OCEAN) {
if (!fval(u, RCF_ILLUSIONARY) && u->race != new_race[RC_SPELL]) { if (!fval(u, RCF_ILLUSIONARY) && u->race != new_race[RC_SPELL]) {
#ifdef WACH_WAFF #ifdef WACH_WAFF
/* Monster der Monsterpartei dürfen immer bewachen */
if (u->faction == findfaction(MONSTER_FACTION)){
guard(u, GUARD_ALL);
continue;
}
if (!armedmen(u)) { if (!armedmen(u)) {
add_message(&u->faction->msgs, add_message(&u->faction->msgs,
msg_error(u, S->s, "unit_unarmed", "")); msg_error(u, S->s, "unit_unarmed", ""));

View file

@ -1651,7 +1651,7 @@ verify_targets(castorder *co)
failed++; failed++;
add_message(&mage->faction->msgs, new_message(mage->faction, add_message(&mage->faction->msgs, new_message(mage->faction,
"spellunitnotfound%u:unit%r:region%s:command%s:id", "spellunitnotfound%u:unit%r:region%s:command%s:id",
mage, mage->region, strdup(co->order), mage, mage->region, strdup(co->order),
strdup(itoa36(spobj->data.i)))); strdup(itoa36(spobj->data.i))));
break; break;
} else { /* Einheit wurde nun gefunden, pointer umsetzen */ } else { /* Einheit wurde nun gefunden, pointer umsetzen */
@ -1685,8 +1685,7 @@ verify_targets(castorder *co)
parameters[P_TEMP]), itoa36(spobj->data.i)); parameters[P_TEMP]), itoa36(spobj->data.i));
add_message(&mage->faction->msgs, new_message(mage->faction, add_message(&mage->faction->msgs, new_message(mage->faction,
"spellunitnotfound%u:unit%r:region%s:command%s:id", "spellunitnotfound%u:unit%r:region%s:command%s:id",
mage, mage->region, strdup(co->order), mage, mage->region, strdup(co->order), strdup(tbuf)));
strdup(tbuf)));
break; break;
} else { } else {
/* Einheit wurde nun gefunden, pointer umsetzen */ /* Einheit wurde nun gefunden, pointer umsetzen */
@ -1827,7 +1826,7 @@ verify_targets(castorder *co)
spobj->flag = TARGET_NOTFOUND; spobj->flag = TARGET_NOTFOUND;
add_message(&mage->faction->msgs, new_message(mage->faction, add_message(&mage->faction->msgs, new_message(mage->faction,
"spellunitnotfound%u:unit%r:region%s:command%s:id", "spellunitnotfound%u:unit%r:region%s:command%s:id",
mage, mage->region, strdup(co->order), mage, mage->region, strdup(co->order),
strdup(itoa36(spobj->data.i)))); strdup(itoa36(spobj->data.i))));
failed++; failed++;
break; break;
@ -1843,7 +1842,7 @@ verify_targets(castorder *co)
add_message(&mage->faction->msgs, new_message(mage->faction, add_message(&mage->faction->msgs, new_message(mage->faction,
"spellunitresists%u:unit%r:region%s:command%s:id", "spellunitresists%u:unit%r:region%s:command%s:id",
mage, mage->region, strdup(co->order), mage, mage->region, strdup(co->order),
strdup(itoa36(spobj->data.i)))); strdup(spobj->data.i)));
break; break;
} }
@ -1866,7 +1865,7 @@ verify_targets(castorder *co)
resists++; resists++;
add_message(&mage->faction->msgs, new_message(mage->faction, add_message(&mage->faction->msgs, new_message(mage->faction,
"spellbuildingresists%u:unit%r:region%s:command%i:id", "spellbuildingresists%u:unit%r:region%s:command%i:id",
mage, mage->region, strdup(co->order), spobj->data.i)); mage, mage->region, strdup(co->order), strdup(spobj->data.i)));
break; break;
} }
success++; success++;
@ -1886,7 +1885,7 @@ verify_targets(castorder *co)
resists++; resists++;
add_message(&mage->faction->msgs, new_message(mage->faction, add_message(&mage->faction->msgs, new_message(mage->faction,
"spellshipresists%u:unit%r:region%s:command%i:id", "spellshipresists%u:unit%r:region%s:command%i:id",
mage, mage->region, strdup(co->order), spobj->data.i)); mage, mage->region, strdup(co->order), strdup(spobj->data.i)));
break; break;
} }
success++; success++;
@ -3194,6 +3193,7 @@ magic(void)
/* zwar wurde mindestens ein Ziel gefunden, das widerstand /* zwar wurde mindestens ein Ziel gefunden, das widerstand
* jedoch dem Zauber. Kosten abziehen und abbrechen. */ * jedoch dem Zauber. Kosten abziehen und abbrechen. */
pay_spell(u, sp, level, co->distance); pay_spell(u, sp, level, co->distance);
countspells(u,1);
sprintf(buf, "%s gelingt es %s zu zaubern, doch der Spruch zeigt " sprintf(buf, "%s gelingt es %s zu zaubern, doch der Spruch zeigt "
"keine Wirkung.", unitname(u), sp->name); "keine Wirkung.", unitname(u), sp->name);
addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE); addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE);

View file

@ -2408,6 +2408,7 @@ patzer_peasantmob(castorder *co)
attrib *a; attrib *a;
region *r; region *r;
unit *mage = (unit *)co->magician; unit *mage = (unit *)co->magician;
strlist *S;
if (mage->region->land){ if (mage->region->land){
r = mage->region; r = mage->region;
@ -2423,7 +2424,11 @@ patzer_peasantmob(castorder *co)
u = createunit(r, findfaction(MONSTER_FACTION), n, new_race[RC_PEASANT]); u = createunit(r, findfaction(MONSTER_FACTION), n, new_race[RC_PEASANT]);
set_string(&u->name, "Bauernmob"); set_string(&u->name, "Bauernmob");
guard(u, GUARD_ALL); /* guard(u, GUARD_ALL); hier zu früh! Befehl BEWACHE setzten */
sprintf(buf, "BEWACHE");
S = makestrlist(buf);
addlist(&u->orders, S);
set_string(&u->thisorder, LOC(u->faction->locale, "defaultorder"));
a = a_new(&at_unitdissolve); a = a_new(&at_unitdissolve);
a->data.ca[0] = 1; /* An rpeasants(r). */ a->data.ca[0] = 1; /* An rpeasants(r). */
a->data.ca[1] = 10; /* 10% */ a->data.ca[1] = 10; /* 10% */

View file

@ -3948,7 +3948,7 @@
</type> </type>
<locale name="en"> <locale name="en">
<nr section="none"> <nr section="none">
<text>"$unit($unit) in $region($region): '$command' - Unit $int36($id) could not be located."</text> <text>"$unit($unit) in $region($region): '$command' - Unit $id could not be located."</text>
</nr> </nr>
</locale> </locale>
</message> </message>