At end of G_RestoreMapState(), update g_player[].ps->i from STAT_PLAYER sprites.

This fixes a potential crash caused by violating the expected invariant
 sprite[g_player[player_index].ps->i].yvel == player_index
otherwise.

git-svn-id: https://svn.eduke32.com/eduke32@4114 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2013-10-25 21:57:09 +00:00
parent 335957800b
commit ab7d3679df

View file

@ -5662,6 +5662,19 @@ void G_RestoreMapState(void)
Gv_RefreshPointers(); Gv_RefreshPointers();
#endif #endif
// Update g_player[].ps->i (sprite indices of players) to be consistent
// with just loaded sprites.
// Otherwise, crashes may ensue: e.g. WGR2 SVN r391, map spiderden:
// - walk forward (to door leading to other level "Shadowpine Forest")
// - in new level, walk backward to get back to the Spider Den
// - walk backward to the door leading to Shadowpine Forest --> crash.
for (SPRITES_OF(STAT_PLAYER, i))
{
int32_t snum = sprite[i].yvel;
Bassert((unsigned)snum < MAXPLAYERS);
g_player[snum].ps->i = i;
}
for (i=0; i<playerswhenstarted; i++) for (i=0; i<playerswhenstarted; i++)
sprite[g_player[i].ps->i].extra = phealth[i]; sprite[g_player[i].ps->i].extra = phealth[i];