diff options
| -rw-r--r-- | engines/director/cast.cpp | 9 | ||||
| -rw-r--r-- | engines/director/score.cpp | 2 | 
2 files changed, 10 insertions, 1 deletions
diff --git a/engines/director/cast.cpp b/engines/director/cast.cpp index 667fc248ea..892ac48f8c 100644 --- a/engines/director/cast.cpp +++ b/engines/director/cast.cpp @@ -45,6 +45,15 @@ BitmapCast::BitmapCast(Common::ReadStreamEndian &stream, uint16 version) {  		boundingRect = Score::readRect(stream);  		regX = stream.readUint16();  		regY = stream.readUint16(); + +		int tail = 0; + +		while (!stream.eos()) { +			stream.readByte(); +			tail++; +		} + +		warning("BitmapCast: %d bytes left", tail);  	}  	modified = 0;  } diff --git a/engines/director/score.cpp b/engines/director/score.cpp index 819ae26830..8a80e30765 100644 --- a/engines/director/score.cpp +++ b/engines/director/score.cpp @@ -436,7 +436,7 @@ void Score::loadCastData(Common::SeekableSubReadStreamEndian &stream, uint16 id)  	debugC(3, kDebugLoading, "CASt: id: %d type: %x size1: %d size2: %d (%x) size3: %d unk1: %d unk2: %d unk3: %d",  				id, castType, size1, size2, size2, size3, unk1, unk2, unk3); -	byte *data = (byte *)calloc(size1 + 16, 1); +	byte *data = (byte *)calloc(size1, 1); // 16 is for bounding rects  	stream.read(data, size1 + 16);  	Common::MemoryReadStreamEndian castStream(data, size1 + 16, stream.isBE());  | 
