aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorEugene Sandulenko2006-11-06 13:40:24 +0000
committerEugene Sandulenko2006-11-06 13:40:24 +0000
commit8ef5e88323972fa8d2fe5e376c78a1903535f50a (patch)
tree387dfd64b52c3c1c3dea767d390d4edbfb07ff65 /engines
parentda3e724a990e1d7482c1654623e01723ba890534 (diff)
downloadscummvm-rg350-8ef5e88323972fa8d2fe5e376c78a1903535f50a.tar.gz
scummvm-rg350-8ef5e88323972fa8d2fe5e376c78a1903535f50a.tar.bz2
scummvm-rg350-8ef5e88323972fa8d2fe5e376c78a1903535f50a.zip
Add support for HE CUP demos based on cyx's standalone player.
svn-id: r24636
Diffstat (limited to 'engines')
-rw-r--r--engines/scumm/he/cup_player_he.cpp495
-rw-r--r--engines/scumm/he/cup_player_he.h76
-rw-r--r--engines/scumm/he/intern_he.h22
-rw-r--r--engines/scumm/module.mk1
-rw-r--r--engines/scumm/plugin.cpp12
-rw-r--r--engines/scumm/scumm-md5.h9
-rw-r--r--engines/scumm/scumm.cpp50
-rw-r--r--engines/scumm/scumm.h3
8 files changed, 664 insertions, 4 deletions
diff --git a/engines/scumm/he/cup_player_he.cpp b/engines/scumm/he/cup_player_he.cpp
new file mode 100644
index 0000000000..72e9f3c8df
--- /dev/null
+++ b/engines/scumm/he/cup_player_he.cpp
@@ -0,0 +1,495 @@
+/* ScummVM - Scumm Interpreter
+ * Copyright (C) 2006 The ScummVM project
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ * $URL$
+ * $Id$
+ *
+ */
+
+#include "common/stdafx.h"
+#include "common/system.h"
+#include "scumm/scumm.h"
+#include "scumm/he/intern_he.h"
+#include "scumm/he/cup_player_he.h"
+
+namespace Scumm {
+
+bool CUP_Player::open(const char *filename) {
+ bool opened = false;
+ debug(1, "opening '%s'", filename);
+ if (_fd.open(filename)) {
+ uint32 tag = _fd.readUint32BE();
+ _fd.readUint32BE();
+ if (tag == 'BEAN') {
+ _playbackRate = 66;
+ _width = 640;
+ _height = 480;
+ parseHeaderTags();
+ debug(1, "rate %d width %d height %d", _playbackRate, _width, _height);
+ _offscreenBuffer = (uint8 *)malloc(_width * _height);
+ memset(_offscreenBuffer, 0, _width * _height);
+ opened = true;
+ }
+ }
+ return opened;
+}
+
+void CUP_Player::close() {
+ _fd.close();
+ free(_offscreenBuffer);
+}
+
+uint32 CUP_Player::loadNextChunk() {
+ uint32 tag = _fd.readUint32BE();
+ uint32 size = _fd.readUint32BE() - 8;
+ if (_currentChunkSize < size) {
+ free(_currentChunkData);
+ _currentChunkSize = 0;
+ _currentChunkData = (uint8 *)malloc(size);
+ }
+ if (_currentChunkData) {
+ _currentChunkSize = size;
+ _fd.read(_currentChunkData, _currentChunkSize);
+ }
+ return tag;
+}
+
+void CUP_Player::parseHeaderTags() {
+ _dataSize = 0;
+ while (_dataSize == 0 && !_vm->_quit && !_fd.ioFailed()) {
+ uint32 tag = loadNextChunk();
+ switch (tag) {
+ case 'HEAD':
+ handleHEAD(_currentChunkData, _currentChunkSize);
+ break;
+ case 'SFXB':
+ handleSFXB(_currentChunkData, _currentChunkSize);
+ break;
+ case 'RGBS':
+ handleRGBS(_currentChunkData, _currentChunkSize);
+ break;
+ case 'DATA':
+ _dataSize = _currentChunkSize;
+ break;
+ case 'GFXB':
+ // this is never triggered
+ default:
+ warning("unhandled tag %c%c%c%c", tag>>24, (tag>>16)&0xFF, (tag>>8)&0xFF, tag&0xFF);
+ break;
+ }
+ }
+}
+
+void CUP_Player::play() {
+ int ticks = _system->getMillis();
+ Common::Rect r;
+ while (_currentChunkSize != 0 && !_vm->_quit) {
+ uint32 tag, size;
+ parseNextTag(_currentChunkData, &r, tag, size);
+ if (tag == 'BLOK') {
+ bool fastMode = false;
+ int diff = _system->getMillis() - ticks;
+ if (diff >= 0 && diff <= _playbackRate && !fastMode) {
+ _system->delayMillis(_playbackRate - diff);
+ } else {
+ _system->delayMillis(1);
+ }
+ _system->setPalette(_paletteData, 0, 256);
+ _system->copyRectToScreen(_offscreenBuffer, _width, 0, 0, _width, _height);
+ _system->updateScreen();
+ _vm->parseEvents();
+
+ ticks = _system->getMillis();
+ size = 8;
+ }
+ _currentChunkData += size;
+ _currentChunkSize -= size;
+ }
+}
+
+void CUP_Player::parseNextTag(const uint8 *data, Common::Rect *r1, uint32 &tag, uint32 &size) {
+ tag = READ_BE_UINT32(data);
+ size = READ_BE_UINT32(data + 4);
+ data += 8;
+ switch (tag) {
+ case 'FRAM':
+ handleFRAM(_offscreenBuffer, data, size);
+ break;
+ case 'LZSS':
+ data = handleLZSS(data, size);
+ if (data) {
+ uint32 t, s;
+ parseNextTag(data, r1, t, s);
+ }
+ break;
+ case 'RATE':
+ handleRATE(data, size);
+ break;
+ case 'RGBS':
+ handleRGBS(data, size);
+ break;
+ case 'SNDE':
+ handleSNDE(data, size);
+ break;
+ case 'TOIL':
+ handleTOIL(data, size);
+ break;
+ case 'BLOK':
+ // not handled here
+ break;
+ case 'SRLE':
+ case 'WRLE':
+ // these are never triggered
+ default:
+ warning("Unhandled tag %c%c%c%c", tag>>24, (tag>>16)&0xFF, (tag>>8)&0xFF, tag&0xFF);
+ break;
+ }
+}
+
+void CUP_Player::handleHEAD(const uint8 *data, uint32 dataSize) {
+ _playbackRate = READ_LE_UINT16(data);
+ _width = READ_LE_UINT16(data + 2);
+ _height = READ_LE_UINT16(data + 4);
+}
+
+void CUP_Player::handleSFXB(const uint8 *data, uint32 dataSize) {
+ // TODO
+ warning("unhandled SFXB");
+}
+
+void CUP_Player::handleRGBS(const uint8 *data, uint32 dataSize) {
+ int i;
+ uint8 *ptr = _paletteData;
+
+ for (i = 0; i < 256; i++) {
+ *ptr++ = *data++;
+ *ptr++ = *data++;
+ *ptr++ = *data++;
+ *ptr++ = 0;
+ }
+}
+
+void CUP_Player::handleFRAM(uint8 *dst, const uint8 *data, uint32 size) {
+ Common::Rect r1;
+ memset(&r1, 0, sizeof(r1));
+ int code = 256;
+ int flags = *data++;
+ if (flags & 1) {
+ code = *data++;
+ }
+ if (flags & 2) {
+ r1.left = READ_LE_UINT16(data); data += 2;
+ r1.top = READ_LE_UINT16(data); data += 2;
+ r1.right = READ_LE_UINT16(data); data += 2;
+ r1.bottom = READ_LE_UINT16(data); data += 2;
+ }
+ if (flags & 0x80) {
+ decodeFRAM(dst, &r1, data, code);
+ }
+}
+
+// decodeWiz, decodeTRLE
+void CUP_Player::decodeFRAM(uint8 *dst, Common::Rect *r1, const uint8 *data, int code1) {
+ if (code1 == 256) {
+ dst += r1->top * _width + r1->left;
+ int h = r1->bottom - r1->top + 1;
+ int w = r1->right - r1->left + 1;
+ if (h < 0 || w < 0) { warning("h=%d w=%d", h, w); return; }
+ while (h--) {
+ uint16 lineSize = READ_LE_UINT16(data); data += 2;
+ uint8 *dstNextLine = dst + _width;
+ const uint8 *dataNextLine = data + lineSize;
+ if (lineSize != 0) {
+ uint8 *dstEnd = dst + w;
+ while (dst < dstEnd) {
+ int code = *data++;
+ if (code & 1) { // skip
+ code >>= 1;
+ dst += code;
+ } else if (code & 2) { // set
+ code = (code >> 2) + 1;
+ const int sz = MIN(code, dstEnd - dst);
+ memset(dst, *data++, sz);
+ dst += sz;
+ } else { // copy
+ code = (code >> 2) + 1;
+ const int sz = MIN(code, dstEnd - dst);
+ memcpy(dst, data, sz);
+ dst += sz;
+ data += sz;
+ }
+ }
+ }
+ dst = dstNextLine;
+ data = dataNextLine;
+ }
+ }
+}
+
+uint8 *CUP_Player::handleLZSS(const uint8 *data, uint32 dataSize) {
+ uint32 compressionType = 0;
+ uint32 compressionSize = 0;
+ uint32 tag, size;
+
+ tag = READ_BE_UINT32(data);
+ size = READ_BE_UINT32(data + 4);
+ if (tag == 'LZHD') {
+ compressionType = READ_LE_UINT32(data + 8);
+ compressionSize = READ_LE_UINT32(data + 12);
+ }
+ data += size;
+
+ tag = READ_BE_UINT32(data);
+ size = READ_BE_UINT32(data + 4);
+ if (tag == 'DATA') {
+ if (compressionType == 0x2000) {
+ if (_bufferLzssSize < compressionSize) {
+ _bufferLzssSize = compressionSize;
+ free(_bufferLzssData);
+ _bufferLzssData = (uint8 *)malloc(_bufferLzssSize);
+ }
+ data += 8;
+ uint32 offset1 = READ_LE_UINT32(data);
+ uint32 offset2 = READ_LE_UINT32(data + 4);
+ decodeLzssData(_bufferLzssData, data + 8, data + offset1, data + offset2, _tempLzssBuffer);
+ return _bufferLzssData;
+ }
+ }
+ return 0;
+}
+
+void CUP_Player::decodeLzssData(uint8 *dst1, const uint8 *src1, const uint8 *src2, const uint8 *src3, uint8 *dst2) {
+ int index = 1;
+ while (1) {
+ int code = *src1++;
+ for (int b = 0; b < 8; ++b) {
+ if (code & (1 << b)) {
+ *dst1++ = dst2[index] = *src2++;
+ ++index;
+ index &= 0xFFF;
+ } else {
+ int cmd = READ_LE_UINT16(src3); src3 += 2;
+ int count = (cmd >> 0xC) + 2;
+ int offs = cmd & 0xFFF;
+ if (offs == 0) {
+ return;
+ }
+ while (count--) {
+ *dst1++ = dst2[index] = dst2[offs];
+ ++index;
+ index &= 0xFFF;
+ ++offs;
+ offs &= 0xFFF;
+ }
+ }
+ }
+ }
+}
+
+void CUP_Player::handleRATE(const uint8 *data, uint32 dataSize) {
+ _playbackRate = (int16)READ_LE_UINT16(data);
+ if (_playbackRate > 4000) {
+ _playbackRate = 4000;
+ } else if (_playbackRate < 1) {
+ _playbackRate = 1;
+ }
+}
+
+void CUP_Player::handleSNDE(const uint8 *data, uint32 dataSize) {
+ // TODO
+ warning("unhandled SNDE");
+ // READ_LE_UINT32
+ // READ_LE_UINT16
+ // READ_LE_UINT16
+ // READ_LE_UINT16
+}
+
+void CUP_Player::handleTOIL(const uint8 *data, uint32 dataSize) {
+ int codesCount = READ_LE_UINT16(data); data += 2;
+ if (dataSize > 0) {
+ while (codesCount != 0) {
+ int codeSize = *data++;
+ if (codeSize == 0) {
+ codeSize = READ_LE_UINT16(data); data += 2;
+ }
+ int code = *data++;
+ if (code == 0) {
+ code = READ_LE_UINT16(data); data += 2;
+ }
+ switch (code) {
+ case 1:
+ _vm->_quit = true;
+ break;
+ case 2:
+ // display copyright/information messagebox
+ break;
+ case 3:
+ // READ_LE_UINT32(data);
+ break;
+ case 4:
+ // restart playback
+ break;
+ case 5:
+ // disable normal screen update
+ break;
+ case 6:
+ // perform offscreen buffers swapping
+ break;
+ case 7:
+ // pause playback at specific frame
+ // READ_LE_UINT32(data);
+ break;
+ default:
+ warning("Unhandled TOIL code=%d", code);
+ break;
+ }
+ dataSize -= codeSize;
+ data += codeSize;
+ --codesCount;
+ }
+ }
+}
+
+#if 0
+void CUP_Player::processSRLE(uint8 *dst1, uint8 *dst2, const uint8 *codeTable, uint8 *data, int32 unpackedSize) {
+ bool bit;
+ uint16 code;
+ while (unpackedSize > 0) {
+ code = *data++;
+ bit = (code & 1) == 1;
+ code >>= 1;
+ if (!bit) {
+ bit = (code & 1) == 1;
+ code >>= 1;
+ if (!bit) {
+ int size = code + 1;
+ unpackedSize -= size;
+ memcpy(dst1, dst2, size);
+ dst1 += size;
+ dst2 += size;
+ } else {
+ bit = (code & 1) == 1;
+ code >>= 1;
+ if (!bit) {
+ ++dst2;
+ *dst1++ = codeTable[code];
+ --unpackedSize;
+ } else if (code == 0) {
+ size = 1 + *data++;
+ color = *data++;
+ color = _cup_colorRemapTable[color];
+ dst2 += size;
+ unpackedSize -= size;
+ memset(dst1, color, size);
+ dst1 += size;
+ } else {
+ size = code;
+ code = *data++;
+ code = _cup_colorRemapTable[code];
+ dst2 += size;
+ unpackedSize -= size;
+ memset(dst1, code, size);
+ dst1 += size;
+ }
+ }
+ } else if (code == 0) {
+ code = READ_LE_UINT16(data); data += 2;
+ ++code;
+ dst1 += code;
+ dst2 += code;
+ unpackedSize -= code;
+ } else {
+ dst1 += code;
+ dst2 += code;
+ unpackedSize -= code;
+ }
+ }
+}
+
+void CUP_Player::processWRLE(uint8 *dst, uint8 *codeTable, const uint8 *data, int32 unpackedSize, uint8 rleCode, int pitch) {
+ uint8 color;
+ uint16 code;
+ if (unpackedSize <= 0) return;
+ do {
+ code = *data++;
+ if ((code & 1) != 0) {
+ int size = ((code & 6) >> 1) + 3;
+ code >>= 3;
+ unpackedSize -= var4;
+ color = codeTable[code];
+ if (color != rleCode) {
+ memset(dst, color, size);
+ } else {
+ memcpy(dst, dst + pitch, size);
+ }
+ } else if ((code & 2) == 0) {
+ code >>= 2;
+ if (code == 0) {
+ code = READ_LE_UINT16(data); data += 2;
+ }
+ dst += code;
+ unpackedSize -= code;
+ } else if ((code & 4) != 0) {
+ code >>= 3;
+ if (code == 0) {
+ code = *data++;
+ }
+ unpackedSize -= code;
+ color = *data++;
+ if (color != rleCode) {
+ memset(dst, color, code);
+ } else {
+ assert(code < pitch);
+ memcpy(dst, dst + pitch, code);
+ }
+ dst += code;
+ } else {
+ code >>= 3;
+ color = codeTable[code];
+ if (color == rleCode) {
+ color = dst[pitch];
+ }
+ *dst++ = code;
+ --unpackedSize;
+ }
+ } while (unpackedSize > 0);
+}
+
+void CUP_Player::handleSRLE(IMAGE *img1, IMAGE *img2, Common::Rect *r, const uint8 *data, uint32 dataSize) {
+ Common::Rect r1;
+ r1.left = READ_LE_UINT16(data);
+ r1.top = READ_LE_UINT16(data + 2);
+ r1.right = READ_LE_UINT16(data + 4);
+ r1.bottom = READ_LE_UINT16(data + 6);
+ const uint8 *codeData = data + 8;
+ uint32 size = READ_LE_UINT32(data + 40);
+ processSRLE(img1->ptr, img2->ptr, codeData, data + 44, size);
+}
+
+void CUP_Player::handleWRLE(IMAGE *img, Common::Rect *r, const uint8 *data, uint32 dataSize) {
+ Common::Rect r1;
+ r1.left = READ_LE_UINT16(data); data += 2;
+ r1.top = READ_LE_UINT16(data); data += 2;
+ r1.right = READ_LE_UINT16(data); data += 2;
+ r1.bottom = READ_LE_UINT16(data); data += 2;
+ const uint8 *codeData = data + 8;
+ uint32 size = READ_LE_UINT32(data + 40);
+ processWRLE(img->ptr, codeData, data + 44, size, 0, -img->w);
+}
+#endif
+
+} // End of namespace Scumm
diff --git a/engines/scumm/he/cup_player_he.h b/engines/scumm/he/cup_player_he.h
new file mode 100644
index 0000000000..3554350b01
--- /dev/null
+++ b/engines/scumm/he/cup_player_he.h
@@ -0,0 +1,76 @@
+/* ScummVM - Scumm Interpreter
+ * Copyright (C) 2006 The ScummVM project
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ * $URL$
+ * $Id$
+ *
+ */
+
+
+#if !defined(CUP_PLAYER_HE_H) && !defined(DISABLE_HE)
+#define CUP_PLAYER_HE_H
+
+namespace Scumm {
+
+struct CUP_Player {
+ Common::File _fd;
+ uint32 _dataSize;
+ int _playbackRate;
+ int _width, _height;
+ uint8 _paletteData[256 * 4];
+ uint8 *_offscreenBuffer;
+ uint8 _tempLzssBuffer[0x1000];
+ uint8 *_currentChunkData;
+ uint32 _currentChunkSize;
+ uint8 *_bufferLzssData;
+ uint32 _bufferLzssSize;
+
+ ScummEngine_vCUPhe *_vm;
+ Audio::Mixer *_mixer;
+ OSystem *_system;
+
+ CUP_Player(OSystem *sys, ScummEngine_vCUPhe *vm, Audio::Mixer *mixer) {
+ _currentChunkData = 0;
+ _currentChunkSize = 0;
+ _bufferLzssData = 0;
+ _bufferLzssSize = 0;
+ _vm = vm;
+ _mixer = mixer;
+ _system = sys;
+ }
+
+ bool open(const char *filename);
+ void close();
+ uint32 loadNextChunk();
+ void parseHeaderTags();
+ void play();
+ void parseNextTag(const uint8 *data, Common::Rect *r1, uint32 &tag, uint32 &size);
+ void handleHEAD(const uint8 *data, uint32 dataSize);
+ void handleSFXB(const uint8 *data, uint32 dataSize);
+ void handleRGBS(const uint8 *data, uint32 dataSize);
+ void handleFRAM(uint8 *dst, const uint8 *data, uint32 size);
+ void decodeFRAM(uint8 *dst, Common::Rect *r1, const uint8 *data, int code);
+ uint8 *handleLZSS(const uint8 *data, uint32 dataSize);
+ void decodeLzssData(uint8 *dst1, const uint8 *src1, const uint8 *src2, const uint8 *src3, uint8 *dst2);
+ void handleRATE(const uint8 *data, uint32 dataSize);
+ void handleSNDE(const uint8 *data, uint32 dataSize);
+ void handleTOIL(const uint8 *data, uint32 dataSize);
+};
+
+} // End of namespace Scumm
+
+#endif
diff --git a/engines/scumm/he/intern_he.h b/engines/scumm/he/intern_he.h
index 35d026dbb1..336e0731af 100644
--- a/engines/scumm/he/intern_he.h
+++ b/engines/scumm/he/intern_he.h
@@ -42,6 +42,7 @@ class ResExtractor;
class LogicHE;
class MoviePlayer;
class Sprite;
+class CUP_Player;
#endif
class ScummEngine_v60he : public ScummEngine_v6 {
@@ -629,6 +630,27 @@ protected:
void o100_getWizData();
void o100_getVideoData();
};
+
+class ScummEngine_vCUPhe : public Engine {
+protected:
+ CUP_Player *_cupPlayer;
+ FilenamePattern _filenamePattern;
+
+public:
+ ScummEngine_vCUPhe(OSystem *syst, const DetectorResult &dr);
+ ~ScummEngine_vCUPhe();
+
+ int init();
+ int go();
+
+ void parseEvents();
+
+ bool _quit;
+ OSystem *_syst;
+
+ GameSettings _game;
+};
+
#endif
diff --git a/engines/scumm/module.mk b/engines/scumm/module.mk
index 69445b03f9..eb4ecb6982 100644
--- a/engines/scumm/module.mk
+++ b/engines/scumm/module.mk
@@ -87,6 +87,7 @@ endif
ifndef DISABLE_HE
MODULE_OBJS += \
he/animation_he.o \
+ he/cup_player_he.o \
he/floodfill_he.o \
he/logic_he.o \
he/palette_he.o \
diff --git a/engines/scumm/plugin.cpp b/engines/scumm/plugin.cpp
index f55716a44d..02792d8f92 100644
--- a/engines/scumm/plugin.cpp
+++ b/engines/scumm/plugin.cpp
@@ -271,6 +271,9 @@ static const GameSettings gameVariantsTable[] = {
{"puttputt", "Demo", GID_PUTTDEMO, 6, 60, MDT_ADLIB | MDT_MIDI, GF_USE_KEY, UNK},
#ifndef DISABLE_HE
+ // HE CUP demos
+ {"", "HE CUP", GID_HECUP, 6, 200, MDT_NONE, 0, UNK},
+
// Humongous Entertainment Scumm Version 7.1
// The first version to use 640x480 resolution
// There are also 7.1 versions of freddemo, airdemo and farmdemo
@@ -500,6 +503,7 @@ static const GameFilenamePattern gameFilenamesTable[] = {
{ "baseball", "baseball", kGenHEPC, UNK_LANG, UNK, 0 },
{ "baseball", "BaseBall", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
+ { "baseball", "basedemo.cup", kGenUnchanged, UNK_LANG, UNK, 0 },
{ "baseball2001", "baseball2001", kGenHEPC, UNK_LANG, UNK, 0 },
{ "baseball2001", "bb2demo", kGenHEPC, UNK_LANG, UNK, 0 },
@@ -516,6 +520,7 @@ static const GameFilenamePattern gameFilenamesTable[] = {
{ "bluesabctime", "bluesabctime", kGenHEPC, UNK_LANG, UNK, 0 },
{ "bluesabctime", "BluesABCTimeDemo", kGenHEPC, UNK_LANG, UNK, 0 },
{ "bluesabctime", "BluesABCTimeDemo", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
+ { "bluesabctime", "abc-slideshow.cup", kGenUnchanged, UNK_LANG, UNK, 0 },
{ "BluesBirthday", "Blue'sBirthday-Red", kGenHEPC, UNK_LANG, UNK, 0 },
{ "BluesBirthday", "Blue'sBirthday-Red", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
@@ -523,6 +528,7 @@ static const GameFilenamePattern gameFilenamesTable[] = {
{ "BluesBirthday", "Blue'sBirthday-Yellow", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
{ "BluesBirthday", "BluesBirthdayDemo", kGenHEPC, UNK_LANG, UNK, 0 },
{ "BluesBirthday", "BluesBirthdayDemo", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
+ { "BluesBirthday", "bda-slideshow.cup", kGenUnchanged, UNK_LANG, UNK, 0 },
{ "catalog", "catalog", kGenHEPC, UNK_LANG, UNK, 0 },
{ "catalog", "catalog2", kGenHEPC, UNK_LANG, UNK, 0 },
@@ -691,6 +697,7 @@ static const GameFilenamePattern gameFilenamesTable[] = {
{ "puttrace", "ToffRennen", kGenHEPC, Common::DE_DEU, UNK, 0 },
{ "puttrace", "ToffRennen", kGenHEMac, Common::DE_DEU, Common::kPlatformMacintosh, 0 },
{ "puttrace", "UKPuttRace", kGenHEPC, Common::RU_RUS, UNK, 0 }, // Russian
+ { "puttrace", "racedemo.cup", kGenUnchanged, UNK_LANG, UNK, 0 },
{ "PuttsFunShop", "PuttsFunShop", kGenHEPC, UNK_LANG, UNK, 0 },
{ "PuttsFunShop", "Putt's FunShop", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
@@ -775,6 +782,7 @@ static const GameFilenamePattern gameFilenamesTable[] = {
{ "spyfox2", "spyfoxsr", kGenHEPC, UNK_LANG, UNK, 0 },
{ "spyfox2", "SpyFoxSR", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
{ "spyfox2", "SPYMini", kGenHEPC, UNK_LANG, UNK, 0 },
+ { "spyfox2", "spy2preview.cup", kGenUnchanged, UNK_LANG, UNK, 0 },
{ "spyozon", "spyozon", kGenHEPC, UNK_LANG, UNK, 0 },
{ "spyozon", "sf3-demo", kGenHEPC, UNK_LANG, UNK, 0 },
@@ -782,6 +790,7 @@ static const GameFilenamePattern gameFilenamesTable[] = {
{ "spyozon", "SPYFoxOZU", kGenHEPC, UNK_LANG, UNK, 0 },
{ "spyozon", "SPYFoxSOS", kGenHEPC, Common::FR_FRA, UNK, 0 },
{ "spyozon", "SpyOzon", kGenHEMac, UNK_LANG, Common::kPlatformMacintosh, 0 },
+ { "spyozon", "ozonepre.cup", kGenUnchanged, UNK_LANG, UNK, "HE CUP" },
{ "thinker1", "1grademo", kGenHEPC, UNK_LANG, UNK, 0 },
{ "thinker1", "thinker1", kGenHEPC, UNK_LANG, UNK, 0 },
@@ -1495,6 +1504,9 @@ PluginError Engine_SCUMM_create(OSystem *syst, Engine **engine) {
case 6:
switch (res.game.heversion) {
#ifndef DISABLE_HE
+ case 200:
+ *engine = new ScummEngine_vCUPhe(syst, res);
+ break;
case 100:
*engine = new ScummEngine_v100he(syst, res);
break;
diff --git a/engines/scumm/scumm-md5.h b/engines/scumm/scumm-md5.h
index 7cf76eee19..09df202bc3 100644
--- a/engines/scumm/scumm-md5.h
+++ b/engines/scumm/scumm-md5.h
@@ -1,5 +1,5 @@
/*
- This file was generated by the md5table tool on Wed Oct 25 01:46:12 2006
+ This file was generated by the md5table tool on Mon Nov 6 00:03:35 2006
DO NOT EDIT MANUALLY!
*/
@@ -128,6 +128,7 @@ static const MD5Table md5table[] = {
{ "33e989f85da700e2014d00f345cab3d7", "puttrace", "HE 98.5", "", -1, Common::FR_FRA, Common::kPlatformWindows },
{ "3433be9866ca4261b2d5d25374e3f243", "monkey", "VGA", "VGA", -1, Common::FR_FRA, Common::kPlatformAmiga },
{ "3486ede0f904789267d4bcc5537a46d4", "puttzoo", "", "Demo", -1, Common::EN_ANY, Common::kPlatformMacintosh },
+ { "356fb5f680b68251333016175935d126", "BluesABCTime", "HE CUP", "Demo", 4133436, Common::UNK_LANG, Common::kPlatformUnknown },
{ "35a2d3040fa512f8232d9e443319d84d", "dig", "", "", 659335495, Common::EN_ANY, Common::kPlatformMacintosh },
{ "362c1d281fb9899254cda66ad246c66a", "dig", "Demo", "Demo", 3472, Common::EN_ANY, Common::kPlatformUnknown },
{ "3686cf8f89e102ececf4366e1d2c8126", "monkey2", "", "", 11135, Common::EN_ANY, Common::kPlatformPC },
@@ -168,6 +169,7 @@ static const MD5Table md5table[] = {
{ "49210e124e4c2b30f1290a9ef6306301", "monkey", "EGA", "EGA", 8357, Common::EN_ANY, Common::kPlatformPC },
{ "4973bbc3899e3826dbf316e1d7271ec7", "zak", "V1", "", -1, Common::DE_DEU, Common::kPlatformC64 },
{ "499c958affc394f2a3868f1eb568c3ee", "freddi4", "HE 99", "Demo", -1, Common::NL_NLD, Common::kPlatformWindows },
+ { "49a1739981a89066b1121fac04b710f4", "spyfox2", "HE CUP", "Demo", 5756234, Common::UNK_LANG, Common::kPlatformUnknown },
{ "4aa93cb30e485b728504ba3a693f12bf", "pajama", "HE 100", "", -1, Common::RU_RUS, Common::kPlatformWindows },
{ "4af4a6b248103c1fe9edef619677f540", "puttmoon", "", "Demo", -1, Common::EN_ANY, Common::kPlatformMacintosh },
{ "4ba37f835be11a59d969f90f272f575b", "water", "HE 80", "", -1, Common::EN_USA, Common::kPlatformUnknown },
@@ -226,6 +228,7 @@ static const MD5Table md5table[] = {
{ "62b8c16b6db226ba95aaa8be73f9885c", "indy3", "EGA", "EGA", -1, Common::ES_ESP, Common::kPlatformAmiga },
{ "63fdcdc95cdeea00060883aed38e5504", "PuttTime", "HE 85", "", -1, Common::EN_ANY, Common::kPlatformUnknown },
{ "6508fd55530e6915507e1cc37f7f045d", "indy3", "EGA", "EGA", -1, Common::EN_ANY, Common::kPlatformPC },
+ { "65563295c3a06493351870f20a1630cf", "spyozon", "HE CUP", "Demo", 5235008, Common::UNK_LANG, Common::kPlatformUnknown },
{ "659942b9a6b519f123a13cca3c333a13", "jungle", "", "", -1, Common::EN_ANY, Common::kPlatformMacintosh },
{ "65fa23d6884e8ca23d5d2406d70de7e8", "puttzoo", "", "Demo", -1, Common::FR_FRA, Common::kPlatformWindows },
{ "66236cd1aec24e1d4aff4c4cc93b7e18", "indy3", "EGA", "EGA", -1, Common::FR_FRA, Common::kPlatformPC },
@@ -246,6 +249,7 @@ static const MD5Table md5table[] = {
{ "6af2419fe3db5c2fdb091ae4e5833770", "puttrace", "HE 98.5", "Demo", -1, Common::NL_NLD, Common::kPlatformUnknown },
{ "6b19d0e25cbf720d05822379b8b90ed9", "PuttTime", "HE 90", "Demo", -1, Common::NL_NLD, Common::kPlatformWindows },
{ "6b257bb2827dd894b8109a50a1a18b5a", "freddicove", "HE 100", "Demo", -1, Common::NL_NLD, Common::kPlatformUnknown },
+ { "6b27dbcd8d5697d5c918eeca0f68ef6a", "puttrace", "HE CUP", "Demo", 3901484, Common::UNK_LANG, Common::kPlatformUnknown },
{ "6b3ec67da214f558dc5ceaa2acd47453", "indy3", "EGA", "EGA", -1, Common::EN_ANY, Common::kPlatformPC },
{ "6b5a3fef241e90d4b2e77f1e222773ee", "maniac", "NES", "extracted", -1, Common::SE_SWE, Common::kPlatformNES },
{ "6bf70eee5de3d24d2403e0dd3d267e8a", "spyfox", "", "", 49221, Common::UNK_LANG, Common::kPlatformWindows },
@@ -309,6 +313,7 @@ static const MD5Table md5table[] = {
{ "89cfc425566003ff74b7dc7b3e6fd469 ", "indy3", "EGA", "EGA", -1, Common::FR_FRA, Common::kPlatformPC },
{ "8a484262363a8e18be87112454f1456b", "pjgames", "", "", -1, Common::EN_USA, Common::kPlatformUnknown },
{ "8aa05d3cdb0e795436043f0546af2da2", "tentacle", "", "CD?", -1, Common::FR_FRA, Common::kPlatformUnknown },
+ { "8aed489aba45d2b9fb8a04079c9c6e6a", "baseball", "HE CUP", "Demo", 12876596, Common::UNK_LANG, Common::kPlatformUnknown },
{ "8afb3cf9f95abf208358e984f0c9e738", "funpack", "", "", -1, Common::EN_ANY, Common::kPlatform3DO },
{ "8bdb0bf87b5e303dd35693afb9351215", "ft", "", "", -1, Common::DE_DEU, Common::kPlatformUnknown },
{ "8d479e36f35e80257dfc102cf4b8a912", "farm", "HE 72", "Demo", -1, Common::EN_ANY, Common::kPlatformWindows },
@@ -331,6 +336,7 @@ static const MD5Table md5table[] = {
{ "92e7727e67f5cd979d8a1070e4eb8cb3", "puttzoo", "HE 98.5", "Updated", -1, Common::EN_ANY, Common::kPlatformUnknown },
{ "92fc0073a4cf259ff36070ecb8628ba8", "thinkerk", "", "", -1, Common::EN_USA, Common::kPlatformUnknown },
{ "94aaedbb8f26d71ed3ad6dd34490e29e", "tentacle", "", "Floppy", -1, Common::FR_FRA, Common::kPlatformPC },
+ { "94db6519da85b8d08c976d8e9a858ea7", "baseball", "HE CUP", "Demo", 10044774, Common::UNK_LANG, Common::kPlatformUnknown },
{ "95b3806e043be08668c54c3ffe98650f", "BluesABCTime", "", "", -1, Common::EN_ANY, Common::kPlatformUnknown },
{ "96a3069a3c63caa7329588ce1fef41ee", "spyozon", "", "", -1, Common::RU_RUS, Common::kPlatformUnknown },
{ "9708cf716ed8bcc9ff3fcfc69413b746", "puttputt", "HE 61", "", -1, Common::EN_ANY, Common::kPlatformPC },
@@ -506,6 +512,7 @@ static const MD5Table md5table[] = {
{ "f79e60c17cca601e411f1f75e8ee9b5a", "spyfox2", "", "", 51286, Common::UNK_LANG, Common::kPlatformUnknown },
{ "f8be685007a8b425ba2a455da732f59f", "pajama2", "HE 99", "", -1, Common::FR_FRA, Common::kPlatformMacintosh },
{ "fa127d7c4bb47d05bb1c33ddcaa9f767", "loom", "EGA", "EGA", 5748, Common::DE_DEU, Common::kPlatformPC },
+ { "fa30c4a7a806629626269b6dcab59a15", "BluesBirthday", "HE CUP", "Demo", 7819264, Common::UNK_LANG, Common::kPlatformUnknown },
{ "fb66aa42de21675116346213f176a366", "monkey", "VGA", "VGA", -1, Common::IT_ITA, Common::kPlatformAmiga },
{ "fbb697d89d2beca87360a145f467bdae", "PuttTime", "HE 90", "Demo", -1, Common::DE_DEU, Common::kPlatformUnknown },
{ "fbbbb38a81fc9d6a61d509278390a290", "farm", "", "", -1, Common::EN_ANY, Common::kPlatformMacintosh },
diff --git a/engines/scumm/scumm.cpp b/engines/scumm/scumm.cpp
index 3cf046715e..9dc8bce477 100644
--- a/engines/scumm/scumm.cpp
+++ b/engines/scumm/scumm.cpp
@@ -60,6 +60,7 @@
#include "scumm/sound.h"
#include "scumm/imuse/sysex.h"
#include "scumm/he/sprite_he.h"
+#include "scumm/he/cup_player_he.h"
#include "scumm/util.h"
#include "scumm/verbs.h"
@@ -765,6 +766,51 @@ ScummEngine_v90he::~ScummEngine_v90he() {
free(_hePalettes);
}
}
+
+ScummEngine_vCUPhe::ScummEngine_vCUPhe(OSystem *syst, const DetectorResult &dr) : Engine(syst){
+ _syst = syst;
+ _game = dr.game;
+ _filenamePattern = dr.fp,
+
+ _cupPlayer = new CUP_Player(syst, this, _mixer);
+}
+
+ScummEngine_vCUPhe::~ScummEngine_vCUPhe() {
+ delete _cupPlayer;
+}
+
+int ScummEngine_vCUPhe::init() {
+ _system->beginGFXTransaction();
+ _system->initSize(640, 480);
+ initCommonGFX(true);
+ _system->endGFXTransaction();
+
+ return 0;
+}
+
+int ScummEngine_vCUPhe::go() {
+ _cupPlayer->open(_filenamePattern.pattern);
+ _cupPlayer->play();
+ _cupPlayer->close();
+
+ return 0;
+}
+
+void ScummEngine_vCUPhe::parseEvents() {
+ OSystem::Event event;
+
+ while (_system->pollEvent(event)) {
+ switch (event.type) {
+ case OSystem::EVENT_QUIT:
+ _quit = true;
+ break;
+
+ default:
+ break;
+ }
+ }
+}
+
#endif
#ifndef DISABLE_SCUMM_7_8
@@ -868,7 +914,7 @@ int ScummEngine::init() {
#endif
- // The kGenAsIs method is only used for 'container files', i.e. files
+ // The kGenUnchanged method is only used for 'container files', i.e. files
// that contain the real game files bundled together in an archive format.
// This is the case of the NES, C64 and Mac versions of certain games.
// Note: All of these can also occur in 'extracted' form, in which case they
@@ -957,7 +1003,7 @@ int ScummEngine::init() {
_fileHandle->close();
} else {
- error("kGenAsIs used with unsupported platform");
+ error("kGenUnchanged used with unsupported platform");
}
} else {
// Regular access, no container file involved
diff --git a/engines/scumm/scumm.h b/engines/scumm/scumm.h
index d1141c5669..a1c36b47f0 100644
--- a/engines/scumm/scumm.h
+++ b/engines/scumm/scumm.h
@@ -235,7 +235,8 @@ enum ScummGameId {
GID_PUTTRACE,
GID_FUNSHOP, // Used for all three funshops
GID_FOOTBALL,
- GID_SOCCER
+ GID_SOCCER,
+ GID_HECUP // CUP demos
};
struct SentenceTab {