* Fixed the Link + Duplicate + Unlink both = 'ODE Invalid Argument in Collision Space Crash'

* Added: Console comment: [PHYSICS]: The scene reused a disposed PhysActor! *waves finger*, Don't be evil.
0.6.0-stable
Teravus Ovares 2008-03-09 16:32:44 +00:00
parent 081b2ac34e
commit 5b6eba968b
2 changed files with 39 additions and 27 deletions

View File

@ -701,7 +701,8 @@ namespace OpenSim.Region.Physics.OdePlugin
{ {
changeadd(timestep); changeadd(timestep);
} }
if (prim_geom != (IntPtr)0)
{
if (m_taintposition != _position) if (m_taintposition != _position)
Move(timestep); Move(timestep);
@ -736,6 +737,11 @@ namespace OpenSim.Region.Physics.OdePlugin
if (m_taintparent != _parent) if (m_taintparent != _parent)
changelink(timestep); changelink(timestep);
} }
else
{
m_log.Error("[PHYISCS]: The scene reused a disposed PhysActor! *waves finger*, Don't be evil.");
}
}
private void changelink(float timestep) private void changelink(float timestep)
{ {

View File

@ -238,6 +238,7 @@ namespace OpenSim.Region.Physics.OdePlugin
internal void waitForSpaceUnlock(IntPtr space) internal void waitForSpaceUnlock(IntPtr space)
{ {
if (space != (IntPtr)0)
while (d.SpaceLockQuery(space)){ } // Wait and do nothing while (d.SpaceLockQuery(space)){ } // Wait and do nothing
} }
@ -1014,6 +1015,11 @@ namespace OpenSim.Region.Physics.OdePlugin
System.Threading.Thread.Sleep(20); System.Threading.Thread.Sleep(20);
if (currentspace != space) if (currentspace != space)
{ {
m_log.Info("[SPACE]: C:" + currentspace.ToString() + " g:" + geom.ToString());
if (currentspace == (IntPtr) 0)
{
int adfadf = 0;
}
if (d.SpaceQuery(currentspace, geom) && currentspace != (IntPtr) 0) if (d.SpaceQuery(currentspace, geom) && currentspace != (IntPtr) 0)
{ {
if (d.GeomIsSpace(currentspace)) if (d.GeomIsSpace(currentspace))