- delayed use of potions.

- combat bonus for ships
- new ship types
- new capacity rules for ships
- E3 island smoothing
This commit is contained in:
Enno Rehling 2009-06-25 19:40:10 +00:00
parent 8861fdfa7e
commit 6a6df68b5d
21 changed files with 517 additions and 127 deletions

View file

@ -1,7 +1,7 @@
/* vi: set ts=2: /* vi: set ts=2:
* *
* *
* Eressea PB(E)M host Copyright (C) 1998-2003 * Eressea PB(E)M host Copyright (C) 1998-2003
* Christian Schlittchen (corwin@amber.kn-bremen.de) * Christian Schlittchen (corwin@amber.kn-bremen.de)
* Katja Zedel (katze@felidae.kn-bremen.de) * Katja Zedel (katze@felidae.kn-bremen.de)
* Henning Peters (faroul@beyond.kn-bremen.de) * Henning Peters (faroul@beyond.kn-bremen.de)
@ -90,20 +90,41 @@ herbsearch(region * r, unit * u, int max)
} }
} }
int static int
use_potion(unit * u, const item_type * itype, int amount, struct order *ord) begin_potion(unit * u, const potion_type * ptype, struct order *ord)
{ {
const potion_type * ptype = resource2potion(itype->rtype); static int rule_multipotion = -1;
const potion_type * use = ugetpotionuse(u);
assert(ptype!=NULL); assert(ptype!=NULL);
if (use != NULL && use!=ptype) { if (rule_multipotion<0) {
ADDMSG(&u->faction->msgs, /* should we allow multiple different potions to be used the same turn? */
msg_message("errusingpotion", "unit using command", rule_multipotion = get_param_int(global.parameters, "rules.magic.multipotion", 0);
u, use->itype->rtype, ord));
return ECUSTOM;
} }
if (!rule_multipotion) {
const potion_type * use = ugetpotionuse(u);
if (use != NULL && use!=ptype) {
ADDMSG(&u->faction->msgs,
msg_message("errusingpotion", "unit using command",
u, use->itype->rtype, ord));
return ECUSTOM;
}
}
return 0;
}
static void
end_potion(unit * u, const potion_type * ptype, int amount)
{
use_pooled(u, ptype->itype->rtype, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK, amount);
usetpotionuse(u, ptype);
ADDMSG(&u->faction->msgs, msg_message("usepotion",
"unit potion", u, ptype->itype->rtype));
}
void
do_potion(unit * u, const potion_type * ptype, int amount)
{
if (ptype==oldpotiontype[P_LIFE]) { if (ptype==oldpotiontype[P_LIFE]) {
region * r = u->region; region * r = u->region;
int holz = 0; int holz = 0;
@ -125,8 +146,6 @@ use_potion(unit * u, const item_type * itype, int amount, struct order *ord)
rsettrees(r, 1, rtrees(r, 1) + holz); rsettrees(r, 1, rtrees(r, 1) + holz);
ADDMSG(&u->faction->msgs, msg_message("growtree_effect", ADDMSG(&u->faction->msgs, msg_message("growtree_effect",
"mage amount", u, holz)); "mage amount", u, holz));
} else if (ptype==oldpotiontype[P_HEAL]) {
return EUNUSABLE;
} else if (ptype==oldpotiontype[P_HEILWASSER]) { } else if (ptype==oldpotiontype[P_HEILWASSER]) {
u->hp = MIN(unit_max_hp(u) * u->number, u->hp + 400 * amount); u->hp = MIN(unit_max_hp(u) * u->number, u->hp + 400 * amount);
} else if (ptype==oldpotiontype[P_PEOPLE]) { } else if (ptype==oldpotiontype[P_PEOPLE]) {
@ -148,11 +167,72 @@ use_potion(unit * u, const item_type * itype, int amount, struct order *ord)
} else { } else {
change_effect(u, ptype, 10*amount); change_effect(u, ptype, 10*amount);
} }
use_pooled(u, ptype->itype->rtype, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK, amount); }
usetpotionuse(u, ptype);
ADDMSG(&u->faction->msgs, msg_message("usepotion", int
"unit potion", u, ptype->itype->rtype)); use_potion(unit * u, const item_type * itype, int amount, struct order *ord)
{
const potion_type * ptype = resource2potion(itype->rtype);
if (ptype==oldpotiontype[P_HEAL]) {
return EUNUSABLE;
} else {
int result = begin_potion(u, ptype, ord);
if (result) return result;
do_potion(u, ptype, amount);
end_potion(u, ptype, amount);
}
return 0;
}
typedef struct potiondelay {
unit * u;
const potion_type * ptype;
int amount;
} potiondelay;
static void init_potiondelay(attrib * a) {
a->data.v = malloc(sizeof(potiondelay));
}
static void free_potiondelay(attrib * a) {
free(a->data.v);
}
static int age_potiondelay(attrib * a) {
potiondelay * pd = (potiondelay *)a->data.v;
do_potion(pd->u, pd->ptype, pd->amount);
return AT_AGE_REMOVE;
}
attrib_type at_potiondelay = {
"eventhandler",
init_potiondelay,
free_potiondelay,
age_potiondelay, 0, 0
};
static attrib *
make_potiondelay(unit * u, const potion_type* ptype, int amount)
{
attrib * a = a_new(&at_potiondelay);
potiondelay * pd = (potiondelay *)a->data.v;
pd->u = u;
pd->ptype = ptype;
pd->amount = amount;
return a;
}
static int
use_wateroflife_delayed(unit * u, const item_type * itype, int amount, struct order *ord)
{
const potion_type * ptype = resource2potion(itype->rtype);
int result = begin_potion(u, ptype, ord);
if (result) return result;
a_add(&u->attribs, make_potiondelay(u, ptype, amount));
end_potion(u, ptype, amount);
return 0; return 0;
} }
@ -163,21 +243,21 @@ use_potion(unit * u, const item_type * itype, int amount, struct order *ord)
static void static void
a_initeffect(attrib *a) a_initeffect(attrib *a)
{ {
a->data.v = calloc(sizeof(effect_data), 1); a->data.v = calloc(sizeof(effect_data), 1);
} }
static void static void
a_finalizeeffect(attrib * a) a_finalizeeffect(attrib * a)
{ {
free(a->data.v); free(a->data.v);
} }
static void static void
a_writeeffect(const attrib *a, storage * store) a_writeeffect(const attrib *a, storage * store)
{ {
effect_data * edata = (effect_data*)a->data.v; effect_data * edata = (effect_data*)a->data.v;
store->w_tok(store, resourcename(edata->type->itype->rtype, 0)); store->w_tok(store, resourcename(edata->type->itype->rtype, 0));
store->w_int(store, edata->value); store->w_int(store, edata->value);
} }
static int static int
@ -201,23 +281,23 @@ a_readeffect(attrib *a, storage * store)
} }
attrib_type at_effect = { attrib_type at_effect = {
"effect", "effect",
a_initeffect, a_initeffect,
a_finalizeeffect, a_finalizeeffect,
DEFAULT_AGE, DEFAULT_AGE,
a_writeeffect, a_writeeffect,
a_readeffect, a_readeffect,
}; };
int int
get_effect(const unit * u, const potion_type * effect) get_effect(const unit * u, const potion_type * effect)
{ {
const attrib * a; const attrib * a;
for (a=a_find(u->attribs, &at_effect); a!=NULL && a->type==&at_effect; a=a->next) { for (a=a_find(u->attribs, &at_effect); a!=NULL && a->type==&at_effect; a=a->next) {
const effect_data * data = (const effect_data *)a->data.v; const effect_data * data = (const effect_data *)a->data.v;
if (data->type==effect) return data->value; if (data->type==effect) return data->value;
} }
return 0; return 0;
} }
int int

View file

@ -58,11 +58,12 @@ extern void init_potions(void);
extern int get_effect(const struct unit * u, const struct potion_type * effect); extern int get_effect(const struct unit * u, const struct potion_type * effect);
extern int change_effect(struct unit * u, const struct potion_type * effect, int value); extern int change_effect(struct unit * u, const struct potion_type * effect, int value);
extern struct attrib_type at_effect; extern struct attrib_type at_effect;
extern struct attrib_type at_potiondelay;
/* rausnehmen, sobald man attribute splitten kann: */ /* rausnehmen, sobald man attribute splitten kann: */
typedef struct effect_data { typedef struct effect_data {
const struct potion_type * type; const struct potion_type * type;
int value; int value;
} effect_data; } effect_data;
#ifdef __cplusplus #ifdef __cplusplus

View file

@ -683,8 +683,10 @@ weapon_skill(const weapon_type * wtype, const unit * u, boolean attacking)
} }
if (attacking) { if (attacking) {
skill += u->race->at_bonus; skill += u->race->at_bonus;
if (u->ship) skill += u->ship->type->at_bonus;
} else { } else {
skill += u->race->df_bonus; skill += u->race->df_bonus;
if (u->ship) skill += u->ship->type->df_bonus;
} }
} else { } else {
/* changed: if we own a weapon, we have at least a skill of 0 */ /* changed: if we own a weapon, we have at least a skill of 0 */
@ -1583,6 +1585,8 @@ select_opponent(battle * b, troop at, int mindist, int maxdist)
int tactics = get_tactics(dt.fighter->side); int tactics = get_tactics(dt.fighter->side);
/* percentage chance to get this attack */ /* percentage chance to get this attack */
double tacch = 0.1 * (b->max_tactics - tactics); double tacch = 0.1 * (b->max_tactics - tactics);
ship * sh = at.fighter->unit->ship;
if (sh) tacch *= sh->type->tac_bonus;
if (!chance(tacch)) { if (!chance(tacch)) {
dt.fighter = NULL; dt.fighter = NULL;
} }

View file

@ -1170,13 +1170,27 @@ enter_ship(unit * u, struct order * ord, int id, boolean report)
return false; return false;
} }
if (CheckOverload()) { if (CheckOverload()) {
static int rule_capacity = -1;
int sweight, scabins; int sweight, scabins;
int mweight = shipcapacity(sh); int mweight = shipcapacity(sh);
int mcabins = sh->type->cabins; int mcabins = sh->type->cabins;
if (rule_capacity<0) {
rule_capacity = get_param_int(global.parameters, "rules.ship.capacity", 0);
}
if (rule_capacity!=0) {
mcabins *= PERSON_WEIGHT;
}
if (mweight>0 && mcabins>0) { if (mweight>0 && mcabins>0) {
getshipweight(sh, &sweight, &scabins); getshipweight(sh, &sweight, &scabins);
sweight += weight(u); sweight += weight(u);
scabins += u->number; if (rule_capacity==0) {
scabins += u->number;
} else {
/* weight goes into number of cabins, not cargo */
scabins += u->number * u->race->weight;
sweight -= u->number * u->race->weight;
}
if (sweight > mweight || scabins > mcabins) { if (sweight > mweight || scabins > mcabins) {
if (report) cmistake(u, ord, 34, MSG_MOVE); if (report) cmistake(u, ord, 34, MSG_MOVE);

View file

@ -2955,6 +2955,7 @@ attrib_init(void)
/* neue UNIT-Attribute */ /* neue UNIT-Attribute */
at_register(&at_siege); at_register(&at_siege);
at_register(&at_effect); at_register(&at_effect);
at_register(&at_potiondelay);
at_register(&at_private); at_register(&at_private);
at_register(&at_icastle); at_register(&at_icastle);

View file

@ -85,6 +85,7 @@ extern "C" {
#define BP_NORMAL 3 #define BP_NORMAL 3
#define BP_ROAD 2 #define BP_ROAD 2
#define PERSON_WEIGHT 1000 /* weight of a "normal" human unit */
#define STAMINA_AFFECTS_HP 1<<0 #define STAMINA_AFFECTS_HP 1<<0
/** /**

View file

@ -1677,7 +1677,7 @@ sail(unit * u, order * ord, boolean move_on_land, region_list **routep)
stormchance = stormyness / shipspeed(sh, u); stormchance = stormyness / shipspeed(sh, u);
if (check_leuchtturm(next_point, NULL)) stormchance /= 3; if (check_leuchtturm(next_point, NULL)) stormchance /= 3;
if (rng_int()%10000 < stormchance && fval(current_point->terrain, SEA_REGION)) { if (rng_int()%10000 < stormchance*sh->type->storm && fval(current_point->terrain, SEA_REGION)) {
if (!is_cursed(sh->attribs, C_SHIP_NODRIFT, 0)) { if (!is_cursed(sh->attribs, C_SHIP_NODRIFT, 0)) {
region * rnext = NULL; region * rnext = NULL;
boolean storm = true; boolean storm = true;
@ -1987,6 +1987,16 @@ travel(unit * u, region_list ** routep)
/* a few pre-checks that need not be done for each step: */ /* a few pre-checks that need not be done for each step: */
if (!fval(r->terrain, SEA_REGION)) { if (!fval(r->terrain, SEA_REGION)) {
ship * sh = u->ship; ship * sh = u->ship;
static int rule_leave = -1;
if (rule_leave<0) {
rule_leave = get_param_int(global.parameters, "rules.move.owner_leave", 0);
}
if (rule_leave && u->building && u==buildingowner(u->region, u->building)) {
cmistake(u, u->thisorder, 150, MSG_MOVE);
return;
}
/* An Land kein NACH wenn in dieser Runde Schiff VERLASSEN! */ /* An Land kein NACH wenn in dieser Runde Schiff VERLASSEN! */
if (sh == NULL) { if (sh == NULL) {
sh = leftship(u); sh = leftship(u);

View file

@ -72,10 +72,10 @@ typedef struct race {
int hitpoints; int hitpoints;
const char *def_damage; const char *def_damage;
char armor; char armor;
char at_default; /* Angriffsskill Unbewaffnet (default: -2)*/ int at_default; /* Angriffsskill Unbewaffnet (default: -2)*/
char df_default; /* Verteidigungsskill Unbewaffnet (default: -2)*/ int df_default; /* Verteidigungsskill Unbewaffnet (default: -2)*/
char at_bonus; /* Verändert den Angriffsskill (default: 0)*/ int at_bonus; /* Verändert den Angriffsskill (default: 0)*/
char df_bonus; /* Verändert den Verteidigungskill (default: 0)*/ int df_bonus; /* Verändert den Verteidigungskill (default: 0)*/
const spell * precombatspell; const spell * precombatspell;
struct att attack[10]; struct att attack[10];
char bonus[MAXSKILLS]; char bonus[MAXSKILLS];

View file

@ -1,7 +1,7 @@
/* vi: set ts=2: /* vi: set ts=2:
* *
* *
* Eressea PB(E)M host Copyright (C) 1998-2003 * Eressea PB(E)M host Copyright (C) 1998-2003
* Christian Schlittchen (corwin@amber.kn-bremen.de) * Christian Schlittchen (corwin@amber.kn-bremen.de)
* Katja Zedel (katze@felidae.kn-bremen.de) * Katja Zedel (katze@felidae.kn-bremen.de)
* Henning Peters (faroul@beyond.kn-bremen.de) * Henning Peters (faroul@beyond.kn-bremen.de)
@ -27,30 +27,34 @@ extern "C" {
#define SFL_FLY 0x02 #define SFL_FLY 0x02
typedef struct ship_type { typedef struct ship_type {
const char * name[2]; const char * name[2];
int range; /* range in regions */ int range; /* range in regions */
int flags; /* flags */ int flags; /* flags */
int combat; /* modifier for combat */ int combat; /* modifier for combat */
double storm; /* multiplier for chance to drift in storm */ double storm; /* multiplier for chance to drift in storm */
double damage; /* multiplier for damage taken by the ship */ double damage; /* multiplier for damage taken by the ship */
int cabins; /* max. cabins (people) */ int cabins; /* max. cabins (people) */
int cargo; /* max. cargo (weight) */ int cargo; /* max. cargo (weight) */
int cptskill; /* min. skill of captain */ int cptskill; /* min. skill of captain */
int minskill; /* min. skill to sail this (crew) */ int minskill; /* min. skill to sail this (crew) */
int sumskill; /* min. sum of crew+captain */ int sumskill; /* min. sum of crew+captain */
const struct terrain_type ** coasts; /* coast that this ship can land on */ int at_bonus; /* Verändert den Angriffsskill (default: 0)*/
int df_bonus; /* Verändert den Verteidigungskill (default: 0)*/
float tac_bonus;
struct construction * construction; /* how to build a ship */ const struct terrain_type ** coasts; /* coast that this ship can land on */
struct construction * construction; /* how to build a ship */
} ship_type; } ship_type;
typedef struct ship_typelist { typedef struct ship_typelist {
struct ship_typelist * next; struct ship_typelist * next;
const ship_type * type; const ship_type * type;
} ship_typelist; } ship_typelist;
extern ship_typelist *shiptypes; extern ship_typelist *shiptypes;
@ -68,18 +72,18 @@ extern void st_register(const ship_type * type);
#define SF_SELECT 1<<3 /* previously FL_DH */ #define SF_SELECT 1<<3 /* previously FL_DH */
typedef struct ship { typedef struct ship {
struct ship *next; struct ship *next;
struct ship *nexthash; struct ship *nexthash;
int no; int no;
struct region *region; struct region *region;
char *name; char *name;
char *display; char *display;
struct attrib * attribs; struct attrib * attribs;
int size; int size;
int damage; /* damage in 100th of a point of size */ int damage; /* damage in 100th of a point of size */
unsigned int flags; unsigned int flags;
const struct ship_type * type; const struct ship_type * type;
direction_t coast; direction_t coast;
} ship; } ship;
extern void damage_ship(ship *sh, double percent); extern void damage_ship(ship *sh, double percent);

View file

@ -513,7 +513,7 @@ parse_ships(xmlDocPtr doc)
if (ships->nodesetval!=NULL) { if (ships->nodesetval!=NULL) {
xmlNodeSetPtr nodes = ships->nodesetval; xmlNodeSetPtr nodes = ships->nodesetval;
for (i=0;i!=nodes->nodeNr;++i) { for (i=0;i!=nodes->nodeNr;++i) {
xmlNodePtr node = nodes->nodeTab[i]; xmlNodePtr child, node = nodes->nodeTab[i];
xmlChar * propValue; xmlChar * propValue;
ship_type * st = calloc(sizeof(ship_type), 1); ship_type * st = calloc(sizeof(ship_type), 1);
xmlXPathObjectPtr result; xmlXPathObjectPtr result;
@ -537,13 +537,23 @@ parse_ships(xmlDocPtr doc)
st->storm = xml_fvalue(node, "storm", 1.0); st->storm = xml_fvalue(node, "storm", 1.0);
st->sumskill = xml_ivalue(node, "sumskill", 0); st->sumskill = xml_ivalue(node, "sumskill", 0);
/* reading eressea/ships/ship/construction */ /* reading eressea/ships/ship/construction */
xpath->node = node; xpath->node = node;
result = xmlXPathEvalExpression(BAD_CAST "construction", xpath); result = xmlXPathEvalExpression(BAD_CAST "construction", xpath);
xml_readconstruction(xpath, result->nodesetval, &st->construction); xml_readconstruction(xpath, result->nodesetval, &st->construction);
xmlXPathFreeObject(result); xmlXPathFreeObject(result);
/* reading eressea/ships/ship/coast */ for (child=node->children;child;child=child->next) {
if (strcmp((const char *)child->name, "modifier")==0) {
double value = xml_fvalue(child, "value", 0.0);
propValue = xmlGetProp(child, BAD_CAST "type");
if (strcmp((const char *)propValue, "tactics")==0) st->tac_bonus = (float)value;
else if (strcmp((const char *)propValue, "attack")==0) st->at_bonus = (int)value;
else if (strcmp((const char *)propValue, "defense")==0) st->df_bonus = (int)value;
xmlFree(propValue);
}
}
/* reading eressea/ships/ship/coast */
xpath->node = node; xpath->node = node;
result = xmlXPathEvalExpression(BAD_CAST "coast", xpath); result = xmlXPathEvalExpression(BAD_CAST "coast", xpath);
for (c=0,k=0;k!=result->nodesetval->nodeNr;++k) { for (c=0,k=0;k!=result->nodesetval->nodeNr;++k) {
@ -1567,7 +1577,7 @@ parse_races(xmlDocPtr doc)
rc->regaura = (float)xml_fvalue(node, "regaura", 1.0); rc->regaura = (float)xml_fvalue(node, "regaura", 1.0);
rc->recruitcost = xml_ivalue(node, "recruitcost", 0); rc->recruitcost = xml_ivalue(node, "recruitcost", 0);
rc->maintenance = xml_ivalue(node, "maintenance", 0); rc->maintenance = xml_ivalue(node, "maintenance", 0);
rc->weight = xml_ivalue(node, "weight", 0); rc->weight = xml_ivalue(node, "weight", PERSON_WEIGHT);
rc->capacity = xml_ivalue(node, "capacity", 540); rc->capacity = xml_ivalue(node, "capacity", 540);
rc->speed = (float)xml_fvalue(node, "speed", 1.0F); rc->speed = (float)xml_fvalue(node, "speed", 1.0F);
rc->hitpoints = xml_ivalue(node, "hp", 0); rc->hitpoints = xml_ivalue(node, "hp", 0);
@ -1645,7 +1655,7 @@ parse_races(xmlDocPtr doc)
rc->bonus[sk] = (char)mod; rc->bonus[sk] = (char)mod;
if (speed) { if (speed) {
if (!rc->study_speed) rc->study_speed = calloc(1, MAXSKILLS); if (!rc->study_speed) rc->study_speed = calloc(1, MAXSKILLS);
rc->study_speed[sk] = speed; rc->study_speed[sk] = (char)speed;
} }
} else { } else {
log_error(("unknown skill '%s' in race '%s'\n", log_error(("unknown skill '%s' in race '%s'\n",

View file

@ -775,7 +775,7 @@ static struct geo {
{ 3, T_SWAMP }, { 3, T_SWAMP },
{ 1, T_VOLCANO }, { 1, T_VOLCANO },
{ 3, T_DESERT }, { 3, T_DESERT },
{ 3, T_HIGHLAND }, { 4, T_HIGHLAND },
{ 3, T_MOUNTAIN }, { 3, T_MOUNTAIN },
{ 2, T_GLACIER }, { 2, T_GLACIER },
{ 1, T_PLAIN } { 1, T_PLAIN }
@ -831,13 +831,61 @@ int region_quality(const region * r)
get_neighbours(r, rn); get_neighbours(r, rn);
for (n=0;n!=MAXDIRECTIONS;++n) { for (n=0;n!=MAXDIRECTIONS;++n) {
if (rn[n] && rn[n]->land) { if (rn[n] && rn[n]->land) {
if (rn[n]->terrain==newterrain(T_VOLCANO)) {
/* nobody likes volcanoes */
result -= 2000;
}
result += rn[n]->land->peasants; result += rn[n]->land->peasants;
} }
} }
// result += r->land->peasants * 2;
return result; return result;
} }
static void smooth_island(region_list * island)
{
region * rn[MAXDIRECTIONS];
region_list * rlist = NULL;
for (rlist=island;rlist;rlist=rlist->next) {
region * r = rlist->data;
int n, nland = 0;
assert(r->land);
get_neighbours(r, rn);
for (n=0;n!=MAXDIRECTIONS && nland<=1;++n) {
if (rn[n]->land) {
++nland;
r = rn[n];
}
}
if (nland==1) {
get_neighbours(r, rn);
for (n=0;n!=MAXDIRECTIONS;++n) {
int n1 = (n+1)%MAXDIRECTIONS;
int n2 = (n+1+MAXDIRECTIONS)%MAXDIRECTIONS;
if (!rn[n]->land && rn[n1]!=r && rn[n2]!=r) {
r = rlist->data;
runhash(r);
runhash(rn[n]);
SWAP(short, r->x, rn[n]->x);
SWAP(short, r->y, rn[n]->y);
rhash(r);
rhash(rn[n]);
rlist->data = r;
for (n=0;n!=MAXDIRECTIONS;++n) {
region * rx = rconnect(r, n);
if (rx==NULL) {
rx = new_region(r->x+delta_x[n], r->y+delta_y[n], 0);
terraform_region(rx, newterrain(T_OCEAN));
}
}
break;
}
}
}
}
}
/* E3A island generation */ /* E3A island generation */
int int
build_island_e3(short x, short y, int numfactions, int minsize) build_island_e3(short x, short y, int numfactions, int minsize)
@ -863,6 +911,9 @@ build_island_e3(short x, short y, int numfactions, int minsize)
} }
r = regionqueue_pop(&rlist); r = regionqueue_pop(&rlist);
} }
smooth_island(island);
for (rlist=island;rlist;rlist=rlist->next) { for (rlist=island;rlist;rlist=rlist->next) {
r = rlist->data; r = rlist->data;
if (fval(r, RF_MARK)) { if (fval(r, RF_MARK)) {
@ -876,11 +927,12 @@ build_island_e3(short x, short y, int numfactions, int minsize)
freset(rn[n], RF_MARK); freset(rn[n], RF_MARK);
} }
q = region_quality(r); q = region_quality(r);
if (q>1500 && nfactions<numfactions) { if (q>=1000 && nfactions<numfactions) {
terraform_region(r, newterrain(T_PLAIN)); terraform_region(r, newterrain(T_PLAIN));
minq = MIN(minq, q); minq = MIN(minq, q);
maxq = MAX(maxq, q); maxq = MAX(maxq, q);
prepare_starting_region(r); prepare_starting_region(r);
r->land->money = 50 * 1000; /* 2% = 1000 silver */
u = addplayer(r, addfaction("enno@eressea.de", itoa36(rng_int()), races, u = addplayer(r, addfaction("enno@eressea.de", itoa36(rng_int()), races,
default_locale, 0)); default_locale, 0));
++nfactions; ++nfactions;

View file

@ -1,7 +1,7 @@
/* vi: set ts=2: /* vi: set ts=2:
* *
* *
* Eressea PB(E)M host Copyright (C) 1998-2003 * Eressea PB(E)M host Copyright (C) 1998-2003
* Christian Schlittchen (corwin@amber.kn-bremen.de) * Christian Schlittchen (corwin@amber.kn-bremen.de)
* Katja Zedel (katze@felidae.kn-bremen.de) * Katja Zedel (katze@felidae.kn-bremen.de)
* Henning Peters (faroul@beyond.kn-bremen.de) * Henning Peters (faroul@beyond.kn-bremen.de)
@ -22,20 +22,20 @@ struct storage;
typedef void (*afun)(void); typedef void (*afun)(void);
typedef struct attrib { typedef struct attrib {
const struct attrib_type * type; const struct attrib_type * type;
union { union {
afun f; afun f;
void * v; void * v;
int i; int i;
float flt; float flt;
char c; char c;
short s; short s;
short sa[2]; short sa[2];
char ca[4]; char ca[4];
} data; } data;
/* internal data, do not modify: */ /* internal data, do not modify: */
struct attrib * next; /* next attribute in the list */ struct attrib * next; /* next attribute in the list */
struct attrib * nexttype; /* skip to attribute of a different type */ struct attrib * nexttype; /* skip to attribute of a different type */
} attrib; } attrib;
#define ATF_UNIQUE (1<<0) /* only one per attribute-list */ #define ATF_UNIQUE (1<<0) /* only one per attribute-list */
@ -43,17 +43,17 @@ typedef struct attrib {
#define ATF_USER_DEFINED (1<<2) /* use this to make udf */ #define ATF_USER_DEFINED (1<<2) /* use this to make udf */
typedef struct attrib_type { typedef struct attrib_type {
const char* name; const char* name;
void (*initialize)(struct attrib *); void (*initialize)(struct attrib *);
void (*finalize)(struct attrib *); void (*finalize)(struct attrib *);
int (*age)(struct attrib *); int (*age)(struct attrib *);
/* age returns 0 if the attribute needs to be removed, !=0 otherwise */ /* age returns 0 if the attribute needs to be removed, !=0 otherwise */
void (*write)(const struct attrib *, struct storage *); void (*write)(const struct attrib *, struct storage *);
int (*read)(struct attrib *, struct storage *); /* return AT_READ_OK on success, AT_READ_FAIL if attrib needs removal */ int (*read)(struct attrib *, struct storage *); /* return AT_READ_OK on success, AT_READ_FAIL if attrib needs removal */
unsigned int flags; unsigned int flags;
/* ---- internal data, do not modify: ---- */ /* ---- internal data, do not modify: ---- */
struct attrib_type * nexthash; struct attrib_type * nexthash;
unsigned int hashkey; unsigned int hashkey;
} attrib_type; } attrib_type;
extern void at_register(attrib_type * at); extern void at_register(attrib_type * at);

View file

@ -52,6 +52,7 @@ extern unsigned int wang_hash(unsigned int a);
#define HASH1 JENKINS_HASH1 #define HASH1 JENKINS_HASH1
#define HASH2 JENKINS_HASH2 #define HASH2 JENKINS_HASH2
#define SWAP(T, a, b) { T x = a; a = b; b = x; }
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View file

@ -792,7 +792,7 @@ handlekey(state * st, int c)
make_block((short)st->cursor.x, (short)st->cursor.y, 6, select_terrain(st, NULL)); make_block((short)st->cursor.x, (short)st->cursor.y, 6, select_terrain(st, NULL));
*/ */
n = rng_int() % 8 + 8; n = rng_int() % 8 + 8;
build_island_e3((short)st->cursor.x, (short)st->cursor.y, n, n*4); build_island_e3((short)st->cursor.x, (short)st->cursor.y, n, n*3);
st->modified = 1; st->modified = 1;
st->wnd_info->update |= 1; st->wnd_info->update |= 1;
st->wnd_status->update |= 1; st->wnd_status->update |= 1;

View file

@ -50,7 +50,7 @@
<item weight="0" score="10" herb="yes"/> <item weight="0" score="10" herb="yes"/>
</resource> </resource>
<resource name="h12" appearance="herbbag"> <resource name="h12" appearance="herbbag"><!-- Windbeutel -->
<item weight="0" score="10" herb="yes"/> <item weight="0" score="10" herb="yes"/>
</resource> </resource>
@ -58,7 +58,7 @@
<item weight="0" score="10" herb="yes"/> <item weight="0" score="10" herb="yes"/>
</resource> </resource>
<resource name="h14" appearance="herbbag"> <resource name="h14" appearance="herbbag"><!-- Alraune -->
<item weight="0" score="10" herb="yes"/> <item weight="0" score="10" herb="yes"/>
</resource> </resource>

View file

@ -15,13 +15,15 @@
<!--xi:include href="common/potions.xml" /--> <!--xi:include href="common/potions.xml" /-->
<xi:include href="spoils.xml"/> <xi:include href="spoils.xml"/>
<xi:include href="prefixes.xml"/> <xi:include href="prefixes.xml"/>
<xi:include href="ships.xml"/> <!--xi:include href="ships.xml"/-->
<xi:include href="buildings.xml"/> <xi:include href="buildings.xml"/>
<xi:include href="equipment.xml"/> <xi:include href="equipment.xml"/>
<!--xi:include href="terrains.xml"/--> <!--xi:include href="terrains.xml"/-->
<xi:include href="dungeons.xml"/> <xi:include href="dungeons.xml"/>
<xi:include href="directions.xml"/> <xi:include href="directions.xml"/>
<xi:include href="e2k9/ships.xml"/>
<xi:include href="e2k9/shipnames.xml"/>
<xi:include href="e2k9/terrains.xml"/> <xi:include href="e2k9/terrains.xml"/>
<xi:include href="e2k9/calendar.xml"/> <xi:include href="e2k9/calendar.xml"/>
<xi:include href="e2k9/items.xml" /> <xi:include href="e2k9/items.xml" />
@ -130,14 +132,17 @@
<param name="study.speedup" value="1"/> <param name="study.speedup" value="1"/>
<param name="rules.check_overload" value="0"/> <param name="rules.check_overload" value="0"/>
<param name="rules.combat.goblinbonus" value="3"/> <param name="rules.combat.goblinbonus" value="3"/>
<param name="rules.ship.capacity" value="1"/> <!-- -->
<param name="rules.alliances" value="1"/> <param name="rules.alliances" value="1"/>
<param name="rules.combat.herospeed" value="3"/> <param name="rules.combat.herospeed" value="3"/>
<param name="rules.combat.demon_vampire" value="5"/> <!-- regen 1 hp per X points of damage done --> <param name="rules.combat.demon_vampire" value="5"/> <!-- regen 1 hp per X points of damage done -->
<param name="rules.combat.skill_bonus" value="0"/> <param name="rules.combat.skill_bonus" value="0"/>
<param name="rules.combat.loot" value="3"/> <!-- only self + monsters --> <param name="rules.combat.loot" value="3"/> <!-- only self + monsters -->
<param name="rules.move.owner_leave" value="1"/> <!-- owner must leave before moving -->
<param name="rules.cavalry.skill" value="2"/> <param name="rules.cavalry.skill" value="2"/>
<param name="rules.cavalry.mode" value="1"/> <param name="rules.cavalry.mode" value="1"/>
<param name="rules.magic.factionlist" value="1"/> <param name="rules.magic.multipotion" value="1"/>
<param name="rules.magic.wol_effect" value="5"/>
<param name="rules.magic.common" value="tybied"/> <!-- tybied spells can be cast by anyone --> <param name="rules.magic.common" value="tybied"/> <!-- tybied spells can be cast by anyone -->
<param name="rules.magic.elfpower" value="1"/> <!-- elves get ring-of-power bonus in a forest --> <param name="rules.magic.elfpower" value="1"/> <!-- elves get ring-of-power bonus in a forest -->
<param name="rules.magic.playerschools" value="gwyrrd illaun draig cerddor"/> <param name="rules.magic.playerschools" value="gwyrrd illaun draig cerddor"/>

View file

@ -1,4 +1,4 @@
<?xml version="1.0" encoding="iso-8859-1" ?> <?xml version="1.0" encoding="UTF-8" ?>
<resources> <resources>
<resource name="ointment" appearance="vial"> <resource name="ointment" appearance="vial">
@ -58,7 +58,7 @@
</resource> </resource>
<resource name="p9" appearance="vial"> <resource name="p9" appearance="vial">
<!-- Pferdeglück --> <!-- Pferdeglück -->
<item weight="0" score="90"> <item weight="0" score="90">
<function name="use" value="usepotion"/> <function name="use" value="usepotion"/>
<potion level="3"/> <potion level="3"/>

View file

@ -59,7 +59,7 @@
<function name="itemdrop" value="defaultdrops"/> <function name="itemdrop" value="defaultdrops"/>
<param name="other_race" value="elf"/> <param name="other_race" value="elf"/>
<param name="other_cost" value="500"/> <param name="other_cost" value="500"/>
<skill name="riding" modifier="+2"/> <skill name="riding" modifier="+1"/>
<skill name="shipcraft" modifier="2"/> <skill name="shipcraft" modifier="2"/>
<skill name="sailing" modifier="2"/> <skill name="sailing" modifier="2"/>
<skill name="magic" modifier="-99"/> <skill name="magic" modifier="-99"/>

View file

@ -0,0 +1,55 @@
<?xml version="1.0" encoding="UTF-8"?>
<strings>
<string name="canoe">
<text locale="de">Einbaum</text>
<text locale="en">canoe</text>
</string>
<string name="raft">
<text locale="de">Floß</text>
<text locale="en">raft</text>
</string>
<string name="cutter">
<text locale="de">Kutter</text>
<text locale="en">cutter</text>
</string>
<string name="barge">
<text locale="de">Barke</text>
<text locale="en">barge</text>
</string>
<string name="royalbarge">
<text locale="de">Königsbarke</text>
<text locale="en">royal barge</text>
</string>
<string name="catamaran">
<text locale="de">Katamaran</text>
<text locale="en">catamaran</text>
</string>
<string name="cog">
<text locale="de">Kogge</text>
<text locale="en">cog</text>
</string>
<string name="caravel">
<text locale="de">Karavelle</text>
<text locale="en">caravel</text>
</string>
<string name="frigate">
<text locale="de">Fregatte</text>
<text locale="en">frigate</text>
</string>
<string name="galleon">
<text locale="de">Galeone</text>
<text locale="en">galleon</text>
</string>
<string name="dragonship">
<text locale="de">Drachenschiff</text>
<text locale="en">dragonship</text>
</string>
<string name="trireme">
<text locale="de">Trireme</text>
<text locale="en">trireme</text>
</string>
</strings>

154
src/res/e2k9/ships.xml Normal file
View file

@ -0,0 +1,154 @@
<?xml version="1.0"?>
<ships>
<ship name="canoe" range="3" storm="1.00" damage="1.00" cabins="2" cargo="2000" cptskill="1" minskill="1" sumskill="2" opensea="no">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<coast terrain="swamp"/>
<coast terrain="desert"/>
<coast terrain="highland"/>
<coast terrain="mountain"/>
<coast terrain="glacier"/>
<coast terrain="volcano"/>
<coast terrain="activevolcano"/>
<coast terrain="iceberg_sleep"/>
<coast terrain="iceberg"/>
<construction skill="shipcraft" minskill="1" maxsize="3" reqsize="1">
<requirement type="log" quantity="1"/>
</construction>
</ship>
<ship name="raft" range="1" storm="1.00" damage="1.00" cabins="5" cargo="50000" cptskill="1" minskill="1" sumskill="7" opensea="no">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<coast terrain="swamp"/>
<coast terrain="desert"/>
<construction skill="shipcraft" minskill="1" maxsize="10" reqsize="1">
<requirement type="log" quantity="1"/>
</construction>
</ship>
<ship name="cutter" range="2" storm="1.00" damage="1.00" cabins="5" cargo="5000" cptskill="2" minskill="1" sumskill="5" opensea="yes">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<coast terrain="swamp"/>
<coast terrain="desert"/>
<coast terrain="highland"/>
<coast terrain="mountain"/>
<coast terrain="glacier"/>
<coast terrain="volcano"/>
<coast terrain="activevolcano"/>
<coast terrain="iceberg_sleep"/>
<coast terrain="iceberg"/>
<construction skill="shipcraft" minskill="2" maxsize="10" reqsize="1">
<requirement type="log" quantity="1"/>
</construction>
</ship>
<ship name="barge" range="4" storm="1.00" damage="1.00" cabins="10" cargo="5000" cptskill="2" minskill="1" sumskill="5" opensea="no">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<coast terrain="swamp"/>
<coast terrain="desert"/>
<coast terrain="highland"/>
<coast terrain="mountain"/>
<coast terrain="glacier"/>
<coast terrain="volcano"/>
<coast terrain="activevolcano"/>
<coast terrain="iceberg_sleep"/>
<coast terrain="iceberg"/>
<construction skill="shipcraft" minskill="2" maxsize="10" reqsize="1">
<requirement type="log" quantity="1"/>
</construction>
</ship>
<ship name="royalbarge" range="6" storm="0.25" damage="1.00" cabins="10" cargo="5000" cptskill="6" minskill="1" sumskill="10" opensea="no">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<coast terrain="swamp"/>
<coast terrain="desert"/>
<coast terrain="highland"/>
<coast terrain="mountain"/>
<coast terrain="glacier"/>
<coast terrain="volcano"/>
<coast terrain="activevolcano"/>
<coast terrain="iceberg_sleep"/>
<coast terrain="iceberg"/>
<construction skill="shipcraft" minskill="6" maxsize="10" reqsize="1">
<requirement type="mallorn" quantity="1"/>
<requirement type="money" quantity="100"/>
</construction>
</ship>
<ship name="catamaran" range="8" storm="0.25" damage="1.00" cabins="20" cargo="10000" cptskill="8" minskill="1" sumskill="20" opensea="yes">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="8" maxsize="30" reqsize="1">
<requirement type="mallorn" quantity="1"/>
<requirement type="money" quantity="100"/>
</construction>
</ship>
<ship name="cog" range="5" storm="0.50" damage="1.00" cabins="50" cargo="200000" cptskill="4" minskill="1" sumskill="20" opensea="yes">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="4" maxsize="100" reqsize="1">
<requirement type="log" quantity="1"/>
</construction>
</ship>
<ship name="caravel" range="5" storm="0.50" damage="1.00" cabins="150" cargo="600000" cptskill="6" minskill="1" sumskill="30" opensea="yes">
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="6" maxsize="300" reqsize="1">
<requirement type="log" quantity="1"/>
</construction>
</ship>
<ship name="frigate" range="5" storm="1.00" damage="1.00" cabins="110" cargo="100000" cptskill="5" minskill="1" sumskill="40" opensea="yes">
<modifier type="attack" value="+2"/>
<modifier type="defense" value="+2"/>
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="5" maxsize="100" reqsize="1">
<requirement type="log" quantity="1"/>
<requirement type="money" quantity="10"/>
</construction>
</ship>
<ship name="galleon" range="5" storm="1.00" damage="1.00" cabins="310" cargo="300000" cptskill="7" minskill="1" sumskill="60" opensea="yes">
<modifier type="attack" value="+2"/>
<modifier type="defense" value="+2"/>
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="7" maxsize="300" reqsize="1">
<requirement type="log" quantity="1"/>
<requirement type="money" quantity="10"/>
</construction>
</ship>
<ship name="dragonship" range="7" storm="1.00" damage="1.00" cabins="110" cargo="50000" cptskill="5" minskill="1" sumskill="60" opensea="yes">
<modifier type="tactics" value="2.00"/>
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="5" maxsize="100" reqsize="1">
<requirement type="log" quantity="1"/>
<requirement type="money" quantity="10"/>
</construction>
</ship>
<ship name="trireme" range="7" storm="1.00" damage="1.00" cabins="310" cargo="150000" cptskill="7" minskill="1" sumskill="90" opensea="yes">
<modifier type="tactics" value="2.00"/>
<coast terrain="ocean"/>
<coast terrain="plain"/>
<construction skill="shipcraft" minskill="7" maxsize="300" reqsize="1">
<requirement type="log" quantity="1"/>
<requirement type="money" quantity="10"/>
</construction>
</ship>
</ships>

View file

@ -6764,7 +6764,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff ist schon fertig."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff ist schon fertig."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The ship is already completed."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is already completed."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is already completed."</text>
</message> </message>
<message name="error15" section="errors"> <message name="error15" section="errors">
@ -6774,7 +6773,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff ist noch nicht fertig gebaut."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff ist noch nicht fertig gebaut."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The ship has not yet been completed."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship has not yet been completed."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship has not yet been completed."</text>
</message> </message>
<message name="error14" section="errors"> <message name="error14" section="errors">
@ -6784,7 +6782,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff ist auf hoher See."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff ist auf hoher See."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The ship is off shore."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is off shore."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is off shore."</text>
</message> </message>
<message name="error13" section="errors"> <message name="error13" section="errors">
@ -6794,9 +6791,17 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff hat sich bereits bewegt."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff hat sich bereits bewegt."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The ship has moved already."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship has moved already."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship has moved already."</text>
</message> </message>
<message name="error150" 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)' - Der Besitzer muss das Boot zuerst verlassen."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The owner must first LEAVE the building."</text>
</message>
<message name="error12" section="errors"> <message name="error12" section="errors">
<type> <type>
<arg name="unit" type="unit"/> <arg name="unit" type="unit"/>
@ -6804,7 +6809,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff gehört uns nicht."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff gehört uns nicht."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The ship is not ours."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is not ours."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is not ours."</text>
</message> </message>
<message name="error11" section="errors"> <message name="error11" section="errors">
@ -6814,7 +6818,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff befindet sich auf hoher See."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Schiff befindet sich auf hoher See."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - The ship is still off shore."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is still off shore."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - The ship is still off shore."</text>
</message> </message>
<message name="error10" section="errors"> <message name="error10" section="errors">
@ -6824,7 +6827,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das macht wenig Sinn."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das macht wenig Sinn."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - That does not make much sense."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - That does not make much sense."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - That does not make much sense."</text>
</message> </message>
<message name="error9" section="errors"> <message name="error9" section="errors">
@ -6834,7 +6836,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das kann man nicht sabotieren."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das kann man nicht sabotieren."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - That cannot be sabotaged."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - That cannot be sabotaged."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - That cannot be sabotaged."</text>
</message> </message>
<message name="error8" section="errors"> <message name="error8" section="errors">
@ -6844,7 +6845,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das ist sinnlos."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das ist sinnlos."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - That is useless."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - That is useless."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - That is useless."</text>
</message> </message>
<message name="error7" section="errors"> <message name="error7" section="errors">
@ -6854,8 +6854,7 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das geht nicht mehr."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das geht nicht mehr."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - This is not possible any longer."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - This is no longer possible."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - This is not possible any longer."</text>
</message> </message>
<message name="error6" section="errors"> <message name="error6" section="errors">
<type> <type>
@ -6864,7 +6863,6 @@
<arg name="command" type="order"/> <arg name="command" type="order"/>
</type> </type>
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Gebäude wurde nicht gefunden."</text> <text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Gebäude wurde nicht gefunden."</text>
<text locale="fr">"$unit($unit) in $region($region): '$order($command)' - Building could not be found."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - Building could not be found."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - Building could not be found."</text>
</message> </message>
<message name="error5" section="errors"> <message name="error5" section="errors">