aboutsummaryrefslogtreecommitdiff
path: root/engines/fullpipe/utils.h
diff options
context:
space:
mode:
authorEugene Sandulenko2016-09-18 00:59:17 +0200
committerEugene Sandulenko2016-09-18 00:59:17 +0200
commitf0d786184bb9b3cfefc16fb2be87d6c6d1017160 (patch)
tree906b396bf2634063e1ded6e3daa86317af5474e1 /engines/fullpipe/utils.h
parentd9457c2f07f22dae83b6702fa7b616aa41696a7f (diff)
downloadscummvm-rg350-f0d786184bb9b3cfefc16fb2be87d6c6d1017160.tar.gz
scummvm-rg350-f0d786184bb9b3cfefc16fb2be87d6c6d1017160.tar.bz2
scummvm-rg350-f0d786184bb9b3cfefc16fb2be87d6c6d1017160.zip
FULLPIPE: Properly save object backreferences
Diffstat (limited to 'engines/fullpipe/utils.h')
-rw-r--r--engines/fullpipe/utils.h18
1 files changed, 18 insertions, 0 deletions
diff --git a/engines/fullpipe/utils.h b/engines/fullpipe/utils.h
index 5de919d383..44bda68cac 100644
--- a/engines/fullpipe/utils.h
+++ b/engines/fullpipe/utils.h
@@ -32,12 +32,30 @@ namespace Fullpipe {
class CObject;
class NGIArchive;
+struct Pointer_EqualTo {
+ bool operator()(const void *x, const void *y) const { return x == y; }
+};
+
+struct Pointer_Hash {
+ uint operator()(const void *x) const {
+#ifdef SCUMM_64BITS
+ uint64 v = (uint64)x;
+ return (v >> 32) ^ (v & 0xffffffff);
+#else
+ return (uint)x;
+#endif
+ }
+};
+
+typedef Common::HashMap<void *, int, Pointer_Hash, Pointer_EqualTo> ObjHash;
+
typedef Common::HashMap<Common::String, int, Common::IgnoreCase_Hash, Common::IgnoreCase_EqualTo> ClassMap;
class MfcArchive : public Common::SeekableReadStream, public Common::WriteStream {
ClassMap _classMap;
Common::Array<CObject *> _objectMap;
Common::Array<int> _objectIdMap;
+ ObjHash _objectHash;
int _lastIndex;
int _level;