mirror of
https://github.com/libretro/scummvm.git
synced 2024-12-24 02:36:27 +00:00
Fix for some cases where the protagonist from some savegames in IHNM was not loaded correctly
svn-id: r28596
This commit is contained in:
parent
985ac6ceaa
commit
d5b7a57536
@ -305,11 +305,14 @@ void SagaEngine::load(const char *fileName) {
|
||||
if (getGameType() != GType_ITE) {
|
||||
if (_scene->currentProtag() != 0 && _scene->currentChapterNumber() != 6) {
|
||||
ActorData *actor1 = _actor->getFirstActor();
|
||||
// Original stores the current protagonist ID from sfSwapActors:
|
||||
//ActorData *actor2 = _actor->getActor(_scene->currentProtag());
|
||||
// However, we already store the protagonist, so merely getting the saved
|
||||
// protagonist is easier and safer, and works without glitches
|
||||
ActorData *actor2 = _actor->_protagonist;
|
||||
ActorData *actor2;
|
||||
// The original gets actor2 from the current protagonist ID, but this is sometimes wrong
|
||||
// If the current protagonist ID is not correct, use the stored protagonist
|
||||
if (!_actor->validActorId(_scene->currentProtag())) {
|
||||
actor2 = _actor->_protagonist;
|
||||
} else {
|
||||
actor2 = _actor->getActor(_scene->currentProtag());
|
||||
}
|
||||
|
||||
SWAP(actor1->_location, actor2->_location);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user