diff options
| author | Torbjörn Andersson | 2004-04-20 07:10:13 +0000 |
|---|---|---|
| committer | Torbjörn Andersson | 2004-04-20 07:10:13 +0000 |
| commit | ac967bde630457fbaf2220145ee048abda652cfe (patch) | |
| tree | bef66caa7aed3524a44c36fad53a04de17944e93 | |
| parent | 9defe4fc1880ab8926c5cdf167f35985c7ee9afc (diff) | |
| download | scummvm-rg350-ac967bde630457fbaf2220145ee048abda652cfe.tar.gz scummvm-rg350-ac967bde630457fbaf2220145ee048abda652cfe.tar.bz2 scummvm-rg350-ac967bde630457fbaf2220145ee048abda652cfe.zip | |
Increased _numNewNames from 50 to 100 to prevent overflow in MI2 endgame.
This should fix bug #936323. (There are still some game versions that use
50, but that can be fixed later, if the need arises.)
svn-id: r13598
| -rw-r--r-- | scumm/resource.cpp | 3 | ||||
| -rw-r--r-- | scumm/saveload.cpp | 8 |
2 files changed, 9 insertions, 2 deletions
diff --git a/scumm/resource.cpp b/scumm/resource.cpp index 4dbd1ff6af..d204df526d 100644 --- a/scumm/resource.cpp +++ b/scumm/resource.cpp @@ -2111,7 +2111,8 @@ void ScummEngine::readMAXS() { _numLocalObjects = _fileHandle.readUint16LE(); // 200 _numArray = 50; _numVerbs = 100; - _numNewNames = 50; + // Used to be 50, which wasn't enough for MI2. See bug #936323. + _numNewNames = 100; _objectRoomTable = NULL; _fileHandle.readUint16LE(); // 50 diff --git a/scumm/saveload.cpp b/scumm/saveload.cpp index cea086a5b6..51a090b87a 100644 --- a/scumm/saveload.cpp +++ b/scumm/saveload.cpp @@ -823,7 +823,13 @@ void ScummEngine::saveLoadResource(Serializer *ser, int type, int idx) { _inventory[idx] = ser->loadUint16(); } if (type == rtObjectName && ser->getVersion() >= VER(25)) { - _newNames[idx] = ser->loadUint16(); + // Paranoia: We increased the possible number of new names + // for MI2 to fix bug #936323. The savegame format didn't + // change, but at least during the transition period there + // is a slight chance that we try to load more names than + // we have allocated space for. If so, discard them. + if (idx < _numNewNames) + _newNames[idx] = ser->loadUint16(); } } } |
