[Scummvm-git-logs] scummvm master -> 75ea458e0ff533380134a657e0354d45e72950f5

whiterandrek whiterandrek at gmail.com
Sat Oct 10 21:20:44 UTC 2020


This automated email contains information about 2 new commits which have been
pushed to the 'scummvm' repo located at https://github.com/scummvm/scummvm .

Summary:
8a660c646b PETKA: refactor FileMgr
75ea458e0f PETKA: fix walk bug


Commit: 8a660c646be4d12e22ffad766e169217d3fa51e0
    https://github.com/scummvm/scummvm/commit/8a660c646be4d12e22ffad766e169217d3fa51e0
Author: Andrei Prykhodko (whiterandrek at gmail.com)
Date: 2020-10-11T00:19:27+03:00

Commit Message:
PETKA: refactor FileMgr

Changed paths:
    engines/petka/file_mgr.cpp
    engines/petka/file_mgr.h


diff --git a/engines/petka/file_mgr.cpp b/engines/petka/file_mgr.cpp
index 66c8ffa53d..a08fc8898f 100644
--- a/engines/petka/file_mgr.cpp
+++ b/engines/petka/file_mgr.cpp
@@ -29,13 +29,8 @@
 
 namespace Petka {
 
-FileMgr::~FileMgr() {
-	debug("FileMgr::dtor");
-	closeAll();
-}
-
 bool FileMgr::openStore(const Common::String &name) {
-	Common::ScopedPtr<Common::File> file(new Common::File());
+	Common::SharedPtr<Common::File> file(new Common::File());
 	if (name.empty() || !file->open(name) || file->readUint32BE() != MKTAG('S', 't', 'O', 'R')) {
 		return false;
 	}
@@ -45,45 +40,45 @@ bool FileMgr::openStore(const Common::String &name) {
 		return false;
 	}
 
+	const uint32 tableSize = file->size() - file->pos();
+
+	Common::ScopedPtr<Common::SeekableReadStream> stream(file->readStream(tableSize));
+	if (stream->size() != (int)tableSize)
+		return false;
+
 	_stores.push_back(Store());
+
 	Store &store = _stores.back();
-	store.descriptions.resize(file->readUint32LE());
+	store.file = file;
+	store.descriptions.resize(stream->readUint32LE());
 
-	for (uint i = 0; i < store.descriptions.size(); ++i) {
-		file->skip(4);
-		store.descriptions[i].offset = file->readUint32LE();
-		store.descriptions[i].size = file->readUint32LE();
+	for (auto &description : store.descriptions) {
+		stream->skip(4);
+		description.offset = stream->readUint32LE();
+		description.size = stream->readUint32LE();
 	}
 
-	for (uint i = 0; i < store.descriptions.size(); ++i) {
+	for (auto &description : store.descriptions) {
 		char ch;
-		while ((ch = file->readByte()) != 0) {
-			store.descriptions[i].name += ch;
+		while ((ch = stream->readByte()) != '\0') {
+			description.name += ch;
 		}
 	}
-	store.file = file.release();
-
-	debug("FileMgr: opened store %s (files count: %d)", name.c_str(), store.descriptions.size());
 
+	debugC(kPetkaDebugResources, "FileMgr: opened store %s (files count: %d)", name.c_str(), store.descriptions.size());
 	return true;
 }
 
 void FileMgr::closeStore(const Common::String &name) {
-	for (uint i = 0; i < _stores.size(); ++i) {
-		if (_stores[i].file->getName() == name) {
-			delete _stores[i].file;
-			_stores.remove_at(i);
+	for (auto it = _stores.begin(); it != _stores.end(); ++it) {
+		if (it->file->getName() == name) {
+			_stores.erase(it);
 			return;
 		}
 	}
-
 }
 
 void FileMgr::closeAll() {
-	debug("FileMgr::closeAll");
-	for (uint i = 0; i < _stores.size(); ++i) {
-		delete _stores[i].file;
-	}
 	_stores.clear();
 }
 
@@ -102,15 +97,14 @@ Common::SeekableReadStream *FileMgr::getFileStream(const Common::String &name) {
 		debugC(kPetkaDebugResources, "FileMgr: %s is opened from game directory", name.c_str());
 		return file.release();
 	}
-	for (uint i = 0; i < _stores.size(); ++i) {
-		for (uint j = 0; j < _stores[i].descriptions.size(); ++j) {
-			const Description &desc = _stores[i].descriptions[j];
-			if (desc.name.compareToIgnoreCase(name) == 0) {
-				return new Common::SafeSeekableSubReadStream(_stores[i].file, desc.offset, desc.offset + desc.size);
-			}
 
+	for (auto &store : _stores) {
+		for (auto &resource : store.descriptions) {
+			if (resource.name.compareToIgnoreCase(name) == 0)
+				return new Common::SafeSeekableSubReadStream(store.file.get(), resource.offset, resource.offset + resource.size);
 		}
 	}
+
 	debugC(kPetkaDebugResources, "FileMgr: %s not found", name.c_str());
 	return nullptr;
 }
diff --git a/engines/petka/file_mgr.h b/engines/petka/file_mgr.h
index ad2b1e6f25..1eb0d0048c 100644
--- a/engines/petka/file_mgr.h
+++ b/engines/petka/file_mgr.h
@@ -23,7 +23,8 @@
 #ifndef PETKA_FILE_MGR_H
 #define PETKA_FILE_MGR_H
 
-#include "common/array.h"
+#include "common/list.h"
+#include "common/ptr.h"
 
 namespace Common {
 	class File;
@@ -34,8 +35,6 @@ namespace Petka {
 
 class FileMgr {
 public:
-	~FileMgr();
-
 	bool openStore(const Common::String &name);
 	void closeStore(const Common::String &name);
 	void closeAll();
@@ -43,14 +42,14 @@ public:
 	Common::SeekableReadStream *getFileStream(const Common::String &name);
 
 private:
-	struct Description {
+	struct Resource {
 		Common::String name;
 		uint32 offset;
 		uint32 size;
 	};
 	struct Store {
-		Common::File *file;
-		Common::Array<Description> descriptions;
+		Common::SharedPtr<Common::File> file;
+		Common::Array<Resource> descriptions;
 	};
 	Common::Array<Store> _stores;
 };


Commit: 75ea458e0ff533380134a657e0354d45e72950f5
    https://github.com/scummvm/scummvm/commit/75ea458e0ff533380134a657e0354d45e72950f5
Author: Andrei Prykhodko (whiterandrek at gmail.com)
Date: 2020-10-11T00:19:27+03:00

Commit Message:
PETKA: fix walk bug

Changed paths:
    engines/petka/walk.cpp


diff --git a/engines/petka/walk.cpp b/engines/petka/walk.cpp
index 592faa8018..754c31afb6 100644
--- a/engines/petka/walk.cpp
+++ b/engines/petka/walk.cpp
@@ -498,7 +498,7 @@ int Walk::sub_423600(Point p) {
 
 		for (int k = 2; k < _bkg3_1[j]; ++k) {
 			for (int l = 0; l < _bkg3_1[j]; ++l) {
-				if (sub_423570(v4[k - 1], _bkg3_2[j][l]) || v4[k - 2] == _bkg3_2[j][l]) {
+				if (sub_423570(v4[k - 1], _bkg3_2[j][l]) && v4[k - 2] != _bkg3_2[j][l]) {
 					v4[k] = _bkg3_2[j][l];
 					break;
 				}




More information about the Scummvm-git-logs mailing list