* Bugfix Durchreiseregionen bei Start=Ziel

* Bugfix Sichtbarkeitsregel bei Borders
* Neu definiert, was eine attribut-funktion zurückliefern soll, wenn sie
  failed. asserts, die checken das ich auch keine vergessen habe.
  damit ist die killunit::handle Geschichte erledigt.
* Bugfix looting. Sowohl eigene als auch fremde Einheiten können looten.
* Korrektur doppeltes shock-attribut.
* Straßen, Diskrepanz im NR und CR beseitigt
* remove_empty_factions macht kein free mehr.
This commit is contained in:
Enno Rehling 2002-04-07 00:44:01 +00:00
parent f2f09674cf
commit 4fb2137edd
60 changed files with 442 additions and 373 deletions

View file

@ -30,39 +30,21 @@ verify_follow(attrib * a)
return 1;
}
#define FOLLOW_PERSISTENT 0
#if FOLLOW_PERSISTENT
static void
write_follow(const attrib * a, FILE * F)
{
write_unit_reference((unit*)a->data.v, F);
}
#else
#define write_follow NULL
#endif
static int
read_follow(attrib * a, FILE * F)
{
if (global.data_version < BASE36IDS_VERSION) {
int i;
fscanf(F, "%d", &i);
#if FOLLOW_PERSISTENT
ur_add((void*)i, (void**)&a->data.v, resolve_unit);
#endif
} else {
#if FOLLOW_PERSISTENT
read_unit_reference((unit**)&a->data.v, F);
#else
read_unit_reference(NULL, F);
#endif
return read_unit_reference(NULL, F);
}
return FOLLOW_PERSISTENT;
return AT_READ_OK;
}
attrib_type at_follow = {
"follow", NULL, NULL, verify_follow, write_follow, read_follow
"follow", NULL, NULL, verify_follow, NULL, read_follow
};
attrib *

View file

@ -68,7 +68,7 @@ a_readgive(attrib * a, FILE * F)
fscanf(F, "%d", &i);
if (i==0) i_add(&gdata->items, i_new(it_find(zText), i));
}
return 1;
return AT_READ_OK;
}
static void

View file

@ -31,8 +31,7 @@ write_gm(const attrib * a, FILE * F)
static int
read_gm(attrib * a, FILE * F)
{
read_plane_reference((plane**)&a->data.v, F);
return 1;
return read_plane_reference((plane**)&a->data.v, F);
}

View file

@ -44,9 +44,9 @@ read_hate(attrib * a, FILE * F)
fscanf(F, "%d", &i);
ur_add((void*)i, (void**)&a->data.v, resolve_unit);
} else {
read_unit_reference((unit**)&a->data.v, F);
return read_unit_reference((unit**)&a->data.v, F);
}
return 1;
return AT_READ_OK;
}
attrib_type at_hate = {

View file

@ -34,7 +34,8 @@ static int
read_moved(attrib * a, FILE * F)
{
fscanf(F, "%d", &a->data.i);
return a->data.i!=0;
if (a->data.i!=0) return AT_READ_OK;
else return AT_READ_FAIL;
}
attrib_type at_moved = {

View file

@ -36,8 +36,8 @@ read_of(struct attrib * a, FILE* F) /* return 1 on success, 0 if attrib needs re
int of;
fscanf(F, "%d", &of);
a->data.v = findfaction(of);
if (a->data.v) return 1;
return 0;
if (a->data.v) return AT_READ_OK;
return AT_READ_FAIL;
}
attrib_type at_otherfaction = {

View file

@ -71,7 +71,7 @@ a_readsynonym(attrib * a, FILE * F)
fscanf(F, "%s", lbuf);
frs->synonyms[3] = strdup(lbuf);
return 1;
return AT_READ_OK;
}
attrib_type at_synonym = {

View file

@ -34,9 +34,9 @@ read_targetregion(attrib * a, FILE * F)
a_readdefault(a, F);
a->data.v = findregion(a->data.sa[0], a->data.sa[1]);
} else {
read_region_reference((region**)&a->data.v, F);
return read_region_reference((region**)&a->data.v, F);
}
return 1;
return AT_READ_OK;
}
attrib_type at_targetregion = {

View file

@ -35,7 +35,7 @@ a_readfunction(struct attrib *a, FILE *F)
char buf[64];
fscanf(F, "%s ", buf);
a->data.f = get_function(buf);
return 1;
return AT_READ_OK;
}
attrib_type at_viewrange = {

View file

@ -834,6 +834,53 @@ report_resource(char * buf, const char * name, const locale * loc, int amount, i
return buf;
}
static void
cr_borders(const region * r, const faction * f, int seemode, FILE * F)
{
direction_t d;
int g = 0;
for (d = 0; d != MAXDIRECTIONS; d++)
{ /* Nachbarregionen, die gesehen werden, ermitteln */
const region * r2 = rconnect(r, d);
const border * b;
if (!r2) continue;
if (seemode==see_neighbour) {
seen_region * sr = find_seen(r2);
if (sr==NULL || sr->mode<=see_neighbour) continue;
}
b = get_borders(r, r2);
while (b) {
boolean cs = b->type->fvisible(b, f, r);
if (!cs) {
cs = b->type->rvisible(b, r);
if (!cs) {
unit * us = r->units;
while (us && !cs) {
if (us->faction==f) {
cs = b->type->uvisible(b, us);
if (cs) break;
}
us=us->next;
}
}
}
if (cs) {
fprintf(F, "GRENZE %d\n", ++g);
fprintf(F, "\"%s\";typ\n", b->type->name(b, r, f, GF_NONE));
fprintf(F, "%d;richtung\n", d);
if (!b->type->transparent(b, f)) fputs("1;opaque\n", F);
/* pfusch: */
if (b->type==&bt_road) {
int p = rroad(r, d)*100/terrain[rterrain(r)].roadreq;
fprintf(F, "%d;prozent\n", p);
}
}
b = b->next;
}
}
}
/* main function of the creport. creates the header and traverses all regions */
void
report_computer(FILE * F, faction * f, const seen_region * seen,
@ -989,12 +1036,11 @@ report_computer(FILE * F, faction * f, const seen_region * seen,
fputs("\"travel\";visibility\n", F);
break;
}
if (seemode != see_neighbour)
{
if (seemode == see_neighbour) {
cr_borders(r, f, seemode, F);
} else {
#define RESOURCECOMPAT
char cbuf[8192], *pos = cbuf;
int g = 0;
direction_t d;
#ifdef RESOURCECOMPAT
if (r->display && strlen(r->display))
fprintf(F, "\"%s\";Beschr\n", r->display);
@ -1120,42 +1166,7 @@ report_computer(FILE * F, faction * f, const seen_region * seen,
}
if (pos!=cbuf) fputs(cbuf, F);
}
for (d = 0; d != MAXDIRECTIONS; d++)
{ /* Nachbarregionen, die gesehen werden, ermitteln */
region * r2 = rconnect(r, d);
border * b;
if (!r2) continue;
b = get_borders(r, r2);
while (b) {
boolean cs = b->type->fvisible(b, f, r);
if (!cs) {
cs = b->type->rvisible(b, r);
if (!cs) {
unit * us = r->units;
while (us && !cs) {
if (us->faction==f) {
cs = b->type->uvisible(b, us);
if (cs) break;
}
us=us->next;
}
}
}
if (cs) {
fprintf(F, "GRENZE %d\n", ++g);
fprintf(F, "\"%s\";typ\n", b->type->name(b, r, f, GF_NONE));
fprintf(F, "%d;richtung\n", d);
if (!b->type->transparent(b, f)) fputs("1;opaque\n", F);
/* pfusch: */
if (b->type==&bt_road) {
int p = rroad(r, d)*100/terrain[rterrain(r)].roadreq;
fprintf(F, "%d;prozent\n", p);
}
}
b = b->next;
}
}
cr_borders(r, f, seemode, F);
if (seemode==see_unit && r->planep && r->planep->id == 1 && !is_cursed(r->attribs, C_ASTRALBLOCK, 0))
{
/* Sonderbehandlung Teleport-Ebene */

View file

@ -888,7 +888,7 @@ f_regionid(const region * r, const faction * f)
}
static void
prices(FILE * F, region * r, faction * f)
prices(FILE * F, const region * r, const faction * f)
{
const luxury_type *sale=NULL;
struct demand * dmd;
@ -928,13 +928,13 @@ extern const direction_t back[MAXDIRECTIONS];
/* ------------------------------------------------------------- */
boolean
see_border(border * b, faction * f, region * r)
see_border(const border * b, const faction * f, const region * r)
{
boolean cs = b->type->fvisible(b, f, r);
if (!cs) {
cs = b->type->rvisible(b, r);
if (!cs) {
unit * us = r->units;
const unit * us = r->units;
while (us && !cs) {
if (us->faction==f) {
cs = b->type->uvisible(b, us);
@ -984,7 +984,7 @@ eval_trail(struct opstack ** stack, const void * userdata) /* (int, int) -> int
}
static void
describe(FILE * F, region * r, int partial, faction * f)
describe(FILE * F, const region * r, int partial, faction * f)
{
char dbuf[512];
int n;
@ -1321,9 +1321,9 @@ describe(FILE * F, region * r, int partial, faction * f)
}
void
statistics(FILE * F, region * r, faction * f)
statistics(FILE * F, const region * r, const faction * f)
{
unit *u;
const unit *u;
int number, p;
item *itm, *items = NULL;
p = rpeasants(r);
@ -1379,7 +1379,7 @@ statistics(FILE * F, region * r, faction * f)
}
static void
durchreisende(FILE * F, region * r, faction * f)
durchreisende(FILE * F, const region * r, const faction * f)
{
attrib *ru;
int wieviele;
@ -1657,7 +1657,7 @@ allies(FILE * F, faction * f)
}
static void
guards(FILE * F, region * r, faction * see)
guards(FILE * F, const region * r, const faction * see)
{ /* die Partei see sieht dies; wegen
* "unbekannte Partei", wenn man es selbst ist... */
@ -1812,7 +1812,7 @@ report(FILE *F, faction * f, const faction_list * addresses,
char ch;
int dh;
int anyunits;
region *r;
const struct region *r;
building *b;
ship *sh;
unit *u;
@ -2536,45 +2536,46 @@ init_intervals()
}
#endif
static boolean
add_seen(region * r, unsigned char mode, boolean dis)
seen_region *
find_seen(const region * r)
{
seen_region * find;
int index = abs((r->x & 0xffff) + ((r->y) << 16)) % MAXSEEHASH;
for (find=seehash[index];find;find=find->nextHash) {
if (find->r==r) {
if (find->mode < mode) {
if (find->mode<=see_neighbour && find->next) {
find->next->prev = find->prev;
if (find->prev) find->prev->next = find->next;
else seen = find->next;
last->next = find;
find->prev = last;
find->next = NULL;
last = find;
append = &last->next;
}
find->mode = mode;
find->disbelieves |= dis;
return true;
}
else return false;
}
seen_region * find=seehash[index];
while (find) {
if (find->r==r) return find;
find=find->nextHash;
}
if (!reuse) reuse = (seen_region*)calloc(1, sizeof(seen_region));
*append = reuse;
reuse = reuse->next;
(*append)->next = NULL;
(*append)->prev = last;
if (last) last->next = *append;
last = *append;
(*append)->nextHash = seehash[index];
seehash[index] = *append;
(*append)->r = r;
(*append)->mode = mode;
(*append)->disbelieves = dis;
append = &(*append)->next;
return NULL;
}
static boolean
add_seen(const struct region * r, unsigned char mode, boolean dis)
{
seen_region * find = find_seen(r);
if (find) {
if (find->mode >= mode) return false;
if (find->mode>see_neighbour || find->next==NULL) return true;
/* take it out the list, so it can get processed again */
find->next->prev = find->prev;
if (find->prev) find->prev->next = find->next;
else seen = find->next;
} else {
int index = abs((r->x & 0xffff) + ((r->y) << 16)) % MAXSEEHASH;
if (!reuse) reuse = (seen_region*)calloc(1, sizeof(seen_region));
*append = find = reuse;
reuse = reuse->next;
find->nextHash = seehash[index];
seehash[index] = find;
find->r = r;
}
/* put it at the end of the list, where the unprocessed nodes are */
if (last) last->next = find;
find->next = NULL;
find->prev = last;
last = find;
append = &last->next;
find->mode = mode;
find->disbelieves |= dis;
return true;
}
@ -2591,6 +2592,10 @@ view_default(region *r, faction *f)
region * r2 = rconnect(r, dir);
if (r2) {
border * b = get_borders(r, r2);
while (b) {
if (!b->type->transparent(b, f)) break;
b = b->next;
}
if (!b) add_seen(r2, see_neighbour, false);
}
}

View file

@ -158,7 +158,7 @@ attack_firesword(const troop * at, int *casualties, int row)
int force = 1+rand()%10;
if (row==FIGHT_ROW) {
enemies = count_enemies(fi->side, FS_ENEMY,
enemies = count_enemies(fi->side->battle, fi->side, FS_ENEMY,
minrow, maxrow);
}
if (!enemies) {
@ -178,7 +178,7 @@ attack_firesword(const troop * at, int *casualties, int row)
}
do {
dt = select_enemy(fi, minrow, maxrow);
dt = select_enemy(fi->side->battle, fi, minrow, maxrow);
assert(dt.fighter);
--force;
killed += terminate(dt, *at, AT_SPELL, damage, 1);
@ -215,11 +215,11 @@ attack_catapult(const troop * at, int * casualties, int row)
}
minrow = FIGHT_ROW;
maxrow = FIGHT_ROW;
n = min(10, count_enemies(af->side, FS_ENEMY, minrow, maxrow));
n = min(10, count_enemies(b, af->side, FS_ENEMY, minrow, maxrow));
while (--n >= 0) {
/* Select defender */
dt = select_enemy(af, minrow, maxrow);
dt = select_enemy(b, af, minrow, maxrow);
if (!dt.fighter)
break;

View file

@ -197,7 +197,7 @@ a_readeffect(attrib *a, FILE *f)
if (ptype==NULL || power==0) return 0;
edata->type = ptype;
edata->value = power;
return 1;
return AT_READ_OK;
}
attrib_type at_effect = {

View file

@ -1241,10 +1241,9 @@ lovar(int n)
/* ------------------------------------------------------------- */
int
count_enemies(side * as, int mask, int minrow, int maxrow)
count_enemies(battle * b, side * as, int mask, int minrow, int maxrow)
/* new implementation of count_enemies ignores mask, since it was never used */
{
battle *b = as->battle;
int i = 0;
void **si;
@ -1252,7 +1251,7 @@ count_enemies(side * as, int mask, int minrow, int maxrow)
for (si = b->sides.begin; si != b->sides.end; ++si) {
side *side = *si;
if (enemy(side, as))
if (as==NULL || enemy(side, as))
{
void **fi;
@ -1275,15 +1274,14 @@ count_enemies(side * as, int mask, int minrow, int maxrow)
/* ------------------------------------------------------------- */
troop
select_enemy(fighter * af, int minrow, int maxrow)
select_enemy(battle * b, fighter * af, int minrow, int maxrow)
{
side *as = af->side;
battle *b = as->battle;
side *as = af?af->side:NULL;
troop dt = no_troop;
void ** si;
int enemies;
if(af->unit->race->flags & RCF_FLY) {
if (af && af->unit->race->flags & RCF_FLY) {
/* flying races ignore min- and maxrow and can attack anyone fighting
* them */
minrow = FIGHT_ROW;
@ -1291,7 +1289,7 @@ select_enemy(fighter * af, int minrow, int maxrow)
}
minrow = max(minrow, FIGHT_ROW);
enemies = count_enemies(af->side, FS_ENEMY, minrow, maxrow);
enemies = count_enemies(b, as, FS_ENEMY, minrow, maxrow);
if (!enemies)
return dt; /* Niemand ist in der angegebenen Entfernung */
@ -1299,7 +1297,7 @@ select_enemy(fighter * af, int minrow, int maxrow)
for (si=b->sides.begin;!dt.fighter && si!=b->sides.end;++si) {
side *ds = *si;
void ** fi;
if (!enemy(as, ds)) continue;
if (as!=NULL && !enemy(as, ds)) continue;
for (fi=ds->fighters.begin;fi!=ds->fighters.end;++fi) {
fighter * df = *fi;
int dr = get_unitrow(df);
@ -1892,11 +1890,11 @@ attack(battle *b, troop ta, const att *a)
boolean missile = false;
if (wp && fval(wp->type, WTF_MISSILE)) missile=true;
if (missile) {
if (row<=BEHIND_ROW) td = select_enemy(af, missile_range[0], missile_range[1]);
if (row<=BEHIND_ROW) td = select_enemy(b, af, missile_range[0], missile_range[1]);
else return;
}
else {
if (row<=FIGHT_ROW) td = select_enemy(af, melee_range[0], melee_range[1]);
if (row<=FIGHT_ROW) td = select_enemy(b, af, melee_range[0], melee_range[1]);
else return;
}
if (!td.fighter) return;
@ -1930,7 +1928,7 @@ attack(battle *b, troop ta, const att *a)
do_extra_spell(ta, a);
break;
case AT_NATURAL:
td = select_enemy(af, melee_range[0]-offset, melee_range[1]-offset);
td = select_enemy(b, af, melee_range[0]-offset, melee_range[1]-offset);
if (!td.fighter) return;
if(td.fighter->person[td.index].last_action < b->turn) {
td.fighter->person[td.index].last_action = b->turn;
@ -1945,7 +1943,7 @@ attack(battle *b, troop ta, const att *a)
}
break;
case AT_DRAIN_ST:
td = select_enemy(af, melee_range[0]-offset, melee_range[1]-offset);
td = select_enemy(b, af, melee_range[0]-offset, melee_range[1]-offset);
if (!td.fighter) return;
if(td.fighter->person[td.index].last_action < b->turn) {
td.fighter->person[td.index].last_action = b->turn;
@ -1968,7 +1966,7 @@ attack(battle *b, troop ta, const att *a)
}
break;
case AT_DRAIN_EXP:
td = select_enemy(af, melee_range[0]-offset, melee_range[1]-offset);
td = select_enemy(b, af, melee_range[0]-offset, melee_range[1]-offset);
if (!td.fighter) return;
if(td.fighter->person[td.index].last_action < b->turn) {
td.fighter->person[td.index].last_action = b->turn;
@ -1983,7 +1981,7 @@ attack(battle *b, troop ta, const att *a)
}
break;
case AT_DAZZLE:
td = select_enemy(af, melee_range[0]-offset, melee_range[1]-offset);
td = select_enemy(b, af, melee_range[0]-offset, melee_range[1]-offset);
if (!td.fighter) return;
if(td.fighter->person[td.index].last_action < b->turn) {
td.fighter->person[td.index].last_action = b->turn;
@ -1998,7 +1996,7 @@ attack(battle *b, troop ta, const att *a)
}
break;
case AT_STRUCTURAL:
td = select_enemy(af, melee_range[0]-offset, melee_range[1]-offset);
td = select_enemy(b, af, melee_range[0]-offset, melee_range[1]-offset);
if (!td.fighter) return;
if(ta.fighter->person[ta.index].last_action < b->turn) {
ta.fighter->person[ta.index].last_action = b->turn;
@ -2045,7 +2043,7 @@ do_attack(fighter * af)
while (ta.index--) {
/* Wir suchen eine beliebige Feind-Einheit aus. An der können
* wir feststellen, ob noch jemand da ist. */
int enemies = count_enemies(af->side, FS_ENEMY, FIGHT_ROW, LAST_ROW);
int enemies = count_enemies(b, af->side, FS_ENEMY, FIGHT_ROW, LAST_ROW);
if (!enemies) break;
for (apr=attacks_per_round(ta); apr > 0; apr--) {
@ -2144,6 +2142,7 @@ loot_items(fighter * corpse)
{
unit * u = corpse->unit;
item * itm = u->items;
battle * b = corpse->side->battle;
u->items = NULL;
while (itm) {
@ -2160,7 +2159,7 @@ loot_items(fighter * corpse)
*/
if (loot>0 && (itm->type->flags & (ITF_CURSED|ITF_NOTLOST)
|| rand()%100 >= 50 - corpse->side->battle->keeploot)) {
fighter *fig = select_enemy(corpse, FIGHT_ROW, LAST_ROW).fighter;
fighter *fig = select_enemy(b, corpse, FIGHT_ROW, LAST_ROW).fighter;
if (fig) {
item * l = fig->loot;
while (l && l->type!=itm->type) l=l->next;

View file

@ -209,8 +209,8 @@ extern void do_battle(void);
/* for combar spells and special attacks */
extern int damage_unit(struct unit *u, const char *dam, boolean armor, boolean magic);
extern troop select_enemy(struct fighter * af, int minrow, int maxrow);
extern int count_enemies(struct side * as, int mask, int minrow, int maxrow);
extern troop select_enemy(struct battle * b, struct fighter * af, int minrow, int maxrow);
extern int count_enemies(struct battle * b, struct side * as, int mask, int minrow, int maxrow);
extern boolean terminate(troop dt, troop at, int type, const char *damage, boolean missile);
extern void battlemsg(battle * b, struct unit * u, const char * s);
extern void battlerecord(battle * b, const char *s);

View file

@ -530,12 +530,12 @@ read_building_reference(struct building ** b, FILE * F)
id = atoi36(zText);
if (id==0) {
*b = NULL;
return 0;
return AT_READ_FAIL;
}
else {
*b = findbuilding(id);
if (*b==NULL) ur_add((void*)id, (void**)b, resolve_building);
return 1;
return AT_READ_OK;
}
}

View file

@ -134,7 +134,7 @@ sp_kampfzauber(fighter * fi, int level, int power, spell * sp)
force = lovar(get_force(power,10));
}
enemies = count_enemies(fi->side, FS_ENEMY,
enemies = count_enemies(b, fi->side, FS_ENEMY,
minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
@ -145,7 +145,7 @@ sp_kampfzauber(fighter * fi, int level, int power, spell * sp)
battlerecord(b, buf);
do {
dt = select_enemy(fi, minrow, maxrow);
dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter);
--force;
killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
@ -175,7 +175,7 @@ sp_versteinern(fighter * fi, int level, int power, spell * sp)
force = lovar(get_force(power,0));
enemies = count_enemies(fi->side, FS_ENEMY,
enemies = count_enemies(b, fi->side, FS_ENEMY,
minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
@ -186,7 +186,7 @@ sp_versteinern(fighter * fi, int level, int power, spell * sp)
battlerecord(b, buf);
do {
troop dt = select_enemy(fi, minrow, maxrow);
troop dt = select_enemy(b, fi, minrow, maxrow);
fighter * df = dt.fighter;
unit * du = df->unit;
if (is_magic_resistant(mage, du, 0) == false) {
@ -234,7 +234,7 @@ sp_stun(fighter * fi, int level, int power, spell * sp)
assert(0);
}
enemies = count_enemies(fi->side, FS_ENEMY, minrow, maxrow);
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
battlerecord(b, buf);
@ -245,7 +245,7 @@ sp_stun(fighter * fi, int level, int power, spell * sp)
stunned = 0;
do {
troop dt = select_enemy(fi, minrow, maxrow);
troop dt = select_enemy(b, fi, minrow, maxrow);
fighter * df = dt.fighter;
unit * du = df->unit;
@ -290,7 +290,7 @@ sp_combatrosthauch(fighter * fi, int level, int power, spell * sp)
force = lovar(power * 15);
enemies = count_enemies(fi->side, FS_ENEMY, minrow, maxrow);
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow, maxrow);
if (!enemies) {
battlemsg(b, fi->unit, msgt[0]);
return 0;
@ -376,7 +376,7 @@ sp_sleep(fighter * fi, int level, int power, spell * sp)
sprintf(buf, "%s zaubert %s", unitname(mage), sp->name);
force = lovar(power * 25);
enemies = count_enemies(fi->side, FS_ENEMY, minrow, maxrow);
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
@ -387,7 +387,7 @@ sp_sleep(fighter * fi, int level, int power, spell * sp)
battlerecord(b, buf);
do {
dt = select_enemy(fi, minrow, maxrow);
dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter);
du = dt.fighter->unit;
if (is_magic_resistant(mage, du, 0) == false) {
@ -522,7 +522,7 @@ sp_mindblast(fighter * fi, int level, int power, spell * sp)
sprintf(buf, "%s zaubert %s", unitname(mage), sp->name);
force = lovar(power * 25);
enemies = count_enemies(fi->side, FS_ENEMY, minrow, maxrow);
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
battlerecord(b, buf);
@ -532,7 +532,7 @@ sp_mindblast(fighter * fi, int level, int power, spell * sp)
battlerecord(b, buf);
do {
dt = select_enemy(fi, minrow, maxrow);
dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter);
du = dt.fighter->unit;
if (humanoidrace(du->race) && is_magic_resistant(mage, du, 0) == false) {
@ -606,7 +606,7 @@ sp_dragonodem(fighter * fi, int level, int power, spell * sp)
/* Jungdrache 3->54, Drache 6->216, Wyrm 12->864 Treffer */
force = lovar(get_force(level,6));
enemies = count_enemies(fi->side, FS_ENEMY, minrow,
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow,
maxrow);
if (!enemies) {
@ -621,7 +621,7 @@ sp_dragonodem(fighter * fi, int level, int power, spell * sp)
at.index = 0;
do {
dt = select_enemy(fi, minrow, maxrow);
dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter);
--force;
killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
@ -655,7 +655,7 @@ sp_drainodem(fighter * fi, int level, int power, spell * sp)
/* Jungdrache 3->54, Drache 6->216, Wyrm 12->864 Treffer */
force = lovar(get_force(level,6));
enemies = count_enemies(fi->side, FS_ENEMY, minrow,
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow,
maxrow);
if (!enemies) {
@ -670,7 +670,7 @@ sp_drainodem(fighter * fi, int level, int power, spell * sp)
at.index = 0;
do {
dt = select_enemy(fi, minrow, maxrow);
dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter);
if (hits(at, dt, NULL)) {
drain_exp(dt.fighter->unit, 90);
@ -864,7 +864,7 @@ sp_chaosrow(fighter * fi, int level, int force, spell * sp)
break;
}
enemies = count_enemies(fi->side, FS_ENEMY, minrow, maxrow);
enemies = count_enemies(b, fi->side, FS_ENEMY, minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
battlerecord(b, buf);
@ -964,7 +964,7 @@ sp_flee(fighter * fi, int level, int power, spell * sp)
force = get_force(power,10);
}
if (!count_enemies(fi->side, FS_ENEMY, minrow, maxrow)) {
if (!count_enemies(b, fi->side, FS_ENEMY, minrow, maxrow)) {
scat(", aber es gab niemanden mehr, der beeinflusst werden konnte.");
battlerecord(b, buf);
return 0;
@ -1140,7 +1140,7 @@ sp_frighten(fighter * fi, int level, int power, spell * sp)
force = get_force(power, 2);
sprintf(buf, "%s zaubert %s", unitname(mage), sp->name);
enemies = count_enemies(fi->side, FS_ENEMY,
enemies = count_enemies(b, fi->side, FS_ENEMY,
minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
@ -1151,7 +1151,7 @@ sp_frighten(fighter * fi, int level, int power, spell * sp)
battlerecord(b, buf);
do {
troop dt = select_enemy(fi, minrow, maxrow);
troop dt = select_enemy(b, fi, minrow, maxrow);
fighter *df = dt.fighter;
--enemies;
@ -1190,7 +1190,7 @@ sp_tiredsoldiers(fighter * fi, int level, int force, spell * sp)
force = force * force * 4;
sprintf(buf, "%s zaubert %s", unitname(mage), sp->name);
if (!count_enemies(fi->side, FS_ENEMY, FIGHT_ROW,
if (!count_enemies(b, fi->side, FS_ENEMY, FIGHT_ROW,
BEHIND_ROW)) {
scat(", aber niemand war in Reichweite.");
battlerecord(b, buf);
@ -1198,7 +1198,7 @@ sp_tiredsoldiers(fighter * fi, int level, int force, spell * sp)
}
while (force) {
troop t = select_enemy(fi, FIGHT_ROW, BEHIND_ROW);
troop t = select_enemy(b, fi, FIGHT_ROW, BEHIND_ROW);
fighter *df = t.fighter;
if (!df)
@ -1250,7 +1250,7 @@ sp_windshield(fighter * fi, int level, int power, spell * sp)
force = power;
at_malus = 2;
}
enemies = count_enemies(fi->side, FS_ENEMY,
enemies = count_enemies(b, fi->side, FS_ENEMY,
minrow, maxrow);
if (!enemies) {
scat(", aber niemand war in Reichweite.");
@ -1259,7 +1259,7 @@ sp_windshield(fighter * fi, int level, int power, spell * sp)
}
do {
troop dt = select_enemy(fi, minrow, maxrow);
troop dt = select_enemy(b, fi, minrow, maxrow);
fighter *df = dt.fighter;
--enemies;

View file

@ -2366,9 +2366,12 @@ remove_empty_factions(void)
}
fprintf(sqlstream, "UPDATE subscriptions set status='DEAD' where "
"faction='%s' and game=%d;", itoa36(f->no), GAME_ID);
stripfaction(f);
*fp = f->next;
free(f);
/* stripfaction(f);
* free(f);
* Wir können die nicht löschen, weil sie evtl. noch in attributen
* referenziert sind ! */
}
else fp = &(*fp)->next;
}

View file

@ -855,7 +855,6 @@ extern int max_unique_id;
#define FL_PARTEITARNUNG (1<<4) /* 16 */
#define FL_DISBELIEVES (1<<5) /* 32 */
#define FL_WARMTH (1<<6) /* 64 */
#define FL_TRAVELTHRU (1<<7) /* 128 */
#define FL_MOVED (1<<8)
#define FL_FOLLOWING (1<<9)

View file

@ -99,9 +99,9 @@ read_group(attrib * a, FILE * f)
a->data.v = g = find_group(gid);
if (g!=0) {
g->members++;
return 1;
return AT_READ_OK;
}
return 0;
return AT_READ_FAIL;
}
static void

View file

@ -148,7 +148,7 @@ a_readicastle(attrib * a, FILE * f)
fscanf(f, "%d", &t);
data->time = 0;
data->type = NULL;
return 0; /* no longer supported */
return AT_READ_FAIL;
} else {
int bno;
fscanf(f, "%s %d %d", buf, &bno, &data->time);
@ -158,7 +158,7 @@ a_readicastle(attrib * a, FILE * f)
ur_add((void*)bno, (void**)&data->building, resolve_building);
}
data->type = bt_find(buf);
return 1;
return AT_READ_OK;
}
}
@ -246,7 +246,7 @@ read_mage(attrib * a, FILE * F)
(*sp)->spellid = (spellid_t)i;
sp = &(*sp)->next;
}
return 1;
return AT_READ_OK;
}
static void
@ -2636,7 +2636,7 @@ read_familiar(attrib * a, FILE * F)
fscanf(F, "%s", buf);
i = atoi36(buf);
ur_add((void*)i, &a->data.v, resolve_familiar);
return 1;
return AT_READ_OK;
}
/* clones */
@ -2713,7 +2713,7 @@ read_clone(attrib * a, FILE * F)
fscanf(F, "%s", buf);
i = atoi36(buf);
ur_add((void*)i, &a->data.v, resolve_clone);
return 1;
return AT_READ_OK;
}
/* mages */
@ -2739,7 +2739,7 @@ read_magician(attrib * a, FILE * F)
fscanf(F, "%s", buf);
i = atoi36(buf);
ur_add((void*)i, &a->data.v, resolve_mage);
return 1;
return AT_READ_OK;
}
static int

View file

@ -103,14 +103,14 @@ a_traveldir_new_age(attrib *a)
int
a_traveldir_new_read(attrib *a, FILE *f)
{
traveldir *t = (traveldir *)(a->data.v);
int no, age, dir;
traveldir *t = (traveldir *)(a->data.v);
int no, age, dir;
fscanf(f, "%d %d %d", &no, &dir, &age);
t->no = no;
t->dir = (direction_t)dir;
t->age = age;
return 1;
fscanf(f, "%d %d %d", &no, &dir, &age);
t->no = no;
t->dir = (direction_t)dir;
t->age = age;
return AT_READ_OK;
}
void
@ -391,12 +391,12 @@ do_maelstrom(region *r, unit *u)
damage_ship(u->ship, 0.01*damage);
if (u->ship->damage >= u->ship->size * DAMAGE_SCALE) {
add_message(&u->faction->msgs,
new_message(u->faction, "entermaelstrom%r:region%h:ship%i:damage%i:sink", r, u->ship, damage, 1));
ADDMSG(&u->faction->msgs, msg_message("entermaelstrom",
"region ship damage sink", r, u->ship, damage, 1));
destroy_ship(u->ship, r);
} else {
add_message(&u->faction->msgs,
new_message(u->faction, "entermaelstrom%r:region%h:ship%i:damage%i:sink", r, u->ship, damage, 0));
ADDMSG(&u->faction->msgs, msg_message("entermaelstrom",
"region ship damage sink", r, u->ship, damage, 0));
}
}
@ -406,7 +406,6 @@ travelthru(unit * u, region * r)
attrib *ru = a_add(&r->attribs, a_new(&at_travelunit));
ru->data.v = u;
fset(u, FL_TRAVELTHRU);
u->faction->first = 0;
u->faction->last = 0;
}
@ -419,8 +418,10 @@ move_ship(ship * sh, region * from, region * to, region ** route)
direction_t dir;
attrib *a;
translist(&from->ships, &to->ships, sh);
sh->region = to;
if (from!=to) {
translist(&from->ships, &to->ships, sh);
sh->region = to;
}
while (u) {
unit *nu = u->next;
@ -457,14 +458,12 @@ move_ship(ship * sh, region * from, region * to, region ** route)
travelthru(u, *ri++);
}
}
u->ship = NULL; /* damit move_unit() kein leave() macht */
move_unit(u, to, ulist);
#if 0
/* das braucht man (fast) sicher nicht. (Enno) */
fset(u->faction, FL_DH);
#endif
ulist = &u->next;
u->ship = sh;
if (from!=to) {
u->ship = NULL; /* damit move_unit() kein leave() macht */
move_unit(u, to, ulist);
ulist = &u->next;
u->ship = sh;
}
if (route && eff_skill(u, SK_SAILING, from) >= 1) {
produceexp(u, SK_SAILING, u->number);
}
@ -1550,7 +1549,7 @@ sail(region * starting_point, unit * u, region * next_point, boolean move_on_lan
} else {
sh->coast = NODIRECTION;
}
fset(sh, FL_MOVED);
sprintf(buf, "Die %s ", shipname(sh));
if( is_cursed(sh->attribs, C_SHIP_FLYING, 0) )
scat("fliegt");
@ -1600,64 +1599,62 @@ sail(region * starting_point, unit * u, region * next_point, boolean move_on_lan
/* Verfolgungen melden */
if (fval(u, FL_FOLLOWING)) caught_target(current_point, u);
if (starting_point != current_point) {
tt[step] = NULL;
sh = move_ship(sh, starting_point, current_point, tt);
tt[step] = NULL;
sh = move_ship(sh, starting_point, current_point, tt);
/* Hafengebühren ? */
/* Hafengebühren ? */
hafenmeister = owner_buildingtyp(current_point, bt_find("harbour"));
if (sh && hafenmeister != NULL) {
item * itm;
assert(trans==NULL);
for (u2 = current_point->units; u2; u2 = u2->next) {
if (u2->ship == u->ship &&
!allied(hafenmeister, u->faction, HELP_GUARD)) {
hafenmeister = owner_buildingtyp(current_point, bt_find("harbour"));
if (sh && hafenmeister != NULL) {
item * itm;
assert(trans==NULL);
for (u2 = current_point->units; u2; u2 = u2->next) {
if (u2->ship == u->ship &&
!allied(hafenmeister, u->faction, HELP_GUARD)) {
if (effskill(hafenmeister, SK_OBSERVATION) > effskill(u2, SK_STEALTH)) {
for (itm=u2->items; itm; itm=itm->next) {
const luxury_type * ltype = resource2luxury(itm->type->rtype);
if (ltype!=NULL && itm->number>0) {
st = itm->number * effskill(hafenmeister, SK_TRADE) / 50;
st = min(itm->number, st);
if (effskill(hafenmeister, SK_OBSERVATION) > effskill(u2, SK_STEALTH)) {
for (itm=u2->items; itm; itm=itm->next) {
const luxury_type * ltype = resource2luxury(itm->type->rtype);
if (ltype!=NULL && itm->number>0) {
st = itm->number * effskill(hafenmeister, SK_TRADE) / 50;
st = min(itm->number, st);
if (st > 0) {
i_change(&u2->items, itm->type, -st);
i_change(&hafenmeister->items, itm->type, st);
i_add(&trans, i_new(itm->type, st));
}
if (st > 0) {
i_change(&u2->items, itm->type, -st);
i_change(&hafenmeister->items, itm->type, st);
i_add(&trans, i_new(itm->type, st));
}
}
}
}
}
if (trans) {
sprintf(buf, "%s erhielt ", hafenmeister->name);
for (itm = trans; itm; itm=itm->next) {
if (first != 1) {
if (itm->next!=NULL && itm->next->next==NULL) {
scat(" und ");
} else {
scat(", ");
}
}
first = 0;
icat(trans->number);
scat(" ");
if (itm->number == 1) {
scat(locale_string(default_locale, resourcename(itm->type->rtype, 0)));
}
if (trans) {
sprintf(buf, "%s erhielt ", hafenmeister->name);
for (itm = trans; itm; itm=itm->next) {
if (first != 1) {
if (itm->next!=NULL && itm->next->next==NULL) {
scat(" und ");
} else {
scat(locale_string(default_locale, resourcename(itm->type->rtype, NMF_PLURAL)));
scat(", ");
}
}
scat(" von der ");
scat(shipname(u->ship));
scat(".");
addmessage(0, u->faction, buf, MSG_COMMERCE, ML_INFO);
addmessage(0, hafenmeister->faction, buf, MSG_INCOME, ML_INFO);
while (trans) i_remove(&trans, trans);
first = 0;
icat(trans->number);
scat(" ");
if (itm->number == 1) {
scat(locale_string(default_locale, resourcename(itm->type->rtype, 0)));
} else {
scat(locale_string(default_locale, resourcename(itm->type->rtype, NMF_PLURAL)));
}
}
scat(" von der ");
scat(shipname(u->ship));
scat(".");
addmessage(0, u->faction, buf, MSG_COMMERCE, ML_INFO);
addmessage(0, hafenmeister->faction, buf, MSG_INCOME, ML_INFO);
while (trans) i_remove(&trans, trans);
}
}
}

View file

@ -242,14 +242,16 @@ write_plane_reference(const plane * u, FILE * F)
fprintf(F, "%d ", u?(u->id):0);
}
void
int
read_plane_reference(plane ** pp, FILE * F)
{
int i;
fscanf(F, "%d", &i);
if (i==0) *pp = NULL;
{
*pp = getplanebyid(i);
if (*pp==NULL) ur_add((void*)i, (void**)pp, resolve_plane);
if (i==0) {
*pp = NULL;
return AT_READ_FAIL;
}
*pp = getplanebyid(i);
if (*pp==NULL) ur_add((void*)i, (void**)pp, resolve_plane);
return AT_READ_OK;
}

View file

@ -74,6 +74,6 @@ extern int rel_to_abs(const struct plane *pl, const struct faction * f, int rel,
extern void * resolve_plane(void * data);
extern void write_plane_reference(const plane * p, FILE * F);
extern void read_plane_reference(plane ** pp, FILE * F);
extern int read_plane_reference(plane ** pp, FILE * F);
#endif

View file

@ -553,7 +553,7 @@ write_race_reference(const race * rc, FILE * F)
fprintf(F, "%s ", rc?rc->_name[0]:"none");
}
void
int
read_race_reference(const struct race ** rp, FILE * F)
{
char zName[20];
@ -564,16 +564,18 @@ read_race_reference(const struct race ** rp, FILE * F)
*rp = new_race[i];
} else {
*rp = NULL;
return AT_READ_FAIL;
}
} else {
fscanf(F, "%s", zName);
if (strcmp(zName, "none")==0) {
*rp = NULL;
} else {
*rp = rc_find(zName);
assert(*rp!=NULL);
return AT_READ_FAIL;
}
*rp = rc_find(zName);
assert(*rp!=NULL);
}
return AT_READ_OK;
}
#include <xml.h>

View file

@ -156,6 +156,6 @@ extern const char *race_prefixes[];
extern const struct race_syn race_synonyms[];
extern void write_race_reference(const struct race * rc, FILE * F);
extern void read_race_reference(const struct race ** rp, FILE * F);
extern int read_race_reference(const struct race ** rp, FILE * F);
#endif

View file

@ -181,7 +181,7 @@ a_readdirection(attrib *a, FILE *f)
d->desc = strdup(cstring(buf));
fscanf(f, "%s ", buf);
d->keyword = strdup(cstring(buf));
return 1;
return AT_READ_OK;
}
void
@ -224,7 +224,7 @@ a_readmoveblock(attrib *a, FILE *f)
fscanf(f, "%d", &i);
m->dir = (direction_t)i;
return 1;
return AT_READ_OK;
}
void
@ -1020,16 +1020,18 @@ production(const region *r)
return p;
}
void
int
read_region_reference(region ** r, FILE * F)
{
int x[2];
fscanf(F, "%d %d", &x[0], &x[1]);
if (x[0]==INT_MAX) *r = NULL;
else {
*r = findregion(x[0], x[1]);
if (*r==NULL) ur_add(memcpy(malloc(sizeof(x)), x, sizeof(x)), (void**)r, resolve_region);
if (x[0]==INT_MAX) {
*r = NULL;
return AT_READ_FAIL;
}
*r = findregion(x[0], x[1]);
if (*r==NULL) ur_add(memcpy(malloc(sizeof(x)), x, sizeof(x)), (void**)r, resolve_region);
return AT_READ_OK;
}
void

View file

@ -216,7 +216,7 @@ extern const int delta_y[MAXDIRECTIONS];
extern const direction_t back[MAXDIRECTIONS];
extern int production(const struct region *r);
extern void read_region_reference(struct region ** r, FILE * F);
extern int read_region_reference(struct region ** r, FILE * F);
extern void write_region_reference(const struct region * r, FILE * F);
#endif /* _REGION_H */

View file

@ -184,7 +184,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode)
strcpy(buf, unitname(u));
fv = visible_faction(f,u);
fv = visible_faction(f, u);
a_otherfaction = a_find(u->attribs, &at_otherfaction);
if (u->faction == f) {

View file

@ -82,12 +82,14 @@ typedef struct seen_region {
struct seen_region * next;
struct seen_region * prev;
struct seen_region * nextHash;
struct region *r;
const struct region *r;
unsigned char mode;
boolean disbelieves;
} seen_region;
extern seen_region * seen;
extern struct seen_region * seen;
extern struct seen_region * find_seen(const struct region * r);
extern const char* resname(resource_t res, int i);
extern char **seasonnames;

View file

@ -89,7 +89,7 @@ int laen_read(attrib * a, FILE * F)
int laen;
fscanf(F, "%d", &laen);
read_laen(current_region, laen);
return 0;
return AT_READ_FAIL;
}
#endif
@ -258,7 +258,6 @@ ri(FILE * F)
return i * vz;
}
static int
ri36(FILE * F)
{
@ -840,7 +839,7 @@ readgame(boolean backup)
n = ri(F);
if (maxregions<0) maxregions = n;
printf(" - Einzulesende Regionen: %d/%d ", maxregions, n);
printf(" - Einzulesende Regionen: %d/%d\r", maxregions, n);
while (--n >= 0) {
unit **up;
@ -862,8 +861,8 @@ readgame(boolean backup)
skip = true;
}
if ((n%1024)==0) { /* das spart extrem Zeit */
printf(" - Einzulesende Regionen: %d/%d ", maxregions, n);
printf("* %d,%d \r", x, y);
printf(" - Einzulesende Regionen: %d/%d ", maxregions, n);
}
if (skip) {
char * r;
@ -966,6 +965,7 @@ readgame(boolean backup)
addlist2(up,u);
}
}
printf("\n");
if (!dirtyload) {
if (global.data_version >= BORDER_VERSION) read_borders(F);
#ifdef USE_UGROUPS
@ -1040,6 +1040,9 @@ readgame(boolean backup)
if(findfaction(0)) {
findfaction(0)->alive = 1;
}
if (maxregions>=0) {
remove_empty_factions();
}
/* Regionen */
for (r=regions;r;r=r->next) {
@ -1449,7 +1452,7 @@ curse_read(attrib * a, FILE * f) {
}
chash(c);
return 1;
return AT_READ_OK;
}
/* ------------------------------------------------------------- */
@ -1499,13 +1502,13 @@ read_faction_reference(faction ** f, FILE * F)
} else {
fscanf(F, "%d ", &id);
}
if (id==0) {
if (id<0) {
*f = NULL;
return 0;
return AT_READ_FAIL;
}
*f = findfaction(id);
if (*f==NULL) ur_add((void*)id, (void**)f, resolve_faction);
return 1;
return AT_READ_OK;
}
void

View file

@ -2939,7 +2939,7 @@ cw_read(attrib * a, FILE * f)
fscanf(f, "%d ", &br->id);
ur_add((void *)br->id, (void**)&wc->wall, resolve_borderid);
ur_add((void *)br, (void**)&wc->buddy, resolve_buddy);
return 1;
return AT_READ_OK;
}
attrib_type at_cursewall =

View file

@ -459,20 +459,23 @@ write_unit_reference(const unit * u, FILE * F)
fprintf(F, "%s ", u?itoa36(u->no):"0");
}
void
int
read_unit_reference(unit ** up, FILE * F)
{
char zId[10];
int i;
fscanf(F, "%s", zId);
i = atoi36(zId);
if (up) {
if (i==0) *up = NULL;
else {
*up = findunit(i);
if (*up==NULL) ur_add((void*)i, (void**)up, resolve_unit);
}
if (up==NULL) {
return AT_READ_FAIL;
}
i = atoi36(zId);
if (i==0) {
*up = NULL;
return AT_READ_FAIL;
}
*up = findunit(i);
if (*up==NULL) ur_add((void*)i, (void**)up, resolve_unit);
return AT_READ_OK;
}
attrib_type at_stealth = {

View file

@ -130,7 +130,7 @@ extern void destroy_unit(struct unit * u);
/* see resolve.h */
extern void * resolve_unit(void * data);
extern void write_unit_reference(const unit * u, FILE * F);
extern void read_unit_reference(unit ** up, FILE * F);
extern int read_unit_reference(unit ** up, FILE * F);
extern void leave(struct region * r, struct unit * u);
extern void leave_ship(unit * u);

View file

@ -267,9 +267,9 @@ read_hurting(attrib * a, FILE * F) {
a->data.v = (void*)findbuilding(i);
if (a->data.v==NULL) {
log_error(("temple of pain is broken\n"));
return 0;
return AT_READ_FAIL;
}
return 1;
return AT_READ_OK;
}
static attrib_type at_hurting = {
@ -446,7 +446,7 @@ caldera_read(trigger * t, FILE * F)
t->data.v = findbuilding(i);
if (t->data.v==NULL) ur_add((void*)i, &t->data.v, resolve_building);
return 1;
return AT_READ_OK;
}
struct trigger_type tt_caldera = {

View file

@ -57,7 +57,7 @@ read_permissions(attrib * a, FILE * F)
{
attrib ** p_a = (attrib**)&a->data.v;
a_read(F, p_a);
return 1;
return AT_READ_OK;
}
struct attrib_type at_permissions = {
@ -93,7 +93,7 @@ read_gmcreate(attrib * a, FILE * F)
fscanf(F, "%s", zText);
*p_itype = it_find(zText);
assert(*p_itype);
return 1;
return AT_READ_OK;
}
/* at_gmcreate specifies that the owner can create items of a particular type */

View file

@ -98,7 +98,7 @@ a_readmuseumgivebackcookie(attrib *a, FILE *f)
{
museumgivebackcookie *gbc = (museumgivebackcookie *)a->data.v;
fscanf(f, "%d %d", &gbc->warden_no, &gbc->cookie);
return 1;
return AT_READ_OK;
}
attrib_type at_museumgivebackcookie = {
@ -141,7 +141,7 @@ a_readmuseumgiveback(attrib *a, FILE *f)
museumgiveback *gb = (museumgiveback *)a->data.v;
fscanf(f, "%d", &gb->cookie);
read_items(f, &gb->items);
return 1;
return AT_READ_OK;
}
attrib_type at_museumgiveback = {

View file

@ -32,7 +32,6 @@ santa_comes_to_town(region * r, unit * santa, void (*action)(unit*))
const item_type * roi = it_find("roi");
assert(roi);
fset(santa, FL_TRAVELTHRU);
for (f = factions;f;f=f->next) {
unit * u;
unit * senior = f->units;

View file

@ -89,15 +89,7 @@ xmasgate_write(const trigger * t, FILE * F)
static int
xmasgate_read(trigger * t, FILE * F)
{
char zText[128];
int i;
fscanf(F, "%s", zText);
i = atoi36(zText);
t->data.v = findbuilding(i);
if (t->data.v==NULL) ur_add((void*)i, &t->data.v, resolve_building);
return 1;
return read_building_reference((building**)&t->data.v, F);
}
struct trigger_type tt_xmasgate = {

View file

@ -70,9 +70,10 @@ static int
alp_read(attrib * a, FILE * F)
{
alp_data * ad = (alp_data*)a->data.v;
read_unit_reference(&ad->mage, F);
read_unit_reference(&ad->target, F);
return 1;
int m = read_unit_reference(&ad->mage, F);
int t = read_unit_reference(&ad->target, F);
if (m!=AT_READ_OK || t!=AT_READ_OK) return AT_READ_FAIL;
return AT_READ_OK;
}
static attrib_type at_alp = {

View file

@ -83,10 +83,11 @@ changefaction_read(trigger * t, FILE * F)
{
changefaction_data * td = (changefaction_data*)t->data.v;
read_unit_reference(&td->unit, F);
read_faction_reference(&td->faction, F);
int u = read_unit_reference(&td->unit, F);
int f = read_faction_reference(&td->faction, F);
return 1;
if (u!=AT_READ_OK || f!=AT_READ_OK) return AT_READ_FAIL;
return AT_READ_OK;
}
trigger_type tt_changefaction = {

View file

@ -84,10 +84,11 @@ static int
changerace_read(trigger * t, FILE * F)
{
changerace_data * td = (changerace_data*)t->data.v;
read_unit_reference(&td->u, F);
read_race_reference(&td->race, F);
read_race_reference(&td->irace, F);
return 1;
int uc = read_unit_reference(&td->u, F);
int rc = read_race_reference(&td->race, F);
int ic = read_race_reference(&td->irace, F);
if (uc!=AT_READ_OK || rc!=AT_READ_OK || ic!=AT_READ_OK) return AT_READ_FAIL;
return AT_READ_OK;
}
trigger_type tt_changerace = {

View file

@ -62,8 +62,7 @@ clonedied_write(const trigger * t, FILE * F)
static int
clonedied_read(trigger * t, FILE * F)
{
read_unit_reference((unit**)&t->data.v, F);
return 1;
return read_unit_reference((unit**)&t->data.v, F);
}
trigger_type tt_clonedied = {

View file

@ -103,7 +103,7 @@ createcurse_read(trigger * t, FILE * F)
if (td->target==NULL) ur_add((void*)i, (void**)&td->target, resolve_unit);
fscanf(F, "%d %d %d %d %d %d ", &td->id, &td->id2, &td->vigour, &td->duration, &td->effect, &td->men);
return 1;
return AT_READ_OK;
}
trigger_type tt_createcurse = {

View file

@ -88,12 +88,14 @@ createunit_read(trigger * t, FILE * F)
{
createunit_data * td = (createunit_data*)t->data.v;
read_unit_reference(&td->u, F);
read_region_reference(&td->r, F);
read_race_reference(&td->race, F);
int uc = read_unit_reference(&td->u, F);
int rc = read_region_reference(&td->r, F);
int ic = read_race_reference(&td->race, F);
fscanf(F, "%d ", &td->number);
return 1;
if (uc!=AT_READ_OK || rc!=AT_READ_OK || ic!=AT_READ_OK) return AT_READ_FAIL;
return AT_READ_OK;
}
trigger_type tt_createunit = {

View file

@ -71,10 +71,11 @@ gate_read(trigger * t, FILE * F)
{
gate_data * gd = (gate_data*)t->data.v;
read_building_reference(&gd->gate, F);
read_region_reference(&gd->target, F);
int bc = read_building_reference(&gd->gate, F);
int rc = read_region_reference(&gd->target, F);
return 1;
if (rc!=AT_READ_OK || bc!=AT_READ_OK) return AT_READ_FAIL;
return AT_READ_OK;
}
static void

View file

@ -91,7 +91,7 @@ giveitem_read(trigger * t, FILE * F)
td->itype = it_find(zText);
assert(td->itype);
return 1;
return AT_READ_OK;
}
trigger_type tt_giveitem = {

View file

@ -54,8 +54,7 @@ killunit_write(const trigger * t, FILE * F)
static int
killunit_read(trigger * t, FILE * F)
{
read_unit_reference((unit**)&t->data.v, F);
return 1;
return read_unit_reference((unit**)&t->data.v, F);
}
trigger_type tt_killunit = {

View file

@ -94,7 +94,7 @@ removecurse_read(trigger * t, FILE * F)
td->curse = cfindhash(i);
if (td->curse==NULL) ur_add((void*)i, (void**)&td->curse, resolve_curse);
return 1;
return AT_READ_OK;
}
trigger_type tt_removecurse = {

View file

@ -49,14 +49,25 @@ static void
shock_write(const trigger * t, FILE * F)
{
unit * u = (unit*)t->data.v;
write_unit_reference(u, F);
trigger * next = t->next;
while (next) {
/* make sure it is unique! */
if (next->type==t->type && next->data.v==t->data.v) break;
next=next->next;
}
if (next && u) {
log_error(("more than one shock-attribut for %s on a unit. FIXED.\n",
unitid(u)));
write_unit_reference(NULL, F);
} else {
write_unit_reference(u, F);
}
}
static int
shock_read(trigger * t, FILE * F)
{
read_unit_reference((unit**)&t->data.v, F);
return 1;
return read_unit_reference((unit**)&t->data.v, F);
}
trigger_type tt_shock = {

View file

@ -83,7 +83,8 @@ timeout_read(trigger * t, FILE * F)
tr = tr->next;
}
}
return (td->triggers!=NULL && td->timer>0);
if (td->triggers!=NULL && td->timer>0) return AT_READ_OK;
return AT_READ_FAIL;
}
trigger_type tt_timeout = {

View file

@ -49,9 +49,7 @@ unguard_write(const trigger * t, FILE * F)
static int
unguard_read(trigger * t, FILE * F)
{
read_building_reference((building**)&t->data.v, F);
return 1;
return read_building_reference((building**)&t->data.v, F);
}
struct trigger_type tt_unguard = {

View file

@ -93,7 +93,7 @@ unitmessage_read(trigger * t, FILE * F)
fscanf(F, "%s %d %d ", zText, &td->type, &td->level);
td->string = strdup(zText);
return 1;
return AT_READ_OK;
}
trigger_type tt_unitmessage = {

View file

@ -174,7 +174,7 @@ a_readdefault(attrib * a, FILE * f)
{
assert(sizeof(int)==sizeof(a->data));
fscanf(f, "%d", &a->data.i);
return 1;
return AT_READ_OK;
}
void
@ -206,7 +206,7 @@ a_readstring(attrib * a, FILE * f)
char zText[4096];
read_quoted(f, zText, sizeof(zText));
a->data.v = strdup(zText);
return 1;
return AT_READ_OK;
}
void
@ -258,10 +258,18 @@ a_read(FILE * f, attrib ** attribs)
}
if (at->read) {
attrib * na = a_new(at);
if (at->read(na, f))
int i = at->read(na, f);
switch (i) {
case AT_READ_OK:
a_add(attribs, na);
else
break;
case AT_READ_FAIL:
a_free(na);
break;
default:
assert(!"invalid return value");
break;
}
} else {
assert(!"fehler: keine laderoutine für attribut");
}

View file

@ -83,4 +83,7 @@ extern void a_write(FILE * f, const attrib * attribs);
#define NO_WRITE NULL
#define NO_READ NULL
#define AT_READ_OK 4711
#define AT_READ_FAIL -4711
#endif

View file

@ -25,13 +25,16 @@
#include <stdlib.h>
#include <assert.h>
#ifdef HAVE_STRTOL
int
atoi36(const char * s)
{
return (int)(strtol(s, NULL, 36));
char * p = NULL;
int i = (int)(strtol(s, &p, 36));
if (*p || i<0) return -1;
return i;
}
#else
#if 0
#include <ctype.h>
int
atoi36(const char * s)
@ -40,14 +43,15 @@ atoi36(const char * s)
assert(s);
if(!(*s)) return 0;
while(!isalnum((int)*s)) ++s;
while(isspace((int)*s)) ++s;
while(isalnum((int)*s)) {
if (isupper((int)*s)) i = i*36 + (*s)-'A' + 10;
else if (islower((int)*s)) i=i*36 + (*s)-'a' + 10;
else if (isdigit((int)*s)) i=i*36 + (*s)-'0';
else return -1;
++s;
}
if (i<0) return 0;
if (i<0 || !isspace(*s) && *s!='0') return -1;
return i;
}
#endif

View file

@ -47,8 +47,20 @@ read_triggers(FILE * F, trigger ** tp)
ttype = tt_find(zText);
assert(ttype || !"unknown trigger-type");
*tp = t_new(ttype);
if (ttype->read) ttype->read(*tp, F);
tp = &(*tp)->next;
if (ttype->read) {
int i = ttype->read(*tp, F);
switch (i) {
case AT_READ_OK:
tp = &(*tp)->next;
break;
case AT_READ_FAIL:
t_free(*tp);
break;
default:
assert(!"invalid return value");
break;
}
}
}
}
@ -130,7 +142,10 @@ read_handler(attrib * a, FILE * F)
fscanf(F, "%s ", zText);
hi->event = strdup(zText);
read_triggers(F, &hi->triggers);
return (hi->triggers!=NULL);
if (hi->triggers!=NULL) {
return AT_READ_OK;
}
return AT_READ_FAIL;
}
attrib_type at_eventhandler = {

View file

@ -108,6 +108,22 @@ LINK32=link.exe
# Name "eressea - Win32 Release"
# Name "eressea - Win32 Debug"
# Name "eressea - Win32 Profile"
# Begin Group "Text Files"
# PROP Default_Filter ""
# Begin Source File
SOURCE=..\commit.txt
# End Source File
# Begin Source File
SOURCE=..\header.txt
# End Source File
# Begin Source File
SOURCE=..\todo.txt
# End Source File
# End Group
# Begin Source File
SOURCE=.\korrektur.c

View file

@ -126,9 +126,8 @@ verify_owners(boolean bOnce)
#define do_once(magic, fun) \
{ \
attrib * a = find_key(global.attribs, atoi36(magic)); \
if (a) { \
log_warning(("[do_once] a unique fix %d=\"%s\" was called a second time\n", atoi36(magic), magic)); \
} else { \
if (!a) { \
log_warning(("[do_once] a unique fix %d=\"%s\" was applied.\n", atoi36(magic), magic)); \
if (fun == 0) a_add(&global.attribs, make_key(atoi36(magic))); \
} \
}
@ -138,12 +137,13 @@ warn_items(void)
{
boolean found = 0;
region * r;
const item_type * it_money = it_find("money");
for (r=regions;r;r=r->next) {
unit * u;
for (u=r->units;u;u=u->next) {
item * itm;
for (itm=u->items;itm;itm=itm->next) {
if (itm->number>1000000) {
if (itm->number>100000 && itm->type!=it_money) {
found = 1;
log_error(("Einheit %s hat %u %s\n",
unitid(u), itm->number,
@ -187,7 +187,6 @@ santa_comes_to_town(void)
santa->irace = new_race[RC_DAEMON];
set_string(&santa->name, "Ein dicker Gnom mit einem Rentierschlitten");
set_string(&santa->display, "hat: 6 Rentiere, Schlitten, Sack mit Geschenken, Kekse für Khorne");
fset(santa, FL_TRAVELTHRU);
for (f=factions;f;f=f->next) {
unit * u;
@ -1337,7 +1336,7 @@ fix_herbtypes(void)
static int
fix_plainherbs(void)
{
region *r, *lastr;
region *r, *lastr = regions;
for (r=regions;r;r=r->next) {
int i;
const char * name;

View file

@ -1,44 +1,53 @@
Status:
*=default
!=critical, muss diese Runde gemacht werden.
+=fixed, muss überprüft werden
V=verified, ist getestet
-=war kein Bug
Announcen:
* Freigewordene Vinyambar-Parteien
* Bugfix Kräuterverteilung
* Schattendämonen, Gewicht
! Schattendämonen, Gewicht
Nächste Woche beachten:
* bei der auswertung auf die resourcenanzeige achten.
* Kräuterneuverteilung
* Bauern in Bofintedlat aussetzen, bitte
+ bei der auswertung auf die resourcenanzeige achten.
+ Kräuterneuverteilung
! Bauern in Bofintedlat aussetzen, bitte
Bugfixes/Debugging:
! TARNE PARTEI NICHT immer noch defekt?
* Tragkraft von monstern unbegrenzt?
* Unterhaltungsmaximum kann nicht ausgeschoepft werden (H. Bruns)
* Schiff nicht abgelegt (Marc Albrecht)
* Antimagiekristall (Stefan Schwarz)
* NR und CR Diskrepanz: Strassen
* shock-Attribut (u. wahrscheinlich andere) mehrfach im Datenfile
* Kampf und Bergung (W. Edel)
* Lernkosten (W. Edel)
* Schattendaemonen kann man mit RESERVIERE Gegenstaende abnehmen, aber sie
+ Antimagiekristall (Stefan Schwarz)
+ NR und CR Diskrepanz: Strassen
+ shock-Attribut (u. wahrscheinlich andere) mehrfach im Datenfile
v Kampf und Bergung (W. Edel)
- Lernkosten (W. Edel)
! Schattendaemonen kann man mit RESERVIERE Gegenstaende abnehmen, aber sie
koennen kein GIB. was ist richtig?
* Monsterroutinen nochmal anschauen, Clustering von Wyrmen
* trigger anschauen. killunit::handle
* Durchreiseregionen werden nicht angezeigt
* Gewicht von Schattendämonen
v trigger anschauen. killunit::handle
v Durchreiseregionen werden nicht angezeigt
v Regionen nach Straßen werden nicht angezeigt
! Gewicht von Schattendämonen
v remove_empty_factions darf kein free machen, weil noch attribute
auf die partei zeigen. Attribute mit faction 0 wurden nie eingelesen.
* Parteien in Durchreise- und Leuchtturmregionen tauchen nicht als PARTEI Block auf
Features:
* Bauernblut-Effekt an der Einheit speichern, wie bei anderen Traenken auch
* Passworte fuer Vinyambar, cancelling von Parteien aus DB an Server
weiterreichen
* cancelling von Parteien aus DB an Server weiterreichen
* Automatisches Einsetzen im allgemeinen
* buildings.xml hat keinen support fuer gebaeude mit mehreren ausbaustufen
(castle). nachtragen, und bt_castle aus dem source werfen
* eigener messagetype für regions-/einheitenbotschaften (nicht string)
- eigener messagetype für regions-/einheitenbotschaften (nicht string)
Webseiten, Mailinglisten:
* mehr logging, vinyambar-accounts
* mailman gate_news konfiguration
* mailgate schickt postings von Arsenius nicht an die mailingliste.
* Option fuer Start in alten Regionen im Webformular
* Regel mit mindestens 0 NMR aus der partieboerse (standin.py) nehmen.
! Option fuer Start in alten Regionen im Webformular
V Regel mit mindestens 0 NMR aus der parteiboerse (standin.py) nehmen.
Designideen zur Diskussion:
* neue Waffen