aboutsummaryrefslogtreecommitdiff
path: root/engines/fullpipe/stateloader.cpp
diff options
context:
space:
mode:
authoranotherguest2014-06-12 10:01:26 +0200
committeranotherguest2014-06-12 10:01:26 +0200
commit17edab101b2a2561e92c71c9538aff7c2e7bd343 (patch)
tree5df1f7a919c5022caa69e83fd4304bbb39601c1a /engines/fullpipe/stateloader.cpp
parentc2debe028de42db324289deefbe23697c95bbae4 (diff)
parent18242b8a2997435353b9c2cfdccb0f4905c443ce (diff)
downloadscummvm-rg350-17edab101b2a2561e92c71c9538aff7c2e7bd343.tar.gz
scummvm-rg350-17edab101b2a2561e92c71c9538aff7c2e7bd343.tar.bz2
scummvm-rg350-17edab101b2a2561e92c71c9538aff7c2e7bd343.zip
Merge branch 'master' of github.com:scummvm/scummvm
Diffstat (limited to 'engines/fullpipe/stateloader.cpp')
-rw-r--r--engines/fullpipe/stateloader.cpp38
1 files changed, 37 insertions, 1 deletions
diff --git a/engines/fullpipe/stateloader.cpp b/engines/fullpipe/stateloader.cpp
index 41641457d3..141196c7d7 100644
--- a/engines/fullpipe/stateloader.cpp
+++ b/engines/fullpipe/stateloader.cpp
@@ -162,7 +162,43 @@ GameVar::GameVar() {
}
GameVar::~GameVar() {
- warning("STUB: GameVar::~GameVar()");
+ if (_varType == 2)
+ free(_value.stringValue);
+
+ if (_parentVarObj && !_prevVarObj ) {
+ if (_parentVarObj->_subVars == this) {
+ _parentVarObj->_subVars = _nextVarObj;
+ } else if (_parentVarObj->_field_14 == this) {
+ _parentVarObj->_field_14 = _nextVarObj;
+ } else {
+ _parentVarObj = 0;
+ }
+ }
+
+ if (_prevVarObj)
+ _prevVarObj->_nextVarObj = _nextVarObj;
+
+ if (_nextVarObj)
+ _nextVarObj->_prevVarObj = _prevVarObj;
+
+ _prevVarObj = 0;
+ _nextVarObj = 0;
+
+ GameVar *s = _subVars;
+
+ while (s) {
+ delete s;
+ s = _subVars;
+ }
+
+ s = _field_14;
+
+ while (s) {
+ delete s;
+ s = _field_14;
+ }
+
+ free(_varName);
}
bool GameVar::load(MfcArchive &file) {