mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
cache1d: Allow loading GRP files from within other GRP files.
git-svn-id: https://svn.eduke32.com/eduke32@5059 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
496f4582d6
commit
8a2b19dd50
2 changed files with 208 additions and 199 deletions
|
@ -31,7 +31,6 @@ int32_t openfrompath(const char *fn, int32_t flags, int32_t mode);
|
||||||
BFILE *fopenfrompath(const char *fn, const char *mode);
|
BFILE *fopenfrompath(const char *fn, const char *mode);
|
||||||
|
|
||||||
int32_t initgroupfile(const char *filename);
|
int32_t initgroupfile(const char *filename);
|
||||||
void uninitsinglegroupfile(int32_t grphandle);
|
|
||||||
void uninitgroupfile(void);
|
void uninitgroupfile(void);
|
||||||
int32_t kopen4load(const char *filename, char searchfirst); // searchfirst: 0 = anywhere, 1 = first group, 2 = any group
|
int32_t kopen4load(const char *filename, char searchfirst); // searchfirst: 0 = anywhere, 1 = first group, 2 = any group
|
||||||
int32_t kread(int32_t handle, void *buffer, int32_t leng);
|
int32_t kread(int32_t handle, void *buffer, int32_t leng);
|
||||||
|
|
|
@ -598,25 +598,21 @@ int32_t findfrompath(const char *fn, char **where)
|
||||||
# define FILENAME_CASE_CHECK
|
# define FILENAME_CASE_CHECK
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef FILENAME_CASE_CHECK
|
static int32_t openfrompath_internal(const char *fn, char **where, int32_t flags, int32_t mode)
|
||||||
// don't free pfn if !=0 AND we Bopen()'ed the file successfully
|
{
|
||||||
static int32_t dont_free_pfn;
|
if (findfrompath(fn, where) < 0)
|
||||||
static char *lastpfn;
|
return -1;
|
||||||
#endif
|
|
||||||
|
return Bopen(*where, flags, mode);
|
||||||
|
}
|
||||||
|
|
||||||
int32_t openfrompath(const char *fn, int32_t flags, int32_t mode)
|
int32_t openfrompath(const char *fn, int32_t flags, int32_t mode)
|
||||||
{
|
{
|
||||||
char *pfn;
|
char *pfn = NULL;
|
||||||
int32_t h;
|
|
||||||
|
|
||||||
if (findfrompath(fn, &pfn) < 0) return -1;
|
int32_t h = openfrompath_internal(fn, &pfn, flags, mode);
|
||||||
|
|
||||||
h = Bopen(pfn, flags, mode);
|
if (pfn)
|
||||||
#ifdef FILENAME_CASE_CHECK
|
|
||||||
if (h>=0 && dont_free_pfn)
|
|
||||||
lastpfn = pfn;
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
Bfree(pfn);
|
Bfree(pfn);
|
||||||
|
|
||||||
return h;
|
return h;
|
||||||
|
@ -664,8 +660,9 @@ EDUKE32_STATIC_ASSERT(MAXGROUPFILES <= GRP_RESERVED_ID_START);
|
||||||
|
|
||||||
int32_t numgroupfiles = 0;
|
int32_t numgroupfiles = 0;
|
||||||
static int32_t gnumfiles[MAXGROUPFILES];
|
static int32_t gnumfiles[MAXGROUPFILES];
|
||||||
static int32_t groupfil[MAXGROUPFILES] = {-1,-1,-1,-1,-1,-1,-1,-1};
|
static intptr_t groupfil[MAXGROUPFILES] = {-1,-1,-1,-1,-1,-1,-1,-1};
|
||||||
static int32_t groupfilpos[MAXGROUPFILES];
|
static int32_t groupfilpos[MAXGROUPFILES];
|
||||||
|
static uint8_t groupfilgrp[MAXGROUPFILES];
|
||||||
static char *gfilelist[MAXGROUPFILES];
|
static char *gfilelist[MAXGROUPFILES];
|
||||||
static int32_t *gfileoffs[MAXGROUPFILES];
|
static int32_t *gfileoffs[MAXGROUPFILES];
|
||||||
|
|
||||||
|
@ -689,60 +686,66 @@ int32_t cache1d_file_fromzip(int32_t fil)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static int32_t kopen_internal(const char *filename, char **lastpfn, char searchfirst, char checkcase, char tryzip, int32_t newhandle, uint8_t *arraygrp, intptr_t *arrayhan, int32_t *arraypos);
|
||||||
|
static int32_t kread_grp(int32_t handle, void *buffer, int32_t leng);
|
||||||
|
static int32_t klseek_grp(int32_t handle, int32_t offset, int32_t whence);
|
||||||
|
static void kclose_grp(int32_t handle);
|
||||||
|
|
||||||
int32_t initgroupfile(const char *filename)
|
int32_t initgroupfile(const char *filename)
|
||||||
{
|
{
|
||||||
char buf[16];
|
char buf[16];
|
||||||
int32_t i, j, k;
|
|
||||||
#ifdef WITHKPLIB
|
|
||||||
char *zfn;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// translate all backslashes (0x5c) to forward slashes (0x2f)
|
// translate all backslashes (0x5c) to forward slashes (0x2f)
|
||||||
toupperlookup[0x5c] = 0x2f;
|
toupperlookup[0x5c] = 0x2f;
|
||||||
|
|
||||||
|
if (filename == NULL)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
// Technically you should be able to load more zips even if your GRPs are maxed out,
|
||||||
|
// but this system is already enough of a disaster.
|
||||||
|
if (numgroupfiles >= MAXGROUPFILES)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
char *zfn = NULL;
|
||||||
|
|
||||||
|
if (kopen_internal(filename, &zfn, 0, 0, 0, numgroupfiles, groupfilgrp, groupfil, groupfilpos) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
if (findfrompath(filename, &zfn) < 0) return -1;
|
// check if ZIP
|
||||||
|
if (zfn)
|
||||||
// check to see if the file passed is a ZIP and pass it on to kplib if it is
|
{
|
||||||
i = Bopen(zfn,BO_BINARY|BO_RDONLY,BS_IREAD);
|
kread_grp(numgroupfiles, buf, 4);
|
||||||
if (i < 0) { Bfree(zfn); return -1; }
|
|
||||||
|
|
||||||
Bread(i, buf, 4);
|
|
||||||
if (buf[0] == 0x50 && buf[1] == 0x4B && buf[2] == 0x03 && buf[3] == 0x04)
|
if (buf[0] == 0x50 && buf[1] == 0x4B && buf[2] == 0x03 && buf[3] == 0x04)
|
||||||
{
|
{
|
||||||
Bclose(i);
|
kclose_grp(numgroupfiles);
|
||||||
j = kzaddstack(zfn);
|
|
||||||
|
kzaddstack(zfn);
|
||||||
Bfree(zfn);
|
Bfree(zfn);
|
||||||
return j;
|
return 0;
|
||||||
}
|
}
|
||||||
|
klseek_grp(numgroupfiles,0,BSEEK_SET);
|
||||||
|
|
||||||
Bfree(zfn);
|
Bfree(zfn);
|
||||||
|
}
|
||||||
if (numgroupfiles >= MAXGROUPFILES) return(-1);
|
|
||||||
|
|
||||||
Blseek(i,0,BSEEK_SET);
|
|
||||||
groupfil[numgroupfiles] = i;
|
|
||||||
#else
|
#else
|
||||||
groupfil[numgroupfiles] = openfrompath(filename,BO_BINARY|BO_RDONLY,BS_IREAD);
|
if (zfn)
|
||||||
if (groupfil[numgroupfiles] != -1)
|
Bfree(zfn);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// check if GRP
|
||||||
|
kread_grp(numgroupfiles,buf,16);
|
||||||
|
if (!Bmemcmp(buf, "KenSilverman", 12))
|
||||||
{
|
{
|
||||||
groupfilpos[numgroupfiles] = 0;
|
|
||||||
Bread(groupfil[numgroupfiles],buf,16);
|
|
||||||
if (Bmemcmp(buf, "KenSilverman", 12))
|
|
||||||
{
|
|
||||||
Bclose(groupfil[numgroupfiles]);
|
|
||||||
groupfil[numgroupfiles] = -1;
|
|
||||||
return(-1);
|
|
||||||
}
|
|
||||||
gnumfiles[numgroupfiles] = B_LITTLE32(*((int32_t *)&buf[12]));
|
gnumfiles[numgroupfiles] = B_LITTLE32(*((int32_t *)&buf[12]));
|
||||||
|
|
||||||
gfilelist[numgroupfiles] = (char *)Xmalloc(gnumfiles[numgroupfiles]<<4);
|
gfilelist[numgroupfiles] = (char *)Xmalloc(gnumfiles[numgroupfiles]<<4);
|
||||||
gfileoffs[numgroupfiles] = (int32_t *)Xmalloc((gnumfiles[numgroupfiles]+1)<<2);
|
gfileoffs[numgroupfiles] = (int32_t *)Xmalloc((gnumfiles[numgroupfiles]+1)<<2);
|
||||||
|
|
||||||
Bread(groupfil[numgroupfiles],gfilelist[numgroupfiles],gnumfiles[numgroupfiles]<<4);
|
kread_grp(numgroupfiles,gfilelist[numgroupfiles],gnumfiles[numgroupfiles]<<4);
|
||||||
|
|
||||||
j = 0;
|
int32_t j = (gnumfiles[numgroupfiles]+1)<<4, k;
|
||||||
for (i=0; i<gnumfiles[numgroupfiles]; i++)
|
for (int32_t i=0; i<gnumfiles[numgroupfiles]; i++)
|
||||||
{
|
{
|
||||||
k = B_LITTLE32(*((int32_t *)&gfilelist[numgroupfiles][(i<<4)+12]));
|
k = B_LITTLE32(*((int32_t *)&gfilelist[numgroupfiles][(i<<4)+12]));
|
||||||
gfilelist[numgroupfiles][(i<<4)+12] = 0;
|
gfilelist[numgroupfiles][(i<<4)+12] = 0;
|
||||||
|
@ -750,53 +753,12 @@ int32_t initgroupfile(const char *filename)
|
||||||
j += k;
|
j += k;
|
||||||
}
|
}
|
||||||
gfileoffs[numgroupfiles][gnumfiles[numgroupfiles]] = j;
|
gfileoffs[numgroupfiles][gnumfiles[numgroupfiles]] = j;
|
||||||
}
|
|
||||||
numgroupfiles++;
|
numgroupfiles++;
|
||||||
return(groupfil[numgroupfiles-1]);
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void uninitsinglegroupfile(int32_t grphandle)
|
kclose_grp(numgroupfiles);
|
||||||
{
|
return -1;
|
||||||
int32_t i, grpnum = -1;
|
|
||||||
|
|
||||||
for (i=numgroupfiles-1; i>=0; i--)
|
|
||||||
if (groupfil[i] != -1 && groupfil[i] == grphandle)
|
|
||||||
{
|
|
||||||
Bfree(gfilelist[i]);
|
|
||||||
Bfree(gfileoffs[i]);
|
|
||||||
Bclose(groupfil[i]);
|
|
||||||
groupfil[i] = -1;
|
|
||||||
grpnum = i;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (grpnum == -1) return;
|
|
||||||
|
|
||||||
// JBF 20040111
|
|
||||||
numgroupfiles--;
|
|
||||||
|
|
||||||
// move any group files following this one back
|
|
||||||
for (i=grpnum+1; i<MAXGROUPFILES; i++)
|
|
||||||
if (groupfil[i] != -1)
|
|
||||||
{
|
|
||||||
groupfil[i-1] = groupfil[i];
|
|
||||||
gnumfiles[i-1] = gnumfiles[i];
|
|
||||||
groupfilpos[i-1] = groupfilpos[i];
|
|
||||||
gfilelist[i-1] = gfilelist[i];
|
|
||||||
gfileoffs[i-1] = gfileoffs[i];
|
|
||||||
groupfil[i] = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// fix up the open files that need attention
|
|
||||||
for (i=0; i<MAXOPENFILES; i++)
|
|
||||||
{
|
|
||||||
if (filegrp[i] >= GRP_RESERVED_ID_START) // external file or ZIPped file
|
|
||||||
continue;
|
|
||||||
else if (filegrp[i] == grpnum) // close file in group we closed
|
|
||||||
filehan[i] = -1;
|
|
||||||
else if (filegrp[i] > grpnum) // move back a file in a group after the one we closed
|
|
||||||
filegrp[i]--;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void uninitgroupfile(void)
|
void uninitgroupfile(void)
|
||||||
|
@ -869,56 +831,33 @@ static int32_t check_filename_mismatch(const char *filename, int32_t ofs)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int32_t kopen4load(const char *filename, char searchfirst)
|
static int32_t kopen_internal(const char *filename, char **lastpfn, char searchfirst, char checkcase, char tryzip, int32_t newhandle, uint8_t *arraygrp, intptr_t *arrayhan, int32_t *arraypos)
|
||||||
{
|
{
|
||||||
int32_t j, k, fil, newhandle = MAXOPENFILES-1;
|
int32_t j, k, fil;
|
||||||
char bad, *gfileptr;
|
char bad, *gfileptr;
|
||||||
intptr_t i;
|
intptr_t i;
|
||||||
|
|
||||||
#ifdef FILENAME_CASE_CHECK
|
if (searchfirst == 0 && (fil = openfrompath_internal(filename, lastpfn, BO_BINARY|BO_RDONLY, BS_IREAD)) >= 0)
|
||||||
const int32_t do_case_check = check_filename_casing_fn && check_filename_casing_fn();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (filename==NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
while (filehan[newhandle] != -1)
|
|
||||||
{
|
|
||||||
newhandle--;
|
|
||||||
if (newhandle < 0)
|
|
||||||
{
|
|
||||||
Bprintf("TOO MANY FILES OPEN IN FILE GROUPING SYSTEM!");
|
|
||||||
Bexit(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef FILENAME_CASE_CHECK
|
|
||||||
dont_free_pfn = do_case_check;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (searchfirst == 0 && (fil = openfrompath(filename,BO_BINARY|BO_RDONLY,BS_IREAD)) >= 0)
|
|
||||||
{
|
{
|
||||||
#ifdef FILENAME_CASE_CHECK
|
#ifdef FILENAME_CASE_CHECK
|
||||||
if (check_filename_casing_fn && check_filename_casing_fn())
|
if (checkcase && check_filename_casing_fn && check_filename_casing_fn())
|
||||||
{
|
{
|
||||||
int32_t status;
|
int32_t status;
|
||||||
char *cp, *lastslash;
|
char *cp, *lastslash;
|
||||||
|
|
||||||
// convert all slashes to backslashes because SHGetFileInfo()
|
// convert all slashes to backslashes because SHGetFileInfo()
|
||||||
// complains else!
|
// complains else!
|
||||||
lastslash = lastpfn;
|
lastslash = *lastpfn;
|
||||||
for (cp=lastpfn; *cp; cp++)
|
for (cp=*lastpfn; *cp; cp++)
|
||||||
if (*cp=='/')
|
if (*cp=='/')
|
||||||
{
|
{
|
||||||
*cp = '\\';
|
*cp = '\\';
|
||||||
lastslash = cp;
|
lastslash = cp;
|
||||||
}
|
}
|
||||||
if (lastslash != lastpfn)
|
if (lastslash != *lastpfn)
|
||||||
lastslash++;
|
lastslash++;
|
||||||
|
|
||||||
status = check_filename_mismatch(lastpfn, lastslash-lastpfn);
|
status = check_filename_mismatch(*lastpfn, lastslash-*lastpfn);
|
||||||
|
|
||||||
dont_free_pfn = 0;
|
|
||||||
|
|
||||||
if (status == -1)
|
if (status == -1)
|
||||||
{
|
{
|
||||||
|
@ -929,38 +868,38 @@ int32_t kopen4load(const char *filename, char searchfirst)
|
||||||
initprintf("warning: case mismatch: passed \"%s\", real \"%s\"\n",
|
initprintf("warning: case mismatch: passed \"%s\", real \"%s\"\n",
|
||||||
lastslash, shinf.szDisplayName);
|
lastslash, shinf.szDisplayName);
|
||||||
}
|
}
|
||||||
|
|
||||||
Bfree(lastpfn);
|
|
||||||
lastpfn=NULL;
|
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
UNREFERENCED_PARAMETER(checkcase);
|
||||||
#endif
|
#endif
|
||||||
filegrp[newhandle] = GRP_FILESYSTEM;
|
arraygrp[newhandle] = GRP_FILESYSTEM;
|
||||||
filehan[newhandle] = fil;
|
arrayhan[newhandle] = fil;
|
||||||
filepos[newhandle] = 0;
|
arraypos[newhandle] = 0;
|
||||||
return(newhandle);
|
return newhandle;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef FILENAME_CASE_CHECK
|
|
||||||
dont_free_pfn = 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for (; toupperlookup[*filename] == '/'; filename++);
|
for (; toupperlookup[*filename] == '/'; filename++);
|
||||||
|
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
|
if (tryzip)
|
||||||
|
{
|
||||||
if ((kzcurhand != newhandle) && (kztell() >= 0))
|
if ((kzcurhand != newhandle) && (kztell() >= 0))
|
||||||
{
|
{
|
||||||
if (kzcurhand >= 0) filepos[kzcurhand] = kztell();
|
if (kzcurhand >= 0) arraypos[kzcurhand] = kztell();
|
||||||
kzclose();
|
kzclose();
|
||||||
}
|
}
|
||||||
if (searchfirst != 1 && (i = kzipopen(filename)) != 0)
|
if (searchfirst != 1 && (i = kzipopen(filename)) != 0)
|
||||||
{
|
{
|
||||||
kzcurhand = newhandle;
|
kzcurhand = newhandle;
|
||||||
filegrp[newhandle] = GRP_ZIP;
|
arraygrp[newhandle] = GRP_ZIP;
|
||||||
filehan[newhandle] = i;
|
arrayhan[newhandle] = i;
|
||||||
filepos[newhandle] = 0;
|
arraypos[newhandle] = 0;
|
||||||
strcpy(filenamsav[newhandle],filename);
|
strcpy(filenamsav[newhandle],filename);
|
||||||
return newhandle;
|
return newhandle;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
UNREFERENCED_PARAMETER(tryzip);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (k=numgroupfiles-1; k>=0; k--)
|
for (k=numgroupfiles-1; k>=0; k--)
|
||||||
|
@ -986,21 +925,48 @@ int32_t kopen4load(const char *filename, char searchfirst)
|
||||||
if (j<13 && gfileptr[j]) continue; // JBF: because e1l1.map might exist before e1l1
|
if (j<13 && gfileptr[j]) continue; // JBF: because e1l1.map might exist before e1l1
|
||||||
if (j==13 && filename[j]) continue; // JBF: long file name
|
if (j==13 && filename[j]) continue; // JBF: long file name
|
||||||
|
|
||||||
filegrp[newhandle] = k;
|
arraygrp[newhandle] = k;
|
||||||
filehan[newhandle] = i;
|
arrayhan[newhandle] = i;
|
||||||
filepos[newhandle] = 0;
|
arraypos[newhandle] = 0;
|
||||||
return(newhandle);
|
return newhandle;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return(-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
int32_t kread(int32_t handle, void *buffer, int32_t leng)
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t kopen4load(const char *filename, char searchfirst)
|
||||||
{
|
{
|
||||||
int32_t i;
|
int32_t newhandle = MAXOPENFILES-1;
|
||||||
int32_t filenum = filehan[handle];
|
|
||||||
int32_t groupnum = filegrp[handle];
|
if (filename==NULL)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
while (filehan[newhandle] != -1)
|
||||||
|
{
|
||||||
|
newhandle--;
|
||||||
|
if (newhandle < 0)
|
||||||
|
{
|
||||||
|
Bprintf("TOO MANY FILES OPEN IN FILE GROUPING SYSTEM!");
|
||||||
|
Bexit(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
char *lastpfn = NULL;
|
||||||
|
|
||||||
|
int32_t h = kopen_internal(filename, &lastpfn, searchfirst, 1, 1, newhandle, filegrp, filehan, filepos);
|
||||||
|
|
||||||
|
if (lastpfn)
|
||||||
|
Bfree(lastpfn);
|
||||||
|
|
||||||
|
return h;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t kread_internal(int32_t handle, void *buffer, int32_t leng, uint8_t *arraygrp, intptr_t *arrayhan, int32_t *arraypos)
|
||||||
|
{
|
||||||
|
int32_t filenum = arrayhan[handle];
|
||||||
|
int32_t groupnum = arraygrp[handle];
|
||||||
|
|
||||||
if (groupnum == GRP_FILESYSTEM) return(Bread(filenum,buffer,leng));
|
if (groupnum == GRP_FILESYSTEM) return(Bread(filenum,buffer,leng));
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
|
@ -1008,49 +974,59 @@ int32_t kread(int32_t handle, void *buffer, int32_t leng)
|
||||||
{
|
{
|
||||||
if (kzcurhand != handle)
|
if (kzcurhand != handle)
|
||||||
{
|
{
|
||||||
if (kztell() >= 0) { filepos[kzcurhand] = kztell(); kzclose(); }
|
if (kztell() >= 0) { arraypos[kzcurhand] = kztell(); kzclose(); }
|
||||||
kzcurhand = handle;
|
kzcurhand = handle;
|
||||||
kzipopen(filenamsav[handle]);
|
kzipopen(filenamsav[handle]);
|
||||||
kzseek(filepos[handle],SEEK_SET);
|
kzseek(arraypos[handle],SEEK_SET);
|
||||||
}
|
}
|
||||||
return(kzread(buffer,leng));
|
return(kzread(buffer,leng));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (groupfil[groupnum] != -1)
|
if (EDUKE32_PREDICT_FALSE(groupfil[groupnum] == -1))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
int32_t rootgroupnum = groupnum;
|
||||||
|
int32_t i = 0;
|
||||||
|
while (groupfilgrp[rootgroupnum] != GRP_FILESYSTEM)
|
||||||
{
|
{
|
||||||
i = gfileoffs[groupnum][filenum]+filepos[handle];
|
i += gfileoffs[groupfilgrp[rootgroupnum]][groupfil[rootgroupnum]];
|
||||||
if (i != groupfilpos[groupnum])
|
rootgroupnum = groupfilgrp[rootgroupnum];
|
||||||
{
|
|
||||||
Blseek(groupfil[groupnum],i+((gnumfiles[groupnum]+1)<<4),BSEEK_SET);
|
|
||||||
groupfilpos[groupnum] = i;
|
|
||||||
}
|
}
|
||||||
leng = min(leng,(gfileoffs[groupnum][filenum+1]-gfileoffs[groupnum][filenum])-filepos[handle]);
|
if (EDUKE32_PREDICT_TRUE(groupfil[rootgroupnum] != -1))
|
||||||
leng = Bread(groupfil[groupnum],buffer,leng);
|
{
|
||||||
filepos[handle] += leng;
|
i += gfileoffs[groupnum][filenum]+arraypos[handle];
|
||||||
groupfilpos[groupnum] += leng;
|
if (i != groupfilpos[rootgroupnum])
|
||||||
|
{
|
||||||
|
Blseek(groupfil[rootgroupnum],i,BSEEK_SET);
|
||||||
|
groupfilpos[rootgroupnum] = i;
|
||||||
|
}
|
||||||
|
leng = min(leng,(gfileoffs[groupnum][filenum+1]-gfileoffs[groupnum][filenum])-arraypos[handle]);
|
||||||
|
leng = Bread(groupfil[rootgroupnum],buffer,leng);
|
||||||
|
arraypos[handle] += leng;
|
||||||
|
groupfilpos[rootgroupnum] += leng;
|
||||||
return(leng);
|
return(leng);
|
||||||
}
|
}
|
||||||
|
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t klseek(int32_t handle, int32_t offset, int32_t whence)
|
int32_t klseek_internal(int32_t handle, int32_t offset, int32_t whence, uint8_t *arraygrp, intptr_t *arrayhan, int32_t *arraypos)
|
||||||
{
|
{
|
||||||
int32_t i, groupnum;
|
int32_t i, groupnum;
|
||||||
|
|
||||||
groupnum = filegrp[handle];
|
groupnum = arraygrp[handle];
|
||||||
|
|
||||||
if (groupnum == GRP_FILESYSTEM) return(Blseek(filehan[handle],offset,whence));
|
if (groupnum == GRP_FILESYSTEM) return(Blseek(arrayhan[handle],offset,whence));
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
else if (groupnum == GRP_ZIP)
|
else if (groupnum == GRP_ZIP)
|
||||||
{
|
{
|
||||||
if (kzcurhand != handle)
|
if (kzcurhand != handle)
|
||||||
{
|
{
|
||||||
if (kztell() >= 0) { filepos[kzcurhand] = kztell(); kzclose(); }
|
if (kztell() >= 0) { arraypos[kzcurhand] = kztell(); kzclose(); }
|
||||||
kzcurhand = handle;
|
kzcurhand = handle;
|
||||||
kzipopen(filenamsav[handle]);
|
kzipopen(filenamsav[handle]);
|
||||||
kzseek(filepos[handle],SEEK_SET);
|
kzseek(arraypos[handle],SEEK_SET);
|
||||||
}
|
}
|
||||||
return(kzseek(offset,whence));
|
return(kzseek(offset,whence));
|
||||||
}
|
}
|
||||||
|
@ -1061,81 +1037,115 @@ int32_t klseek(int32_t handle, int32_t offset, int32_t whence)
|
||||||
switch (whence)
|
switch (whence)
|
||||||
{
|
{
|
||||||
case BSEEK_SET:
|
case BSEEK_SET:
|
||||||
filepos[handle] = offset; break;
|
arraypos[handle] = offset; break;
|
||||||
case BSEEK_END:
|
case BSEEK_END:
|
||||||
i = filehan[handle];
|
i = arrayhan[handle];
|
||||||
filepos[handle] = (gfileoffs[groupnum][i+1]-gfileoffs[groupnum][i])+offset;
|
arraypos[handle] = (gfileoffs[groupnum][i+1]-gfileoffs[groupnum][i])+offset;
|
||||||
break;
|
break;
|
||||||
case BSEEK_CUR:
|
case BSEEK_CUR:
|
||||||
filepos[handle] += offset; break;
|
arraypos[handle] += offset; break;
|
||||||
}
|
}
|
||||||
return(filepos[handle]);
|
return(arraypos[handle]);
|
||||||
}
|
}
|
||||||
return(-1);
|
return(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t kfilelength(int32_t handle)
|
int32_t kfilelength_internal(int32_t handle, uint8_t *arraygrp, intptr_t *arrayhan, int32_t *arraypos)
|
||||||
{
|
{
|
||||||
int32_t i, groupnum;
|
int32_t i, groupnum;
|
||||||
|
|
||||||
groupnum = filegrp[handle];
|
groupnum = arraygrp[handle];
|
||||||
if (groupnum == GRP_FILESYSTEM)
|
if (groupnum == GRP_FILESYSTEM)
|
||||||
{
|
{
|
||||||
// return(filelength(filehan[handle]))
|
// return(filelength(arrayhan[handle]))
|
||||||
return Bfilelength(filehan[handle]);
|
return Bfilelength(arrayhan[handle]);
|
||||||
}
|
}
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
else if (groupnum == GRP_ZIP)
|
else if (groupnum == GRP_ZIP)
|
||||||
{
|
{
|
||||||
if (kzcurhand != handle)
|
if (kzcurhand != handle)
|
||||||
{
|
{
|
||||||
if (kztell() >= 0) { filepos[kzcurhand] = kztell(); kzclose(); }
|
if (kztell() >= 0) { arraypos[kzcurhand] = kztell(); kzclose(); }
|
||||||
kzcurhand = handle;
|
kzcurhand = handle;
|
||||||
kzipopen(filenamsav[handle]);
|
kzipopen(filenamsav[handle]);
|
||||||
kzseek(filepos[handle],SEEK_SET);
|
kzseek(arraypos[handle],SEEK_SET);
|
||||||
}
|
}
|
||||||
return kzfilelength();
|
return kzfilelength();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
i = filehan[handle];
|
i = arrayhan[handle];
|
||||||
return(gfileoffs[groupnum][i+1]-gfileoffs[groupnum][i]);
|
return(gfileoffs[groupnum][i+1]-gfileoffs[groupnum][i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t ktell(int32_t handle)
|
int32_t ktell_internal(int32_t handle, uint8_t *arraygrp, intptr_t *arrayhan, int32_t *arraypos)
|
||||||
{
|
{
|
||||||
int32_t groupnum = filegrp[handle];
|
int32_t groupnum = arraygrp[handle];
|
||||||
|
|
||||||
if (groupnum == GRP_FILESYSTEM) return(Blseek(filehan[handle],0,BSEEK_CUR));
|
if (groupnum == GRP_FILESYSTEM) return(Blseek(arrayhan[handle],0,BSEEK_CUR));
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
else if (groupnum == GRP_ZIP)
|
else if (groupnum == GRP_ZIP)
|
||||||
{
|
{
|
||||||
if (kzcurhand != handle)
|
if (kzcurhand != handle)
|
||||||
{
|
{
|
||||||
if (kztell() >= 0) { filepos[kzcurhand] = kztell(); kzclose(); }
|
if (kztell() >= 0) { arraypos[kzcurhand] = kztell(); kzclose(); }
|
||||||
kzcurhand = handle;
|
kzcurhand = handle;
|
||||||
kzipopen(filenamsav[handle]);
|
kzipopen(filenamsav[handle]);
|
||||||
kzseek(filepos[handle],SEEK_SET);
|
kzseek(arraypos[handle],SEEK_SET);
|
||||||
}
|
}
|
||||||
return kztell();
|
return kztell();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (groupfil[groupnum] != -1)
|
if (groupfil[groupnum] != -1)
|
||||||
return filepos[handle];
|
return arraypos[handle];
|
||||||
return(-1);
|
return(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void kclose(int32_t handle)
|
void kclose_internal(int32_t handle, uint8_t *arraygrp, intptr_t *arrayhan)
|
||||||
{
|
{
|
||||||
if (handle < 0) return;
|
if (handle < 0) return;
|
||||||
if (filegrp[handle] == GRP_FILESYSTEM) Bclose(filehan[handle]);
|
if (arraygrp[handle] == GRP_FILESYSTEM) Bclose(arrayhan[handle]);
|
||||||
#ifdef WITHKPLIB
|
#ifdef WITHKPLIB
|
||||||
else if (filegrp[handle] == GRP_ZIP)
|
else if (arraygrp[handle] == GRP_ZIP)
|
||||||
{
|
{
|
||||||
kzclose();
|
kzclose();
|
||||||
kzcurhand = -1;
|
kzcurhand = -1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
filehan[handle] = -1;
|
arrayhan[handle] = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t kread(int32_t handle, void *buffer, int32_t leng)
|
||||||
|
{
|
||||||
|
return kread_internal(handle, buffer, leng, filegrp, filehan, filepos);
|
||||||
|
}
|
||||||
|
int32_t klseek(int32_t handle, int32_t offset, int32_t whence)
|
||||||
|
{
|
||||||
|
return klseek_internal(handle, offset, whence, filegrp, filehan, filepos);
|
||||||
|
}
|
||||||
|
int32_t kfilelength(int32_t handle)
|
||||||
|
{
|
||||||
|
return kfilelength_internal(handle, filegrp, filehan, filepos);
|
||||||
|
}
|
||||||
|
int32_t ktell(int32_t handle)
|
||||||
|
{
|
||||||
|
return ktell_internal(handle, filegrp, filehan, filepos);
|
||||||
|
}
|
||||||
|
void kclose(int32_t handle)
|
||||||
|
{
|
||||||
|
return kclose_internal(handle, filegrp, filehan);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t kread_grp(int32_t handle, void *buffer, int32_t leng)
|
||||||
|
{
|
||||||
|
return kread_internal(handle, buffer, leng, groupfilgrp, groupfil, groupfilpos);
|
||||||
|
}
|
||||||
|
static int32_t klseek_grp(int32_t handle, int32_t offset, int32_t whence)
|
||||||
|
{
|
||||||
|
return klseek_internal(handle, offset, whence, groupfilgrp, groupfil, groupfilpos);
|
||||||
|
}
|
||||||
|
static void kclose_grp(int32_t handle)
|
||||||
|
{
|
||||||
|
return kclose_internal(handle, groupfilgrp, groupfil);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t klistaddentry(CACHE1D_FIND_REC **rec, const char *name, int32_t type, int32_t source)
|
static int32_t klistaddentry(CACHE1D_FIND_REC **rec, const char *name, int32_t type, int32_t source)
|
||||||
|
|
Loading…
Reference in a new issue