mirror of
https://github.com/GTAmodding/re3.git
synced 2024-11-15 07:48:59 +00:00
Peds: Efforts to find the reason of crashes on GCC 7.5.0
* Prevent deleted peds to be in nearPeds list (was always needed, might be unrelated to crashes) * Add asserts to nearPeds and PedIK ctor (crash reasons) * Shouldn't fix reported crashes since they were caused by null peds.
This commit is contained in:
parent
70fa7fc239
commit
424a6d90bd
3 changed files with 30 additions and 4 deletions
|
@ -308,6 +308,30 @@ CPed::~CPed(void)
|
||||||
m_pFire->Extinguish();
|
m_pFire->Extinguish();
|
||||||
CPopulation::UpdatePedCount((ePedType)m_nPedType, true);
|
CPopulation::UpdatePedCount((ePedType)m_nPedType, true);
|
||||||
DMAudio.DestroyEntity(m_audioEntityId);
|
DMAudio.DestroyEntity(m_audioEntityId);
|
||||||
|
|
||||||
|
// Because of the nature of ped lists in GTA, it can sometimes be outdated.
|
||||||
|
// Remove ourself from nearPeds list of the Peds in our nearPeds list.
|
||||||
|
#ifdef FIX_BUGS
|
||||||
|
for(int i = 0; i < m_numNearPeds; i++) {
|
||||||
|
CPed *nearPed = m_nearPeds[i];
|
||||||
|
assert(nearPed != nil);
|
||||||
|
if (!nearPed->IsPointerValid())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
for(int j = 0; j < nearPed->m_numNearPeds;) {
|
||||||
|
assert(j == ARRAY_SIZE(m_nearPeds) - 1 || nearPed->m_nearPeds[j] || !nearPed->m_nearPeds[j+1]); // ensure nil comes after nil
|
||||||
|
|
||||||
|
if (nearPed->m_nearPeds[j] == this) {
|
||||||
|
for (int k = j; k < ARRAY_SIZE(m_nearPeds) - 1; k++) {
|
||||||
|
nearPed->m_nearPeds[k] = nearPed->m_nearPeds[k + 1];
|
||||||
|
nearPed->m_nearPeds[k + 1] = nil;
|
||||||
|
}
|
||||||
|
nearPed->m_numNearPeds--;
|
||||||
|
} else
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -398,13 +422,15 @@ CPed::BuildPedLists(void)
|
||||||
} else
|
} else
|
||||||
removePed = true;
|
removePed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert(i == ARRAY_SIZE(m_nearPeds) - 1 || m_nearPeds[i] || !m_nearPeds[i+1]); // ensure nil comes after nil
|
||||||
|
|
||||||
if (removePed) {
|
if (removePed) {
|
||||||
// If we arrive here, the ped we're checking isn't "near", so we should remove it.
|
// If we arrive here, the ped we're checking isn't "near", so we should remove it.
|
||||||
for (int j = i; j < ARRAY_SIZE(m_nearPeds) - 1; j++) {
|
for (int j = i; j < ARRAY_SIZE(m_nearPeds) - 1; j++) {
|
||||||
m_nearPeds[j] = m_nearPeds[j + 1];
|
m_nearPeds[j] = m_nearPeds[j + 1];
|
||||||
m_nearPeds[j + 1] = nil;
|
m_nearPeds[j + 1] = nil;
|
||||||
}
|
}
|
||||||
// Above loop won't work on last slot, so we need to empty it.
|
|
||||||
m_nearPeds[ARRAY_SIZE(m_nearPeds) - 1] = nil;
|
m_nearPeds[ARRAY_SIZE(m_nearPeds) - 1] = nil;
|
||||||
m_numNearPeds--;
|
m_numNearPeds--;
|
||||||
} else
|
} else
|
||||||
|
|
|
@ -17,9 +17,9 @@ const RwV3d XaxisIK = { 1.0f, 0.0f, 0.0f};
|
||||||
const RwV3d YaxisIK = { 0.0f, 1.0f, 0.0f};
|
const RwV3d YaxisIK = { 0.0f, 1.0f, 0.0f};
|
||||||
const RwV3d ZaxisIK = { 0.0f, 0.0f, 1.0f};
|
const RwV3d ZaxisIK = { 0.0f, 0.0f, 1.0f};
|
||||||
|
|
||||||
CPedIK::CPedIK(CPed *ped)
|
CPedIK::CPedIK(CPed *ped) : m_ped(ped)
|
||||||
{
|
{
|
||||||
m_ped = ped;
|
assert(ped != nil);
|
||||||
m_flags = 0;
|
m_flags = 0;
|
||||||
m_headOrient.yaw = 0.0f;
|
m_headOrient.yaw = 0.0f;
|
||||||
m_headOrient.pitch = 0.0f;
|
m_headOrient.pitch = 0.0f;
|
||||||
|
|
|
@ -34,7 +34,7 @@ public:
|
||||||
AIMS_WITH_ARM = 4,
|
AIMS_WITH_ARM = 4,
|
||||||
};
|
};
|
||||||
|
|
||||||
CPed *m_ped;
|
CPed *Const m_ped;
|
||||||
LimbOrientation m_headOrient;
|
LimbOrientation m_headOrient;
|
||||||
LimbOrientation m_torsoOrient;
|
LimbOrientation m_torsoOrient;
|
||||||
LimbOrientation m_upperArmOrient;
|
LimbOrientation m_upperArmOrient;
|
||||||
|
|
Loading…
Reference in a new issue