16#ifdef JPH_DEBUG_RENDERER
29#ifdef JPH_ENABLE_ASSERTS
35 void Add(
Constraint **inConstraints,
int inNumber);
38 void Remove(
Constraint **inConstraint,
int inNumber);
47 void GetActiveConstraints(
uint32 inStartConstraintIdx,
uint32 inEndConstraintIdx,
Constraint **outActiveConstraints,
uint32 &outNumActiveConstraints)
const;
53 static void sSortConstraints(
Constraint **inActiveConstraints,
uint32 *inConstraintIdxBegin,
uint32 *inConstraintIdxEnd);
56 static void sSetupVelocityConstraints(
Constraint **inActiveConstraints,
uint32 inNumActiveConstraints,
float inDeltaTime);
59 template <
class Constra
intCallback>
60 static void sWarmStartVelocityConstraints(
Constraint **inActiveConstraints,
const uint32 *inConstraintIdxBegin,
const uint32 *inConstraintIdxEnd,
float inWarmStartImpulseRatio, ConstraintCallback &ioCallback);
63 static bool sSolveVelocityConstraints(
Constraint **inActiveConstraints,
const uint32 *inConstraintIdxBegin,
const uint32 *inConstraintIdxEnd,
float inDeltaTime);
66 static bool sSolvePositionConstraints(
Constraint **inActiveConstraints,
const uint32 *inConstraintIdxBegin,
const uint32 *inConstraintIdxEnd,
float inDeltaTime,
float inBaumgarte);
68#ifdef JPH_DEBUG_RENDERER
76 void DrawConstraintReferenceFrame(
DebugRenderer *inRenderer)
const;
90#ifdef JPH_ENABLE_ASSERTS
91 PhysicsLockContext mLockContext;
94 mutable Mutex mConstraintsMutex;
#define JPH_EXPORT
Definition: Core.h:236
#define JPH_NAMESPACE_END
Definition: Core.h:378
std::uint32_t uint32
Definition: Core.h:455
#define JPH_NAMESPACE_BEGIN
Definition: Core.h:372
#define JPH_IF_ENABLE_ASSERTS(...)
Definition: IssueReporting.h:35
#define JPH_OVERRIDE_NEW_DELETE
Macro to override the new and delete functions.
Definition: Memory.h:31
Class that contains all bodies.
Definition: BodyManager.h:44
Base class for all physics constraints. A constraint removes one or more degrees of freedom for a rig...
Definition: Constraint.h:103
A constraint manager manages all constraints of the same type.
Definition: ConstraintManager.h:25
uint32 GetNumConstraints() const
Get total number of constraints.
Definition: ConstraintManager.h:44
void LockAllConstraints()
Lock all constraints. This should only be done during PhysicsSystem::Update().
Definition: ConstraintManager.h:86
void UnlockAllConstraints()
Definition: ConstraintManager.h:87
Definition: DebugRenderer.h:47
Keeps track of connected bodies and builds islands for multithreaded velocity/position update.
Definition: IslandBuilder.h:19
Class that makes another class non-copyable. Usage: Inherit from NonCopyable.
Definition: NonCopyable.h:11
static void sUnlock(LockType &inMutex JPH_IF_ENABLE_ASSERTS(, PhysicsLockContext inContext, EPhysicsLockTypes inType))
Definition: PhysicsLock.h:61
static void sLock(LockType &inMutex JPH_IF_ENABLE_ASSERTS(, PhysicsLockContext inContext, EPhysicsLockTypes inType))
Definition: PhysicsLock.h:54
User callbacks that allow determining which parts of the simulation should be saved by a StateRecorde...
Definition: StateRecorder.h:74
Definition: StateRecorder.h:105