From 79052366d049b767d43258f8a8c0926f9f10d7fe Mon Sep 17 00:00:00 2001 From: Paul Gilbert Date: Thu, 3 Jan 2019 18:30:22 -0800 Subject: GLK: FROTZ: Support using prior palette when a pic doesn't have one --- engines/glk/frotz/pics.cpp | 21 ++++++++++++++------- engines/glk/frotz/pics.h | 6 ++++++ 2 files changed, 20 insertions(+), 7 deletions(-) (limited to 'engines/glk/frotz') diff --git a/engines/glk/frotz/pics.cpp b/engines/glk/frotz/pics.cpp index 86cd5feb25..9dca324315 100644 --- a/engines/glk/frotz/pics.cpp +++ b/engines/glk/frotz/pics.cpp @@ -41,6 +41,8 @@ Pics::Pics() : Common::Archive(), _filename(getFilename()) { if (!f.open(_filename)) error("Error reading Pics file"); + _palette = new Common::Array(); + Common::Array offsets; byte buffer[16]; f.read(buffer, 16); @@ -95,6 +97,10 @@ Pics::Pics() : Common::Archive(), _filename(getFilename()) { f.close(); } +Pics::~Pics() { + delete _palette; +} + Common::String Pics::getFilename() { Common::String filename = g_vm->getFilename(); while (filename.contains('.')) @@ -137,22 +143,23 @@ Common::SeekableReadStream *Pics::createReadStreamForMember(const Common::String for (uint idx = 0; idx < _index.size(); ++idx) { const Entry &e = _index[idx]; if (e._filename.equalsIgnoreCase(name)) { - Common::Array palette; Common::File f; Common::SeekableReadStream *dest; if (!f.open(_filename)) error("Reading failed"); if (e._dataSize) { - // Read in the image's palette - assert(e._paletteOffset); - f.seek(e._paletteOffset); - palette.resize(f.readByte() * 3); - f.read(&palette[0], palette.size()); + if (e._paletteOffset) { + // Read in the image's palette + assert(e._paletteOffset); + f.seek(e._paletteOffset); + _palette->resize(f.readByte() * 3); + f.read(&(*_palette)[0], _palette->size()); + } f.seek(e._dataOffset); Common::SeekableReadStream *src = f.readStream(e._dataSize); - dest = decoder.decode(*src, e._flags, palette, kMCGA, e._width, e._height); + dest = decoder.decode(*src, e._flags, *_palette, kMCGA, e._width, e._height); delete src; } else { byte *rect = (byte *)malloc(2 * sizeof(uint16)); diff --git a/engines/glk/frotz/pics.h b/engines/glk/frotz/pics.h index ab2204f414..68facf5b9f 100644 --- a/engines/glk/frotz/pics.h +++ b/engines/glk/frotz/pics.h @@ -65,6 +65,7 @@ private: Common::Array _index; ///< list of entries uint _entrySize; uint _version; + Common::Array *_palette; private: /** * Returns the filename for the pictures archive @@ -81,6 +82,11 @@ public: */ Pics(); + /** + * Destructor + */ + ~Pics(); + /** * Return the number of entries in the file */ -- cgit v1.2.3