mirror of
https://github.com/dborth/fceugx.git
synced 2025-01-07 14:28:18 +01:00
fix bug w/ reading files < 2048 bytes
This commit is contained in:
parent
9ed631add7
commit
31c1d13fcf
@ -440,13 +440,12 @@ LoadFileBuf (char * rbuffer, char *filepath, u32 length, int method, bool silent
|
|||||||
fstat(file->_file, &fileinfo);
|
fstat(file->_file, &fileinfo);
|
||||||
size = fileinfo.st_size;
|
size = fileinfo.st_size;
|
||||||
|
|
||||||
memcpy (rbuffer, zipbuffer, 2048); // copy what we already read
|
memcpy (rbuffer, zipbuffer, readsize); // copy what we already read
|
||||||
|
|
||||||
ShowProgress ("Loading...", 2048, length);
|
u32 offset = readsize;
|
||||||
|
|
||||||
u32 offset = 2048;
|
|
||||||
while(offset < size)
|
while(offset < size)
|
||||||
{
|
{
|
||||||
|
ShowProgress ("Loading...", offset, size);
|
||||||
readsize = fread (rbuffer + offset, 1, (1024*512), file); // read in 512K chunks
|
readsize = fread (rbuffer + offset, 1, (1024*512), file); // read in 512K chunks
|
||||||
|
|
||||||
if(readsize <= 0 || readsize > (1024*512))
|
if(readsize <= 0 || readsize > (1024*512))
|
||||||
@ -454,7 +453,6 @@ LoadFileBuf (char * rbuffer, char *filepath, u32 length, int method, bool silent
|
|||||||
|
|
||||||
if(readsize > 0)
|
if(readsize > 0)
|
||||||
offset += readsize;
|
offset += readsize;
|
||||||
ShowProgress ("Loading...", offset, length);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(offset != size) // # bytes read doesn't match # expected
|
if(offset != size) // # bytes read doesn't match # expected
|
||||||
|
@ -807,6 +807,8 @@ ShowProgress (const char *msg, int done, int total)
|
|||||||
return;
|
return;
|
||||||
else if(done > total) // this shouldn't happen
|
else if(done > total) // this shouldn't happen
|
||||||
done = total;
|
done = total;
|
||||||
|
else if(total < (256*1024)) // don't bother showing progress for small files
|
||||||
|
return;
|
||||||
|
|
||||||
int xpos, ypos;
|
int xpos, ypos;
|
||||||
int i;
|
int i;
|
||||||
|
Loading…
Reference in New Issue
Block a user