summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/p_setup.c3
-rw-r--r--src/w_wad.c153
-rw-r--r--src/w_wad.h6
3 files changed, 33 insertions, 129 deletions
diff --git a/src/p_setup.c b/src/p_setup.c
index 446bba49..739a60b5 100644
--- a/src/p_setup.c
+++ b/src/p_setup.c
@@ -656,9 +656,6 @@ P_SetupLevel
// UNUSED W_Profile ();
P_InitThinkers ();
-
- // if working with a devlopment map, reload it
- W_Reload ();
// find map name
if ( gamemode == commercial)
diff --git a/src/w_wad.c b/src/w_wad.c
index 0a9645a0..9425705c 100644
--- a/src/w_wad.c
+++ b/src/w_wad.c
@@ -128,37 +128,20 @@ unsigned int W_LumpNameHash(const char *s)
// with multiple lumps.
// Other files are single lumps with the base filename
// for the lump name.
-//
-// If filename starts with a tilde, the file is handled
-// specially to allow map reloads.
-// But: the reload feature is a fragile hack...
-
-unsigned int reloadlump;
-char* reloadname;
-
wad_file_t *W_AddFile (char *filename)
{
- wadinfo_t header;
- lumpinfo_t* lump_p;
- unsigned int i;
- wad_file_t *wad_file;
- int length;
- int startlump;
- filelump_t* fileinfo;
- filelump_t* filerover;
- wad_file_t *storehandle;
+ wadinfo_t header;
+ lumpinfo_t *lump_p;
+ unsigned int i;
+ wad_file_t *wad_file;
+ int length;
+ int startlump;
+ filelump_t *fileinfo;
+ filelump_t *filerover;
// open the file and add to directory
- // handle reload indicator.
- if (filename[0] == '~')
- {
- filename++;
- reloadname = filename;
- reloadlump = numlumps;
- }
-
wad_file = W_OpenFile(filename);
if (wad_file == NULL)
@@ -215,29 +198,29 @@ wad_file_t *W_AddFile (char *filename)
}
// Fill in lumpinfo
- lumpinfo = realloc (lumpinfo, numlumps*sizeof(lumpinfo_t));
+ lumpinfo = realloc(lumpinfo, numlumps * sizeof(lumpinfo_t));
- if (!lumpinfo)
+ if (lumpinfo == NULL)
+ {
I_Error ("Couldn't realloc lumpinfo");
+ }
lump_p = &lumpinfo[startlump];
- storehandle = reloadname ? NULL : wad_file;
-
- for (i=startlump,filerover=fileinfo ; i<numlumps ; i++,lump_p++, filerover++)
+ filerover = fileinfo;
+
+ for (i=startlump; i<numlumps; ++i)
{
- lump_p->wad_file = storehandle;
+ lump_p->wad_file = wad_file;
lump_p->position = LONG(filerover->filepos);
lump_p->size = LONG(filerover->size);
lump_p->cache = NULL;
strncpy(lump_p->name, filerover->name, 8);
+
+ ++lump_p;
+ ++filerover;
}
- if (reloadname)
- {
- W_CloseFile(wad_file);
- }
-
Z_Free(fileinfo);
if (lumphash != NULL)
@@ -251,62 +234,6 @@ wad_file_t *W_AddFile (char *filename)
-
-//
-// W_Reload
-// Flushes any of the reloadable lumps in memory
-// and reloads the directory.
-//
-void W_Reload (void)
-{
- wadinfo_t header;
- int lumpcount;
- lumpinfo_t* lump_p;
- unsigned int i;
- wad_file_t* wad_file;
- int length;
- filelump_t* fileinfo;
-
- if (reloadname == NULL)
- {
- return;
- }
-
- wad_file = W_OpenFile(reloadname);
-
- if (wad_file == NULL)
- {
- I_Error ("W_Reload: couldn't open %s", reloadname);
- }
-
- W_Read(wad_file, 0, &header, sizeof(header));
- lumpcount = LONG(header.numlumps);
- header.infotableofs = LONG(header.infotableofs);
- length = lumpcount*sizeof(filelump_t);
- fileinfo = Z_Malloc(length, PU_STATIC, 0);
- W_Read(wad_file, header.infotableofs, fileinfo, length);
-
- // Fill in lumpinfo
- lump_p = &lumpinfo[reloadlump];
-
- for (i=reloadlump; i<reloadlump+lumpcount; i++, lump_p++, fileinfo++)
- {
- if (lumpinfo[i].cache)
- {
- Z_Free (lumpinfo[i].cache);
- }
-
- lump_p->position = LONG(fileinfo->filepos);
- lump_p->size = LONG(fileinfo->size);
- }
-
- W_CloseFile(wad_file);
-
- Z_Free(fileinfo);
-}
-
-
-
//
// W_NumLumps
//
@@ -378,9 +305,11 @@ int W_GetNumForName (char* name)
i = W_CheckNumForName (name);
- if (i == -1)
- I_Error ("W_GetNumForName: %s not found!", name);
-
+ if (i < 0)
+ {
+ I_Error ("W_GetNumForName: %s not found!", name);
+ }
+
return i;
}
@@ -392,7 +321,9 @@ int W_GetNumForName (char* name)
int W_LumpLength (unsigned int lump)
{
if (lump >= numlumps)
- I_Error ("W_LumpLength: %i >= numlumps",lump);
+ {
+ I_Error ("W_LumpLength: %i >= numlumps", lump);
+ }
return lumpinfo[lump].size;
}
@@ -406,36 +337,19 @@ int W_LumpLength (unsigned int lump)
//
void W_ReadLump(unsigned int lump, void *dest)
{
- int c;
- lumpinfo_t* l;
- wad_file_t* wad_file;
+ int c;
+ lumpinfo_t *l;
if (lump >= numlumps)
{
- I_Error ("W_ReadLump: %i >= numlumps",lump);
+ I_Error ("W_ReadLump: %i >= numlumps", lump);
}
l = lumpinfo+lump;
I_BeginRead ();
- if (l->wad_file == NULL)
- {
- // reloadable file, so use open / read / close
-
- wad_file = W_OpenFile(reloadname);
-
- if (wad_file == NULL)
- {
- I_Error ("W_ReadLump: couldn't open %s",reloadname);
- }
- }
- else
- {
- wad_file = l->wad_file;
- }
-
- c = W_Read(wad_file, l->position, dest, l->size);
+ c = W_Read(l->wad_file, l->position, dest, l->size);
if (c < l->size)
{
@@ -443,11 +357,6 @@ void W_ReadLump(unsigned int lump, void *dest)
c, l->size, lump);
}
- if (l->wad_file == NULL)
- {
- W_CloseFile(wad_file);
- }
-
I_EndRead ();
}
diff --git a/src/w_wad.h b/src/w_wad.h
index f28b5e37..d2626426 100644
--- a/src/w_wad.h
+++ b/src/w_wad.h
@@ -59,12 +59,10 @@ struct lumpinfo_s
};
-extern void** lumpcache;
-extern lumpinfo_t* lumpinfo;
-extern unsigned int numlumps;
+extern lumpinfo_t *lumpinfo;
+extern unsigned int numlumps;
wad_file_t *W_AddFile (char *filename);
-void W_Reload (void);
int W_CheckNumForName (char* name);
int W_GetNumForName (char* name);