aboutsummaryrefslogtreecommitdiff
path: root/engines/kyra/resource.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'engines/kyra/resource.cpp')
-rw-r--r--engines/kyra/resource.cpp17
1 files changed, 11 insertions, 6 deletions
diff --git a/engines/kyra/resource.cpp b/engines/kyra/resource.cpp
index 2425444be1..cb484b6183 100644
--- a/engines/kyra/resource.cpp
+++ b/engines/kyra/resource.cpp
@@ -42,11 +42,11 @@
namespace Kyra {
namespace {
-struct ResFilenameEqual : public Common::BinaryFunction<ResourceFile*, uint, bool> {
+struct ResFilenameEqual : public Common::UnaryFunction<ResourceFile*, bool> {
uint _filename;
ResFilenameEqual(uint file) : _filename(file) {}
- bool operator()(ResourceFile *f) {
+ bool operator()(const ResourceFile *f) {
return f->filename() == _filename;
}
};
@@ -220,8 +220,11 @@ uint8 *Resource::fileData(const char *file, uint32 *size) const {
bool Resource::getFileHandle(const char *file, uint32 *size, Common::File &filehandle) {
filehandle.close();
- if (filehandle.open(file))
+ if (filehandle.open(file)) {
+ if (size)
+ *size = filehandle.size();
return true;
+ }
uint fileHash = Common::hashit_lower(file);
for (ResIterator start = _pakfiles.begin() ;start != _pakfiles.end(); ++start) {
@@ -229,12 +232,14 @@ bool Resource::getFileHandle(const char *file, uint32 *size, Common::File &fileh
continue;
if ((*start)->getFileHandle(fileHash, filehandle)) {
-
- *size = (*start)->getFileSize(fileHash);
+ uint32 tSize = (*start)->getFileSize(fileHash);
- if (!(*size))
+ if (!tSize)
continue;
+ if (size)
+ *size = tSize;
+
return true;
}
}