Clean up how game state file sizes are checked
New struct empfile member nent replaces ef_open() parameter nelt.
Cleaner, because the expected size is a property of the file, not of
how it's used. Also fixes empdump to check file sizes.
Complication: with EFF_CREATE, ef_open() creates an empty file, to be
extended to the correct size. Callers passed nelt argument -1 along
with EFF_CREATE, to make ef_open() accept the empty file. Can't do
the same for empfile member nent. Instead, make ef_open() not check
the (zero) size then.
Replaces commit 5750107b
, v4.3.15.
This commit is contained in:
parent
516ab86a6e
commit
0fcd935999
7 changed files with 68 additions and 64 deletions
|
@ -34,8 +34,7 @@
|
|||
#include <config.h>
|
||||
|
||||
#include "file.h"
|
||||
#include "nat.h"
|
||||
#include "optlist.h"
|
||||
#include "nsc.h"
|
||||
#include "prototypes.h"
|
||||
#include "unit.h"
|
||||
|
||||
|
@ -92,23 +91,23 @@ ef_open_srv(void)
|
|||
{
|
||||
int failed = 0;
|
||||
|
||||
failed |= !ef_open(EF_NATION, EFF_MEM, MAXNOC);
|
||||
failed |= !ef_open(EF_SECTOR, EFF_MEM, WORLD_SZ());
|
||||
failed |= !ef_open(EF_SHIP, EFF_MEM, -1);
|
||||
failed |= !ef_open(EF_PLANE, EFF_MEM, -1);
|
||||
failed |= !ef_open(EF_LAND, EFF_MEM, -1);
|
||||
failed |= !ef_open(EF_GAME, EFF_MEM, 1);
|
||||
failed |= !ef_open(EF_NEWS, 0, -1);
|
||||
failed |= !ef_open(EF_LOAN, 0, -1);
|
||||
failed |= !ef_open(EF_TREATY, 0, -1);
|
||||
failed |= !ef_open(EF_NUKE, EFF_MEM, -1);
|
||||
failed |= !ef_open(EF_POWER, 0, -1);
|
||||
failed |= !ef_open(EF_TRADE, 0, -1);
|
||||
failed |= !ef_open(EF_MAP, EFF_MEM, MAXNOC);
|
||||
failed |= !ef_open(EF_BMAP, EFF_MEM, MAXNOC);
|
||||
failed |= !ef_open(EF_COMM, 0, -1);
|
||||
failed |= !ef_open(EF_LOST, 0, -1);
|
||||
failed |= !ef_open(EF_REALM, EFF_MEM, MAXNOC * MAXNOR);
|
||||
failed |= !ef_open(EF_NATION, EFF_MEM);
|
||||
failed |= !ef_open(EF_SECTOR, EFF_MEM);
|
||||
failed |= !ef_open(EF_SHIP, EFF_MEM);
|
||||
failed |= !ef_open(EF_PLANE, EFF_MEM);
|
||||
failed |= !ef_open(EF_LAND, EFF_MEM);
|
||||
failed |= !ef_open(EF_GAME, EFF_MEM);
|
||||
failed |= !ef_open(EF_NEWS, 0);
|
||||
failed |= !ef_open(EF_LOAN, 0);
|
||||
failed |= !ef_open(EF_TREATY, 0);
|
||||
failed |= !ef_open(EF_NUKE, EFF_MEM);
|
||||
failed |= !ef_open(EF_POWER, 0);
|
||||
failed |= !ef_open(EF_TRADE, 0);
|
||||
failed |= !ef_open(EF_MAP, EFF_MEM);
|
||||
failed |= !ef_open(EF_BMAP, EFF_MEM);
|
||||
failed |= !ef_open(EF_COMM, 0);
|
||||
failed |= !ef_open(EF_LOST, 0);
|
||||
failed |= !ef_open(EF_REALM, EFF_MEM);
|
||||
if (!failed)
|
||||
failed |= ef_open_view(EF_COUNTRY);
|
||||
if (failed) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue