- fixed incomplete savegame restoration from inside the game.

This now quits the game loop instead of trying to set up the loaded level from inside it.
This commit is contained in:
Christoph Oelckers 2020-02-01 10:50:40 +01:00
parent ab3811bac0
commit 77ad7dfb81
3 changed files with 18 additions and 9 deletions

View file

@ -258,7 +258,7 @@ DoActorNoise(ANIMATORp Action, short SpriteNum)
PlaySpriteSound(SpriteNum, attr_attack, v3df_follow); PlaySpriteSound(SpriteNum, attr_attack, v3df_follow);
// MONO_PRINT("Attack Sound"); // MONO_PRINT("Attack Sound");
} }
if (Action == InitActorPainNoise) else if (Action == InitActorPainNoise)
{ {
PlaySpriteSound(SpriteNum, attr_pain, v3df_follow); PlaySpriteSound(SpriteNum, attr_pain, v3df_follow);
// MONO_PRINT("Pain Sound"); // MONO_PRINT("Pain Sound");
@ -280,15 +280,15 @@ DoActorNoise(ANIMATORp Action, short SpriteNum)
{ {
PlaySpriteSound(SpriteNum, attr_extra3, v3df_follow); PlaySpriteSound(SpriteNum, attr_extra3, v3df_follow);
} }
if (Action == InitActorExtra4Noise) else if (Action == InitActorExtra4Noise)
{ {
PlaySpriteSound(SpriteNum, attr_extra4, v3df_follow); PlaySpriteSound(SpriteNum, attr_extra4, v3df_follow);
} }
if (Action == InitActorExtra5Noise) else if (Action == InitActorExtra5Noise)
{ {
PlaySpriteSound(SpriteNum, attr_extra5, v3df_follow); PlaySpriteSound(SpriteNum, attr_extra5, v3df_follow);
} }
if (Action == InitActorExtra6Noise) else if (Action == InitActorExtra6Noise)
{ {
PlaySpriteSound(SpriteNum, attr_extra6, v3df_follow); PlaySpriteSound(SpriteNum, attr_extra6, v3df_follow);
} }

View file

@ -1018,14 +1018,14 @@ InitLevel(void)
// A few IMPORTANT GLOBAL RESETS // A few IMPORTANT GLOBAL RESETS
InitLevelGlobals(); InitLevelGlobals();
if (!DemoMode)
Mus_Stop();
if (LoadGameOutsideMoveLoop) if (LoadGameOutsideMoveLoop)
{ {
return; return;
} }
if (!DemoMode)
Mus_Stop();
InitLevelGlobals2(); InitLevelGlobals2();
if (DemoMode) if (DemoMode)
{ {
@ -1359,8 +1359,12 @@ void NewLevel(void)
} }
else else
{ {
InitLevel(); do
RunLevel(); {
InitLevel();
RunLevel();
}
while (LoadGameOutsideMoveLoop);
STAT_Update(false); STAT_Update(false);
if (!QuitFlag) if (!QuitFlag)
@ -2629,6 +2633,10 @@ void RunLevel(void)
OSD_DispatchQueued(); OSD_DispatchQueued();
D_ProcessEvents(); D_ProcessEvents();
faketimerhandler(); faketimerhandler();
if (LoadGameOutsideMoveLoop)
{
return;
}
if (M_Active()) if (M_Active())
{ {

View file

@ -2096,6 +2096,7 @@ int _PlaySound(int num, SPRITEp sprite, PLAYERp player, vec3_t *pos, Voc3D_Flags
void InitAmbient(int num, SPRITEp sprite); void InitAmbient(int num, SPRITEp sprite);
inline void PlaySound(int num, SPRITEp sprite, Voc3D_Flags flags, int channel = 8) inline void PlaySound(int num, SPRITEp sprite, Voc3D_Flags flags, int channel = 8)
{ {
assert(num != DIGI_NINJAPAIN);
_PlaySound(num, sprite, nullptr, nullptr, flags, channel); _PlaySound(num, sprite, nullptr, nullptr, flags, channel);
} }
inline void PlaySound(int num, PLAYERp player, Voc3D_Flags flags, int channel = 8) inline void PlaySound(int num, PLAYERp player, Voc3D_Flags flags, int channel = 8)