forked from github/server
SIMPLE_ESCAPE: Flucht verhindert BEWACHE.
This commit is contained in:
parent
d46151998d
commit
c61127ab6f
9 changed files with 130 additions and 83 deletions
|
@ -2461,22 +2461,22 @@ status_cmd(unit * u, struct order * ord)
|
||||||
param = getstrtoken();
|
param = getstrtoken();
|
||||||
switch (findparam(param, u->faction->locale)) {
|
switch (findparam(param, u->faction->locale)) {
|
||||||
case P_NOT:
|
case P_NOT:
|
||||||
u->status = ST_AVOID;
|
setstatus(u, ST_AVOID);
|
||||||
break;
|
break;
|
||||||
case P_BEHIND:
|
case P_BEHIND:
|
||||||
u->status = ST_BEHIND;
|
setstatus(u, ST_BEHIND);
|
||||||
break;
|
break;
|
||||||
case P_FLEE:
|
case P_FLEE:
|
||||||
u->status = ST_FLEE;
|
setstatus(u, ST_FLEE);
|
||||||
break;
|
break;
|
||||||
case P_CHICKEN:
|
case P_CHICKEN:
|
||||||
u->status = ST_CHICKEN;
|
setstatus(u, ST_CHICKEN);
|
||||||
break;
|
break;
|
||||||
case P_AGGRO:
|
case P_AGGRO:
|
||||||
u->status = ST_AGGRO;
|
setstatus(u, ST_AGGRO);
|
||||||
break;
|
break;
|
||||||
case P_VORNE:
|
case P_VORNE:
|
||||||
u->status = ST_FIGHT;
|
setstatus(u, ST_FIGHT);
|
||||||
break;
|
break;
|
||||||
case P_HELP:
|
case P_HELP:
|
||||||
if (getparam(u->faction->locale) == P_NOT) {
|
if (getparam(u->faction->locale) == P_NOT) {
|
||||||
|
@ -2490,7 +2490,7 @@ status_cmd(unit * u, struct order * ord)
|
||||||
add_message(&u->faction->msgs,
|
add_message(&u->faction->msgs,
|
||||||
msg_feedback(u, ord, "unknown_status", ""));
|
msg_feedback(u, ord, "unknown_status", ""));
|
||||||
} else {
|
} else {
|
||||||
u->status = ST_FIGHT;
|
setstatus(u, ST_FIGHT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2548,11 +2548,14 @@ combatspell_cmd(unit * u, struct order * ord)
|
||||||
/* Beachten: einige Monster sollen auch unbewaffent die Region bewachen
|
/* Beachten: einige Monster sollen auch unbewaffent die Region bewachen
|
||||||
* können */
|
* können */
|
||||||
|
|
||||||
enum { E_GUARD_OK, E_GUARD_UNARMED, E_GUARD_NEWBIE };
|
enum { E_GUARD_OK, E_GUARD_UNARMED, E_GUARD_NEWBIE, E_GUARD_FLEEING };
|
||||||
|
|
||||||
static int
|
static int
|
||||||
can_start_guarding(const unit * u)
|
can_start_guarding(const unit * u)
|
||||||
{
|
{
|
||||||
|
#ifdef SIMPLE_ESCAPE
|
||||||
|
if (u->status>=ST_FLEE) return E_GUARD_FLEEING;
|
||||||
|
#endif
|
||||||
if (fval(u->race, RCF_UNARMEDGUARD)) return E_GUARD_OK;
|
if (fval(u->race, RCF_UNARMEDGUARD)) return E_GUARD_OK;
|
||||||
if (!armedmen(u)) return E_GUARD_UNARMED;
|
if (!armedmen(u)) return E_GUARD_UNARMED;
|
||||||
if (u->faction->age < NewbieImmunity()) return E_GUARD_NEWBIE;
|
if (u->faction->age < NewbieImmunity()) return E_GUARD_NEWBIE;
|
||||||
|
@ -2598,12 +2601,14 @@ guard_on_cmd(unit * u, struct order * ord)
|
||||||
guard(u, GUARD_ALL);
|
guard(u, GUARD_ALL);
|
||||||
} else {
|
} else {
|
||||||
int err = can_start_guarding(u);
|
int err = can_start_guarding(u);
|
||||||
if (err==E_GUARD_UNARMED) {
|
if (err==E_GUARD_OK) {
|
||||||
|
guard(u, GUARD_ALL);
|
||||||
|
} else if (err==E_GUARD_UNARMED) {
|
||||||
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_unarmed", ""));
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_unarmed", ""));
|
||||||
|
} else if (err==E_GUARD_FLEEING) {
|
||||||
|
cmistake(u, ord, 320, MSG_EVENT);
|
||||||
} else if (err==E_GUARD_NEWBIE) {
|
} else if (err==E_GUARD_NEWBIE) {
|
||||||
cmistake(u, ord, 304, MSG_EVENT);
|
cmistake(u, ord, 304, MSG_EVENT);
|
||||||
} else {
|
|
||||||
guard(u, GUARD_ALL);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -805,10 +805,12 @@ recruit_dracoids(unit * dragon, int size)
|
||||||
change_money(dragon, -un->number * 50);
|
change_money(dragon, -un->number * 50);
|
||||||
equip_unit(un, get_equipment("recruited_dracoid"));
|
equip_unit(un, get_equipment("recruited_dracoid"));
|
||||||
|
|
||||||
un->status = ST_FIGHT;
|
setstatus(un, ST_FIGHT);
|
||||||
for (weapon=un->items;weapon;weapon=weapon->next) {
|
for (weapon=un->items;weapon;weapon=weapon->next) {
|
||||||
const weapon_type * wtype = weapon->type->rtype->wtype;
|
const weapon_type * wtype = weapon->type->rtype->wtype;
|
||||||
if (wtype && (wtype->flags & WTF_MISSILE)) un->status = ST_BEHIND;
|
if (wtype && (wtype->flags & WTF_MISSILE)) {
|
||||||
|
setstatus(un, ST_BEHIND);
|
||||||
|
}
|
||||||
sprintf(buf, "%s \"%s\"", keywords[K_STUDY],
|
sprintf(buf, "%s \"%s\"", keywords[K_STUDY],
|
||||||
skillname(weapon->type->rtype->wtype->skill, f->locale));
|
skillname(weapon->type->rtype->wtype->skill, f->locale));
|
||||||
new_order = parse_order(buf, default_locale);
|
new_order = parse_order(buf, default_locale);
|
||||||
|
@ -941,7 +943,10 @@ plan_monsters(void)
|
||||||
attack_chance = 0.0;
|
attack_chance = 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (u->status>ST_BEHIND) u->status = ST_FIGHT; /* all monsters fight */
|
if (u->status>ST_BEHIND) {
|
||||||
|
setstatus(u, ST_FIGHT);
|
||||||
|
/* all monsters fight */
|
||||||
|
}
|
||||||
/* Monster bekommen jede Runde ein paar Tage Wahrnehmung dazu */
|
/* Monster bekommen jede Runde ein paar Tage Wahrnehmung dazu */
|
||||||
produceexp(u, SK_OBSERVATION, u->number);
|
produceexp(u, SK_OBSERVATION, u->number);
|
||||||
|
|
||||||
|
|
|
@ -1960,7 +1960,7 @@ create_unit(region * r, faction * f, int number, const struct race *urace, int i
|
||||||
attrib * a;
|
attrib * a;
|
||||||
|
|
||||||
/* erbt Kampfstatus */
|
/* erbt Kampfstatus */
|
||||||
u->status = creator->status;
|
setstatus(u, creator->status);
|
||||||
|
|
||||||
/* erbt Gebäude/Schiff*/
|
/* erbt Gebäude/Schiff*/
|
||||||
if (creator->region==r) {
|
if (creator->region==r) {
|
||||||
|
@ -2427,12 +2427,29 @@ attrib_type at_guard = {
|
||||||
ATF_UNIQUE
|
ATF_UNIQUE
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
setstatus(struct unit * u, int status)
|
||||||
|
{
|
||||||
|
assert(status>=ST_AGGRO && status<=ST_FLEE);
|
||||||
|
if (u->status!=status) {
|
||||||
|
u->status = status;
|
||||||
|
#ifdef SIMPLE_ESCAPE
|
||||||
|
if (u->status==ST_FLEE) {
|
||||||
|
setguard(u, GUARD_NONE);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
setguard(unit * u, unsigned int flags)
|
setguard(unit * u, unsigned int flags)
|
||||||
{
|
{
|
||||||
/* setzt die guard-flags der Einheit */
|
/* setzt die guard-flags der Einheit */
|
||||||
attrib * a = NULL;
|
attrib * a = NULL;
|
||||||
assert(flags==0 || !fval(u, UFL_MOVED));
|
assert(flags==0 || !fval(u, UFL_MOVED));
|
||||||
|
#ifdef SIMPLE_ESCAPE
|
||||||
|
assert(flags==0 || u->status<ST_FLEE);
|
||||||
|
#endif
|
||||||
if (fval(u, UFL_GUARD)) {
|
if (fval(u, UFL_GUARD)) {
|
||||||
a = a_find(u->attribs, &at_guard);
|
a = a_find(u->attribs, &at_guard);
|
||||||
}
|
}
|
||||||
|
@ -2449,7 +2466,6 @@ setguard(unit * u, unsigned int flags)
|
||||||
unsigned int
|
unsigned int
|
||||||
getguard(const unit * u)
|
getguard(const unit * u)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (!fval(u->region->terrain, LAND_REGION)) return GUARD_NONE;
|
if (!fval(u->region->terrain, LAND_REGION)) return GUARD_NONE;
|
||||||
if (fval(u, UFL_GUARD)) {
|
if (fval(u, UFL_GUARD)) {
|
||||||
attrib * a = a_find(u->attribs, &at_guard);
|
attrib * a = a_find(u->attribs, &at_guard);
|
||||||
|
|
|
@ -1035,8 +1035,10 @@ void addmessage(struct region * r, struct faction * f, const char *s, msg_t mtyp
|
||||||
/* Verhindert Abbau von Resourcen mit RTF_LIMITED */
|
/* Verhindert Abbau von Resourcen mit RTF_LIMITED */
|
||||||
#define GUARD_ALL 0xFFFF
|
#define GUARD_ALL 0xFFFF
|
||||||
|
|
||||||
|
extern void setstatus(struct unit * u, int status);
|
||||||
|
/* !< sets combatstatus of a unit */
|
||||||
extern void setguard(struct unit * u, unsigned int flags);
|
extern void setguard(struct unit * u, unsigned int flags);
|
||||||
/* setzt die guard-flags der Einheit */
|
/* !< setzt die guard-flags der Einheit */
|
||||||
extern unsigned int getguard(const struct unit * u);
|
extern unsigned int getguard(const struct unit * u);
|
||||||
/* liest die guard-flags der Einheit */
|
/* liest die guard-flags der Einheit */
|
||||||
extern void guard(struct unit * u, unsigned int mask);
|
extern void guard(struct unit * u, unsigned int mask);
|
||||||
|
|
|
@ -1015,34 +1015,42 @@ readunit(FILE * F)
|
||||||
if (count_unit(u)) u->faction->no_units++;
|
if (count_unit(u)) u->faction->no_units++;
|
||||||
|
|
||||||
set_number(u, number);
|
set_number(u, number);
|
||||||
u->building = findbuilding(rid(F));
|
u->building = findbuilding(rid(F));
|
||||||
u->ship = findship(rid(F));
|
u->ship = findship(rid(F));
|
||||||
|
|
||||||
if (global.data_version <= 73) {
|
if (global.data_version <= 73) {
|
||||||
if (ri(F)) {
|
if (ri(F)) {
|
||||||
fset(u, UFL_OWNER);
|
fset(u, UFL_OWNER);
|
||||||
} else {
|
} else {
|
||||||
freset(u, UFL_OWNER);
|
freset(u, UFL_OWNER);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
u->status = (status_t) ri(F);
|
setstatus(u, ri(F));
|
||||||
if (global.data_version < NEWSTATUS_VERSION) {
|
if (global.data_version < NEWSTATUS_VERSION) {
|
||||||
switch (u->status) {
|
switch (u->status) {
|
||||||
case 0: u->status = ST_FIGHT; break;
|
case 0:
|
||||||
case 1: u->status = ST_BEHIND; break;
|
setstatus(u, ST_FIGHT);
|
||||||
case 2: u->status = ST_AVOID; break;
|
break;
|
||||||
case 3: u->status = ST_FLEE; break;
|
case 1:
|
||||||
default: assert(0);
|
setstatus(u, ST_BEHIND);
|
||||||
}
|
break;
|
||||||
}
|
case 2:
|
||||||
if (global.data_version <= 73) {
|
setstatus(u, ST_AVOID);
|
||||||
if (ri(F)) {
|
break;
|
||||||
guard(u, GUARD_ALL);
|
case 3:
|
||||||
} else {
|
setstatus(u, ST_FLEE);
|
||||||
guard(u, GUARD_NONE);
|
default:
|
||||||
}
|
assert(!"unknown status in data");
|
||||||
} else {
|
}
|
||||||
u->flags = ri(F) & ~UFL_DEBUG;
|
}
|
||||||
|
if (global.data_version <= 73) {
|
||||||
|
if (ri(F)) {
|
||||||
|
guard(u, GUARD_ALL);
|
||||||
|
} else {
|
||||||
|
guard(u, GUARD_NONE);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
u->flags = ri(F) & ~UFL_DEBUG;
|
||||||
u->flags &= UFL_SAVEMASK;
|
u->flags &= UFL_SAVEMASK;
|
||||||
}
|
}
|
||||||
/* Persistente Befehle einlesen */
|
/* Persistente Befehle einlesen */
|
||||||
|
|
|
@ -89,43 +89,43 @@ static attrib_type at_alp = {
|
||||||
int
|
int
|
||||||
sp_summon_alp(struct castorder *co)
|
sp_summon_alp(struct castorder *co)
|
||||||
{
|
{
|
||||||
unit *alp, *opfer;
|
unit *alp, *opfer;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = co->magician.u;
|
unit *mage = co->magician.u;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
|
||||||
opfer = pa->param[0]->data.u;
|
opfer = pa->param[0]->data.u;
|
||||||
|
|
||||||
/* Der Alp gehört den Monstern, darum erhält der Magier auch keine
|
/* Der Alp gehört den Monstern, darum erhält der Magier auch keine
|
||||||
* Regionsberichte von ihm. Er erhält aber später eine Mitteilung,
|
* Regionsberichte von ihm. Er erhält aber später eine Mitteilung,
|
||||||
* sobald der Alp sein Opfer erreicht hat.
|
* sobald der Alp sein Opfer erreicht hat.
|
||||||
*/
|
*/
|
||||||
alp = createunit(r, findfaction(MONSTER_FACTION), 1, new_race[RC_ALP]);
|
alp = createunit(r, findfaction(MONSTER_FACTION), 1, new_race[RC_ALP]);
|
||||||
set_level(alp, SK_STEALTH, 7);
|
set_level(alp, SK_STEALTH, 7);
|
||||||
set_string(&alp->name, "Alp");
|
set_string(&alp->name, "Alp");
|
||||||
alp->status = ST_FLEE; /* flieht */
|
setstatus(alp, ST_FLEE); /* flieht */
|
||||||
|
|
||||||
{
|
{
|
||||||
attrib * a = a_add(&alp->attribs, a_new(&at_alp));
|
attrib * a = a_add(&alp->attribs, a_new(&at_alp));
|
||||||
alp_data * ad = (alp_data*) a->data.v;
|
alp_data * ad = (alp_data*) a->data.v;
|
||||||
ad->mage = mage;
|
ad->mage = mage;
|
||||||
ad->target = opfer;
|
ad->target = opfer;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
/* Wenn der Alp stirbt, den Magier nachrichtigen */
|
/* Wenn der Alp stirbt, den Magier nachrichtigen */
|
||||||
add_trigger(&alp->attribs, "destroy", trigger_unitmessage(mage,
|
add_trigger(&alp->attribs, "destroy", trigger_unitmessage(mage,
|
||||||
"Ein Alp starb, ohne sein Ziel zu erreichen.", MSG_EVENT, ML_INFO));
|
"Ein Alp starb, ohne sein Ziel zu erreichen.", MSG_EVENT, ML_INFO));
|
||||||
/* Wenn Opfer oder Magier nicht mehr existieren, dann stirbt der Alp */
|
/* Wenn Opfer oder Magier nicht mehr existieren, dann stirbt der Alp */
|
||||||
add_trigger(&mage->attribs, "destroy", trigger_killunit(alp));
|
add_trigger(&mage->attribs, "destroy", trigger_killunit(alp));
|
||||||
add_trigger(&opfer->attribs, "destroy", trigger_killunit(alp));
|
add_trigger(&opfer->attribs, "destroy", trigger_killunit(alp));
|
||||||
}
|
}
|
||||||
sprintf(buf, "%s beschwört den Alp %s für %s.", unitname(mage),
|
sprintf(buf, "%s beschwört den Alp %s für %s.", unitname(mage),
|
||||||
unitname(alp), unitname(opfer));
|
unitname(alp), unitname(opfer));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_INFO);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_INFO);
|
||||||
|
|
||||||
return cast_level;
|
return cast_level;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -737,7 +737,7 @@ sp_shadowcall(fighter * fi, int level, double power, spell * sp)
|
||||||
unused(sp);
|
unused(sp);
|
||||||
|
|
||||||
u = create_unit(r, mage->faction, force, rc, 0, NULL, mage);
|
u = create_unit(r, mage->faction, force, rc, 0, NULL, mage);
|
||||||
u->status = ST_FIGHT;
|
setstatus(u, ST_FIGHT);
|
||||||
|
|
||||||
set_string(&u->name, racename(mage->faction->locale, u, u->race));
|
set_string(&u->name, racename(mage->faction->locale, u, u->race));
|
||||||
set_level(u, SK_WEAPONLESS, (int)(power/2));
|
set_level(u, SK_WEAPONLESS, (int)(power/2));
|
||||||
|
@ -767,7 +767,7 @@ sp_wolfhowl(fighter * fi, int level, double power, spell * sp)
|
||||||
unit *u = create_unit(r, mage->faction, force, new_race[RC_WOLF], 0, NULL, mage);
|
unit *u = create_unit(r, mage->faction, force, new_race[RC_WOLF], 0, NULL, mage);
|
||||||
unused(sp);
|
unused(sp);
|
||||||
|
|
||||||
u->status = ST_FIGHT;
|
setstatus(u, ST_FIGHT);
|
||||||
|
|
||||||
set_string(&u->name, racename(mage->faction->locale, u, u->race));
|
set_string(&u->name, racename(mage->faction->locale, u, u->race));
|
||||||
set_level(u, SK_WEAPONLESS, (int)(power/3));
|
set_level(u, SK_WEAPONLESS, (int)(power/3));
|
||||||
|
@ -802,7 +802,7 @@ sp_shadowknights(fighter * fi, int level, double power, spell * sp)
|
||||||
unused(sp);
|
unused(sp);
|
||||||
|
|
||||||
u = create_unit(r, mage->faction, force, new_race[RC_SHADOWKNIGHT], 0, NULL, mage);
|
u = create_unit(r, mage->faction, force, new_race[RC_SHADOWKNIGHT], 0, NULL, mage);
|
||||||
u->status = ST_FIGHT;
|
setstatus(u, ST_FIGHT);
|
||||||
|
|
||||||
set_string(&u->name, "Schattenritter");
|
set_string(&u->name, "Schattenritter");
|
||||||
u->hp = u->number * unit_max_hp(u);
|
u->hp = u->number * unit_max_hp(u);
|
||||||
|
@ -1683,7 +1683,7 @@ sp_undeadhero(fighter * fi, int level, double power, spell * sp)
|
||||||
/* new units gets some stats from old unit */
|
/* new units gets some stats from old unit */
|
||||||
set_string(&u->name, du->name);
|
set_string(&u->name, du->name);
|
||||||
set_string(&u->display, du->display);
|
set_string(&u->display, du->display);
|
||||||
u->status = du->status;
|
setstatus(u, du->status);
|
||||||
setguard(u, GUARD_NONE);
|
setguard(u, GUARD_NONE);
|
||||||
|
|
||||||
/* inherit stealth from magician */
|
/* inherit stealth from magician */
|
||||||
|
|
|
@ -575,7 +575,7 @@ sp_summon_familiar(castorder *co)
|
||||||
familiar->building = mage->building;
|
familiar->building = mage->building;
|
||||||
familiar->ship = mage->ship;
|
familiar->ship = mage->ship;
|
||||||
}
|
}
|
||||||
familiar->status = ST_FLEE; /* flieht */
|
setstatus(familiar, ST_FLEE);
|
||||||
sprintf(buf, "Vertrauter von %s", unitname(mage));
|
sprintf(buf, "Vertrauter von %s", unitname(mage));
|
||||||
set_string(&familiar->name, buf);
|
set_string(&familiar->name, buf);
|
||||||
if (fval(mage, UFL_PARTEITARNUNG)) fset(familiar, UFL_PARTEITARNUNG);
|
if (fval(mage, UFL_PARTEITARNUNG)) fset(familiar, UFL_PARTEITARNUNG);
|
||||||
|
@ -2222,7 +2222,7 @@ sp_ironkeeper(castorder *co)
|
||||||
/*keeper->age = cast_level + 2;*/
|
/*keeper->age = cast_level + 2;*/
|
||||||
guard(keeper, GUARD_MINING);
|
guard(keeper, GUARD_MINING);
|
||||||
fset(keeper, UFL_ISNEW);
|
fset(keeper, UFL_ISNEW);
|
||||||
keeper->status = ST_AVOID; /* kaempft nicht */
|
setstatus(keeper, ST_AVOID); /* kaempft nicht */
|
||||||
/* Parteitarnen, damit man nicht sofort weiß, wer dahinter steckt */
|
/* Parteitarnen, damit man nicht sofort weiß, wer dahinter steckt */
|
||||||
fset(keeper, UFL_PARTEITARNUNG);
|
fset(keeper, UFL_PARTEITARNUNG);
|
||||||
{
|
{
|
||||||
|
@ -5291,7 +5291,7 @@ sp_clonecopy(castorder *co)
|
||||||
|
|
||||||
sprintf(buf, "Klon von %s", unitname(mage));
|
sprintf(buf, "Klon von %s", unitname(mage));
|
||||||
clone = create_unit(target_region, mage->faction, 1, new_race[RC_CLONE], 0, buf, mage);
|
clone = create_unit(target_region, mage->faction, 1, new_race[RC_CLONE], 0, buf, mage);
|
||||||
clone->status = ST_FLEE;
|
setstatus(clone, ST_FLEE);
|
||||||
fset(clone, UFL_LOCKED);
|
fset(clone, UFL_LOCKED);
|
||||||
|
|
||||||
create_newclone(mage, clone);
|
create_newclone(mage, clone);
|
||||||
|
|
|
@ -2803,6 +2803,17 @@
|
||||||
<text locale="en">"$unit($unit) drowns when $ship($ship) in $region($region) sinks."</text>
|
<text locale="en">"$unit($unit) drowns when $ship($ship) in $region($region) sinks."</text>
|
||||||
</message>
|
</message>
|
||||||
|
|
||||||
|
<message name="error320" section="errors">
|
||||||
|
<type>
|
||||||
|
<arg name="unit" type="unit"/>
|
||||||
|
<arg name="region" type="region"/>
|
||||||
|
<arg name="command" type="order"/>
|
||||||
|
</type>
|
||||||
|
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Die Einheit kann nicht bewachen, da sie veruscht zu fliehen."</text>
|
||||||
|
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The unit cannot guard the region because it's trying to flee."</text>
|
||||||
|
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The unit cannot guard the region because it's trying to flee."</text>
|
||||||
|
</message>
|
||||||
|
|
||||||
<message name="error319" section="errors">
|
<message name="error319" section="errors">
|
||||||
<type>
|
<type>
|
||||||
<arg name="unit" type="unit"/>
|
<arg name="unit" type="unit"/>
|
||||||
|
|
Loading…
Reference in a new issue