mirror of https://github.com/zeldaret/botw.git
Havok: Add hkpConstraintOwner
This commit is contained in:
parent
a291d84b2b
commit
0c734c4cbd
|
@ -107,6 +107,7 @@ add_library(hkStubs OBJECT
|
|||
Havok/Physics2012/Dynamics/Common/hkpMaterial.h
|
||||
Havok/Physics2012/Dynamics/Common/hkpProperty.h
|
||||
Havok/Physics2012/Dynamics/Constraint/hkpConstraintInstance.h
|
||||
Havok/Physics2012/Dynamics/Constraint/hkpConstraintOwner.h
|
||||
Havok/Physics2012/Dynamics/Entity/hkpEntity.h
|
||||
Havok/Physics2012/Dynamics/Entity/hkpRigidBody.h
|
||||
Havok/Physics2012/Dynamics/Entity/hkpRigidBodyCinfo.h
|
||||
|
|
|
@ -14,3 +14,12 @@
|
|||
#include <Havok/Common/Base/Math/Vector/hkVector4Comparison.h>
|
||||
|
||||
#include <Havok/Common/Base/Math/Vector/hkVector4f.inl>
|
||||
|
||||
namespace hkMath {
|
||||
|
||||
template <typename T1, typename T2>
|
||||
HK_FORCE_INLINE T1 max2(T1 x, T2 y) {
|
||||
return x > static_cast<T1>(y) ? x : static_cast<T1>(y);
|
||||
}
|
||||
|
||||
} // namespace hkMath
|
||||
|
|
|
@ -5,8 +5,32 @@
|
|||
struct hkpConstraintInfo {
|
||||
HK_DECLARE_CLASS_ALLOCATOR(hkpConstraintInfo)
|
||||
|
||||
inline void add(int schemaSize, int numSolverResults, int numSolverTempElems);
|
||||
inline void add(const hkpConstraintInfo& delta);
|
||||
inline void sub(const hkpConstraintInfo& delta);
|
||||
|
||||
int m_maxSizeOfSchema;
|
||||
int m_sizeOfSchemas;
|
||||
int m_numSolverResults;
|
||||
int m_numSolverElemTemps;
|
||||
};
|
||||
|
||||
inline void hkpConstraintInfo::add(int schemaSize, int numSolverResults, int numSolverTempElems) {
|
||||
m_sizeOfSchemas += schemaSize;
|
||||
m_numSolverResults += numSolverResults;
|
||||
m_numSolverElemTemps += numSolverTempElems;
|
||||
}
|
||||
|
||||
inline void hkpConstraintInfo::add(const hkpConstraintInfo& delta) {
|
||||
m_maxSizeOfSchema = hkMath::max2(m_maxSizeOfSchema, delta.m_maxSizeOfSchema);
|
||||
m_maxSizeOfSchema = hkMath::max2(m_maxSizeOfSchema, delta.m_sizeOfSchemas);
|
||||
m_sizeOfSchemas += delta.m_sizeOfSchemas;
|
||||
m_numSolverResults += delta.m_numSolverResults;
|
||||
m_numSolverElemTemps += delta.m_numSolverElemTemps;
|
||||
}
|
||||
|
||||
inline void hkpConstraintInfo::sub(const hkpConstraintInfo& delta) {
|
||||
m_sizeOfSchemas -= delta.m_sizeOfSchemas;
|
||||
m_numSolverResults -= delta.m_numSolverResults;
|
||||
m_numSolverElemTemps -= delta.m_numSolverElemTemps;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,39 @@
|
|||
#pragma once
|
||||
|
||||
#include <Havok/Common/Base/hkBase.h>
|
||||
#include <Havok/Physics2012/Dynamics/Constraint/hkpConstraintInstance.h>
|
||||
|
||||
class hkpConstraintOwner : public hkReferencedObject {
|
||||
public:
|
||||
HK_DECLARE_CLASS_ALLOCATOR(hkpConstraintOwner)
|
||||
|
||||
inline void addConstraintInfo(hkpConstraintInstance* constraint, hkpConstraintInfo& delta);
|
||||
inline void subConstraintInfo(hkpConstraintInstance* constraint, hkpConstraintInfo& delta);
|
||||
|
||||
virtual void addConstraintToCriticalLockedIsland(hkpConstraintInstance* constraint) {}
|
||||
virtual void removeConstraintFromCriticalLockedIsland(hkpConstraintInstance* constraint) {}
|
||||
virtual void addCallbackRequest(hkpConstraintInstance* constraint, int request) {}
|
||||
virtual void checkAccessRw() {}
|
||||
|
||||
hkpConstraintInfo m_constraintInfo;
|
||||
};
|
||||
|
||||
inline void hkpConstraintOwner::addConstraintInfo(hkpConstraintInstance* constraint,
|
||||
hkpConstraintInfo& delta) {
|
||||
if (!constraint->m_internal)
|
||||
return;
|
||||
|
||||
m_constraintInfo.add(delta);
|
||||
constraint->m_internal->addConstraintInfo(delta);
|
||||
m_constraintInfo.m_maxSizeOfSchema =
|
||||
hkMath::max2(m_constraintInfo.m_maxSizeOfSchema, constraint->m_internal->m_sizeOfSchemas);
|
||||
}
|
||||
|
||||
inline void hkpConstraintOwner::subConstraintInfo(hkpConstraintInstance* constraint,
|
||||
hkpConstraintInfo& delta) {
|
||||
if (!constraint->m_internal)
|
||||
return;
|
||||
|
||||
m_constraintInfo.sub(delta);
|
||||
constraint->m_internal->subConstraintInfo(delta);
|
||||
}
|
Loading…
Reference in New Issue