[Scummvm-cvs-logs] SF.net SVN: scummvm:[34925] scummvm/trunk/common

fingolfin at users.sourceforge.net fingolfin at users.sourceforge.net
Fri Nov 7 11:14:57 CET 2008


Revision: 34925
          http://scummvm.svn.sourceforge.net/scummvm/?rev=34925&view=rev
Author:   fingolfin
Date:     2008-11-07 10:14:57 +0000 (Fri, 07 Nov 2008)

Log Message:
-----------
Refactoring the Arj decoder code, phase 4 (done for now, TODO added for future work)

Modified Paths:
--------------
    scummvm/trunk/common/unarj.cpp
    scummvm/trunk/common/unarj.h

Modified: scummvm/trunk/common/unarj.cpp
===================================================================
--- scummvm/trunk/common/unarj.cpp	2008-11-07 09:57:54 UTC (rev 34924)
+++ scummvm/trunk/common/unarj.cpp	2008-11-07 10:14:57 UTC (rev 34925)
@@ -87,13 +87,22 @@
 	uint32 headerCrc;
 };
 
+static int32 findHeader(SeekableReadStream &stream);
+static ArjHeader *readHeader(SeekableReadStream &stream);
+
 class ArjDecoder {
 public:
-	int32 findHeader(SeekableReadStream &stream);
-	ArjHeader *readHeader(SeekableReadStream &stream);
+	ArjDecoder(const ArjHeader *hdr) {
+		_compsize = hdr->compSize;
+	}
+	
+	~ArjDecoder() {
+		delete _compressed;
+		delete _outstream;
+	}
 
-	void decode();
-	void decode_f();
+	void decode(int32 origsize);
+	void decode_f(int32 origsize);
 
 	MemoryReadStream *_compressed;
 	MemoryWriteStream *_outstream;
@@ -102,7 +111,6 @@
 	uint16 _bitbuf;
 	uint16 _bytebuf;
 	int32 _compsize;
-	int32 _origsize;
 	byte _subbitbuf;
 	int _bitcount;
 
@@ -181,7 +189,6 @@
 }
 
 ArjFile::ArjFile() : _uncompressed(0) {
-	_decoder = new ArjDecoder;
 	InitCRC();
 	_fallBack = false;
 }
@@ -191,8 +198,6 @@
 
 	for (uint i = 0; i < _headers.size(); i++)
 		delete _headers[i];
-	
-	delete _decoder;
 }
 
 void ArjFile::registerArchive(const String &filename) {
@@ -203,7 +208,7 @@
 	if (!archiveFile.open(filename))
 		return;
 
-	first_hdr_pos = _decoder->findHeader(archiveFile);
+	first_hdr_pos = findHeader(archiveFile);
 
 	if (first_hdr_pos < 0) {
 		warning("ArjFile::registerArchive(): Could not find a valid header");
@@ -211,10 +216,10 @@
 	}
 
 	archiveFile.seek(first_hdr_pos, SEEK_SET);
-	if (_decoder->readHeader(archiveFile) == NULL)
+	if (readHeader(archiveFile) == NULL)
 		return;
 
-	while ((header = _decoder->readHeader(archiveFile)) != NULL) {
+	while ((header = readHeader(archiveFile)) != NULL) {
 		_headers.push_back(header);
 
 		archiveFile.seek(header->compSize, SEEK_CUR);
@@ -230,7 +235,7 @@
 // Source for findHeader and readHeader: arj_arcv.c
 //
 
-int32 ArjDecoder::findHeader(SeekableReadStream &stream) {
+int32 findHeader(SeekableReadStream &stream) {
 	long end_pos, tmp_pos;
 	int id;
 	byte header[HEADERSIZE_MAX];
@@ -269,7 +274,7 @@
 	return -1;
 }
 
-ArjHeader *ArjDecoder::readHeader(SeekableReadStream &stream) {
+ArjHeader *readHeader(SeekableReadStream &stream) {
 	ArjHeader header;
 	ArjHeader *head;
 	byte headData[HEADERSIZE_MAX];
@@ -354,38 +359,34 @@
 		return false;
 
 	ArjHeader *hdr = _headers[_fileMap[filename]];
+	byte *uncompressedData = (byte *)malloc(hdr->origSize);
 
-	_decoder->_compsize = hdr->compSize;
-	_decoder->_origsize = hdr->origSize;
-
-	byte *uncompressedData = (byte *)malloc(_decoder->_origsize);
-	_decoder->_outstream = new MemoryWriteStream(uncompressedData, _decoder->_origsize);
-
 	File archiveFile;
 	archiveFile.open(_archMap[filename]);
 	archiveFile.seek(hdr->pos, SEEK_SET);
 
 	if (hdr->method == 0) { // store
-        archiveFile.read(uncompressedData, _decoder->	_origsize);
+        int32 len = archiveFile.read(uncompressedData, hdr->origSize);
+        assert(len == hdr->origSize);
 	} else {
-		byte *_compressedData = (byte *)malloc(_decoder->_compsize);
-		archiveFile.read(_compressedData, _decoder->_compsize);
+		ArjDecoder *decoder = new ArjDecoder(hdr);
 
-		_decoder->_compressed = new MemoryReadStream(_compressedData, _decoder->_compsize);
+		byte *compressedData = (byte *)malloc(hdr->compSize);
+		archiveFile.read(compressedData, hdr->compSize);
 
+		decoder->_compressed = new MemoryReadStream(compressedData, hdr->compSize, true);
+		decoder->_outstream = new MemoryWriteStream(uncompressedData, hdr->origSize);
+
 		if (hdr->method == 1 || hdr->method == 2 || hdr->method == 3)
-			_decoder->decode();
+			decoder->decode(hdr->origSize);
 		else if (hdr->method == 4)
-			_decoder->decode_f();
-
-		delete _decoder->_compressed;
-		free(_compressedData);
+			decoder->decode_f(hdr->origSize);
+		
+		delete decoder;
 	}
 
-	delete _decoder->_outstream;
-	_decoder->_outstream = NULL;
 
-	_uncompressed = new MemoryReadStream(uncompressedData, _decoder->_origsize, true);
+	_uncompressed = new MemoryReadStream(uncompressedData, hdr->origSize, true);
 	assert(_uncompressed);
 
 	return true;
@@ -680,7 +681,7 @@
 }
 
 // Decodes the entire file
-void ArjDecoder::decode() {
+void ArjDecoder::decode(int32 origsize) {
 	int16 i;
 	int16 r;
 	int16 c;
@@ -688,7 +689,7 @@
 	int32 count;
 
 	decode_start();
-	count = _origsize;
+	count = origsize;
 	r = 0;
 
 	while (count > 0) {
@@ -770,7 +771,7 @@
 }
 
 // Decodes the entire file, using method 4
-void ArjDecoder::decode_f() {
+void ArjDecoder::decode_f(int32 origsize) {
 	int16 i;
 	int16 j;
 	int16 c;
@@ -782,7 +783,7 @@
 	_getlen = _getbuf = 0;
 	r = 0;
 
-	while (ncount < (uint32)_origsize) {
+	while (ncount < (uint32)origsize) {
 		c = decode_len();
 		if (c == 0) {
 			ncount++;

Modified: scummvm/trunk/common/unarj.h
===================================================================
--- scummvm/trunk/common/unarj.h	2008-11-07 09:57:54 UTC (rev 34924)
+++ scummvm/trunk/common/unarj.h	2008-11-07 10:14:57 UTC (rev 34925)
@@ -32,10 +32,11 @@
 namespace Common {
 
 struct ArjHeader;
-class ArjDecoder;
 
 typedef HashMap<String, int, IgnoreCase_Hash, IgnoreCase_EqualTo> ArjFilesMap;
 
+// TODO: Get rid of this class, by implementing an ArjArchive subclass of Common::Archive.
+// Then ArjFile can be substituted by a SearchSet full of ArjArchives plus SearchMan.
 class ArjFile : public SeekableReadStream, public NonCopyable {
 public:
 	ArjFile();
@@ -63,8 +64,6 @@
 	StringMap _archMap;
 
 	SeekableReadStream *_uncompressed;
-
-	ArjDecoder *_decoder;
 };
 
 } // End of namespace Common


This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.




More information about the Scummvm-git-logs mailing list