forked from github/server
Mehr englische Beschreibungen
Mehr Dinge aus settings.h heraus und in xml-files hinein Sortierung von alliierten bleibt gleich wenn laden/speichern (kleinere diffs)
This commit is contained in:
parent
27cd78ab66
commit
b18a812fa2
19 changed files with 449 additions and 481 deletions
|
@ -103,6 +103,17 @@ int *month_season;
|
||||||
char *agename;
|
char *agename;
|
||||||
int seasons;
|
int seasons;
|
||||||
|
|
||||||
|
static const char*
|
||||||
|
MailitPath()
|
||||||
|
{
|
||||||
|
static const char * value = NULL;
|
||||||
|
if (value==NULL) {
|
||||||
|
value = get_param(global.parameters, "report.mailit");
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
read_datenames(const char *filename)
|
read_datenames(const char *filename)
|
||||||
{
|
{
|
||||||
|
@ -1795,36 +1806,36 @@ enemies(FILE * F, const faction * f)
|
||||||
static void
|
static void
|
||||||
guards(FILE * F, const region * r, const faction * see)
|
guards(FILE * F, const region * r, const faction * see)
|
||||||
{ /* die Partei see sieht dies; wegen
|
{ /* die Partei see sieht dies; wegen
|
||||||
* "unbekannte Partei", wenn man es selbst ist... */
|
* "unbekannte Partei", wenn man es selbst ist... */
|
||||||
|
|
||||||
faction* guardians[512];
|
faction* guardians[512];
|
||||||
|
|
||||||
int nextguard = 0;
|
int nextguard = 0;
|
||||||
|
|
||||||
unit *u;
|
unit *u;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
boolean tarned = false;
|
boolean tarned = false;
|
||||||
/* Bewachung */
|
/* Bewachung */
|
||||||
|
|
||||||
for (u = r->units; u; u = u->next) {
|
for (u = r->units; u; u = u->next) {
|
||||||
if (getguard(u)) {
|
if (getguard(u)) {
|
||||||
faction *f = u->faction;
|
faction *f = u->faction;
|
||||||
faction *fv = visible_faction(see, u);
|
faction *fv = visible_faction(see, u);
|
||||||
|
|
||||||
if(fv != f && see != fv) {
|
if(fv != f && see != fv) {
|
||||||
f = fv;
|
f = fv;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (f != see && fval(u, UFL_PARTEITARNUNG)) {
|
if (f != see && fval(u, UFL_PARTEITARNUNG)) {
|
||||||
tarned=true;
|
tarned=true;
|
||||||
} else {
|
} else {
|
||||||
for (i=0;i!=nextguard;++i) if (guardians[i]==f) break;
|
for (i=0;i!=nextguard;++i) if (guardians[i]==f) break;
|
||||||
if (i==nextguard) {
|
if (i==nextguard) {
|
||||||
guardians[nextguard++] = f;
|
guardians[nextguard++] = f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nextguard || tarned) {
|
if (nextguard || tarned) {
|
||||||
|
@ -1832,21 +1843,21 @@ guards(FILE * F, const region * r, const faction * see)
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i!=nextguard+(tarned?1:0); ++i) {
|
|
||||||
if (i!=0) {
|
|
||||||
if (i == nextguard-(tarned?0:1))
|
|
||||||
scat(" und ");
|
|
||||||
else
|
|
||||||
scat(", ");
|
|
||||||
}
|
|
||||||
if (i<nextguard) scat(factionname(guardians[i]));
|
|
||||||
|
|
||||||
else scat("unbekannten Einheiten");
|
for (i = 0; i!=nextguard+(tarned?1:0); ++i) {
|
||||||
|
if (i!=0) {
|
||||||
|
if (i == nextguard-(tarned?0:1))
|
||||||
|
scat(" und ");
|
||||||
|
else
|
||||||
|
scat(", ");
|
||||||
|
}
|
||||||
|
if (i<nextguard) scat(factionname(guardians[i]));
|
||||||
|
|
||||||
|
else scat("unbekannten Einheiten");
|
||||||
}
|
}
|
||||||
scat(" bewacht.");
|
scat(" bewacht.");
|
||||||
rnl(F);
|
rnl(F);
|
||||||
rparagraph(F, buf, 0, 0);
|
rparagraph(F, buf, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -2355,54 +2366,48 @@ report(FILE *F, faction * f, const faction_list * addresses,
|
||||||
FILE *
|
FILE *
|
||||||
openbatch(void)
|
openbatch(void)
|
||||||
{
|
{
|
||||||
faction *f;
|
faction *f;
|
||||||
FILE * BAT = NULL;
|
FILE * BAT = NULL;
|
||||||
|
|
||||||
/* falls und mind. ein internet spieler gefunden wird, schreibe den
|
/* falls und mind. ein internet spieler gefunden wird, schreibe den
|
||||||
* header des batch files. ab nun kann BAT verwendet werden, um zu
|
* header des batch files. ab nun kann BAT verwendet werden, um zu
|
||||||
* pruefen, ob netspieler vorhanden sind und ins mailit batch
|
* pruefen, ob netspieler vorhanden sind und ins mailit batch
|
||||||
* geschrieben werden darf. */
|
* geschrieben werden darf. */
|
||||||
|
|
||||||
for (f = factions; f; f = f->next) {
|
for (f = factions; f; f = f->next) {
|
||||||
|
|
||||||
/* bei "internet:" verschicken wir die mail per batchfile. für
|
/* bei "internet:" verschicken wir die mail per batchfile. für
|
||||||
* unix kann man alles in EIN batchfile schreiben, als
|
* unix kann man alles in EIN batchfile schreiben, als
|
||||||
* sogenanntes "herefile". Konnte der batchfile nicht geoeffnet
|
* sogenanntes "herefile". Konnte der batchfile nicht geoeffnet
|
||||||
* werden, schreiben wir die reports einzeln. der BAT file wird
|
* werden, schreiben wir die reports einzeln. der BAT file wird
|
||||||
* nur gemacht, wenn es auch internet benutzer gibt. */
|
* nur gemacht, wenn es auch internet benutzer gibt. */
|
||||||
|
|
||||||
if (f->email) {
|
if (f->email) {
|
||||||
sprintf(buf, "%s/mailit", reportpath());
|
sprintf(buf, "%s/mailit", reportpath());
|
||||||
if ((BAT = fopen(buf, "w")) == NULL)
|
if ((BAT = fopen(buf, "w")) == NULL)
|
||||||
log_error(("mailit konnte nicht geöffnet werden!\n"));
|
log_error(("mailit konnte nicht geöffnet werden!\n"));
|
||||||
else
|
else
|
||||||
fprintf(BAT,
|
fprintf(BAT,
|
||||||
"#!/bin/sh\n"
|
"#!/bin/sh\n\n"
|
||||||
"\n"
|
"# MAILIT shell file, vom Eressea Host generiert\n#\n"
|
||||||
"# MAILIT shell file, vom Eressea Host generiert\n"
|
"# Verwendung: nohup mailit &\n#\n\n"
|
||||||
"#\n"
|
"PATH=%s\n\n"
|
||||||
"# Verwendung: nohup mailit &\n"
|
"chmod 755 *.sh\n"
|
||||||
"#\n"
|
"\n", MailitPath());
|
||||||
"\n"
|
break;
|
||||||
"PATH=%s\n"
|
|
||||||
"\n"
|
|
||||||
"chmod 755 *.sh\n"
|
|
||||||
"\n"
|
|
||||||
,MAILITPATH);
|
|
||||||
break;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return BAT;
|
return BAT;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
closebatch(FILE * BAT)
|
closebatch(FILE * BAT)
|
||||||
{
|
{
|
||||||
if (BAT) {
|
if (BAT) {
|
||||||
fputs("\n", BAT);
|
fputs("\n", BAT);
|
||||||
fclose(BAT);
|
fclose(BAT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2690,7 +2695,7 @@ reports(void)
|
||||||
if (f->no > 0 && f->email && BAT) {
|
if (f->no > 0 && f->email && BAT) {
|
||||||
sprintf(buf, "%s/%s.sh", reportpath(), factionid(f));
|
sprintf(buf, "%s/%s.sh", reportpath(), factionid(f));
|
||||||
shfp = fopen(buf, "w");
|
shfp = fopen(buf, "w");
|
||||||
fprintf(shfp,"#!/bin/sh\n\nPATH=%s\n\n",MAILITPATH);
|
fprintf(shfp,"#!/bin/sh\n\nPATH=%s\n\n",MailitPath());
|
||||||
fprintf(shfp,"if [ $# -ge 1 ]; then\n");
|
fprintf(shfp,"if [ $# -ge 1 ]; then\n");
|
||||||
fprintf(shfp,"\taddr=$1\n");
|
fprintf(shfp,"\taddr=$1\n");
|
||||||
fprintf(shfp,"else\n");
|
fprintf(shfp,"else\n");
|
||||||
|
|
|
@ -53,7 +53,17 @@
|
||||||
|
|
||||||
#define TEACHNUMBER 10
|
#define TEACHNUMBER 10
|
||||||
|
|
||||||
/* ------------------------------------------------------------- */
|
static boolean
|
||||||
|
ExpensiveMigrants()
|
||||||
|
{
|
||||||
|
int value = -1;
|
||||||
|
if (value<0) {
|
||||||
|
const char * str = get_param(global.parameters, "study.expensivemigrants");
|
||||||
|
value = str?atoi(str):0;
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
static skill_t
|
static skill_t
|
||||||
getskill(const struct locale * lang)
|
getskill(const struct locale * lang)
|
||||||
{
|
{
|
||||||
|
@ -510,13 +520,11 @@ learn(void)
|
||||||
/* keine kostenpflichtigen Talente für Migranten. Vertraute sind
|
/* keine kostenpflichtigen Talente für Migranten. Vertraute sind
|
||||||
* keine Migranten, wird in is_migrant abgefangen. Vorsicht,
|
* keine Migranten, wird in is_migrant abgefangen. Vorsicht,
|
||||||
* studycost darf hier noch nicht durch Akademie erhöht sein */
|
* studycost darf hier noch nicht durch Akademie erhöht sein */
|
||||||
#if MIGRANTS_CAN_LEARN_EXPENSIVE_SKILLS == 0
|
if (studycost > 0 && !ExpensiveMigrants() && is_migrant(u)) {
|
||||||
if (is_migrant(u) && studycost > 0){
|
|
||||||
sprintf(buf, "Migranten können keine kostenpflichtigen Talente lernen");
|
sprintf(buf, "Migranten können keine kostenpflichtigen Talente lernen");
|
||||||
mistake(u, u->thisorder, buf, MSG_EVENT);
|
mistake(u, u->thisorder, buf, MSG_EVENT);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
/* Akademie: */
|
/* Akademie: */
|
||||||
{
|
{
|
||||||
struct building * b = inside_building(u);
|
struct building * b = inside_building(u);
|
||||||
|
|
|
@ -2606,41 +2606,41 @@ print_fighters(battle * b, cvector * fighters)
|
||||||
static void
|
static void
|
||||||
print_header(battle * b)
|
print_header(battle * b)
|
||||||
{
|
{
|
||||||
bfaction * bf;
|
bfaction * bf;
|
||||||
void **fi;
|
void **fi;
|
||||||
cvector *fighters = &b->fighters;
|
cvector *fighters = &b->fighters;
|
||||||
boolean * seen = malloc(sizeof(boolean)*cv_size(&b->sides));
|
boolean * seen = malloc(sizeof(boolean)*cv_size(&b->sides));
|
||||||
|
|
||||||
for (bf=b->factions;bf;bf=bf->next) {
|
for (bf=b->factions;bf;bf=bf->next) {
|
||||||
faction * f = bf->faction;
|
faction * f = bf->faction;
|
||||||
const char * lastf = NULL;
|
const char * lastf = NULL;
|
||||||
boolean first = false;
|
boolean first = false;
|
||||||
|
|
||||||
strcpy(buf, "Der Kampf wurde ausgelöst von ");
|
strcpy(buf, "Der Kampf wurde ausgelöst von ");
|
||||||
memset(seen, 0, sizeof(boolean)*cv_size(&b->sides));
|
memset(seen, 0, sizeof(boolean)*cv_size(&b->sides));
|
||||||
|
|
||||||
for (fi = fighters->begin; fi != fighters->end; ++fi) {
|
for (fi = fighters->begin; fi != fighters->end; ++fi) {
|
||||||
fighter *df = *fi;
|
fighter *df = *fi;
|
||||||
if (!fval(df, FIG_ATTACKED)) continue;
|
if (!fval(df, FIG_ATTACKED)) continue;
|
||||||
if (!seen[df->side->index] ) {
|
if (!seen[df->side->index] ) {
|
||||||
if (first) strcat(buf, ", ");
|
if (first) strcat(buf, ", ");
|
||||||
if (lastf) {
|
if (lastf) {
|
||||||
strcat(buf, lastf);
|
strcat(buf, lastf);
|
||||||
first = true;
|
first = true;
|
||||||
}
|
}
|
||||||
if (seematrix(f, df->side) == true)
|
if (seematrix(f, df->side) == true)
|
||||||
lastf = sidename(df->side, false);
|
lastf = sidename(df->side, false);
|
||||||
else
|
else
|
||||||
lastf = "einer unbekannten Partei";
|
lastf = "einer unbekannten Partei";
|
||||||
seen[df->side->index] = true;
|
seen[df->side->index] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (first) strcat(buf, " und ");
|
if (first) strcat(buf, " und ");
|
||||||
if (lastf) strcat(buf, lastf);
|
if (lastf) strcat(buf, lastf);
|
||||||
strcat(buf, ".");
|
strcat(buf, ".");
|
||||||
fbattlerecord(b, f, buf);
|
fbattlerecord(b, f, buf);
|
||||||
}
|
}
|
||||||
free(seen);
|
free(seen);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -67,7 +67,16 @@
|
||||||
* Laen, Mallorn}, UnterSilber, UnterSpezialTyp, UnterSpezial */
|
* Laen, Mallorn}, UnterSilber, UnterSpezialTyp, UnterSpezial */
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------- */
|
static boolean
|
||||||
|
CheckOverload()
|
||||||
|
{
|
||||||
|
static int value = -1;
|
||||||
|
if (value<0) {
|
||||||
|
const char * str = get_param(global.parameters, "rules.check_overload");
|
||||||
|
value = str?atoi(str):0;
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
slipthru(const region * r, const unit * u, const building * b)
|
slipthru(const region * r, const unit * u, const building * b)
|
||||||
|
@ -1130,8 +1139,7 @@ entership(unit * u, ship * sh, const char * cmd, boolean lasttry)
|
||||||
if (lasttry) cmistake(u, cmd, 34, MSG_MOVE);
|
if (lasttry) cmistake(u, cmd, 34, MSG_MOVE);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#ifdef CHECK_OVERLOAD_ON_ENTER
|
if (CheckOverload()) {
|
||||||
{
|
|
||||||
int sweight, scabins;
|
int sweight, scabins;
|
||||||
int mweight = shipcapacity(sh);
|
int mweight = shipcapacity(sh);
|
||||||
int mcabins = sh->type->cabins;
|
int mcabins = sh->type->cabins;
|
||||||
|
@ -1146,7 +1154,6 @@ entership(unit * u, ship * sh, const char * cmd, boolean lasttry)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
leave(u->region, u);
|
leave(u->region, u);
|
||||||
u->ship = sh;
|
u->ship = sh;
|
||||||
|
|
|
@ -104,65 +104,63 @@ get_force(double power, int formel)
|
||||||
int
|
int
|
||||||
sp_kampfzauber(fighter * fi, int level, double power, spell * sp)
|
sp_kampfzauber(fighter * fi, int level, double power, spell * sp)
|
||||||
{
|
{
|
||||||
battle *b = fi->side->battle;
|
battle *b = fi->side->battle;
|
||||||
troop dt;
|
troop at, dt;
|
||||||
troop at;
|
message * m;
|
||||||
/* Immer aus der ersten Reihe nehmen */
|
/* Immer aus der ersten Reihe nehmen */
|
||||||
int minrow = FIGHT_ROW;
|
int minrow = FIGHT_ROW;
|
||||||
int maxrow = BEHIND_ROW-1;
|
int maxrow = BEHIND_ROW-1;
|
||||||
int force, enemies;
|
int force, enemies;
|
||||||
int killed = 0;
|
int killed = 0;
|
||||||
const char *damage;
|
const char *damage;
|
||||||
at.fighter = fi;
|
|
||||||
at.index = 0;
|
|
||||||
|
|
||||||
if (power <= 0) return 0;
|
if (power <= 0) return 0;
|
||||||
|
at.fighter = fi;
|
||||||
|
at.index = 0;
|
||||||
|
|
||||||
sprintf(buf, "%s zaubert %s", unitname(fi->unit),
|
switch(sp->id) {
|
||||||
spell_name(sp, default_locale));
|
/* lovar halbiert im Schnitt! */
|
||||||
|
case SPL_FIREBALL:
|
||||||
|
damage = spell_damage(0);
|
||||||
|
force = lovar(get_force(power,0));
|
||||||
|
break;
|
||||||
|
case SPL_HAGEL:
|
||||||
|
damage = spell_damage(2);
|
||||||
|
force = lovar(get_force(power,4));
|
||||||
|
break;
|
||||||
|
case SPL_METEORRAIN:
|
||||||
|
damage = spell_damage(1);
|
||||||
|
force = lovar(get_force(power,1));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
damage = spell_damage(10);
|
||||||
|
force = lovar(get_force(power,10));
|
||||||
|
}
|
||||||
|
|
||||||
switch(sp->id) {
|
sprintf(buf, "%s zaubert %s", unitname(fi->unit),
|
||||||
/* lovar halbiert im Schnitt! */
|
spell_name(sp, default_locale));
|
||||||
case SPL_FIREBALL:
|
|
||||||
damage = spell_damage(0);
|
|
||||||
force = lovar(get_force(power,0));
|
|
||||||
break;
|
|
||||||
case SPL_HAGEL:
|
|
||||||
damage = spell_damage(2);
|
|
||||||
force = lovar(get_force(power,4));
|
|
||||||
break;
|
|
||||||
case SPL_METEORRAIN:
|
|
||||||
damage = spell_damage(1);
|
|
||||||
force = lovar(get_force(power,1));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
damage = spell_damage(10);
|
|
||||||
force = lovar(get_force(power,10));
|
|
||||||
}
|
|
||||||
|
|
||||||
enemies = count_enemies(b, fi->side, minrow, maxrow);
|
enemies = count_enemies(b, fi->side, minrow, maxrow);
|
||||||
if (!enemies) {
|
if (enemies==0) {
|
||||||
message * m = msg_message("battle::out_of_range", "mage spell", fi->unit, sp);
|
m = msg_message("battle::out_of_range", "mage spell", fi->unit, sp);
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
scat(":");
|
|
||||||
battlerecord(b, buf);
|
|
||||||
|
|
||||||
while (force>0 && killed < enemies) {
|
while (force>0 && killed < enemies) {
|
||||||
dt = select_enemy(b, fi, minrow, maxrow);
|
dt = select_enemy(b, fi, minrow, maxrow);
|
||||||
assert(dt.fighter);
|
assert(dt.fighter);
|
||||||
--force;
|
--force;
|
||||||
killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
|
killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
sprintf(buf, "%d Personen %s getötet",
|
m = msg_message("battle::combatspell", "mage spell dead",
|
||||||
killed, killed == 1 ? "wurde" : "wurden");
|
fi->unit, sp, killed);
|
||||||
|
message_all(b, m);
|
||||||
|
msg_release(m);
|
||||||
|
|
||||||
scat(".");
|
return level;
|
||||||
battlerecord(b, buf);
|
|
||||||
return level;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Versteinern */
|
/* Versteinern */
|
||||||
|
|
|
@ -969,7 +969,7 @@ cancast(unit * u, spell * sp, int level, int range, char * cmd)
|
||||||
/* Noch fehlte keine Komponente, wir generieren den Anfang der
|
/* Noch fehlte keine Komponente, wir generieren den Anfang der
|
||||||
* Fehlermeldung */
|
* Fehlermeldung */
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER %s' Für diesen Zauber fehlen "
|
sprintf(buf, "%s in %s: 'ZAUBER %s' Für diesen Zauber fehlen "
|
||||||
"noch %d ", unitname(u), regionid(u->region),
|
"noch %d ", unitname(u), regionid(u->region),
|
||||||
spell_name(sp, u->faction->locale),
|
spell_name(sp, u->faction->locale),
|
||||||
itemanz);
|
itemanz);
|
||||||
scat(locale_string(u->faction->locale,
|
scat(locale_string(u->faction->locale,
|
||||||
|
@ -1282,7 +1282,7 @@ do_fumble(castorder *co)
|
||||||
int duration;
|
int duration;
|
||||||
const char * sp_name = spell_name(sp, u->faction->locale);
|
const char * sp_name = spell_name(sp, u->faction->locale);
|
||||||
|
|
||||||
ADDMSG(&u->faction->msgs, msg_message("patzer", "unit region spell",
|
ADDMSG(&u->faction->msgs, msg_message("patzer", "unit region spell",
|
||||||
u, r, sp_name));
|
u, r, sp_name));
|
||||||
switch (rand() % 10) {
|
switch (rand() % 10) {
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -1486,7 +1486,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 */
|
||||||
|
@ -1661,7 +1661,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;
|
||||||
|
@ -2798,7 +2798,7 @@ magic(void)
|
||||||
&& !fval(u->race, RCF_SWIM)
|
&& !fval(u->race, RCF_SWIM)
|
||||||
&& !(sp->sptyp & OCEANCASTABLE)) {
|
&& !(sp->sptyp & OCEANCASTABLE)) {
|
||||||
/* Fehlermeldung */
|
/* Fehlermeldung */
|
||||||
ADDMSG(&u->faction->msgs, msg_message("spellfail_onocean",
|
ADDMSG(&u->faction->msgs, msg_message("spellfail_onocean",
|
||||||
"unit region command", u, u->region, so->s));
|
"unit region command", u, u->region, so->s));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -2824,12 +2824,9 @@ magic(void)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (range > 1024) { /* (2^10) weiter als 10 Regionen entfernt */
|
if (range > 1024) { /* (2^10) weiter als 10 Regionen entfernt */
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER %s' Zu der Region %s kann keine "
|
ADDMSG(&u->faction->msgs, msg_message("spellfail::nolevel",
|
||||||
"Verbindung hergestellt werden", unitname(u),
|
"mage region order target", u, u->region, so->s,
|
||||||
regionid(u->region),
|
gc_add(strdup(regionid(target_r)))));
|
||||||
spell_name(sp, u->faction->locale),
|
|
||||||
regionid(target_r));
|
|
||||||
addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2838,11 +2835,8 @@ magic(void)
|
||||||
int ilevel = eff_skill(u, SK_MAGIC, u->region);
|
int ilevel = eff_skill(u, SK_MAGIC, u->region);
|
||||||
if (ilevel!=level) {
|
if (ilevel!=level) {
|
||||||
level = ilevel;
|
level = ilevel;
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER %s' Dieser Zauber kann nicht "
|
ADDMSG(&u->faction->msgs, msg_message("spellfail::nolevel",
|
||||||
"mit Stufenangabe gezaubert werden.", unitname(u),
|
"mage region order", u, u->region, so->s));
|
||||||
regionid(u->region),
|
|
||||||
spell_name(sp, u->faction->locale));
|
|
||||||
addmessage(0, u->faction, buf, MSG_MAGIC, ML_WARN);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Vertrautenmagie */
|
/* Vertrautenmagie */
|
||||||
|
@ -2920,7 +2914,7 @@ magic(void)
|
||||||
region * target_r = co->rt;
|
region * target_r = co->rt;
|
||||||
|
|
||||||
/* reichen die Komponenten nicht, wird der Level reduziert. */
|
/* reichen die Komponenten nicht, wird der Level reduziert. */
|
||||||
co->level = eff_spelllevel(u, sp, cast_level, co->distance);
|
co->level = eff_spelllevel(u, sp, cast_level, co->distance);
|
||||||
|
|
||||||
if (co->level < 1) {
|
if (co->level < 1) {
|
||||||
/* Fehlermeldung mit Komponenten generieren */
|
/* Fehlermeldung mit Komponenten generieren */
|
||||||
|
@ -2933,7 +2927,7 @@ magic(void)
|
||||||
* gezaubert, co->level ist aber defaultmäßig Stufe des Magiers */
|
* gezaubert, co->level ist aber defaultmäßig Stufe des Magiers */
|
||||||
if (spl_costtyp(sp) != SPC_FIX) {
|
if (spl_costtyp(sp) != SPC_FIX) {
|
||||||
sprintf(buf, "%s hat nur genügend Komponenten um %s auf Stufe %d "
|
sprintf(buf, "%s hat nur genügend Komponenten um %s auf Stufe %d "
|
||||||
"zu zaubern.", unitname(u), spell_name(sp, u->faction->locale),
|
"zu zaubern.", unitname(u), spell_name(sp, u->faction->locale),
|
||||||
co->level);
|
co->level);
|
||||||
addmessage(0, u->faction, buf, MSG_MAGIC, ML_INFO);
|
addmessage(0, u->faction, buf, MSG_MAGIC, ML_INFO);
|
||||||
}
|
}
|
||||||
|
@ -2951,7 +2945,7 @@ magic(void)
|
||||||
if (co->force <= 0) {
|
if (co->force <= 0) {
|
||||||
co->force = 0;
|
co->force = 0;
|
||||||
sprintf(buf, "%s schafft es nicht genügend Kraft aufzubringen "
|
sprintf(buf, "%s schafft es nicht genügend Kraft aufzubringen "
|
||||||
"um %s dennoch zu zaubern.", unitname(u),
|
"um %s dennoch zu zaubern.", unitname(u),
|
||||||
spell_name(sp, u->faction->locale));
|
spell_name(sp, u->faction->locale));
|
||||||
addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
}
|
}
|
||||||
|
@ -2981,7 +2975,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. */
|
||||||
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),
|
"keine Wirkung.", unitname(u),
|
||||||
spell_name(sp, u->faction->locale));
|
spell_name(sp, u->faction->locale));
|
||||||
addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(0, u->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
co->force = 0;
|
co->force = 0;
|
||||||
|
@ -3039,7 +3033,7 @@ create_special_direction(region *r, int x, int y, int duration,
|
||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
spell_info(const struct spell * sp, const struct locale * lang)
|
spell_info(const struct spell * sp, const struct locale * lang)
|
||||||
{
|
{
|
||||||
if (sp->info==NULL) {
|
if (sp->info==NULL) {
|
||||||
|
@ -3048,7 +3042,7 @@ spell_info(const struct spell * sp, const struct locale * lang)
|
||||||
return sp->info;
|
return sp->info;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
spell_name(const struct spell * sp, const struct locale * lang)
|
spell_name(const struct spell * sp, const struct locale * lang)
|
||||||
{
|
{
|
||||||
if (sp->info==NULL) {
|
if (sp->info==NULL) {
|
||||||
|
@ -3057,7 +3051,7 @@ spell_name(const struct spell * sp, const struct locale * lang)
|
||||||
return sp->sname;
|
return sp->sname;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
add_spelllist(spell_list ** lspells, spell * sp)
|
add_spelllist(spell_list ** lspells, spell * sp)
|
||||||
{
|
{
|
||||||
spell_list * entry = malloc(sizeof(spell_list));
|
spell_list * entry = malloc(sizeof(spell_list));
|
||||||
|
|
|
@ -1498,31 +1498,32 @@ writeregion(FILE * F, const region * r)
|
||||||
wnl(F);
|
wnl(F);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static ally **
|
||||||
addally(const faction * f, ally ** sfp, int aid, int state)
|
addally(const faction * f, ally ** sfp, int aid, int state)
|
||||||
{
|
{
|
||||||
struct faction * af = findfaction(aid);
|
struct faction * af = findfaction(aid);
|
||||||
ally * sf;
|
ally * sf;
|
||||||
state &= ~HELP_OBSERVE;
|
state &= ~HELP_OBSERVE;
|
||||||
#ifndef REGIONOWNERS
|
#ifndef REGIONOWNERS
|
||||||
state &= ~HELP_TRAVEL;
|
state &= ~HELP_TRAVEL;
|
||||||
#endif
|
#endif
|
||||||
#ifdef ALLIANCES
|
#ifdef ALLIANCES
|
||||||
# ifdef ALLIES_ONLY
|
# ifdef ALLIES_ONLY
|
||||||
if (af!=NULL && af->alliance!=f->alliance) state &= ~ALLIES_ONLY;;
|
if (af!=NULL && af->alliance!=f->alliance) state &= ~ALLIES_ONLY;;
|
||||||
# else
|
# else
|
||||||
# endif
|
# endif
|
||||||
if (af!=NULL && af->alliance!=f->alliance) return;
|
if (af!=NULL && af->alliance!=f->alliance) return;
|
||||||
#endif
|
#endif
|
||||||
if (state==0) return;
|
if (state==0) return;
|
||||||
|
|
||||||
sf = calloc(1, sizeof(ally));
|
sf = calloc(1, sizeof(ally));
|
||||||
sf->faction = af;
|
sf->faction = af;
|
||||||
if (!sf->faction) ur_add((void*)aid, (void**)&sf->faction, resolve_faction);
|
if (!sf->faction) ur_add((void*)aid, (void**)&sf->faction, resolve_faction);
|
||||||
sf->status = state;
|
sf->status = state;
|
||||||
sf->next = *sfp;
|
|
||||||
|
|
||||||
*sfp = sf;
|
while (*sfp) sfp=&(*sfp)->next;
|
||||||
|
*sfp = sf;
|
||||||
|
return &sf;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Reads a faction from a file.
|
/** Reads a faction from a file.
|
||||||
|
@ -1647,7 +1648,7 @@ readfaction(FILE * F)
|
||||||
while (--p >= 0) {
|
while (--p >= 0) {
|
||||||
int aid = rid(F);
|
int aid = rid(F);
|
||||||
int state = ri(F);
|
int state = ri(F);
|
||||||
addally(f, sfp, aid, state);
|
sfp = addally(f, sfp, aid, state);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
@ -1656,7 +1657,7 @@ readfaction(FILE * F)
|
||||||
else {
|
else {
|
||||||
int aid = atoi36(buf);
|
int aid = atoi36(buf);
|
||||||
int state = ri(F);
|
int state = ri(F);
|
||||||
addally(f, sfp, aid, state);
|
sfp = addally(f, sfp, aid, state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -470,7 +470,7 @@ report_effect(region * r, unit * mage, message * seen, message * unseen)
|
||||||
* ML_WARN ausgegeben werden. (stehen im Kopf der Auswertung unter
|
* ML_WARN ausgegeben werden. (stehen im Kopf der Auswertung unter
|
||||||
* Zauberwirkungen)
|
* Zauberwirkungen)
|
||||||
|
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': [hier die Fehlermeldung].",
|
sprintf(buf, "%s in %s: 'ZAUBER %s': [hier die Fehlermeldung].",
|
||||||
unitname(mage), regionid(mage->region), sa->strings[0]);
|
unitname(mage), regionid(mage->region), sa->strings[0]);
|
||||||
add_message(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
add_message(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
|
||||||
|
@ -1018,14 +1018,14 @@ sp_blessstonecircle(castorder *co)
|
||||||
b = p->param[0]->data.b;
|
b = p->param[0]->data.b;
|
||||||
|
|
||||||
if(b->type != bt_find("stonecircle")) {
|
if(b->type != bt_find("stonecircle")) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': %s ist kein Steinkreis.",
|
sprintf(buf, "%s in %s: 'ZAUBER %s': %s ist kein Steinkreis.",
|
||||||
unitname(mage), regionid(mage->region), co->order, buildingname(b));
|
unitname(mage), regionid(mage->region), co->order, buildingname(b));
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(b->size < b->type->maxsize) {
|
if(b->size < b->type->maxsize) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': %s muss vor der Weihe "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': %s muss vor der Weihe "
|
||||||
"fertiggestellt sein.", unitname(mage), regionid(mage->region),
|
"fertiggestellt sein.", unitname(mage), regionid(mage->region),
|
||||||
co->order, buildingname(b));
|
co->order, buildingname(b));
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -3004,7 +3004,7 @@ wall_move(const border * b, struct unit * u, const struct region * from, const s
|
||||||
hp = min (u->hp, hp);
|
hp = min (u->hp, hp);
|
||||||
u->hp -= hp;
|
u->hp -= hp;
|
||||||
if (u->hp) {
|
if (u->hp) {
|
||||||
ADDMSG(&u->faction->msgs, msg_message("firewall_damage",
|
ADDMSG(&u->faction->msgs, msg_message("firewall_damage",
|
||||||
"region unit", from, u));
|
"region unit", from, u));
|
||||||
}
|
}
|
||||||
else ADDMSG(&u->faction->msgs, msg_message("firewall_death", "region unit", from, u));
|
else ADDMSG(&u->faction->msgs, msg_message("firewall_death", "region unit", from, u));
|
||||||
|
@ -3269,7 +3269,7 @@ sp_unholypower(castorder *co)
|
||||||
* Magier gerät in den Staub und verliert zufällige Zahl von HP bis
|
* Magier gerät in den Staub und verliert zufällige Zahl von HP bis
|
||||||
* auf max(hp,2)
|
* auf max(hp,2)
|
||||||
* Besonderheiten:
|
* Besonderheiten:
|
||||||
* Nicht als curse implementiert, was schlecht ist - man kann dadurch
|
* Nicht als curse implementiert, was schlecht ist - man kann dadurch
|
||||||
* kein dispell machen. Wegen fix unter Zeitdruck erstmal nicht zu
|
* kein dispell machen. Wegen fix unter Zeitdruck erstmal nicht zu
|
||||||
* ändern...
|
* ändern...
|
||||||
* Missbrauchsmöglichkeit:
|
* Missbrauchsmöglichkeit:
|
||||||
|
@ -3290,7 +3290,7 @@ typedef struct dc_data {
|
||||||
boolean active;
|
boolean active;
|
||||||
} dc_data;
|
} dc_data;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dc_initialize(struct attrib *a)
|
dc_initialize(struct attrib *a)
|
||||||
{
|
{
|
||||||
dc_data * data = (dc_data *)malloc(sizeof(dc_data));
|
dc_data * data = (dc_data *)malloc(sizeof(dc_data));
|
||||||
|
@ -3298,13 +3298,13 @@ dc_initialize(struct attrib *a)
|
||||||
data->active = true;
|
data->active = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dc_finalize(struct attrib * a)
|
dc_finalize(struct attrib * a)
|
||||||
{
|
{
|
||||||
free(a->data.v);
|
free(a->data.v);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
dc_age(struct attrib * a)
|
dc_age(struct attrib * a)
|
||||||
/* age returns 0 if the attribute needs to be removed, !=0 otherwise */
|
/* age returns 0 if the attribute needs to be removed, !=0 otherwise */
|
||||||
{
|
{
|
||||||
|
@ -3339,20 +3339,20 @@ dc_age(struct attrib * a)
|
||||||
for (u = r->units; u; u = u->next ) {
|
for (u = r->units; u; u = u->next ) {
|
||||||
if (!fval(u->faction, FL_DH) ) {
|
if (!fval(u->faction, FL_DH) ) {
|
||||||
fset(u->faction, FL_DH);
|
fset(u->faction, FL_DH);
|
||||||
ADDMSG(&u->faction->msgs, msg_message("deathcloud_effect",
|
ADDMSG(&u->faction->msgs, msg_message("deathcloud_effect",
|
||||||
"mage region", cansee(u->faction, r, mage, 0) ? mage : NULL, r));
|
"mage region", cansee(u->faction, r, mage, 0) ? mage : NULL, r));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fval(mage->faction, FL_DH)){
|
if (!fval(mage->faction, FL_DH)){
|
||||||
ADDMSG(&mage->faction->msgs, msg_message("deathcloud_effect",
|
ADDMSG(&mage->faction->msgs, msg_message("deathcloud_effect",
|
||||||
"mage region", mage, r));
|
"mage region", mage, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
return --data->countdown;
|
return --data->countdown;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dc_write(const struct attrib * a, FILE* F)
|
dc_write(const struct attrib * a, FILE* F)
|
||||||
{
|
{
|
||||||
const dc_data * data = (const dc_data *)a->data.v;
|
const dc_data * data = (const dc_data *)a->data.v;
|
||||||
|
@ -3380,7 +3380,7 @@ mk_deathcloud(unit * mage, region * r, double strength, int duration)
|
||||||
{
|
{
|
||||||
attrib * a = a_new(&at_deathcloud);
|
attrib * a = a_new(&at_deathcloud);
|
||||||
dc_data * data = (dc_data *)a->data.v;
|
dc_data * data = (dc_data *)a->data.v;
|
||||||
|
|
||||||
data->countdown = duration;
|
data->countdown = duration;
|
||||||
data->r = r;
|
data->r = r;
|
||||||
data->mage = mage;
|
data->mage = mage;
|
||||||
|
@ -4334,109 +4334,106 @@ sp_raisepeasantmob(castorder *co)
|
||||||
static int
|
static int
|
||||||
sp_migranten(castorder *co)
|
sp_migranten(castorder *co)
|
||||||
{
|
{
|
||||||
unit *target;
|
unit *target;
|
||||||
strlist *S;
|
strlist *S;
|
||||||
int kontaktiert = 0;
|
int kontaktiert = 0;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
spell *sp = co->sp;
|
spell *sp = co->sp;
|
||||||
|
|
||||||
/* wenn kein Ziel gefunden, Zauber abbrechen */
|
/* wenn kein Ziel gefunden, Zauber abbrechen */
|
||||||
if(pa->param[0]->flag == TARGET_NOTFOUND) return 0;
|
if(pa->param[0]->flag == TARGET_NOTFOUND) return 0;
|
||||||
|
|
||||||
target = pa->param[0]->data.u; /* Zieleinheit */
|
target = pa->param[0]->data.u; /* Zieleinheit */
|
||||||
|
|
||||||
/* Personen unserer Rasse können problemlos normal übergeben werden */
|
/* Personen unserer Rasse können problemlos normal übergeben werden */
|
||||||
if (target->race == mage->faction->race){
|
if (target->race == mage->faction->race){
|
||||||
/* u ist von unserer Art, das Ritual wäre verschwendete Aura. */
|
/* u ist von unserer Art, das Ritual wäre verschwendete Aura. */
|
||||||
ADDMSG(&mage->faction->msgs, msg_message(
|
ADDMSG(&mage->faction->msgs, msg_message(
|
||||||
"sp_migranten_fail1", "unit region command target", mage,
|
"sp_migranten_fail1", "unit region command target", mage,
|
||||||
mage->region, strdup(co->order), target));
|
mage->region, strdup(co->order), target));
|
||||||
}
|
}
|
||||||
/* Auf eigene Einheiten versucht zu zaubern? Garantiert Tippfehler */
|
/* Auf eigene Einheiten versucht zu zaubern? Garantiert Tippfehler */
|
||||||
if (target->faction == mage->faction){
|
if (target->faction == mage->faction){
|
||||||
cmistake(mage, strdup(co->order), 45, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 45, MSG_MAGIC);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Keine Monstereinheiten */
|
/* Keine Monstereinheiten */
|
||||||
if (!playerrace(target->race)){
|
if (!playerrace(target->race)){
|
||||||
sprintf(buf, "%s kann nicht auf Monster gezaubert werden.",
|
sprintf(buf, "%s kann nicht auf Monster gezaubert werden.",
|
||||||
spell_name(sp, mage->faction->locale));
|
spell_name(sp, mage->faction->locale));
|
||||||
addmessage(0, mage->faction, buf, MSG_EVENT, ML_WARN);
|
addmessage(0, mage->faction, buf, MSG_EVENT, ML_WARN);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/* niemand mit teurem Talent */
|
/* niemand mit teurem Talent */
|
||||||
if (teure_talente(target)) {
|
if (teure_talente(target)) {
|
||||||
sprintf(buf, "%s hat unaufkündbare Bindungen an seine alte Partei.",
|
sprintf(buf, "%s hat unaufkündbare Bindungen an seine alte Partei.",
|
||||||
unitname(target));
|
unitname(target));
|
||||||
addmessage(0, mage->faction, buf, MSG_EVENT, ML_WARN);
|
addmessage(0, mage->faction, buf, MSG_EVENT, ML_WARN);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/* maximal Stufe Personen */
|
/* maximal Stufe Personen */
|
||||||
if (target->number > cast_level
|
if (target->number > cast_level
|
||||||
|| target->number > max_spellpoints(r, mage))
|
|| target->number > max_spellpoints(r, mage))
|
||||||
{
|
{
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': So viele Personen übersteigen "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': So viele Personen übersteigen "
|
||||||
"meine Kräfte.", unitname(mage), regionid(mage->region),
|
"meine Kräfte.", unitname(mage), regionid(mage->region),
|
||||||
spell_name(sp, mage->faction->locale));
|
spell_name(sp, mage->faction->locale));
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_WARN);
|
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_WARN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Kontakt prüfen (aus alter Teleportroutine übernommen) */
|
/* Kontakt prüfen (aus alter Teleportroutine übernommen) */
|
||||||
{
|
{
|
||||||
/* Nun kommt etwas reichlich krankes, um den
|
/* Nun kommt etwas reichlich krankes, um den
|
||||||
* KONTAKTIERE-Befehl des Ziels zu überprüfen. */
|
* KONTAKTIERE-Befehl des Ziels zu überprüfen. */
|
||||||
|
|
||||||
for (S = target->orders; S; S = S->next) {
|
for (S = target->orders; S; S = S->next) {
|
||||||
if (strncasecmp("KON", S->s, 3) == 0) {
|
if (strncasecmp("KON", S->s, 3) == 0) {
|
||||||
char *c;
|
char *c;
|
||||||
int kontakt = -1;
|
int kontakt = -1;
|
||||||
/* So weit, so gut. S->s ist also ein KONTAKTIERE. Nun gilt es,
|
/* So weit, so gut. S->s ist also ein KONTAKTIERE. Nun gilt es,
|
||||||
* herauszufinden, wer kontaktiert wird. Das ist nicht trivial.
|
* herauszufinden, wer kontaktiert wird. Das ist nicht trivial.
|
||||||
* Zuerst muß der Parameter herausoperiert werden. */
|
* Zuerst muß der Parameter herausoperiert werden. */
|
||||||
/* Leerzeichen finden */
|
/* Leerzeichen finden */
|
||||||
|
|
||||||
for (c = S->s; *c != 0; c++) {
|
for (c = S->s; *c != 0; c++) {
|
||||||
if (isspace((int)*c) != 0) {
|
if (isspace((int)*c) != 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Wenn ein Leerzeichen da ist, ist *c != 0 und zeigt auf das
|
/* Wenn ein Leerzeichen da ist, ist *c != 0 und zeigt auf das
|
||||||
* Leerzeichen. */
|
* Leerzeichen. */
|
||||||
|
|
||||||
if (*c == 0) {
|
if (*c == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
kontakt = atoi36(c);
|
kontakt = atoi36(c);
|
||||||
|
|
||||||
if (kontakt == mage->no) {
|
if (kontakt == mage->no) {
|
||||||
kontaktiert = 1;
|
kontaktiert = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (kontaktiert == 0){
|
if (kontaktiert == 0) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Die Einheit %s hat keinen "
|
ADDMSG(&mage->faction->msgs, msg_message("spellfail::contact",
|
||||||
"Kontakt mit uns aufgenommen.", unitname(mage),
|
"mage region order target", mage, mage->region, strdup(co->order),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale)
|
target));
|
||||||
, unitname(target));
|
return 0;
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
}
|
||||||
return 0;
|
u_setfaction(target,mage->faction);
|
||||||
}
|
set_string(&target->thisorder, "");
|
||||||
u_setfaction(target,mage->faction);
|
|
||||||
set_string(&target->thisorder, "");
|
|
||||||
|
|
||||||
/* Erfolg melden */
|
/* Erfolg melden */
|
||||||
ADDMSG(&mage->faction->msgs, msg_message(
|
ADDMSG(&mage->faction->msgs, msg_message("sp_migranten",
|
||||||
"sp_migranten", "unit region command target", mage,
|
"unit region command target", mage, mage->region, strdup(co->order), target));
|
||||||
mage->region, strdup(co->order), target));
|
|
||||||
|
|
||||||
return target->number;
|
return target->number;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
@ -4841,7 +4838,7 @@ sp_calm_monster(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
c = create_curse(mage, &target->attribs, ct_find("calmmonster"), force,
|
c = create_curse(mage, &target->attribs, ct_find("calmmonster"), force,
|
||||||
(int)force, (int)mage->faction, 0);
|
(int)force, (int)mage->faction, 0);
|
||||||
if (c==NULL) {
|
if (c==NULL) {
|
||||||
report_failure(mage, co->order);
|
report_failure(mage, co->order);
|
||||||
|
@ -5824,7 +5821,7 @@ sp_enterastral(castorder *co)
|
||||||
ro = r;
|
ro = r;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Dieser Zauber funktioniert "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Dieser Zauber funktioniert "
|
||||||
"nur in der materiellen Welt.", unitname(mage),
|
"nur in der materiellen Welt.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -5832,7 +5829,7 @@ sp_enterastral(castorder *co)
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!rt) {
|
if(!rt) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Es kann hier kein Kontakt zur "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Es kann hier kein Kontakt zur "
|
||||||
"Astralwelt hergestellt werden.", unitname(mage),
|
"Astralwelt hergestellt werden.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -5841,7 +5838,7 @@ sp_enterastral(castorder *co)
|
||||||
|
|
||||||
if(is_cursed(rt->attribs, C_ASTRALBLOCK, 0) ||
|
if(is_cursed(rt->attribs, C_ASTRALBLOCK, 0) ||
|
||||||
is_cursed(ro->attribs, C_ASTRALBLOCK, 0)) {
|
is_cursed(ro->attribs, C_ASTRALBLOCK, 0)) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Es kann kein Kontakt zu "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Es kann kein Kontakt zu "
|
||||||
"dieser astralen Region hergestellt werden.", unitname(mage),
|
"dieser astralen Region hergestellt werden.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -5948,7 +5945,7 @@ sp_pullastral(castorder *co)
|
||||||
rl2 = rl2->next;
|
rl2 = rl2->next;
|
||||||
}
|
}
|
||||||
if(!rl2) {
|
if(!rl2) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Es kann kein Kontakt zu "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Es kann kein Kontakt zu "
|
||||||
"dieser Region hergestellt werden.", unitname(mage),
|
"dieser Region hergestellt werden.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -5958,7 +5955,7 @@ sp_pullastral(castorder *co)
|
||||||
free_regionlist(rl);
|
free_regionlist(rl);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Dieser Zauber funktioniert "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Dieser Zauber funktioniert "
|
||||||
"nur in der astralen Welt.", unitname(mage),
|
"nur in der astralen Welt.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -5967,7 +5964,7 @@ sp_pullastral(castorder *co)
|
||||||
|
|
||||||
if(is_cursed(rt->attribs, C_ASTRALBLOCK, 0) ||
|
if(is_cursed(rt->attribs, C_ASTRALBLOCK, 0) ||
|
||||||
is_cursed(ro->attribs, C_ASTRALBLOCK, 0)) {
|
is_cursed(ro->attribs, C_ASTRALBLOCK, 0)) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Es kann kein Kontakt zu "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Es kann kein Kontakt zu "
|
||||||
"dieser Region hergestellt werden.", unitname(mage),
|
"dieser Region hergestellt werden.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -6094,7 +6091,7 @@ sp_leaveastral(castorder *co)
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
remaining_cap = (int)((power-3) * 1500);
|
remaining_cap = (int)((power-3) * 1500);
|
||||||
|
|
||||||
/* für jede Einheit in der Kommandozeile */
|
/* für jede Einheit in der Kommandozeile */
|
||||||
|
@ -6623,7 +6620,7 @@ sp_permtransfer(castorder *co)
|
||||||
aura = pa->param[0]->data.i;
|
aura = pa->param[0]->data.i;
|
||||||
|
|
||||||
if(!is_mage(tu)) {
|
if(!is_mage(tu)) {
|
||||||
/* sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Einheit ist kein Magier."
|
/* sprintf(buf, "%s in %s: 'ZAUBER %s': Einheit ist kein Magier."
|
||||||
, unitname(mage), regionid(mage->region),sa->strings[0]); */
|
, unitname(mage), regionid(mage->region),sa->strings[0]); */
|
||||||
cmistake(mage, strdup(co->order), 214, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 214, MSG_MAGIC);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -6669,7 +6666,7 @@ sp_movecastle(castorder *co)
|
||||||
dir = finddirection(pa->param[1]->data.s, mage->faction->locale);
|
dir = finddirection(pa->param[1]->data.s, mage->faction->locale);
|
||||||
|
|
||||||
if(dir == NODIRECTION) {
|
if(dir == NODIRECTION) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Ungültige Richtung %s.",
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Ungültige Richtung %s.",
|
||||||
unitname(mage), regionid(mage->region),
|
unitname(mage), regionid(mage->region),
|
||||||
spell_name(sp, mage->faction->locale),
|
spell_name(sp, mage->faction->locale),
|
||||||
pa->param[1]->data.s);
|
pa->param[1]->data.s);
|
||||||
|
@ -6678,7 +6675,7 @@ sp_movecastle(castorder *co)
|
||||||
}
|
}
|
||||||
|
|
||||||
if(b->size > (cast_level-12) * 250) {
|
if(b->size > (cast_level-12) * 250) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Der Elementar ist "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Der Elementar ist "
|
||||||
"zu klein, um das Gebäude zu tragen.", unitname(mage),
|
"zu klein, um das Gebäude zu tragen.", unitname(mage),
|
||||||
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
regionid(mage->region), spell_name(sp, mage->faction->locale));
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
|
@ -6688,7 +6685,7 @@ sp_movecastle(castorder *co)
|
||||||
target_region = rconnect(r,dir);
|
target_region = rconnect(r,dir);
|
||||||
|
|
||||||
if(!(terrain[target_region->terrain].flags & LAND_REGION)) {
|
if(!(terrain[target_region->terrain].flags & LAND_REGION)) {
|
||||||
sprintf(buf, "%s in %s: 'ZAUBER \"%s\"': Der Erdelementar "
|
sprintf(buf, "%s in %s: 'ZAUBER %s': Der Erdelementar "
|
||||||
"weigert sich, nach %s zu gehen.",
|
"weigert sich, nach %s zu gehen.",
|
||||||
unitname(mage), regionid(mage->region),
|
unitname(mage), regionid(mage->region),
|
||||||
spell_name(sp, mage->faction->locale),
|
spell_name(sp, mage->faction->locale),
|
||||||
|
@ -7708,7 +7705,7 @@ get_spellnames(const struct locale * lang, magic_t mtype)
|
||||||
return sn;
|
return sn;
|
||||||
}
|
}
|
||||||
|
|
||||||
static spell *
|
static spell *
|
||||||
find_spellbyname_i(const char *name, const struct locale * lang, magic_t mtype)
|
find_spellbyname_i(const char *name, const struct locale * lang, magic_t mtype)
|
||||||
{
|
{
|
||||||
spell * sp = NULL;
|
spell * sp = NULL;
|
||||||
|
@ -9927,7 +9924,7 @@ static spell spelldaten[] =
|
||||||
},
|
},
|
||||||
(spell_f)sp_pullastral, patzer
|
(spell_f)sp_pullastral, patzer
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
SPL_FETCHASTRAL, "Ruf der Realität",
|
SPL_FETCHASTRAL, "Ruf der Realität",
|
||||||
"Ein Magier, welcher sich in der materiellen Welt befindet, kann er mit "
|
"Ein Magier, welcher sich in der materiellen Welt befindet, kann er mit "
|
||||||
|
@ -10079,7 +10076,7 @@ static spell spelldaten[] =
|
||||||
},
|
},
|
||||||
(spell_f)sp_magicrunes, patzer
|
(spell_f)sp_magicrunes, patzer
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
SPL_REDUCESHIELD, "Schild des Fisches",
|
SPL_REDUCESHIELD, "Schild des Fisches",
|
||||||
"Dieser Zauber vermag dem Gegner ein geringfügig versetztes Bild der "
|
"Dieser Zauber vermag dem Gegner ein geringfügig versetztes Bild der "
|
||||||
|
@ -10518,7 +10515,7 @@ static spell spelldaten[] =
|
||||||
},
|
},
|
||||||
(spell_f)sp_wdwpyramid, patzer
|
(spell_f)sp_wdwpyramid, patzer
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
SPL_WDWPYRAMID_DRUIDE, "Kraft der Natur",
|
SPL_WDWPYRAMID_DRUIDE, "Kraft der Natur",
|
||||||
"Mit Hilfe dieses Zaubers kann der Magier erkennen, ob eine "
|
"Mit Hilfe dieses Zaubers kann der Magier erkennen, ob eine "
|
||||||
|
@ -10566,10 +10563,10 @@ static spell spelldaten[] =
|
||||||
{
|
{
|
||||||
SPL_NOSPELL, "Keiner", NULL, NULL, NULL, 0, 0, 0, 0,
|
SPL_NOSPELL, "Keiner", NULL, NULL, NULL, 0, 0, 0, 0,
|
||||||
{
|
{
|
||||||
{ 0, 0, 0 },
|
{ 0, 0, 0 },
|
||||||
{ 0, 0, 0 },
|
{ 0, 0, 0 },
|
||||||
{ 0, 0, 0 },
|
{ 0, 0, 0 },
|
||||||
{ 0, 0, 0 },
|
{ 0, 0, 0 },
|
||||||
{ 0, 0, 0 }
|
{ 0, 0, 0 }
|
||||||
},
|
},
|
||||||
NULL, NULL
|
NULL, NULL
|
||||||
|
|
|
@ -39,13 +39,8 @@
|
||||||
|
|
||||||
#define ZEROFOKS_QUESTMASTER "eressea@zerofoks.net"
|
#define ZEROFOKS_QUESTMASTER "eressea@zerofoks.net"
|
||||||
|
|
||||||
#define CHECK_OVERLOAD_ON_ENTER
|
|
||||||
#undef REGIONOWNERS
|
|
||||||
|
|
||||||
#undef DUNGEON_MODULE
|
#undef DUNGEON_MODULE
|
||||||
#define MUSEUM_MODULE
|
#define MUSEUM_MODULE
|
||||||
#define ARENA_MODULE
|
#define ARENA_MODULE
|
||||||
#define WORMHOLE_MODULE
|
#define WORMHOLE_MODULE
|
||||||
|
|
||||||
#define MAILITPATH "/usr/sbin:$HOME/eressea/bin:/bin:/usr/bin:/usr/local/bin"
|
|
||||||
|
|
||||||
|
|
|
@ -35,5 +35,3 @@
|
||||||
#define PEASANTS_DO_NOT_STARVE 0
|
#define PEASANTS_DO_NOT_STARVE 0
|
||||||
#define NEW_MIGRATION 1
|
#define NEW_MIGRATION 1
|
||||||
#define ASTRAL_HUNGER
|
#define ASTRAL_HUNGER
|
||||||
|
|
||||||
#define MAILITPATH "/usr/sbin:$HOME/tutorial/bin:/bin:/usr/bin:/usr/local/bin"
|
|
||||||
|
|
|
@ -34,7 +34,6 @@
|
||||||
#define COMBAT_TURNS 5
|
#define COMBAT_TURNS 5
|
||||||
#define PEASANTS_DO_NOT_STARVE 0
|
#define PEASANTS_DO_NOT_STARVE 0
|
||||||
#define NEW_MIGRATION 1
|
#define NEW_MIGRATION 1
|
||||||
#define MIGRANTS_CAN_LEARN_EXPENSIVE_SKILLS 1 /* vinyambar 3 only */
|
|
||||||
|
|
||||||
#if NEWATSROI == 1
|
#if NEWATSROI == 1
|
||||||
#define ATSBONUS 2
|
#define ATSBONUS 2
|
||||||
|
|
|
@ -1,38 +0,0 @@
|
||||||
/* vi: set ts=2:
|
|
||||||
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
||||||
| | Enno Rehling <enno@eressea-pbem.de>
|
|
||||||
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
|
|
||||||
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
|
|
||||||
| | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de>
|
|
||||||
+-------------------+ Stefan Reich <reich@halbling.de>
|
|
||||||
|
|
||||||
This program may not be used, modified or distributed
|
|
||||||
without prior permission by the authors of Eressea.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Contains defines for the "classic" game (Vinyambar I) .
|
|
||||||
* Include this file from settings.h to make eressea work.
|
|
||||||
*/
|
|
||||||
#define ENTERTAINFRACTION 20
|
|
||||||
#define IMMUN_GEGEN_ANGRIFF 8
|
|
||||||
#define RESOURCE_CONVERSION 0
|
|
||||||
#define NEW_RESOURCEGROWTH 0
|
|
||||||
#define LARGE_CASTLES 0
|
|
||||||
#define GROWING_TREES 0
|
|
||||||
#define REDUCED_PEASANTGROWTH 0
|
|
||||||
#define RACE_ADJUSTMENTS 0
|
|
||||||
#define TEACHDIFFERENCE 1
|
|
||||||
#define PEASANT_ADJUSTMENT 0
|
|
||||||
#define GUARD_DISABLES_RECRUIT 0
|
|
||||||
#define GUARD_DISABLES_PRODUCTION 0
|
|
||||||
#define RESOURCE_QUANTITY 1.0
|
|
||||||
#define RECRUITFRACTION 20
|
|
||||||
#define CATAPULT_AMMUNITION 0
|
|
||||||
#define CHANGED_CROSSBOWS 0
|
|
||||||
#define NEWATSROI 0
|
|
||||||
#define COMBAT_TURNS 10
|
|
||||||
#define PEASANTS_DO_NOT_STARVE 0
|
|
||||||
#define NEW_MIGRATION 1
|
|
||||||
|
|
||||||
#define MAILITPATH "/usr/sbin:$HOME/bin:/bin:/usr/bin:/usr/local/bin"
|
|
|
@ -1,38 +0,0 @@
|
||||||
/* vi: set ts=2:
|
|
||||||
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
||||||
| | Enno Rehling <enno@eressea-pbem.de>
|
|
||||||
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
|
|
||||||
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
|
|
||||||
| | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de>
|
|
||||||
+-------------------+ Stefan Reich <reich@halbling.de>
|
|
||||||
|
|
||||||
This program may not be used, modified or distributed
|
|
||||||
without prior permission by the authors of Eressea.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Contains defines for the "modern" vinyambar game.
|
|
||||||
* Include this file from settings.h to make eressea work.
|
|
||||||
*/
|
|
||||||
#define ENTERTAINFRACTION 20
|
|
||||||
#define IMMUN_GEGEN_ANGRIFF 8
|
|
||||||
#define RESOURCE_CONVERSION 1
|
|
||||||
#define NEW_RESOURCEGROWTH 1
|
|
||||||
#define LARGE_CASTLES 1
|
|
||||||
#define GROWING_TREES 1
|
|
||||||
#define REDUCED_PEASANTGROWTH 0
|
|
||||||
#define RACE_ADJUSTMENTS 0
|
|
||||||
#define TEACHDIFFERENCE 1
|
|
||||||
#define PEASANT_ADJUSTMENT 0
|
|
||||||
#define GUARD_DISABLES_RECRUIT 0
|
|
||||||
#define GUARD_DISABLES_PRODUCTION 0
|
|
||||||
#define RESOURCE_QUANTITY 1.0
|
|
||||||
#define RECRUITFRACTION 20
|
|
||||||
#define CATAPULT_AMMUNITION 0
|
|
||||||
#define CHANGED_CROSSBOWS 0
|
|
||||||
#define NEWATSROI 0
|
|
||||||
#define COMBAT_TURNS 10
|
|
||||||
#define PEASANTS_DO_NOT_STARVE 0
|
|
||||||
#define NEW_MIGRATION 1
|
|
||||||
|
|
||||||
#define MAILITPATH "/usr/sbin:$HOME/bin:/bin:/usr/bin:/usr/local/bin"
|
|
|
@ -34,7 +34,6 @@
|
||||||
#define COMBAT_TURNS 5
|
#define COMBAT_TURNS 5
|
||||||
#define PEASANTS_DO_NOT_STARVE 0
|
#define PEASANTS_DO_NOT_STARVE 0
|
||||||
#define NEW_MIGRATION 1
|
#define NEW_MIGRATION 1
|
||||||
#define MIGRANTS_CAN_LEARN_EXPENSIVE_SKILLS 1 /* vinyambar 3 only */
|
|
||||||
#define ASTRAL_HUNGER
|
#define ASTRAL_HUNGER
|
||||||
|
|
||||||
#if NEWATSROI == 1
|
#if NEWATSROI == 1
|
||||||
|
@ -52,5 +51,3 @@
|
||||||
#define WDW_PHOENIX
|
#define WDW_PHOENIX
|
||||||
#define WDW_PYRAMIDSPELL
|
#define WDW_PYRAMIDSPELL
|
||||||
#define NEW_STARTEQUIPMENT
|
#define NEW_STARTEQUIPMENT
|
||||||
|
|
||||||
#define MAILITPATH "/usr/sbin:$HOME/bin:/bin:/usr/bin:/usr/local/bin"
|
|
||||||
|
|
|
@ -26,7 +26,9 @@
|
||||||
<param name="GiveRestriction" value="3"/>
|
<param name="GiveRestriction" value="3"/>
|
||||||
<param name="hunger.long" value="1"/>
|
<param name="hunger.long" value="1"/>
|
||||||
<param name="database.gameid" value="0"/>
|
<param name="database.gameid" value="0"/>
|
||||||
|
<param name="rules.check_overload" value="1"/>
|
||||||
<param name="firstturn" value="184"/>
|
<param name="firstturn" value="184"/>
|
||||||
|
<param name="report.mailit" value="/usr/sbin:$HOME/eressea/bin:/bin:/usr/bin:/usr/local/bin"/>
|
||||||
</game>
|
</game>
|
||||||
<xi:include href="eressea/de/strings.xml"/>
|
<xi:include href="eressea/de/strings.xml"/>
|
||||||
<xi:include href="eressea/en/strings.xml"/>
|
<xi:include href="eressea/en/strings.xml"/>
|
||||||
|
|
|
@ -5762,6 +5762,15 @@
|
||||||
<text locale="de">"In $region($region) findet ein Kampf statt."</text>
|
<text locale="de">"In $region($region) findet ein Kampf statt."</text>
|
||||||
<text locale="en">"There is a battle in $region($region)."</text>
|
<text locale="en">"There is a battle in $region($region)."</text>
|
||||||
</message>
|
</message>
|
||||||
|
<message name="battle::combatspell" section="battle">
|
||||||
|
<type>
|
||||||
|
<arg name="mage" type="unit"/>
|
||||||
|
<arg name="spell" type="spell"/>
|
||||||
|
<arg name="dead" type="int"/>
|
||||||
|
</type>
|
||||||
|
<text locale="de">"$unit($mage) zaubert $spell($spell): $int($dead) $if($eq($dead,1),"Krieger wurde", "Krieger wurden") getötet."</text>
|
||||||
|
<text locale="en">"$unit($mage) casts $spell($spell): $int($dead) $if($eq($dead,1),"enemy was", "enemies were") killed."</text>
|
||||||
|
</message>
|
||||||
<message name="battle::army_report" section="battle">
|
<message name="battle::army_report" section="battle">
|
||||||
<type>
|
<type>
|
||||||
<arg name="index" type="int"/>
|
<arg name="index" type="int"/>
|
||||||
|
@ -5773,5 +5782,34 @@
|
||||||
<text locale="de">"Heer $int($index)($abbrev): $int($dead) Tote, $int($flown) Geflohene, $int($survived) Überlebende."</text>
|
<text locale="de">"Heer $int($index)($abbrev): $int($dead) Tote, $int($flown) Geflohene, $int($survived) Überlebende."</text>
|
||||||
<text locale="en">"Army $int($index)($abbrev): $int($dead) dead, $int($flown) flown, $int($survived) survivors."</text>
|
<text locale="en">"Army $int($index)($abbrev): $int($dead) dead, $int($flown) flown, $int($survived) survivors."</text>
|
||||||
</message>
|
</message>
|
||||||
|
<message name="spellfail::nolevel" section="magic">
|
||||||
|
<type>
|
||||||
|
<arg name="mage" type="unit"/>
|
||||||
|
<arg name="region" type="region"/>
|
||||||
|
<arg name="command" type="order"/>
|
||||||
|
</type>
|
||||||
|
<text locale="de">"$unit($mage) in $region($region): '$order($command)' - Dieser Zauber kann nicht mit Stufenangabe gezaubert werden."</text>
|
||||||
|
<text locale="en">"$unit($mage) in $region($region): '$order($command)' - This spell cannot be cast with variable level."</text>
|
||||||
|
</message>
|
||||||
|
<message name="spellfail::nocontact" section="magic">
|
||||||
|
<type>
|
||||||
|
<arg name="mage" type="unit"/>
|
||||||
|
<arg name="region" type="region"/>
|
||||||
|
<arg name="command" type="order"/>
|
||||||
|
<arg name="target" type="string"/>
|
||||||
|
</type>
|
||||||
|
<text locale="de">"$unit($mage) in $region($region): '$order($command)' - Zur Region $target kann kein Kontakt hergestellt werden."</text>
|
||||||
|
<text locale="en">"$unit($mage) in $region($region): '$order($command)' - The region $target could not be contacted."</text>
|
||||||
|
</message>
|
||||||
|
<message name="spellfail::contact" section="magic">
|
||||||
|
<type>
|
||||||
|
<arg name="unit" type="unit"/>
|
||||||
|
<arg name="region" type="region"/>
|
||||||
|
<arg name="command" type="order"/>
|
||||||
|
<arg name="target" type="unit"/>
|
||||||
|
</type>
|
||||||
|
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Die Einheit $unit($target) hat keinen Kontakt mit uns aufgenommen."</text>
|
||||||
|
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - The unit $unit($target) did not contact us."</text>
|
||||||
|
</message>
|
||||||
</messages>
|
</messages>
|
||||||
|
|
||||||
|
|
|
@ -1,44 +1,45 @@
|
||||||
<?xml version="1.0"?>
|
<?xml version="1.0"?>
|
||||||
<eressea xmlns:xi="http://www.w3.org/2001/XInclude">
|
<eressea xmlns:xi="http://www.w3.org/2001/XInclude">
|
||||||
<xi:include href="messages.xml"/>
|
<xi:include href="messages.xml"/>
|
||||||
|
|
||||||
<comment>Localization</comment>
|
<comment>Localization</comment>
|
||||||
<xi:include href="de/strings.xml"/>
|
<xi:include href="de/strings.xml"/>
|
||||||
<xi:include href="en/strings.xml"/>
|
<xi:include href="en/strings.xml"/>
|
||||||
<xi:include file="fr/strings.xml"/>
|
<xi:include file="fr/strings.xml"/>
|
||||||
|
|
||||||
<xi:include href="races.xml"/>
|
<xi:include href="races.xml"/>
|
||||||
<xi:include href="resources.xml"/>
|
<xi:include href="resources.xml"/>
|
||||||
<xi:include href="ships.xml"/>
|
<xi:include href="ships.xml"/>
|
||||||
<xi:include href="buildings.xml"/>
|
<xi:include href="buildings.xml"/>
|
||||||
|
|
||||||
<game name="Tutorial" welcome="tutorial">
|
<game name="Tutorial" welcome="tutorial">
|
||||||
<comment>Game specific</comment>
|
<comment>Game specific</comment>
|
||||||
<order name="EMAIL" disable="yes"></order>
|
<order name="EMAIL" disable="yes"></order>
|
||||||
<order name="MEINUNG" disable="yes"></order>
|
<order name="MEINUNG" disable="yes"></order>
|
||||||
<order name="MAGIEGEBIET" disable="yes"></order>
|
<order name="MAGIEGEBIET" disable="yes"></order>
|
||||||
<param name="entertain.base" value="0"></param>
|
<param name="entertain.base" value="0"></param>
|
||||||
<param name="entertain.perlevel" value="20"></param>
|
<param name="entertain.perlevel" value="20"></param>
|
||||||
<param name="nmr.timeout" value="2"></param>
|
<param name="nmr.timeout" value="2"></param>
|
||||||
<param name="nmr.removenewbie" value="1"></param>
|
<param name="nmr.removenewbie" value="1"></param>
|
||||||
<param name="GiveRestriction" value="3"></param>
|
<param name="GiveRestriction" value="3"></param>
|
||||||
<param name="database.gameid" value="1"></param>
|
<param name="database.gameid" value="1"></param>
|
||||||
<param name="hunger.long" value="1"></param>
|
<param name="hunger.long" value="1"></param>
|
||||||
<param name="MaxAge" value="8"></param>
|
<param name="MaxAge" value="8"></param>
|
||||||
</game>
|
<param name="report.mailit" value="/usr/sbin:$HOME/eressea/bin:/bin:/usr/bin:/usr/local/bin"/>
|
||||||
<xi:include file="tutorial/de/strings.xml"/>
|
</game>
|
||||||
<xi:include file="tutorial/en/strings.xml"/>
|
<xi:include file="tutorial/de/strings.xml"/>
|
||||||
<xi:include file="eressea/races.xml"/>
|
<xi:include file="tutorial/en/strings.xml"/>
|
||||||
<xi:include file="eressea/items.xml"/>
|
<xi:include file="eressea/races.xml"/>
|
||||||
<xi:include file="eressea/dungeons.xml"/>
|
<xi:include file="eressea/items.xml"/>
|
||||||
<strings>
|
<xi:include file="eressea/dungeons.xml"/>
|
||||||
<string name="mailto">
|
<strings>
|
||||||
<text locale="en">tutorial@eressea.upb.de</text>
|
<string name="mailto">
|
||||||
<text locale="de">tutorial@eressea.upb.de</text>
|
<text locale="en">tutorial@eressea.upb.de</text>
|
||||||
</string>
|
<text locale="de">tutorial@eressea.upb.de</text>
|
||||||
<string name="mailcmd">
|
</string>
|
||||||
<text locale="de">ERESSEA BEFEHLE</text>
|
<string name="mailcmd">
|
||||||
<text locale="en">ERESSEA ORDERS</text>
|
<text locale="de">ERESSEA BEFEHLE</text>
|
||||||
</string>
|
<text locale="en">ERESSEA ORDERS</text>
|
||||||
</strings>
|
</string>
|
||||||
|
</strings>
|
||||||
</eressea>
|
</eressea>
|
||||||
|
|
|
@ -1,36 +1,38 @@
|
||||||
<eressea>
|
<eressea>
|
||||||
<include file="messages.xml"></include>
|
<include file="messages.xml"></include>
|
||||||
|
|
||||||
<comment>Localization</comment>
|
<comment>Localization</comment>
|
||||||
<include file="de/strings.xml"></include>
|
<include file="de/strings.xml"></include>
|
||||||
<include file="en/strings.xml"></include>
|
<include file="en/strings.xml"></include>
|
||||||
|
|
||||||
<include file="races.xml"></include>
|
<include file="races.xml"></include>
|
||||||
<include file="resources.xml"></include>
|
<include file="resources.xml"></include>
|
||||||
<include file="ships.xml"></include>
|
<include file="ships.xml"></include>
|
||||||
<include file="buildings.xml"></include>
|
<include file="buildings.xml"></include>
|
||||||
|
|
||||||
<game name="Kreis der Macht" units="250" welcome="vinyambar">
|
<game name="Kreis der Macht" units="250" welcome="vinyambar">
|
||||||
<comment>Game specific</comment>
|
<comment>Game specific</comment>
|
||||||
<order name="ARBEITEN" disable></order>
|
<order name="ARBEITEN" disable></order>
|
||||||
<order name="MEINUNG" disable></order>
|
<order name="MEINUNG" disable></order>
|
||||||
<order name="MAGIEGEBIET" disable></order>
|
<order name="MAGIEGEBIET" disable></order>
|
||||||
<param name="entertain.base" value="15"></param>
|
<param name="entertain.base" value="15"></param>
|
||||||
<param name="entertain.perlevel" value="5"></param>
|
<param name="entertain.perlevel" value="5"></param>
|
||||||
<param name="nmr.timeout" value="5"></param>
|
<param name="nmr.timeout" value="5"></param>
|
||||||
<param name="nmr.removenewbie" value="0"></param>
|
<param name="nmr.removenewbie" value="0"></param>
|
||||||
<param name="GiveRestriction" value="0"></param>
|
<param name="GiveRestriction" value="0"></param>
|
||||||
<param name="database.gameid" value="3"></param>
|
<param name="database.gameid" value="3"></param>
|
||||||
<param name="hunger.long" value="0"></param>
|
<param name="hunger.long" value="0"></param>
|
||||||
</game>
|
<param name="study.expensivemigrants" value="1"/>
|
||||||
<include file="vinyambar/de/strings.xml"></include>
|
<param name="report.mailit" value="/usr/sbin:$HOME/bin:/bin:/usr/bin:/usr/local/bin"/>
|
||||||
<include file="vinyambar/stronghold.xml"></include>
|
</game>
|
||||||
<strings>
|
<include file="vinyambar/de/strings.xml"></include>
|
||||||
<string name="mailto">
|
<include file="vinyambar/stronghold.xml"></include>
|
||||||
<text>vinyambar@eressea.amber.kn-bremen.de</text>
|
<strings>
|
||||||
</string>
|
<string name="mailto">
|
||||||
<string name="mailcmd">
|
<text>vinyambar@eressea.amber.kn-bremen.de</text>
|
||||||
<text>VIN3 BEFEHLE</text>
|
</string>
|
||||||
</string>
|
<string name="mailcmd">
|
||||||
</strings>
|
<text>VIN3 BEFEHLE</text>
|
||||||
|
</string>
|
||||||
|
</strings>
|
||||||
</eressea>
|
</eressea>
|
||||||
|
|
|
@ -31,6 +31,8 @@
|
||||||
<param name="magic.regeneration" value="0.5"/>
|
<param name="magic.regeneration" value="0.5"/>
|
||||||
<param name="magic.power" value="0.5"/>
|
<param name="magic.power" value="0.5"/>
|
||||||
<param name="resource.factor" value="0.25"/>
|
<param name="resource.factor" value="0.25"/>
|
||||||
|
<param name="study.expensivemigrants" value="1"/>
|
||||||
|
<param name="report.mailit" value="/usr/sbin:$HOME/bin:/bin:/usr/bin:/usr/local/bin"/>
|
||||||
</game>
|
</game>
|
||||||
|
|
||||||
<xi:include href="vinyambar/wdw-strings.xml"/>
|
<xi:include href="vinyambar/wdw-strings.xml"/>
|
||||||
|
|
Loading…
Reference in a new issue