fix some bugs created during conversions (thanks, tests!)

This commit is contained in:
Enno Rehling 2017-09-22 17:19:55 +02:00
parent 3aed0b1ee5
commit 0a9705809b
10 changed files with 14 additions and 13 deletions

View file

@ -322,8 +322,6 @@ void write_building_reference(const struct building *b, struct storage *store)
WRITE_INT(store, (b && b->region) ? b->no : 0); WRITE_INT(store, (b && b->region) ? b->no : 0);
} }
#define RESOLVE_BUILDING (TYP_BUILDING << 24)
void resolve_building(building *b) void resolve_building(building *b)
{ {
resolve(RESOLVE_BUILDING | b->no, b); resolve(RESOLVE_BUILDING | b->no, b);

View file

@ -152,6 +152,7 @@ extern "C" {
#include "build.h" #include "build.h"
#define NOBUILDING NULL #define NOBUILDING NULL
#define RESOLVE_BUILDING (TYP_BUILDING << 24)
void resolve_building(building *b); void resolve_building(building *b);
void write_building_reference(const struct building *b, void write_building_reference(const struct building *b,
struct storage *store); struct storage *store);

View file

@ -317,8 +317,6 @@ bool checkpasswd(const faction * f, const char *passwd)
return true; return true;
} }
#define RESOLVE_FACTION (TYP_FACTION << 24)
void resolve_faction(faction *f) void resolve_faction(faction *f)
{ {
resolve(RESOLVE_FACTION | f->no, f); resolve(RESOLVE_FACTION | f->no, f);

View file

@ -130,6 +130,8 @@ extern "C" {
void write_faction_reference(const struct faction *f, void write_faction_reference(const struct faction *f,
struct storage *store); struct storage *store);
int read_faction_reference(struct gamedata *data, struct faction **fp, resolve_fun fun); int read_faction_reference(struct gamedata *data, struct faction **fp, resolve_fun fun);
#define RESOLVE_FACTION (TYP_FACTION << 24)
void resolve_faction(struct faction *f); void resolve_faction(struct faction *f);
void renumber_faction(faction * f, int no); void renumber_faction(faction * f, int no);

View file

@ -24,6 +24,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include "ally.h" #include "ally.h"
#include "faction.h" #include "faction.h"
#include "unit.h" #include "unit.h"
#include "objtypes.h"
/* attrib includes */ /* attrib includes */
#include <attributes/raceprefix.h> #include <attributes/raceprefix.h>
@ -239,9 +240,13 @@ void read_groups(gamedata *data, faction * f)
pa = &g->allies; pa = &g->allies;
for (;;) { for (;;) {
ally *al; ally *al;
int id;
READ_INT(store, &id);
if (id == 0) break;
al = ally_add(pa, NULL); al = ally_add(pa, NULL);
if (read_faction_reference(data, &al->faction, NULL) <= 0) { al->faction = findfaction(id);
break; if (!al->faction) {
ur_add(RESOLVE_FACTION | id, (void **)&al->faction, NULL);
} }
READ_INT(store, &al->status); READ_INT(store, &al->status);
} }

View file

@ -1255,8 +1255,6 @@ int production(const region * r)
return p; return p;
} }
#define RESOLVE_REGION (TYP_REGION << 24)
void resolve_region(region *r) void resolve_region(region *r)
{ {
resolve(RESOLVE_REGION | r->uid, r); resolve(RESOLVE_REGION | r->uid, r);

View file

@ -259,9 +259,10 @@ extern "C" {
int region_get_morale(const region * r); int region_get_morale(const region * r);
void region_set_morale(region * r, int morale, int turn); void region_set_morale(region * r, int morale, int turn);
#define RESOLVE_REGION (TYP_REGION << 24)
void resolve_region(region *r);
void write_region_reference(const struct region *r, struct storage *store); void write_region_reference(const struct region *r, struct storage *store);
int read_region_reference(struct gamedata *data, region **rp, resolve_fun fun); int read_region_reference(struct gamedata *data, region **rp, resolve_fun fun);
void resolve_region(region *r);
const char *regionname(const struct region *r, const struct faction *f); const char *regionname(const struct region *r, const struct faction *f);

View file

@ -749,8 +749,6 @@ void write_unit_reference(const unit * u, struct storage *store)
WRITE_INT(store, (u && u->region) ? u->no : 0); WRITE_INT(store, (u && u->region) ? u->no : 0);
} }
#define RESOLVE_UNIT (TYP_UNIT << 24)
void resolve_unit(unit *u) void resolve_unit(unit *u)
{ {
resolve(RESOLVE_UNIT | u->no, u); resolve(RESOLVE_UNIT | u->no, u);

View file

@ -185,6 +185,7 @@ extern "C" {
void make_zombie(struct unit * u); void make_zombie(struct unit * u);
/* see resolve.h */ /* see resolve.h */
#define RESOLVE_UNIT (TYP_UNIT << 24)
void resolve_unit(struct unit *u); void resolve_unit(struct unit *u);
void write_unit_reference(const struct unit *u, struct storage *store); void write_unit_reference(const struct unit *u, struct storage *store);
int read_unit_reference(struct gamedata * data, struct unit **up, resolve_fun fun); int read_unit_reference(struct gamedata * data, struct unit **up, resolve_fun fun);

View file

@ -86,8 +86,7 @@ static int changefaction_read(trigger * t, gamedata *data)
changefaction_data *td = (changefaction_data *)t->data.v; changefaction_data *td = (changefaction_data *)t->data.v;
read_unit_reference(data, &td->unit, NULL); read_unit_reference(data, &td->unit, NULL);
read_faction_reference(data, &td->faction, NULL); return read_faction_reference(data, &td->faction, NULL) > 0 ? AT_READ_OK : AT_READ_FAIL;
return AT_READ_OK;
} }
trigger_type tt_changefaction = { trigger_type tt_changefaction = {