aboutsummaryrefslogtreecommitdiff
path: root/engines/wintermute/base/base_file_manager.cpp
diff options
context:
space:
mode:
authorEinar Johan Trøan Sømåen2013-03-23 18:08:08 +0100
committerEinar Johan Trøan Sømåen2013-03-24 17:41:10 +0100
commitdedde93d1e2b2595e874ae5055a9426579476f13 (patch)
treeb7f6e6489f005d2324b46ad63ac7d9efc85ef224 /engines/wintermute/base/base_file_manager.cpp
parent94893636e421a4c90d7a443e3cdb9ff241ed8953 (diff)
downloadscummvm-rg350-dedde93d1e2b2595e874ae5055a9426579476f13.tar.gz
scummvm-rg350-dedde93d1e2b2595e874ae5055a9426579476f13.tar.bz2
scummvm-rg350-dedde93d1e2b2595e874ae5055a9426579476f13.zip
WINTERMUTE: Avoid REQUIRING wintermute.zip during detection.
Diffstat (limited to 'engines/wintermute/base/base_file_manager.cpp')
-rw-r--r--engines/wintermute/base/base_file_manager.cpp19
1 files changed, 12 insertions, 7 deletions
diff --git a/engines/wintermute/base/base_file_manager.cpp b/engines/wintermute/base/base_file_manager.cpp
index 08358f9033..28e0b3af6e 100644
--- a/engines/wintermute/base/base_file_manager.cpp
+++ b/engines/wintermute/base/base_file_manager.cpp
@@ -53,7 +53,8 @@ namespace Wintermute {
//////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////
-BaseFileManager::BaseFileManager(Common::Language lang) {
+BaseFileManager::BaseFileManager(Common::Language lang, bool detectionMode) {
+ _detectionMode = detectionMode;
_language = lang;
_resources = nullptr;
initResources();
@@ -232,12 +233,14 @@ bool BaseFileManager::registerPackage(Common::FSNode file, const Common::String
void BaseFileManager::initResources() {
_resources = Common::makeZipArchive("wintermute.zip");
- if (!_resources) {
+ if (!_resources && !_detectionMode) { // Wintermute.zip is unavailable during detection
error("Couldn't load wintermute.zip");
}
- assert(_resources->hasFile("syste_font.bmp"));
- assert(_resources->hasFile("invalid.bmp"));
- assert(_resources->hasFile("invalid_debug.bmp"));
+ if (_resources) {
+ assert(_resources->hasFile("syste_font.bmp"));
+ assert(_resources->hasFile("invalid.bmp"));
+ assert(_resources->hasFile("invalid_debug.bmp"));
+ }
}
//////////////////////////////////////////////////////////////////////////
@@ -277,7 +280,7 @@ bool BaseFileManager::hasFile(const Common::String &filename) {
if (_packages.hasFile(filename)) {
return true; // We don't bother checking if the file can actually be opened, something bigger is wrong if that is the case.
}
- if (_resources->hasFile(filename)) {
+ if (!_detectionMode && _resources->hasFile(filename)) {
return true;
}
return false;
@@ -337,7 +340,9 @@ Common::SeekableReadStream *BaseFileManager::openFileRaw(const Common::String &f
return ret;
}
- ret = _resources->createReadStreamForMember(filename);
+ if (!_detectionMode) {
+ ret = _resources->createReadStreamForMember(filename);
+ }
if (ret) {
return ret;
}