SW: Update MFILE to use the same calls KenBuild uses to save.

git-svn-id: https://svn.eduke32.com/eduke32@5224 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2015-05-19 22:09:25 +00:00
parent 033698eaa1
commit 4440fca632
2 changed files with 46 additions and 71 deletions

View file

@ -24,41 +24,16 @@ Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms
*/ */
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
#define FILE_ANSI_STD 0 #include "compat.h"
#define FILE_KEN 1 #include "cache1d.h"
#define FILE_DOS 2
//#define FILE_TYPE FILE_ANSI_STD typedef BFILE* MFILE_WRITE;
#define FILE_TYPE FILE_KEN typedef int32_t MFILE_READ;
#define MREAD(ptr, size, num,handle) kdfread((ptr),(size),(num),(handle))
#if FILE_TYPE == FILE_ANSI_STD
typedef FILE *MFILE;
#define MREAD(ptr, size, num,handle) fread((ptr),(size),(num),(handle))
#define MWRITE(ptr, size, num,handle) fwrite((ptr),(size),(num),(handle))
#define MOPEN_WRITE(name) fopen(name,"wb")
#define MOPEN_READ(name) fopen(name,"rb")
#define MCLOSE(handle) fclose(handle)
#define MF_ERR 0
#endif
#if FILE_TYPE == FILE_KEN
typedef FILE *MFILE;
size_t dfread(void *, size_t, size_t, FILE *);
size_t dfwrite(void *, size_t, size_t, FILE *);
#define MREAD(ptr, size, num,handle) dfread((ptr),(size),(num),(handle))
#define MWRITE(ptr, size, num,handle) dfwrite((ptr),(size),(num),(handle)) #define MWRITE(ptr, size, num,handle) dfwrite((ptr),(size),(num),(handle))
#define MOPEN_WRITE(name) fopen(name,"wb") #define MOPEN_WRITE(name) Bfopen(name,"wb")
#define MOPEN_READ(name) fopen(name,"rb") #define MOPEN_READ(name) kopen4load(name,0)
#define MCLOSE(handle) fclose(handle) #define MCLOSE_WRITE(handle) Bfclose(handle)
#define MF_ERR 0 #define MCLOSE_READ(handle) kclose(handle)
#endif #define MOPEN_WRITE_ERR 0
#define MOPEN_READ_ERR -1
#if FILE_TYPE == FILE_DOS
typedef long MFILE;
#define MREAD(ptr, size, num,handle) read((handle),(ptr),(size)*(num))
#define MWRITE(ptr, size, num,handle) write((handle),(ptr),(size)*(num))
#define MOPEN_WRITE(name) open(name,O_BINARY|O_TRUNC|O_CREAT|O_WRONLY,S_IREAD|S_IWRITE)
#define MOPEN_READ(name) open(name,O_BINARY|O_RDWR,S_IREAD)
#define MCLOSE(handle) close(handle)
#define MF_ERR -1
#endif

View file

@ -91,10 +91,10 @@ void ScreenTileLock(void);
void ScreenTileUnLock(void); void ScreenTileUnLock(void);
int ScreenSaveSetup(PLAYERp pp); int ScreenSaveSetup(PLAYERp pp);
void ScreenSave(FILE *fout); void ScreenSave(MFILE_WRITE fout);
int ScreenLoadSaveSetup(PLAYERp pp); int ScreenLoadSaveSetup(PLAYERp pp);
void ScreenLoad(FILE *fin); void ScreenLoad(MFILE_READ fin);
#define PANEL_SAVE 1 #define PANEL_SAVE 1
#define ANIM_SAVE 1 #define ANIM_SAVE 1
@ -150,7 +150,7 @@ PanelNdxToSprite(PLAYERp pp, int ndx)
return NULL; return NULL;
} }
int SaveSymDataInfo(MFILE fil, void *ptr) int SaveSymDataInfo(MFILE_WRITE fil, void *ptr)
{ {
saveddatasym sym; saveddatasym sym;
@ -171,7 +171,7 @@ int SaveSymDataInfo(MFILE fil, void *ptr)
return 0; return 0;
} }
int SaveSymCodeInfo(MFILE fil, void *ptr) int SaveSymCodeInfo(MFILE_WRITE fil, void *ptr)
{ {
savedcodesym sym; savedcodesym sym;
@ -193,7 +193,7 @@ int SaveSymCodeInfo(MFILE fil, void *ptr)
return 0; return 0;
} }
int LoadSymDataInfo(MFILE fil, void **ptr) int LoadSymDataInfo(MFILE_READ fil, void **ptr)
{ {
saveddatasym sym; saveddatasym sym;
@ -201,7 +201,7 @@ int LoadSymDataInfo(MFILE fil, void **ptr)
return Saveable_RestoreDataSym(&sym, ptr); return Saveable_RestoreDataSym(&sym, ptr);
} }
int LoadSymCodeInfo(MFILE fil, void **ptr) int LoadSymCodeInfo(MFILE_READ fil, void **ptr)
{ {
savedcodesym sym; savedcodesym sym;
@ -213,7 +213,7 @@ int LoadSymCodeInfo(MFILE fil, void **ptr)
int SaveGame(short save_num) int SaveGame(short save_num)
{ {
MFILE fil; MFILE_WRITE fil;
int i,j; int i,j;
short ndx; short ndx;
SPRITE tsp; SPRITE tsp;
@ -238,7 +238,7 @@ int SaveGame(short save_num)
Saveable_Init(); Saveable_Init();
sprintf(game_name,"game%d.sav",save_num); sprintf(game_name,"game%d.sav",save_num);
if ((fil = MOPEN_WRITE(game_name)) == MF_ERR) if ((fil = MOPEN_WRITE(game_name)) == MOPEN_WRITE_ERR)
return -1; return -1;
MWRITE(&GameVersion,sizeof(GameVersion),1,fil); MWRITE(&GameVersion,sizeof(GameVersion),1,fil);
@ -676,7 +676,7 @@ int SaveGame(short save_num)
MWRITE(BossSpriteNum, sizeof(BossSpriteNum), 1, fil); MWRITE(BossSpriteNum, sizeof(BossSpriteNum), 1, fil);
//MWRITE(&Zombies, sizeof(Zombies), 1, fil); //MWRITE(&Zombies, sizeof(Zombies), 1, fil);
MCLOSE(fil); MCLOSE_WRITE(fil);
////DSPRINTF(ds, "done saving"); ////DSPRINTF(ds, "done saving");
//MONO_PRINT(ds); //MONO_PRINT(ds);
@ -689,19 +689,19 @@ int SaveGame(short save_num)
int LoadGameFullHeader(short save_num, char *descr, short *level, short *skill) int LoadGameFullHeader(short save_num, char *descr, short *level, short *skill)
{ {
MFILE fil; MFILE_READ fil;
char game_name[80]; char game_name[80];
short tile; short tile;
int ver; int ver;
sprintf(game_name,"game%d.sav",save_num); sprintf(game_name,"game%d.sav",save_num);
if ((fil = MOPEN_READ(game_name)) == MF_ERR) if ((fil = MOPEN_READ(game_name)) == MOPEN_READ_ERR)
return -1; return -1;
MREAD(&ver,sizeof(ver),1,fil); MREAD(&ver,sizeof(ver),1,fil);
if (ver != GameVersion) if (ver != GameVersion)
{ {
MCLOSE(fil); MCLOSE_READ(fil);
return -1; return -1;
} }
@ -713,38 +713,38 @@ int LoadGameFullHeader(short save_num, char *descr, short *level, short *skill)
tile = ScreenLoadSaveSetup(Player + myconnectindex); tile = ScreenLoadSaveSetup(Player + myconnectindex);
ScreenLoad(fil); ScreenLoad(fil);
MCLOSE(fil); MCLOSE_READ(fil);
return tile; return tile;
} }
void LoadGameDescr(short save_num, char *descr) void LoadGameDescr(short save_num, char *descr)
{ {
MFILE fil; MFILE_READ fil;
char game_name[80]; char game_name[80];
short tile; short tile;
int ver; int ver;
sprintf(game_name,"game%d.sav",save_num); sprintf(game_name,"game%d.sav",save_num);
if ((fil = MOPEN_READ(game_name)) == MF_ERR) if ((fil = MOPEN_READ(game_name)) == MOPEN_READ_ERR)
return; return;
MREAD(&ver,sizeof(ver),1,fil); MREAD(&ver,sizeof(ver),1,fil);
if (ver != GameVersion) if (ver != GameVersion)
{ {
MCLOSE(fil); MCLOSE_READ(fil);
return; return;
} }
MREAD(descr, sizeof(SaveGameDescr[0]),1,fil); MREAD(descr, sizeof(SaveGameDescr[0]),1,fil);
MCLOSE(fil); MCLOSE_READ(fil);
} }
int LoadGame(short save_num) int LoadGame(short save_num)
{ {
MFILE fil; MFILE_READ fil;
int i,j,saveisshot=0; int i,j,saveisshot=0;
short ndx,SpriteNum,sectnum; short ndx,SpriteNum,sectnum;
PLAYERp pp = NULL; PLAYERp pp = NULL;
@ -770,13 +770,13 @@ int LoadGame(short save_num)
Saveable_Init(); Saveable_Init();
sprintf(game_name,"game%d.sav",save_num); sprintf(game_name,"game%d.sav",save_num);
if ((fil = MOPEN_READ(game_name)) == MF_ERR) if ((fil = MOPEN_READ(game_name)) == MOPEN_READ_ERR)
return -1; return -1;
MREAD(&i,sizeof(i),1,fil); MREAD(&i,sizeof(i),1,fil);
if (i != GameVersion) if (i != GameVersion)
{ {
MCLOSE(fil); MCLOSE_READ(fil);
return -1; return -1;
} }
@ -830,7 +830,7 @@ int LoadGame(short save_num)
saveisshot |= LoadSymCodeInfo(fil, (void **)&pp->DoPlayerAction); saveisshot |= LoadSymCodeInfo(fil, (void **)&pp->DoPlayerAction);
saveisshot |= LoadSymDataInfo(fil, (void **)&pp->sop_control); saveisshot |= LoadSymDataInfo(fil, (void **)&pp->sop_control);
saveisshot |= LoadSymDataInfo(fil, (void **)&pp->sop_riding); saveisshot |= LoadSymDataInfo(fil, (void **)&pp->sop_riding);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
} }
@ -862,12 +862,12 @@ int LoadGame(short save_num)
saveisshot |= LoadSymDataInfo(fil, (void **)&psp->ActionState); saveisshot |= LoadSymDataInfo(fil, (void **)&psp->ActionState);
saveisshot |= LoadSymDataInfo(fil, (void **)&psp->RestState); saveisshot |= LoadSymDataInfo(fil, (void **)&psp->RestState);
saveisshot |= LoadSymCodeInfo(fil, (void **)&psp->PanelSpriteFunc); saveisshot |= LoadSymCodeInfo(fil, (void **)&psp->PanelSpriteFunc);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
for (j = 0; j < (int)SIZ(psp->over); j++) for (j = 0; j < (int)SIZ(psp->over); j++)
{ {
saveisshot |= LoadSymDataInfo(fil, (void **)&psp->over[j].State); saveisshot |= LoadSymDataInfo(fil, (void **)&psp->over[j].State);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
} }
} }
@ -957,7 +957,7 @@ int LoadGame(short save_num)
saveisshot |= LoadSymDataInfo(fil, (void **)&u->SpriteP); saveisshot |= LoadSymDataInfo(fil, (void **)&u->SpriteP);
saveisshot |= LoadSymDataInfo(fil, (void **)&u->PlayerP); saveisshot |= LoadSymDataInfo(fil, (void **)&u->PlayerP);
saveisshot |= LoadSymDataInfo(fil, (void **)&u->tgt_sp); saveisshot |= LoadSymDataInfo(fil, (void **)&u->tgt_sp);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
MREAD(&SpriteNum,sizeof(SpriteNum),1,fil); MREAD(&SpriteNum,sizeof(SpriteNum),1,fil);
} }
@ -973,7 +973,7 @@ int LoadGame(short save_num)
saveisshot |= LoadSymCodeInfo(fil, (void **)&sop->Animator); saveisshot |= LoadSymCodeInfo(fil, (void **)&sop->Animator);
saveisshot |= LoadSymDataInfo(fil, (void **)&sop->controller); saveisshot |= LoadSymDataInfo(fil, (void **)&sop->controller);
saveisshot |= LoadSymDataInfo(fil, (void **)&sop->sp_child); saveisshot |= LoadSymDataInfo(fil, (void **)&sop->sp_child);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
} }
MREAD(SineWaveFloor, sizeof(SineWaveFloor),1,fil); MREAD(SineWaveFloor, sizeof(SineWaveFloor),1,fil);
@ -1045,7 +1045,7 @@ int LoadGame(short save_num)
saveisshot |= LoadSymCodeInfo(fil, (void **)&a->callback); saveisshot |= LoadSymCodeInfo(fil, (void **)&a->callback);
saveisshot |= LoadSymDataInfo(fil, (void **)&a->callbackdata); saveisshot |= LoadSymDataInfo(fil, (void **)&a->callbackdata);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
} }
#else #else
AnimCnt = 0; AnimCnt = 0;
@ -1065,7 +1065,7 @@ int LoadGame(short save_num)
saveisshot |= LoadSymDataInfo(fil, (void **)&a->ptr); saveisshot |= LoadSymDataInfo(fil, (void **)&a->ptr);
saveisshot |= LoadSymCodeInfo(fil, (void **)&a->callback); saveisshot |= LoadSymCodeInfo(fil, (void **)&a->callback);
saveisshot |= LoadSymDataInfo(fil, (void **)&a->callbackdata); saveisshot |= LoadSymDataInfo(fil, (void **)&a->callbackdata);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
} }
#endif #endif
#endif #endif
@ -1094,7 +1094,7 @@ int LoadGame(short save_num)
MREAD(bakipos,sizeof(bakipos),1,fil); MREAD(bakipos,sizeof(bakipos),1,fil);
for (i = numinterpolations - 1; i >= 0; i--) for (i = numinterpolations - 1; i >= 0; i--)
saveisshot |= LoadSymDataInfo(fil, (void **)&curipos[i]); saveisshot |= LoadSymDataInfo(fil, (void **)&curipos[i]);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
// short interpolations // short interpolations
MREAD(&short_numinterpolations,sizeof(short_numinterpolations),1,fil); MREAD(&short_numinterpolations,sizeof(short_numinterpolations),1,fil);
@ -1103,7 +1103,7 @@ int LoadGame(short save_num)
MREAD(short_bakipos,sizeof(short_bakipos),1,fil); MREAD(short_bakipos,sizeof(short_bakipos),1,fil);
for (i = short_numinterpolations - 1; i >= 0; i--) for (i = short_numinterpolations - 1; i >= 0; i--)
saveisshot |= LoadSymDataInfo(fil, (void **)&short_curipos[i]); saveisshot |= LoadSymDataInfo(fil, (void **)&short_curipos[i]);
if (saveisshot) { MCLOSE(fil); return -1; } if (saveisshot) { MCLOSE_READ(fil); return -1; }
// parental lock // parental lock
for (i = 0; i < (int)SIZ(otlist); i++) for (i = 0; i < (int)SIZ(otlist); i++)
@ -1192,7 +1192,7 @@ int LoadGame(short save_num)
MREAD(BossSpriteNum, sizeof(BossSpriteNum), 1, fil); MREAD(BossSpriteNum, sizeof(BossSpriteNum), 1, fil);
//MREAD(&Zombies, sizeof(Zombies), 1, fil); //MREAD(&Zombies, sizeof(Zombies), 1, fil);
MCLOSE(fil); MCLOSE_READ(fil);
//!!IMPORTANT - this POST stuff will not work here now becaus it does actual reads //!!IMPORTANT - this POST stuff will not work here now becaus it does actual reads
@ -1301,15 +1301,15 @@ int LoadGame(short save_num)
} }
void void
ScreenSave(MFILE fout) ScreenSave(MFILE_WRITE fout)
{ {
int num; // int num;
num = MWRITE((void *)waloff[SAVE_SCREEN_TILE], SAVE_SCREEN_XSIZE * SAVE_SCREEN_YSIZE, 1, fout); MWRITE((void *)waloff[SAVE_SCREEN_TILE], SAVE_SCREEN_XSIZE * SAVE_SCREEN_YSIZE, 1, fout);
ASSERT(num == 1); // ASSERT(num == 1);
} }
void void
ScreenLoad(MFILE fin) ScreenLoad(MFILE_READ fin)
{ {
int num; int num;