mirror of
https://github.com/ZDoom/gzdoom.git
synced 2024-12-01 00:12:27 +00:00
Merge branch 'master' of https://github.com/raa-eruanna/qzdoom into qzdoom
This commit is contained in:
commit
e0f1fc4066
1 changed files with 14 additions and 0 deletions
|
@ -238,6 +238,7 @@ TArray<PClassActor *> TouchedActors;
|
|||
|
||||
char *UnchangedSpriteNames;
|
||||
int NumUnchangedSprites;
|
||||
bool changedStates;
|
||||
|
||||
// Sprite<->Class map for ADehackedPickup::DetermineType
|
||||
static struct DehSpriteMap
|
||||
|
@ -988,6 +989,7 @@ static int PatchThing (int thingy)
|
|||
{
|
||||
statedef.MakeStateDefines(type);
|
||||
patchedStates = true;
|
||||
changedStates = true;
|
||||
}
|
||||
|
||||
if (!strnicmp (Line1, "Initial", 7))
|
||||
|
@ -1460,6 +1462,7 @@ static int PatchFrame (int frameNum)
|
|||
else if (keylen == 10 && stricmp (Line1, "Next frame") == 0)
|
||||
{
|
||||
info->NextState = FindState (val);
|
||||
changedStates = true;
|
||||
}
|
||||
else if (keylen == 16 && stricmp (Line1, "Sprite subnumber") == 0)
|
||||
{
|
||||
|
@ -3049,6 +3052,17 @@ void FinishDehPatch ()
|
|||
DPrintf (DMSG_NOTIFY, "%s replaces %s\n", subclass->TypeName.GetChars(), type->TypeName.GetChars());
|
||||
}
|
||||
|
||||
// To avoid errors, flag all potentially touched states for use in weapons.
|
||||
if (changedStates)
|
||||
{
|
||||
for (auto &s : StateMap)
|
||||
{
|
||||
for (auto i = 0; i < s.StateSpan; i++)
|
||||
{
|
||||
s.State[i].UseFlags |= SUF_WEAPON;
|
||||
}
|
||||
}
|
||||
}
|
||||
// Now that all Dehacked patches have been processed, it's okay to free StateMap.
|
||||
StateMap.Clear();
|
||||
StateMap.ShrinkToFit();
|
||||
|
|
Loading…
Reference in a new issue