- fixed some remaining issues:

* initial positioning in a subsection of a file failed. This mainly affected music playback.
* made the FileRdr constructor which takes a FileReaderInterface private so that everything that needs it must be explicitly declared as friend.
* removed a few redundant construction initializers for FileRdrs.
* loading compressed nodes needs to check the validity of its reader.
* use GetLength to detemine the size of a Zip file instead of doing another seek to the end.
* removed duplicate Length variables.
This commit is contained in:
Christoph Oelckers 2018-03-11 13:26:30 +01:00
parent b14ee50d0d
commit 8bbfd39f42
7 changed files with 42 additions and 39 deletions

View file

@ -51,7 +51,6 @@
class StdFileReader : public FileReaderInterface class StdFileReader : public FileReaderInterface
{ {
FILE *File = nullptr; FILE *File = nullptr;
long Length = 0;
long StartPos = 0; long StartPos = 0;
long FilePos = 0; long FilePos = 0;
@ -76,7 +75,7 @@ public:
StartPos = startpos; StartPos = startpos;
Length = CalcFileLen(); Length = CalcFileLen();
if (len >= 0 && len < Length) Length = len; if (len >= 0 && len < Length) Length = len;
if (startpos > 0) Seek(startpos, SEEK_SET); if (startpos > 0) Seek(0, SEEK_SET);
return true; return true;
} }
@ -99,7 +98,7 @@ public:
{ {
offset += StartPos + Length; offset += StartPos + Length;
} }
if (offset < StartPos || offset >= StartPos + Length) return -1; // out of scope if (offset < StartPos || offset > StartPos + Length) return -1; // out of scope
if (0 == fseek(File, offset, SEEK_SET)) if (0 == fseek(File, offset, SEEK_SET))
{ {
@ -161,7 +160,6 @@ private:
class FileReaderRedirect : public FileReaderInterface class FileReaderRedirect : public FileReaderInterface
{ {
FileRdr *mReader = nullptr; FileRdr *mReader = nullptr;
long Length = 0;
long StartPos = 0; long StartPos = 0;
long FilePos = 0; long FilePos = 0;
@ -196,7 +194,7 @@ public:
offset += (long)mReader->Tell(); offset += (long)mReader->Tell();
break; break;
} }
if (offset < StartPos || offset >= StartPos + Length) return -1; // out of scope if (offset < StartPos || offset > StartPos + Length) return -1; // out of scope
if (mReader->Seek(offset, FileRdr::SeekSet) == 0) if (mReader->Seek(offset, FileRdr::SeekSet) == 0)
{ {
FilePos = offset; FilePos = offset;

View file

@ -43,7 +43,7 @@
#include "doomtype.h" #include "doomtype.h"
#include "m_swap.h" #include "m_swap.h"
// Zip compression methods, extended by some internal types to be passed to FileReader::OpenDecompressor // Zip compression methods, extended by some internal types to be passed to OpenDecompressor
enum enum
{ {
METHOD_STORED = 0, METHOD_STORED = 0,
@ -70,6 +70,16 @@ public:
long GetLength () const { return Length; } long GetLength () const { return Length; }
}; };
class DecompressorBase : public FileReaderInterface
{
public:
// These do not work but need to be defined to satisfy the FileReaderInterface.
// They will just error out when called.
long Tell() const override;
long Seek(long offset, int origin) override;
char *Gets(char *strbuf, int len) override;
};
class MemoryReader : public FileReaderInterface class MemoryReader : public FileReaderInterface
{ {
protected: protected:
@ -95,14 +105,22 @@ public:
}; };
struct FResourceLump;
class FileRdr // this is just a temporary name, until the old FileReader hierarchy can be made private. class FileRdr
{ {
friend struct FResourceLump; // needs access to the private constructor.
FileReaderInterface *mReader = nullptr; FileReaderInterface *mReader = nullptr;
FileRdr(const FileRdr &r) = delete; FileRdr(const FileRdr &r) = delete;
FileRdr &operator=(const FileRdr &r) = delete; FileRdr &operator=(const FileRdr &r) = delete;
explicit FileRdr(FileReaderInterface *r)
{
mReader = r;
}
public: public:
enum ESeek enum ESeek
{ {
@ -115,12 +133,6 @@ public:
FileRdr() {} FileRdr() {}
// These two functions are only needed as long as the FileReader has not been fully replaced throughout the code.
explicit FileRdr(FileReaderInterface *r)
{
mReader = r;
}
FileRdr(FileRdr &&r) FileRdr(FileRdr &&r)
{ {
mReader = r.mReader; mReader = r.mReader;

View file

@ -42,26 +42,21 @@
#include "m_misc.h" #include "m_misc.h"
class DecompressorBase : public FileReaderInterface long DecompressorBase::Tell () const
{
public:
// These do not work but need to be defined to satisfy the FileReader interface
long Tell () const override
{ {
I_Error("Cannot get position of decompressor stream"); I_Error("Cannot get position of decompressor stream");
return 0; return 0;
} }
virtual long Seek (long offset, int origin) override long DecompressorBase::Seek (long offset, int origin)
{ {
I_Error("Cannot seek in decompressor stream"); I_Error("Cannot seek in decompressor stream");
return 0; return 0;
} }
virtual char *Gets(char *strbuf, int len) override char *DecompressorBase::Gets(char *strbuf, int len)
{ {
I_Error("Cannot use Gets on decompressor stream"); I_Error("Cannot use Gets on decompressor stream");
return nullptr; return nullptr;
} }
};
//========================================================================== //==========================================================================
// //

View file

@ -75,7 +75,7 @@ struct IHDR
uint8_t Interlace; uint8_t Interlace;
}; };
PNGHandle::PNGHandle (FileRdr &file) : File(0), bDeleteFilePtr(true), ChunkPt(0) PNGHandle::PNGHandle (FileRdr &file) : bDeleteFilePtr(true), ChunkPt(0)
{ {
File = std::move(file); File = std::move(file);
} }

View file

@ -3853,7 +3853,7 @@ void P_SetupLevel (const char *lumpname, int position)
if (!ForceNodeBuild) if (!ForceNodeBuild)
{ {
// Check for compressed nodes first, then uncompressed nodes // Check for compressed nodes first, then uncompressed nodes
FileRdr *fr; FileRdr *fr = nullptr;
uint32_t id = MAKE_ID('X','x','X','x'), idcheck = 0, idcheck2 = 0, idcheck3 = 0, idcheck4 = 0, idcheck5 = 0, idcheck6 = 0; uint32_t id = MAKE_ID('X','x','X','x'), idcheck = 0, idcheck2 = 0, idcheck3 = 0, idcheck4 = 0, idcheck5 = 0, idcheck6 = 0;
if (map->Size(ML_ZNODES) != 0) if (map->Size(ML_ZNODES) != 0)
@ -3874,7 +3874,7 @@ void P_SetupLevel (const char *lumpname, int position)
idcheck6 = MAKE_ID('X','G','L','3'); idcheck6 = MAKE_ID('X','G','L','3');
} }
fr->Read (&id, 4); if (fr != nullptr && fr->isOpen()) fr->Read (&id, 4);
if (id != 0 && (id == idcheck || id == idcheck2 || id == idcheck3 || id == idcheck4 || id == idcheck5 || id == idcheck6)) if (id != 0 && (id == idcheck || id == idcheck2 || id == idcheck3 || id == idcheck4 || id == idcheck5 || id == idcheck6))
{ {
try try

View file

@ -124,9 +124,7 @@ static uint32_t Zip_FindCentralDir(FileRdr &fin)
uint32_t uMaxBack; // maximum size of global comment uint32_t uMaxBack; // maximum size of global comment
uint32_t uPosFound=0; uint32_t uPosFound=0;
fin.Seek(0, FileRdr::SeekEnd); FileSize = (uint32_t)fin.GetLength();
FileSize = (uint32_t)fin.Tell();
uMaxBack = MIN<uint32_t>(0xffff, FileSize); uMaxBack = MIN<uint32_t>(0xffff, FileSize);
uBackRead = 4; uBackRead = 4;

View file

@ -290,7 +290,7 @@ class OpenALSoundStream : public SoundStream
public: public:
OpenALSoundStream(OpenALSoundRenderer *renderer) OpenALSoundStream(OpenALSoundRenderer *renderer)
: Renderer(renderer), Source(0), Playing(false), Looping(false), Volume(1.0f), Reader(NULL), Decoder(NULL) : Renderer(renderer), Source(0), Playing(false), Looping(false), Volume(1.0f), Decoder(NULL)
{ {
memset(Buffers, 0, sizeof(Buffers)); memset(Buffers, 0, sizeof(Buffers));
Renderer->AddStream(this); Renderer->AddStream(this);