Browse Source

PhysX conversion code validation at compile-time

Seriously? Offsetof has been around for a long time, and eap added a
compiler_assert for his crazy netcode. There's no excuse for that to be
happening at runtime.
Adam Johnson 12 years ago
parent
commit
9634f9b050
  1. 48
      Sources/Plasma/PubUtilLib/plPhysX/plPXConvert.cpp
  2. 1
      Sources/Plasma/PubUtilLib/plPhysX/plPXConvert.h
  3. 8
      Sources/Plasma/PubUtilLib/plPhysX/plSimulationMgr.cpp

48
Sources/Plasma/PubUtilLib/plPhysX/plPXConvert.cpp

@ -39,44 +39,20 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
Mead, WA 99021 Mead, WA 99021
*==LICENSE==*/ *==LICENSE==*/
#include "plPXConvert.h"
bool plPXConvert::Validate()
{
NxVec3 nxVec;
hsVector3 plVec;
int nxVecXOffset = ((char*)&nxVec.x) - ((char*)&nxVec);
int nxVecYOffset = ((char*)&nxVec.y) - ((char*)&nxVec);
int nxVecZOffset = ((char*)&nxVec.z) - ((char*)&nxVec);
int plVecXOffset = ((char*)&plVec.fX) - ((char*)&plVec); #include "plPXConvert.h"
int plVecYOffset = ((char*)&plVec.fY) - ((char*)&plVec);
int plVecZOffset = ((char*)&plVec.fZ) - ((char*)&plVec);
NxQuat nxQuat;
hsQuat plQuat;
int nxQuatXOffset = ((char*)&nxQuat.x) - ((char*)&nxQuat);
int nxQuatYOffset = ((char*)&nxQuat.y) - ((char*)&nxQuat);
int nxQuatZOffset = ((char*)&nxQuat.z) - ((char*)&nxQuat);
int nxQuatWOffset = ((char*)&nxQuat.w) - ((char*)&nxQuat);
int plQuatXOffset = ((char*)&plQuat.fX) - ((char*)&plQuat); #define CHECK_OFFSET(NxCls, NxMem, hsCls, hsMem) \
int plQuatYOffset = ((char*)&plQuat.fY) - ((char*)&plQuat); static_assert(offsetof(NxCls, NxMem) == offsetof(hsCls, hsMem), \
int plQuatZOffset = ((char*)&plQuat.fZ) - ((char*)&plQuat); "PhysX Conversion Failure: "#NxCls " and " #hsCls " offsets do not match for " #NxMem "!");
int plQuatWOffset = ((char*)&plQuat.fW) - ((char*)&plQuat);
bool offsetsOK = CHECK_OFFSET(NxVec3, x, hsScalarTriple, fX);
nxVecXOffset == plVecXOffset && CHECK_OFFSET(NxVec3, y, hsScalarTriple, fY);
nxVecYOffset == plVecYOffset && CHECK_OFFSET(NxVec3, z, hsScalarTriple, fZ);
nxVecZOffset == plVecZOffset &&
nxQuatXOffset == plQuatXOffset &&
nxQuatYOffset == plQuatYOffset &&
nxQuatZOffset == plQuatZOffset &&
nxQuatWOffset == plQuatWOffset;
hsAssert(offsetsOK, "PhysX or Plasma offsets have changed, need to rewrite conversion code"); CHECK_OFFSET(NxQuat, x, hsQuat, fX);
CHECK_OFFSET(NxQuat, y, hsQuat, fY);
CHECK_OFFSET(NxQuat, z, hsQuat, fZ);
CHECK_OFFSET(NxQuat, w, hsQuat, fW);
#undef CHECK_OFFSET
return offsetsOK;
}

1
Sources/Plasma/PubUtilLib/plPhysX/plPXConvert.h

@ -73,7 +73,6 @@ namespace plPXConvert
inline void Matrix(const hsMatrix44& fromMat, NxMat34& toMat) { toMat.setRowMajor44(&fromMat.fMap[0][0]); } inline void Matrix(const hsMatrix44& fromMat, NxMat34& toMat) { toMat.setRowMajor44(&fromMat.fMap[0][0]); }
inline void Matrix(const NxMat34& fromMat, hsMatrix44& toMat) { toMat.NotIdentity(); fromMat.getRowMajor44(&toMat.fMap[0][0]); } inline void Matrix(const NxMat34& fromMat, hsMatrix44& toMat) { toMat.NotIdentity(); fromMat.getRowMajor44(&toMat.fMap[0][0]); }
bool Validate();
}; };
#endif // plPXConvert_h_inc #endif // plPXConvert_h_inc

8
Sources/Plasma/PubUtilLib/plPhysX/plSimulationMgr.cpp

@ -301,14 +301,6 @@ bool plSimulationMgr::InitSimulation()
fSDK->getFoundationSDK().getRemoteDebugger()->connect("localhost", 5425); fSDK->getFoundationSDK().getRemoteDebugger()->connect("localhost", 5425);
#endif #endif
if ( !plPXConvert::Validate() )
{
#ifndef PLASMA_EXTERNAL_RELEASE
hsMessageBox("Ageia's PhysX or Plasma offsets have changed, need to rewrite conversion code.","PhysX Error",hsMBoxOk);
#endif
return false; // client will handle this and ask user to install
}
return true; return true;
} }

Loading…
Cancel
Save