aboutsummaryrefslogtreecommitdiff
path: root/engines/sci/engine/savegame.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'engines/sci/engine/savegame.cpp')
-rw-r--r--engines/sci/engine/savegame.cpp14
1 files changed, 9 insertions, 5 deletions
diff --git a/engines/sci/engine/savegame.cpp b/engines/sci/engine/savegame.cpp
index 433878429e..427e32deb3 100644
--- a/engines/sci/engine/savegame.cpp
+++ b/engines/sci/engine/savegame.cpp
@@ -104,10 +104,6 @@ void syncWithSerializer(Common::Serializer &s, Node &obj) {
syncWithSerializer(s, obj.value);
}
-void syncWithSerializer(Common::Serializer &s, bool &obj) {
- s.syncAsByte(obj);
-}
-
#pragma mark -
// By default, sync using syncWithSerializer, which in turn can easily be overloaded.
@@ -427,12 +423,20 @@ void Object::saveLoadWithSerializer(Common::Serializer &s) {
s.syncAsSint32LE(_methodCount); // that's actually a uint16
syncArray<reg_t>(s, _variables);
+
+#ifdef ENABLE_SCI32
if (s.getVersion() >= 42 && getSciVersion() == SCI_VERSION_3) {
- syncArray<bool>(s, _mustSetViewVisible);
+ // Obsolete mustSetViewVisible array
+ if (s.getVersion() == 42 && s.isLoading()) {
+ uint32 len;
+ s.syncAsUint32LE(len);
+ s.skip(len);
+ }
syncWithSerializer(s, _superClassPosSci3);
syncWithSerializer(s, _speciesSelectorSci3);
syncWithSerializer(s, _infoSelectorSci3);
}
+#endif
}