Move file initialization from files.c to empfile oninit()

files.c writes initial contents to game state files with fixed size.
Necessary for setting up invariants, such as struct sctstr members
sct_x, sct_y matching sct_uid.

Do that from the oninit() callback, so ef_blank() sets up invariants
correctly.  Since ef_blank() isn't used for these files right now,
this isn't a bug fix, just cleanup.
This commit is contained in:
Markus Armbruster 2011-05-03 20:48:56 +02:00
parent 576a3c60ed
commit 3fe3cd376f
2 changed files with 57 additions and 69 deletions

View file

@ -55,6 +55,11 @@
#include "version.h" #include "version.h"
#include "xy.h" #include "xy.h"
static void sct_oninit(void *);
static void nat_oninit(void *);
static void realm_oninit(void *);
static void game_oninit(void *);
/* Number of elements in ARRAY. */ /* Number of elements in ARRAY. */
#define SZ(array) (sizeof(array) / sizeof((array)[0])) #define SZ(array) (sizeof(array) / sizeof((array)[0]))
@ -121,7 +126,7 @@ struct empfile empfile[] = {
*/ */
{EF_SECTOR, "sect", "sector", sect_ca, EF_BAD, {EF_SECTOR, "sect", "sector", sect_ca, EF_BAD,
UNMAPPED_CACHE(struct sctstr, -1, EFF_TYPED | EFF_XY | EFF_OWNER), UNMAPPED_CACHE(struct sctstr, -1, EFF_TYPED | EFF_XY | EFF_OWNER),
NULL, NULL, NULL, NULL}, sct_oninit, NULL, NULL, NULL},
{EF_SHIP, "ship", "ship", ship_ca, EF_BAD, {EF_SHIP, "ship", "ship", ship_ca, EF_BAD,
UNMAPPED_CACHE(struct shpstr, -1, UNMAPPED_CACHE(struct shpstr, -1,
EFF_TYPED | EFF_XY | EFF_OWNER | EFF_GROUP), EFF_TYPED | EFF_XY | EFF_OWNER | EFF_GROUP),
@ -151,7 +156,7 @@ struct empfile empfile[] = {
NULL, NULL, NULL, NULL}, NULL, NULL, NULL, NULL},
{EF_NATION, "nat", "nation", nat_ca, EF_BAD, {EF_NATION, "nat", "nation", nat_ca, EF_BAD,
UNMAPPED_CACHE(struct natstr, MAXNOC, EFF_TYPED | EFF_OWNER), UNMAPPED_CACHE(struct natstr, MAXNOC, EFF_TYPED | EFF_OWNER),
NULL, NULL, NULL, NULL}, nat_oninit, NULL, NULL, NULL},
{EF_LOAN, "loan", "loan", loan_ca, EF_BAD, {EF_LOAN, "loan", "loan", loan_ca, EF_BAD,
UNMAPPED_CACHE(struct lonstr, -1, EFF_TYPED), UNMAPPED_CACHE(struct lonstr, -1, EFF_TYPED),
NULL, NULL, NULL, NULL}, NULL, NULL, NULL, NULL},
@ -168,10 +173,10 @@ struct empfile empfile[] = {
{EF_REALM, "realm", "realms", realm_ca, EF_BAD, {EF_REALM, "realm", "realms", realm_ca, EF_BAD,
UNMAPPED_CACHE(struct realmstr, MAXNOC * MAXNOR, UNMAPPED_CACHE(struct realmstr, MAXNOC * MAXNOR,
EFF_TYPED | EFF_OWNER), EFF_TYPED | EFF_OWNER),
NULL, NULL, NULL, NULL}, realm_oninit, NULL, NULL, NULL},
{EF_GAME, "game", "game", game_ca, EF_BAD, {EF_GAME, "game", "game", game_ca, EF_BAD,
UNMAPPED_CACHE(struct gamestr, 1, EFF_TYPED), UNMAPPED_CACHE(struct gamestr, 1, EFF_TYPED),
NULL, NULL, NULL, NULL}, game_oninit, NULL, NULL, NULL},
/* /*
* Static game data (configuration) * Static game data (configuration)
@ -261,6 +266,42 @@ struct empfile empfile[] = {
0, -1, 0, NULL, 0, 0, 0, 0, -1, NULL, NULL, NULL, NULL}, 0, -1, 0, NULL, 0, 0, 0, 0, -1, NULL, NULL, NULL, NULL},
}; };
static void
sct_oninit(void *ptr)
{
struct sctstr *sp = (struct sctstr *)ptr;
sp->sct_y = sp->sct_uid * 2 / WORLD_X;
sp->sct_x = sp->sct_uid * 2 % WORLD_X + sp->sct_y % 2;
sp->sct_dist_x = sp->sct_x;
sp->sct_dist_y = sp->sct_y;
sp->sct_newtype = sp->sct_type = SCT_WATER;
sp->sct_coastal = 1;
}
static void
nat_oninit(void *ptr)
{
struct natstr *np = ptr;
np->nat_cnum = np->nat_uid;
}
static void
realm_oninit(void *ptr)
{
struct realmstr *realm = ptr;
realm->r_cnum = realm->r_uid / MAXNOR;
realm->r_realm = realm->r_uid % MAXNOR;
}
static void
game_oninit(void *ptr)
{
((struct gamestr *)ptr)->game_turn = 1;
}
static void static void
ef_fix_size(struct empfile *ep, int n) ef_fix_size(struct empfile *ep, int n)
{ {

View file

@ -55,8 +55,6 @@
#include "trade.h" #include "trade.h"
#include "version.h" #include "version.h"
static void file_sct_init(coord, coord, struct sctstr *ptr);
static void static void
print_usage(char *program_name) print_usage(char *program_name)
{ {
@ -74,13 +72,8 @@ main(int argc, char *argv[])
{ {
char buf[255]; char buf[255];
char *filename; char *filename;
int x, y;
struct gamestr game;
struct natstr nat; struct natstr nat;
struct realmstr realm; int i;
struct sctstr sct;
int i, j;
char *map;
int opt; int opt;
char *config_file = NULL; char *config_file = NULL;
int force = 0; int force = 0;
@ -133,6 +126,7 @@ main(int argc, char *argv[])
if (!fgets(buf, sizeof(buf), stdin) || (*buf != 'y' && *buf != 'Y')) if (!fgets(buf, sizeof(buf), stdin) || (*buf != 'y' && *buf != 'Y'))
exit(1); exit(1);
} }
for (i = 0; i < EF_MAX; i++) { for (i = 0; i < EF_MAX; i++) {
if (!EF_IS_GAME_STATE(i)) if (!EF_IS_GAME_STATE(i))
continue; continue;
@ -141,39 +135,19 @@ main(int argc, char *argv[])
exit(1); exit(1);
} }
} }
memset(&game, 0, sizeof(game));
game.ef_type = EF_GAME; ef_extend(EF_GAME, 1);
game.game_turn = 1; ef_extend(EF_NATION, MAXNOC);
ef_write(EF_GAME, 0, &game); ef_read(EF_NATION, 0, &nat);
memset(&nat, 0, sizeof(nat));
nat.ef_type = EF_NATION;
strcpy(nat.nat_cnam, "POGO"); strcpy(nat.nat_cnam, "POGO");
strcpy(nat.nat_pnam, "peter"); strcpy(nat.nat_pnam, "peter");
nat.nat_stat = STAT_GOD; nat.nat_stat = STAT_GOD;
nat.nat_btu = 255; nat.nat_btu = 255;
nat.nat_money = 123456789; nat.nat_money = 123456789;
nat.nat_cnum = 0;
nat.nat_flags |= NF_FLASH; nat.nat_flags |= NF_FLASH;
putnat((&nat)); ef_write(EF_NATION, 0, &nat);
printf("All praise to %s!\n", nat.nat_cnam); printf("All praise to %s!\n", nat.nat_cnam);
memset(&nat, 0, sizeof(nat)); ef_extend(EF_REALM, MAXNOC * MAXNOR);
for (i = 1; i < MAXNOC; i++) {
nat.ef_type = EF_NATION;
nat.nat_cnum = nat.nat_uid = i;
nat.nat_seqno = 0;
putnat((&nat));
}
memset(&realm, 0, sizeof(realm));
realm.ef_type = EF_REALM;
for (i = 0; i < MAXNOC; i++) {
realm.r_cnum = i;
for (j = 0; j < MAXNOR; j++) {
realm.r_realm = j;
realm.r_uid = (i * MAXNOR) + j;
realm.r_seqno = 0;
putrealm(&realm);
}
}
if (mkdir(teldir, S_IRWXU | S_IRWXG) < 0 && errno != EEXIST) { if (mkdir(teldir, S_IRWXU | S_IRWXG) < 0 && errno != EEXIST) {
perror(teldir); perror(teldir);
printf("Can't make telegram directory\n"); printf("Can't make telegram directory\n");
@ -185,21 +159,10 @@ main(int argc, char *argv[])
} }
close(creat(annfil, S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP)); close(creat(annfil, S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP));
/* create a zero-filled sector file */ ef_extend(EF_SECTOR, WORLD_SZ());
memset(&sct, 0, sizeof(sct)); ef_extend(EF_MAP, MAXNOC);
for (y = 0; y < WORLD_Y; y++) { ef_extend(EF_BMAP, MAXNOC);
for (x = 0; x < WORLD_X / 2; x++) {
file_sct_init(x * 2 + (y & 1), y, &sct);
putsect(&sct);
}
}
map = calloc(WORLD_SZ(), sizeof(*map));
for (i = 0; i < MAXNOC; i++) {
ef_write(EF_MAP, i, map);
}
for (i = 0; i < MAXNOC; i++) {
ef_write(EF_BMAP, i, map);
}
for (i = 0; i < EF_MAX; i++) { for (i = 0; i < EF_MAX; i++) {
if (!EF_IS_GAME_STATE(i)) if (!EF_IS_GAME_STATE(i))
continue; continue;
@ -208,19 +171,3 @@ main(int argc, char *argv[])
exit(0); exit(0);
} }
static void
file_sct_init(coord x, coord y, struct sctstr *ptr)
{
struct sctstr *sp = (struct sctstr *)ptr;
sp->ef_type = EF_SECTOR;
sp->sct_uid = XYOFFSET(x, y);
sp->sct_seqno = 0;
sp->sct_x = x;
sp->sct_y = y;
sp->sct_dist_x = x;
sp->sct_dist_y = y;
sp->sct_newtype = sp->sct_type = SCT_WATER;
sp->sct_coastal = 1;
}