@bloomengine/engine 0.3.3 → 0.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/native/shared/build.rs +137 -6
- package/package.json +4 -11
- package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/build.gradle +0 -51
- package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/src/main/AndroidManifest.xml +0 -20
- package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/src/main/cpp/CMakeLists.txt +0 -20
- package/native/third_party/JoltPhysics/Build/Android/UnitTests/build.gradle +0 -51
- package/native/third_party/JoltPhysics/Build/Android/UnitTests/src/main/AndroidManifest.xml +0 -20
- package/native/third_party/JoltPhysics/Build/Android/UnitTests/src/main/cpp/CMakeLists.txt +0 -20
- package/native/third_party/JoltPhysics/Build/Android/build.gradle +0 -17
- package/native/third_party/JoltPhysics/Build/Android/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/native/third_party/JoltPhysics/Build/Android/gradle/wrapper/gradle-wrapper.properties +0 -5
- package/native/third_party/JoltPhysics/Build/Android/gradle.properties +0 -21
- package/native/third_party/JoltPhysics/Build/Android/gradlew +0 -185
- package/native/third_party/JoltPhysics/Build/Android/gradlew.bat +0 -89
- package/native/third_party/JoltPhysics/Build/Android/settings.gradle +0 -10
- package/native/third_party/JoltPhysics/Build/CMakeLists.txt +0 -449
- package/native/third_party/JoltPhysics/Build/README.md +0 -250
- package/native/third_party/JoltPhysics/Build/cmake_linux_clang_gcc.sh +0 -28
- package/native/third_party/JoltPhysics/Build/cmake_linux_emscripten.sh +0 -19
- package/native/third_party/JoltPhysics/Build/cmake_linux_mingw.sh +0 -19
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_32bit.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_arm.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_arm_32bit.bat +0 -4
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_cross_platform_deterministic.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_double.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_no_object_stream.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang.bat +0 -10
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang_cross_platform_deterministic.bat +0 -10
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang_double.bat +0 -10
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_uwp.bat +0 -5
- package/native/third_party/JoltPhysics/Build/cmake_vs2022_uwp_arm.bat +0 -5
- package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl_cross_platform_deterministic.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl_double.bat +0 -3
- package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang.bat +0 -10
- package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang_cross_platform_deterministic.bat +0 -10
- package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang_double.bat +0 -10
- package/native/third_party/JoltPhysics/Build/cmake_windows_mingw.sh +0 -19
- package/native/third_party/JoltPhysics/Build/cmake_xcode_ios.sh +0 -4
- package/native/third_party/JoltPhysics/Build/cmake_xcode_macos.sh +0 -4
- package/native/third_party/JoltPhysics/Build/iOS/JoltViewerInfo.plist +0 -34
- package/native/third_party/JoltPhysics/Build/iOS/SamplesInfo.plist +0 -34
- package/native/third_party/JoltPhysics/Build/iOS/UnitTestsInfo.plist +0 -34
- package/native/third_party/JoltPhysics/Build/macOS/icon.icns +0 -0
- package/native/third_party/JoltPhysics/Build/macos_install_vulkan_sdk.sh +0 -13
- package/native/third_party/JoltPhysics/Build/ubuntu24_install_vulkan_sdk.sh +0 -4
- package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeBuilder.cpp +0 -242
- package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeBuilder.h +0 -121
- package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeToBuffer.h +0 -296
- package/native/third_party/JoltPhysics/Jolt/AABBTree/NodeCodec/NodeCodecQuadTreeHalfFloat.h +0 -323
- package/native/third_party/JoltPhysics/Jolt/AABBTree/TriangleCodec/TriangleCodecIndexed8BitPackSOA4Flags.h +0 -555
- package/native/third_party/JoltPhysics/Jolt/ConfigurationString.h +0 -112
- package/native/third_party/JoltPhysics/Jolt/Core/ARMNeon.h +0 -94
- package/native/third_party/JoltPhysics/Jolt/Core/Array.h +0 -713
- package/native/third_party/JoltPhysics/Jolt/Core/Atomics.h +0 -44
- package/native/third_party/JoltPhysics/Jolt/Core/BinaryHeap.h +0 -96
- package/native/third_party/JoltPhysics/Jolt/Core/ByteBuffer.h +0 -74
- package/native/third_party/JoltPhysics/Jolt/Core/Color.cpp +0 -38
- package/native/third_party/JoltPhysics/Jolt/Core/Color.h +0 -98
- package/native/third_party/JoltPhysics/Jolt/Core/Core.h +0 -652
- package/native/third_party/JoltPhysics/Jolt/Core/FPControlWord.h +0 -143
- package/native/third_party/JoltPhysics/Jolt/Core/FPException.h +0 -96
- package/native/third_party/JoltPhysics/Jolt/Core/FPFlushDenormals.h +0 -43
- package/native/third_party/JoltPhysics/Jolt/Core/Factory.cpp +0 -92
- package/native/third_party/JoltPhysics/Jolt/Core/Factory.h +0 -54
- package/native/third_party/JoltPhysics/Jolt/Core/FixedSizeFreeList.h +0 -122
- package/native/third_party/JoltPhysics/Jolt/Core/FixedSizeFreeList.inl +0 -215
- package/native/third_party/JoltPhysics/Jolt/Core/HashCombine.h +0 -234
- package/native/third_party/JoltPhysics/Jolt/Core/HashTable.h +0 -876
- package/native/third_party/JoltPhysics/Jolt/Core/InsertionSort.h +0 -58
- package/native/third_party/JoltPhysics/Jolt/Core/IssueReporting.cpp +0 -27
- package/native/third_party/JoltPhysics/Jolt/Core/IssueReporting.h +0 -38
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystem.h +0 -311
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystem.inl +0 -56
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystemSingleThreaded.cpp +0 -65
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystemSingleThreaded.h +0 -62
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystemThreadPool.cpp +0 -364
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystemThreadPool.h +0 -101
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystemWithBarrier.cpp +0 -230
- package/native/third_party/JoltPhysics/Jolt/Core/JobSystemWithBarrier.h +0 -85
- package/native/third_party/JoltPhysics/Jolt/Core/LinearCurve.cpp +0 -51
- package/native/third_party/JoltPhysics/Jolt/Core/LinearCurve.h +0 -67
- package/native/third_party/JoltPhysics/Jolt/Core/LockFreeHashMap.h +0 -182
- package/native/third_party/JoltPhysics/Jolt/Core/LockFreeHashMap.inl +0 -351
- package/native/third_party/JoltPhysics/Jolt/Core/Memory.cpp +0 -85
- package/native/third_party/JoltPhysics/Jolt/Core/Memory.h +0 -85
- package/native/third_party/JoltPhysics/Jolt/Core/Mutex.h +0 -223
- package/native/third_party/JoltPhysics/Jolt/Core/MutexArray.h +0 -98
- package/native/third_party/JoltPhysics/Jolt/Core/NonCopyable.h +0 -18
- package/native/third_party/JoltPhysics/Jolt/Core/Profiler.cpp +0 -677
- package/native/third_party/JoltPhysics/Jolt/Core/Profiler.h +0 -301
- package/native/third_party/JoltPhysics/Jolt/Core/Profiler.inl +0 -90
- package/native/third_party/JoltPhysics/Jolt/Core/QuickSort.h +0 -137
- package/native/third_party/JoltPhysics/Jolt/Core/RTTI.cpp +0 -149
- package/native/third_party/JoltPhysics/Jolt/Core/RTTI.h +0 -436
- package/native/third_party/JoltPhysics/Jolt/Core/Reference.h +0 -244
- package/native/third_party/JoltPhysics/Jolt/Core/Result.h +0 -174
- package/native/third_party/JoltPhysics/Jolt/Core/STLAlignedAllocator.h +0 -72
- package/native/third_party/JoltPhysics/Jolt/Core/STLAllocator.h +0 -127
- package/native/third_party/JoltPhysics/Jolt/Core/STLLocalAllocator.h +0 -170
- package/native/third_party/JoltPhysics/Jolt/Core/STLTempAllocator.h +0 -80
- package/native/third_party/JoltPhysics/Jolt/Core/ScopeExit.h +0 -49
- package/native/third_party/JoltPhysics/Jolt/Core/Semaphore.cpp +0 -135
- package/native/third_party/JoltPhysics/Jolt/Core/Semaphore.h +0 -68
- package/native/third_party/JoltPhysics/Jolt/Core/StaticArray.h +0 -329
- package/native/third_party/JoltPhysics/Jolt/Core/StreamIn.h +0 -120
- package/native/third_party/JoltPhysics/Jolt/Core/StreamOut.h +0 -97
- package/native/third_party/JoltPhysics/Jolt/Core/StreamUtils.h +0 -168
- package/native/third_party/JoltPhysics/Jolt/Core/StreamWrapper.h +0 -53
- package/native/third_party/JoltPhysics/Jolt/Core/StridedPtr.h +0 -63
- package/native/third_party/JoltPhysics/Jolt/Core/StringTools.cpp +0 -101
- package/native/third_party/JoltPhysics/Jolt/Core/StringTools.h +0 -38
- package/native/third_party/JoltPhysics/Jolt/Core/TempAllocator.h +0 -209
- package/native/third_party/JoltPhysics/Jolt/Core/TickCounter.cpp +0 -37
- package/native/third_party/JoltPhysics/Jolt/Core/TickCounter.h +0 -58
- package/native/third_party/JoltPhysics/Jolt/Core/UnorderedMap.h +0 -80
- package/native/third_party/JoltPhysics/Jolt/Core/UnorderedSet.h +0 -32
- package/native/third_party/JoltPhysics/Jolt/Geometry/AABox.h +0 -313
- package/native/third_party/JoltPhysics/Jolt/Geometry/AABox4.h +0 -224
- package/native/third_party/JoltPhysics/Jolt/Geometry/ClipPoly.h +0 -200
- package/native/third_party/JoltPhysics/Jolt/Geometry/ClosestPoint.h +0 -498
- package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder.cpp +0 -1467
- package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder.h +0 -276
- package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder2D.cpp +0 -335
- package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder2D.h +0 -105
- package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexSupport.h +0 -188
- package/native/third_party/JoltPhysics/Jolt/Geometry/EPAConvexHullBuilder.h +0 -845
- package/native/third_party/JoltPhysics/Jolt/Geometry/EPAPenetrationDepth.h +0 -557
- package/native/third_party/JoltPhysics/Jolt/Geometry/Ellipse.h +0 -77
- package/native/third_party/JoltPhysics/Jolt/Geometry/GJKClosestPoint.h +0 -945
- package/native/third_party/JoltPhysics/Jolt/Geometry/IndexedTriangle.h +0 -130
- package/native/third_party/JoltPhysics/Jolt/Geometry/Indexify.cpp +0 -222
- package/native/third_party/JoltPhysics/Jolt/Geometry/Indexify.h +0 -19
- package/native/third_party/JoltPhysics/Jolt/Geometry/MortonCode.h +0 -40
- package/native/third_party/JoltPhysics/Jolt/Geometry/OrientedBox.cpp +0 -178
- package/native/third_party/JoltPhysics/Jolt/Geometry/OrientedBox.h +0 -39
- package/native/third_party/JoltPhysics/Jolt/Geometry/Plane.h +0 -104
- package/native/third_party/JoltPhysics/Jolt/Geometry/RayAABox.h +0 -241
- package/native/third_party/JoltPhysics/Jolt/Geometry/RayCapsule.h +0 -37
- package/native/third_party/JoltPhysics/Jolt/Geometry/RayCylinder.h +0 -101
- package/native/third_party/JoltPhysics/Jolt/Geometry/RaySphere.h +0 -96
- package/native/third_party/JoltPhysics/Jolt/Geometry/RayTriangle.h +0 -158
- package/native/third_party/JoltPhysics/Jolt/Geometry/Sphere.h +0 -72
- package/native/third_party/JoltPhysics/Jolt/Geometry/Triangle.h +0 -34
- package/native/third_party/JoltPhysics/Jolt/Jolt.cmake +0 -703
- package/native/third_party/JoltPhysics/Jolt/Jolt.h +0 -16
- package/native/third_party/JoltPhysics/Jolt/Jolt.natvis +0 -116
- package/native/third_party/JoltPhysics/Jolt/Math/BVec16.h +0 -99
- package/native/third_party/JoltPhysics/Jolt/Math/BVec16.inl +0 -177
- package/native/third_party/JoltPhysics/Jolt/Math/DMat44.h +0 -158
- package/native/third_party/JoltPhysics/Jolt/Math/DMat44.inl +0 -310
- package/native/third_party/JoltPhysics/Jolt/Math/DVec3.h +0 -291
- package/native/third_party/JoltPhysics/Jolt/Math/DVec3.inl +0 -941
- package/native/third_party/JoltPhysics/Jolt/Math/Double3.h +0 -48
- package/native/third_party/JoltPhysics/Jolt/Math/DynMatrix.h +0 -31
- package/native/third_party/JoltPhysics/Jolt/Math/EigenValueSymmetric.h +0 -177
- package/native/third_party/JoltPhysics/Jolt/Math/FindRoot.h +0 -42
- package/native/third_party/JoltPhysics/Jolt/Math/Float2.h +0 -36
- package/native/third_party/JoltPhysics/Jolt/Math/Float3.h +0 -50
- package/native/third_party/JoltPhysics/Jolt/Math/Float4.h +0 -44
- package/native/third_party/JoltPhysics/Jolt/Math/GaussianElimination.h +0 -102
- package/native/third_party/JoltPhysics/Jolt/Math/HalfFloat.h +0 -208
- package/native/third_party/JoltPhysics/Jolt/Math/Mat44.h +0 -243
- package/native/third_party/JoltPhysics/Jolt/Math/Mat44.inl +0 -952
- package/native/third_party/JoltPhysics/Jolt/Math/Math.h +0 -208
- package/native/third_party/JoltPhysics/Jolt/Math/MathTypes.h +0 -32
- package/native/third_party/JoltPhysics/Jolt/Math/Matrix.h +0 -259
- package/native/third_party/JoltPhysics/Jolt/Math/Quat.h +0 -268
- package/native/third_party/JoltPhysics/Jolt/Math/Quat.inl +0 -406
- package/native/third_party/JoltPhysics/Jolt/Math/Real.h +0 -44
- package/native/third_party/JoltPhysics/Jolt/Math/Swizzle.h +0 -19
- package/native/third_party/JoltPhysics/Jolt/Math/Trigonometry.h +0 -79
- package/native/third_party/JoltPhysics/Jolt/Math/UVec4.h +0 -232
- package/native/third_party/JoltPhysics/Jolt/Math/UVec4.inl +0 -636
- package/native/third_party/JoltPhysics/Jolt/Math/Vec3.cpp +0 -71
- package/native/third_party/JoltPhysics/Jolt/Math/Vec3.h +0 -308
- package/native/third_party/JoltPhysics/Jolt/Math/Vec3.inl +0 -942
- package/native/third_party/JoltPhysics/Jolt/Math/Vec4.h +0 -320
- package/native/third_party/JoltPhysics/Jolt/Math/Vec4.inl +0 -1152
- package/native/third_party/JoltPhysics/Jolt/Math/Vector.h +0 -211
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/GetPrimitiveTypeOfType.h +0 -54
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStream.cpp +0 -38
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStream.h +0 -337
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryIn.cpp +0 -252
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryIn.h +0 -57
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryOut.cpp +0 -165
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryOut.h +0 -57
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamIn.cpp +0 -635
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamIn.h +0 -148
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamOut.cpp +0 -166
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamOut.h +0 -101
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextIn.cpp +0 -418
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextIn.h +0 -55
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextOut.cpp +0 -255
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextOut.h +0 -62
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTypes.h +0 -26
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttribute.h +0 -111
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttributeEnum.h +0 -67
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttributeTyped.h +0 -60
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableObject.cpp +0 -15
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableObject.h +0 -170
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/TypeDeclarations.cpp +0 -70
- package/native/third_party/JoltPhysics/Jolt/ObjectStream/TypeDeclarations.h +0 -45
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/AllowedDOFs.h +0 -68
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.cpp +0 -426
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.h +0 -452
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.inl +0 -197
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyAccess.h +0 -68
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyActivationListener.h +0 -28
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyCreationSettings.cpp +0 -234
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyCreationSettings.h +0 -124
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyFilter.h +0 -130
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyID.h +0 -101
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyInterface.cpp +0 -1099
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyInterface.h +0 -324
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLock.h +0 -111
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLockInterface.h +0 -134
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLockMulti.h +0 -120
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyManager.cpp +0 -1220
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyManager.h +0 -403
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyPair.h +0 -36
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyType.h +0 -19
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MassProperties.cpp +0 -185
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MassProperties.h +0 -58
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.cpp +0 -92
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.h +0 -308
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.inl +0 -178
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionQuality.h +0 -31
- package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionType.h +0 -17
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/Character.cpp +0 -354
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/Character.h +0 -159
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterBase.cpp +0 -59
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterBase.h +0 -157
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterID.h +0 -98
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterVirtual.cpp +0 -1933
- package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterVirtual.h +0 -752
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/AABoxCast.h +0 -20
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ActiveEdgeMode.h +0 -17
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ActiveEdges.h +0 -114
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BackFaceMode.h +0 -16
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhase.cpp +0 -16
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhase.h +0 -109
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseBruteForce.cpp +0 -313
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseBruteForce.h +0 -38
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayer.h +0 -148
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayerInterfaceMask.h +0 -92
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayerInterfaceTable.h +0 -64
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuadTree.cpp +0 -629
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuadTree.h +0 -108
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuery.h +0 -56
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/ObjectVsBroadPhaseLayerFilterMask.h +0 -35
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/ObjectVsBroadPhaseLayerFilterTable.h +0 -66
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/QuadTree.cpp +0 -1768
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/QuadTree.h +0 -389
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastConvexVsTriangles.cpp +0 -107
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastConvexVsTriangles.h +0 -46
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastResult.h +0 -37
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastSphereVsTriangles.cpp +0 -223
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastSphereVsTriangles.h +0 -49
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollectFacesMode.h +0 -16
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideConvexVsTriangles.cpp +0 -155
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideConvexVsTriangles.h +0 -56
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollidePointResult.h +0 -25
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideShape.h +0 -106
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideShapeVsShapePerLeaf.h +0 -94
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSoftBodyVertexIterator.h +0 -110
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSoftBodyVerticesVsTriangles.h +0 -102
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSphereVsTriangles.cpp +0 -121
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSphereVsTriangles.h +0 -50
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionCollector.h +0 -109
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionCollectorImpl.h +0 -219
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionDispatch.cpp +0 -107
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionDispatch.h +0 -97
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionGroup.cpp +0 -35
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionGroup.h +0 -97
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ContactListener.h +0 -143
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/EstimateCollisionResponse.cpp +0 -213
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/EstimateCollisionResponse.h +0 -48
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilter.cpp +0 -32
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilter.h +0 -46
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilterTable.cpp +0 -38
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilterTable.h +0 -130
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/InternalEdgeRemovingCollector.h +0 -279
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ManifoldBetweenTwoFaces.cpp +0 -271
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ManifoldBetweenTwoFaces.h +0 -44
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseQuery.cpp +0 -448
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseQuery.h +0 -77
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseStats.cpp +0 -62
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseStats.h +0 -110
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayer.h +0 -111
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayerPairFilterMask.h +0 -52
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayerPairFilterTable.h +0 -78
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterial.cpp +0 -35
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterial.h +0 -57
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterialSimple.cpp +0 -38
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterialSimple.h +0 -37
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/RayCast.h +0 -87
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/BoxShape.cpp +0 -318
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/BoxShape.h +0 -115
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CapsuleShape.cpp +0 -438
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CapsuleShape.h +0 -129
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShape.cpp +0 -433
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShape.h +0 -354
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShapeVisitors.h +0 -461
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexHullShape.cpp +0 -1311
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexHullShape.h +0 -202
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexShape.cpp +0 -566
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexShape.h +0 -150
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CylinderShape.cpp +0 -418
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CylinderShape.h +0 -126
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/DecoratedShape.cpp +0 -87
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/DecoratedShape.h +0 -80
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/EmptyShape.cpp +0 -64
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/EmptyShape.h +0 -75
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/GetTrianglesContext.h +0 -248
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/HeightFieldShape.cpp +0 -2754
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/HeightFieldShape.h +0 -380
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MeshShape.cpp +0 -1305
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MeshShape.h +0 -228
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MutableCompoundShape.cpp +0 -596
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MutableCompoundShape.h +0 -176
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/OffsetCenterOfMassShape.cpp +0 -217
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/OffsetCenterOfMassShape.h +0 -140
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PlaneShape.cpp +0 -541
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PlaneShape.h +0 -147
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PolyhedronSubmergedVolumeCalculator.h +0 -319
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/RotatedTranslatedShape.cpp +0 -333
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/RotatedTranslatedShape.h +0 -161
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaleHelpers.h +0 -83
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaledShape.cpp +0 -238
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaledShape.h +0 -145
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/Shape.cpp +0 -325
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/Shape.h +0 -466
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SphereShape.cpp +0 -347
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SphereShape.h +0 -125
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/StaticCompoundShape.cpp +0 -674
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/StaticCompoundShape.h +0 -139
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SubShapeID.h +0 -138
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SubShapeIDPair.h +0 -65
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.cpp +0 -453
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.gliffy +0 -1
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.h +0 -135
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCylinderShape.cpp +0 -691
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCylinderShape.h +0 -132
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TriangleShape.cpp +0 -430
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TriangleShape.h +0 -143
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ShapeCast.h +0 -173
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ShapeFilter.h +0 -73
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SimShapeFilter.h +0 -40
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SimShapeFilterWrapper.h +0 -58
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SortReverseAndStore.h +0 -48
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/TransformedShape.cpp +0 -180
- package/native/third_party/JoltPhysics/Jolt/Physics/Collision/TransformedShape.h +0 -194
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/CalculateSolverSteps.h +0 -70
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConeConstraint.cpp +0 -246
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConeConstraint.h +0 -133
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/Constraint.cpp +0 -73
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/Constraint.h +0 -243
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintManager.cpp +0 -289
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintManager.h +0 -100
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/AngleConstraintPart.h +0 -257
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/AxisConstraintPart.h +0 -682
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/DualAxisConstraintPart.h +0 -276
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/GearConstraintPart.h +0 -195
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/HingeRotationConstraintPart.h +0 -222
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/IndependentAxisConstraintPart.h +0 -246
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/PointConstraintPart.h +0 -239
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RackAndPinionConstraintPart.h +0 -196
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RotationEulerConstraintPart.h +0 -283
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RotationQuatConstraintPart.h +0 -246
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/SpringPart.h +0 -169
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/SwingTwistConstraintPart.h +0 -597
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ContactConstraintManager.cpp +0 -1804
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ContactConstraintManager.h +0 -524
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/DistanceConstraint.cpp +0 -266
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/DistanceConstraint.h +0 -120
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/FixedConstraint.cpp +0 -215
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/FixedConstraint.h +0 -96
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/GearConstraint.cpp +0 -188
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/GearConstraint.h +0 -116
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/HingeConstraint.cpp +0 -443
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/HingeConstraint.h +0 -205
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/MotorSettings.cpp +0 -43
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/MotorSettings.h +0 -66
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraint.cpp +0 -458
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraint.h +0 -191
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPath.cpp +0 -85
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPath.h +0 -76
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPathHermite.cpp +0 -308
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPathHermite.h +0 -54
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PointConstraint.cpp +0 -157
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PointConstraint.h +0 -94
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PulleyConstraint.cpp +0 -253
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PulleyConstraint.h +0 -137
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/RackAndPinionConstraint.cpp +0 -189
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/RackAndPinionConstraint.h +0 -118
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SixDOFConstraint.cpp +0 -900
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SixDOFConstraint.h +0 -289
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SliderConstraint.cpp +0 -501
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SliderConstraint.h +0 -198
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SpringSettings.cpp +0 -35
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SpringSettings.h +0 -70
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SwingTwistConstraint.cpp +0 -524
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SwingTwistConstraint.h +0 -197
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/TwoBodyConstraint.cpp +0 -56
- package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/TwoBodyConstraint.h +0 -65
- package/native/third_party/JoltPhysics/Jolt/Physics/DeterminismLog.cpp +0 -17
- package/native/third_party/JoltPhysics/Jolt/Physics/DeterminismLog.h +0 -159
- package/native/third_party/JoltPhysics/Jolt/Physics/EActivation.h +0 -16
- package/native/third_party/JoltPhysics/Jolt/Physics/EPhysicsUpdateError.h +0 -37
- package/native/third_party/JoltPhysics/Jolt/Physics/IslandBuilder.cpp +0 -492
- package/native/third_party/JoltPhysics/Jolt/Physics/IslandBuilder.h +0 -144
- package/native/third_party/JoltPhysics/Jolt/Physics/LargeIslandSplitter.cpp +0 -582
- package/native/third_party/JoltPhysics/Jolt/Physics/LargeIslandSplitter.h +0 -187
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsLock.h +0 -169
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsScene.cpp +0 -261
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsScene.h +0 -104
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSettings.h +0 -125
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsStepListener.h +0 -37
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSystem.cpp +0 -2915
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSystem.h +0 -391
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsUpdateContext.cpp +0 -25
- package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsUpdateContext.h +0 -176
- package/native/third_party/JoltPhysics/Jolt/Physics/Ragdoll/Ragdoll.cpp +0 -744
- package/native/third_party/JoltPhysics/Jolt/Physics/Ragdoll/Ragdoll.h +0 -245
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyContactListener.h +0 -55
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyCreationSettings.cpp +0 -128
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyCreationSettings.h +0 -75
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyManifold.h +0 -74
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyMotionProperties.cpp +0 -1501
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyMotionProperties.h +0 -333
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyShape.cpp +0 -354
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyShape.h +0 -73
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodySharedSettings.cpp +0 -1487
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodySharedSettings.h +0 -390
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyUpdateContext.h +0 -63
- package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyVertex.h +0 -36
- package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorder.h +0 -136
- package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorderImpl.cpp +0 -90
- package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorderImpl.h +0 -50
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/MotorcycleController.cpp +0 -306
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/MotorcycleController.h +0 -119
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/TrackedVehicleController.cpp +0 -547
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/TrackedVehicleController.h +0 -169
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleAntiRollBar.cpp +0 -33
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleAntiRollBar.h +0 -33
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleCollisionTester.cpp +0 -376
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleCollisionTester.h +0 -146
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleConstraint.cpp +0 -703
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleConstraint.h +0 -252
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleController.cpp +0 -17
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleController.h +0 -87
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleDifferential.cpp +0 -81
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleDifferential.h +0 -39
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleEngine.cpp +0 -122
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleEngine.h +0 -93
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTrack.cpp +0 -52
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTrack.h +0 -56
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTransmission.cpp +0 -159
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTransmission.h +0 -87
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/Wheel.cpp +0 -93
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/Wheel.h +0 -148
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/WheeledVehicleController.cpp +0 -866
- package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/WheeledVehicleController.h +0 -205
- package/native/third_party/JoltPhysics/Jolt/RegisterTypes.cpp +0 -204
- package/native/third_party/JoltPhysics/Jolt/RegisterTypes.h +0 -29
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRenderer.cpp +0 -1107
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRenderer.h +0 -383
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererPlayback.cpp +0 -168
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererPlayback.h +0 -48
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererRecorder.cpp +0 -158
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererRecorder.h +0 -130
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererSimple.cpp +0 -80
- package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererSimple.h +0 -88
- package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletalAnimation.cpp +0 -165
- package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletalAnimation.h +0 -91
- package/native/third_party/JoltPhysics/Jolt/Skeleton/Skeleton.cpp +0 -82
- package/native/third_party/JoltPhysics/Jolt/Skeleton/Skeleton.h +0 -72
- package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonMapper.cpp +0 -237
- package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonMapper.h +0 -145
- package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonPose.cpp +0 -87
- package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonPose.h +0 -82
- package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitter.cpp +0 -73
- package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitter.h +0 -84
- package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterBinning.cpp +0 -139
- package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterBinning.h +0 -52
- package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterMean.cpp +0 -43
- package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterMean.h +0 -28
- package/native/third_party/JoltPhysics/LICENSE +0 -7
- package/native/third_party/JoltPhysics/README.md +0 -173
- package/native/third_party/bloom_jolt/CMakeLists.txt +0 -87
- package/native/third_party/bloom_jolt/include/bloom_jolt.h +0 -519
- package/native/third_party/bloom_jolt/src/bloom_jolt.cpp +0 -1780
|
@@ -1,364 +0,0 @@
|
|
|
1
|
-
// Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
|
|
2
|
-
// SPDX-FileCopyrightText: 2021 Jorrit Rouwe
|
|
3
|
-
// SPDX-License-Identifier: MIT
|
|
4
|
-
|
|
5
|
-
#include <Jolt/Jolt.h>
|
|
6
|
-
|
|
7
|
-
#include <Jolt/Core/JobSystemThreadPool.h>
|
|
8
|
-
#include <Jolt/Core/Profiler.h>
|
|
9
|
-
#include <Jolt/Core/FPException.h>
|
|
10
|
-
|
|
11
|
-
#ifdef JPH_PLATFORM_WINDOWS
|
|
12
|
-
JPH_SUPPRESS_WARNING_PUSH
|
|
13
|
-
JPH_MSVC_SUPPRESS_WARNING(5039) // winbase.h(13179): warning C5039: 'TpSetCallbackCleanupGroup': pointer or reference to potentially throwing function passed to 'extern "C"' function under -EHc. Undefined behavior may occur if this function throws an exception.
|
|
14
|
-
JPH_MSVC2026_PLUS_SUPPRESS_WARNING(4865) // wingdi.h(2806,1): '<unnamed-enum-DISPLAYCONFIG_OUTPUT_TECHNOLOGY_OTHER>': the underlying type will change from 'int' to '__int64' when '/Zc:enumTypes' is specified on the command line
|
|
15
|
-
#ifndef WIN32_LEAN_AND_MEAN
|
|
16
|
-
#define WIN32_LEAN_AND_MEAN
|
|
17
|
-
#endif
|
|
18
|
-
#ifndef JPH_COMPILER_MINGW
|
|
19
|
-
#include <Windows.h>
|
|
20
|
-
#else
|
|
21
|
-
#include <windows.h>
|
|
22
|
-
#endif
|
|
23
|
-
JPH_SUPPRESS_WARNING_POP
|
|
24
|
-
#endif
|
|
25
|
-
#ifdef JPH_PLATFORM_LINUX
|
|
26
|
-
#include <sys/prctl.h>
|
|
27
|
-
#endif
|
|
28
|
-
|
|
29
|
-
JPH_NAMESPACE_BEGIN
|
|
30
|
-
|
|
31
|
-
void JobSystemThreadPool::Init(uint inMaxJobs, uint inMaxBarriers, int inNumThreads)
|
|
32
|
-
{
|
|
33
|
-
JobSystemWithBarrier::Init(inMaxBarriers);
|
|
34
|
-
|
|
35
|
-
// Init freelist of jobs
|
|
36
|
-
mJobs.Init(inMaxJobs, inMaxJobs);
|
|
37
|
-
|
|
38
|
-
// Init queue
|
|
39
|
-
for (atomic<Job *> &j : mQueue)
|
|
40
|
-
j = nullptr;
|
|
41
|
-
|
|
42
|
-
// Start the worker threads
|
|
43
|
-
StartThreads(inNumThreads);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
JobSystemThreadPool::JobSystemThreadPool(uint inMaxJobs, uint inMaxBarriers, int inNumThreads)
|
|
47
|
-
{
|
|
48
|
-
Init(inMaxJobs, inMaxBarriers, inNumThreads);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
void JobSystemThreadPool::StartThreads([[maybe_unused]] int inNumThreads)
|
|
52
|
-
{
|
|
53
|
-
#if !defined(JPH_CPU_WASM) || defined(__EMSCRIPTEN_PTHREADS__) // If we're running without threads support we cannot create threads and we ignore the inNumThreads parameter
|
|
54
|
-
// Auto detect number of threads
|
|
55
|
-
if (inNumThreads < 0)
|
|
56
|
-
inNumThreads = thread::hardware_concurrency() - 1;
|
|
57
|
-
|
|
58
|
-
// If no threads are requested we're done
|
|
59
|
-
if (inNumThreads == 0)
|
|
60
|
-
return;
|
|
61
|
-
|
|
62
|
-
// Don't quit the threads
|
|
63
|
-
mQuit = false;
|
|
64
|
-
|
|
65
|
-
// Allocate heads
|
|
66
|
-
mHeads = reinterpret_cast<atomic<uint> *>(Allocate(sizeof(atomic<uint>) * inNumThreads));
|
|
67
|
-
for (int i = 0; i < inNumThreads; ++i)
|
|
68
|
-
mHeads[i] = 0;
|
|
69
|
-
|
|
70
|
-
// Start running threads
|
|
71
|
-
JPH_ASSERT(mThreads.empty());
|
|
72
|
-
mThreads.reserve(inNumThreads);
|
|
73
|
-
for (int i = 0; i < inNumThreads; ++i)
|
|
74
|
-
mThreads.emplace_back([this, i] { ThreadMain(i); });
|
|
75
|
-
#endif
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
JobSystemThreadPool::~JobSystemThreadPool()
|
|
79
|
-
{
|
|
80
|
-
// Stop all worker threads
|
|
81
|
-
StopThreads();
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
void JobSystemThreadPool::StopThreads()
|
|
85
|
-
{
|
|
86
|
-
if (mThreads.empty())
|
|
87
|
-
return;
|
|
88
|
-
|
|
89
|
-
// Signal threads that we want to stop and wake them up
|
|
90
|
-
mQuit = true;
|
|
91
|
-
mSemaphore.Release((uint)mThreads.size());
|
|
92
|
-
|
|
93
|
-
// Wait for all threads to finish
|
|
94
|
-
for (thread &t : mThreads)
|
|
95
|
-
if (t.joinable())
|
|
96
|
-
t.join();
|
|
97
|
-
|
|
98
|
-
// Delete all threads
|
|
99
|
-
mThreads.clear();
|
|
100
|
-
|
|
101
|
-
// Ensure that there are no lingering jobs in the queue
|
|
102
|
-
for (uint head = 0; head != mTail; ++head)
|
|
103
|
-
{
|
|
104
|
-
// Fetch job
|
|
105
|
-
Job *job_ptr = mQueue[head & (cQueueLength - 1)].exchange(nullptr);
|
|
106
|
-
if (job_ptr != nullptr)
|
|
107
|
-
{
|
|
108
|
-
// And execute it
|
|
109
|
-
job_ptr->Execute();
|
|
110
|
-
job_ptr->Release();
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
// Destroy heads and reset tail
|
|
115
|
-
Free(mHeads);
|
|
116
|
-
mHeads = nullptr;
|
|
117
|
-
mTail = 0;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
JobHandle JobSystemThreadPool::CreateJob(const char *inJobName, ColorArg inColor, const JobFunction &inJobFunction, uint32 inNumDependencies)
|
|
121
|
-
{
|
|
122
|
-
JPH_PROFILE_FUNCTION();
|
|
123
|
-
|
|
124
|
-
// Loop until we can get a job from the free list
|
|
125
|
-
uint32 index;
|
|
126
|
-
for (;;)
|
|
127
|
-
{
|
|
128
|
-
index = mJobs.ConstructObject(inJobName, inColor, this, inJobFunction, inNumDependencies);
|
|
129
|
-
if (index != AvailableJobs::cInvalidObjectIndex)
|
|
130
|
-
break;
|
|
131
|
-
JPH_ASSERT(false, "No jobs available!");
|
|
132
|
-
std::this_thread::sleep_for(std::chrono::microseconds(100));
|
|
133
|
-
}
|
|
134
|
-
Job *job = &mJobs.Get(index);
|
|
135
|
-
|
|
136
|
-
// Construct handle to keep a reference, the job is queued below and may immediately complete
|
|
137
|
-
JobHandle handle(job);
|
|
138
|
-
|
|
139
|
-
// If there are no dependencies, queue the job now
|
|
140
|
-
if (inNumDependencies == 0)
|
|
141
|
-
QueueJob(job);
|
|
142
|
-
|
|
143
|
-
// Return the handle
|
|
144
|
-
return handle;
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
void JobSystemThreadPool::FreeJob(Job *inJob)
|
|
148
|
-
{
|
|
149
|
-
mJobs.DestructObject(inJob);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
uint JobSystemThreadPool::GetHead() const
|
|
153
|
-
{
|
|
154
|
-
// Find the minimal value across all threads
|
|
155
|
-
uint head = mTail;
|
|
156
|
-
for (size_t i = 0; i < mThreads.size(); ++i)
|
|
157
|
-
head = min(head, mHeads[i].load());
|
|
158
|
-
return head;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
void JobSystemThreadPool::QueueJobInternal(Job *inJob)
|
|
162
|
-
{
|
|
163
|
-
// Add reference to job because we're adding the job to the queue
|
|
164
|
-
inJob->AddRef();
|
|
165
|
-
|
|
166
|
-
// Need to read head first because otherwise the tail can already have passed the head
|
|
167
|
-
// We read the head outside of the loop since it involves iterating over all threads and we only need to update
|
|
168
|
-
// it if there's not enough space in the queue.
|
|
169
|
-
uint head = GetHead();
|
|
170
|
-
|
|
171
|
-
for (;;)
|
|
172
|
-
{
|
|
173
|
-
// Check if there's space in the queue
|
|
174
|
-
uint old_value = mTail;
|
|
175
|
-
if (old_value - head >= cQueueLength)
|
|
176
|
-
{
|
|
177
|
-
// We calculated the head outside of the loop, update head (and we also need to update tail to prevent it from passing head)
|
|
178
|
-
head = GetHead();
|
|
179
|
-
old_value = mTail;
|
|
180
|
-
|
|
181
|
-
// Second check if there's space in the queue
|
|
182
|
-
if (old_value - head >= cQueueLength)
|
|
183
|
-
{
|
|
184
|
-
// Wake up all threads in order to ensure that they can clear any nullptrs they may not have processed yet
|
|
185
|
-
mSemaphore.Release((uint)mThreads.size());
|
|
186
|
-
|
|
187
|
-
// Sleep a little (we have to wait for other threads to update their head pointer in order for us to be able to continue)
|
|
188
|
-
std::this_thread::sleep_for(std::chrono::microseconds(100));
|
|
189
|
-
continue;
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
// Write the job pointer if the slot is empty
|
|
194
|
-
Job *expected_job = nullptr;
|
|
195
|
-
bool success = mQueue[old_value & (cQueueLength - 1)].compare_exchange_strong(expected_job, inJob);
|
|
196
|
-
|
|
197
|
-
// Regardless of who wrote the slot, we will update the tail (if the successful thread got scheduled out
|
|
198
|
-
// after writing the pointer we still want to be able to continue)
|
|
199
|
-
mTail.compare_exchange_strong(old_value, old_value + 1);
|
|
200
|
-
|
|
201
|
-
// If we successfully added our job we're done
|
|
202
|
-
if (success)
|
|
203
|
-
break;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
void JobSystemThreadPool::QueueJob(Job *inJob)
|
|
208
|
-
{
|
|
209
|
-
JPH_PROFILE_FUNCTION();
|
|
210
|
-
|
|
211
|
-
// If we have no worker threads, we can't queue the job either. We assume in this case that the job will be added to a barrier and that the barrier will execute the job when it's Wait() function is called.
|
|
212
|
-
if (mThreads.empty())
|
|
213
|
-
return;
|
|
214
|
-
|
|
215
|
-
// Queue the job
|
|
216
|
-
QueueJobInternal(inJob);
|
|
217
|
-
|
|
218
|
-
// Wake up thread
|
|
219
|
-
mSemaphore.Release();
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
void JobSystemThreadPool::QueueJobs(Job **inJobs, uint inNumJobs)
|
|
223
|
-
{
|
|
224
|
-
JPH_PROFILE_FUNCTION();
|
|
225
|
-
|
|
226
|
-
JPH_ASSERT(inNumJobs > 0);
|
|
227
|
-
|
|
228
|
-
// If we have no worker threads, we can't queue the job either. We assume in this case that the job will be added to a barrier and that the barrier will execute the job when it's Wait() function is called.
|
|
229
|
-
if (mThreads.empty())
|
|
230
|
-
return;
|
|
231
|
-
|
|
232
|
-
// Queue all jobs
|
|
233
|
-
for (Job **job = inJobs, **job_end = inJobs + inNumJobs; job < job_end; ++job)
|
|
234
|
-
QueueJobInternal(*job);
|
|
235
|
-
|
|
236
|
-
// Wake up threads
|
|
237
|
-
mSemaphore.Release(min(inNumJobs, (uint)mThreads.size()));
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
#if defined(JPH_PLATFORM_WINDOWS)
|
|
241
|
-
|
|
242
|
-
#if !defined(JPH_COMPILER_MINGW) // MinGW doesn't support __try/__except)
|
|
243
|
-
// Sets the current thread name in MSVC debugger
|
|
244
|
-
static void RaiseThreadNameException(const char *inName)
|
|
245
|
-
{
|
|
246
|
-
#pragma pack(push, 8)
|
|
247
|
-
|
|
248
|
-
struct THREADNAME_INFO
|
|
249
|
-
{
|
|
250
|
-
DWORD dwType; // Must be 0x1000.
|
|
251
|
-
LPCSTR szName; // Pointer to name (in user addr space).
|
|
252
|
-
DWORD dwThreadID; // Thread ID (-1=caller thread).
|
|
253
|
-
DWORD dwFlags; // Reserved for future use, must be zero.
|
|
254
|
-
};
|
|
255
|
-
|
|
256
|
-
#pragma pack(pop)
|
|
257
|
-
|
|
258
|
-
THREADNAME_INFO info;
|
|
259
|
-
info.dwType = 0x1000;
|
|
260
|
-
info.szName = inName;
|
|
261
|
-
info.dwThreadID = (DWORD)-1;
|
|
262
|
-
info.dwFlags = 0;
|
|
263
|
-
|
|
264
|
-
__try
|
|
265
|
-
{
|
|
266
|
-
RaiseException(0x406D1388, 0, sizeof(info) / sizeof(ULONG_PTR), (ULONG_PTR *)&info);
|
|
267
|
-
}
|
|
268
|
-
__except(EXCEPTION_EXECUTE_HANDLER)
|
|
269
|
-
{
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
#endif // !JPH_COMPILER_MINGW
|
|
273
|
-
|
|
274
|
-
static void SetThreadName(const char* inName)
|
|
275
|
-
{
|
|
276
|
-
JPH_SUPPRESS_WARNING_PUSH
|
|
277
|
-
|
|
278
|
-
// Suppress casting warning, it's fine here as GetProcAddress doesn't really return a FARPROC
|
|
279
|
-
JPH_CLANG_SUPPRESS_WARNING("-Wcast-function-type") // error : cast from 'FARPROC' (aka 'long long (*)()') to 'SetThreadDescriptionFunc' (aka 'long (*)(void *, const wchar_t *)') converts to incompatible function type
|
|
280
|
-
JPH_CLANG_SUPPRESS_WARNING("-Wcast-function-type-strict") // error : cast from 'FARPROC' (aka 'long long (*)()') to 'SetThreadDescriptionFunc' (aka 'long (*)(void *, const wchar_t *)') converts to incompatible function type
|
|
281
|
-
JPH_MSVC_SUPPRESS_WARNING(4191) // reinterpret_cast' : unsafe conversion from 'FARPROC' to 'SetThreadDescriptionFunc'. Calling this function through the result pointer may cause your program to fail
|
|
282
|
-
|
|
283
|
-
using SetThreadDescriptionFunc = HRESULT(WINAPI*)(HANDLE hThread, PCWSTR lpThreadDescription);
|
|
284
|
-
static SetThreadDescriptionFunc SetThreadDescription = reinterpret_cast<SetThreadDescriptionFunc>(GetProcAddress(GetModuleHandleW(L"Kernel32.dll"), "SetThreadDescription"));
|
|
285
|
-
|
|
286
|
-
JPH_SUPPRESS_WARNING_POP
|
|
287
|
-
|
|
288
|
-
if (SetThreadDescription)
|
|
289
|
-
{
|
|
290
|
-
wchar_t name_buffer[64] = { 0 };
|
|
291
|
-
if (MultiByteToWideChar(CP_UTF8, 0, inName, -1, name_buffer, sizeof(name_buffer) / sizeof(wchar_t) - 1) == 0)
|
|
292
|
-
return;
|
|
293
|
-
|
|
294
|
-
SetThreadDescription(GetCurrentThread(), name_buffer);
|
|
295
|
-
}
|
|
296
|
-
#if !defined(JPH_COMPILER_MINGW)
|
|
297
|
-
else if (IsDebuggerPresent())
|
|
298
|
-
RaiseThreadNameException(inName);
|
|
299
|
-
#endif // !JPH_COMPILER_MINGW
|
|
300
|
-
}
|
|
301
|
-
#elif defined(JPH_PLATFORM_LINUX)
|
|
302
|
-
static void SetThreadName(const char *inName)
|
|
303
|
-
{
|
|
304
|
-
JPH_ASSERT(strlen(inName) < 16); // String will be truncated if it is longer
|
|
305
|
-
prctl(PR_SET_NAME, inName, 0, 0, 0);
|
|
306
|
-
}
|
|
307
|
-
#endif // JPH_PLATFORM_LINUX
|
|
308
|
-
|
|
309
|
-
void JobSystemThreadPool::ThreadMain(int inThreadIndex)
|
|
310
|
-
{
|
|
311
|
-
// Name the thread
|
|
312
|
-
char name[64];
|
|
313
|
-
snprintf(name, sizeof(name), "Worker %d", int(inThreadIndex + 1));
|
|
314
|
-
|
|
315
|
-
#if defined(JPH_PLATFORM_WINDOWS) || defined(JPH_PLATFORM_LINUX)
|
|
316
|
-
SetThreadName(name);
|
|
317
|
-
#endif // JPH_PLATFORM_WINDOWS && !JPH_COMPILER_MINGW
|
|
318
|
-
|
|
319
|
-
// Enable floating point exceptions
|
|
320
|
-
FPExceptionsEnable enable_exceptions;
|
|
321
|
-
JPH_UNUSED(enable_exceptions);
|
|
322
|
-
|
|
323
|
-
JPH_PROFILE_THREAD_START(name);
|
|
324
|
-
|
|
325
|
-
// Call the thread init function
|
|
326
|
-
mThreadInitFunction(inThreadIndex);
|
|
327
|
-
|
|
328
|
-
atomic<uint> &head = mHeads[inThreadIndex];
|
|
329
|
-
|
|
330
|
-
while (!mQuit)
|
|
331
|
-
{
|
|
332
|
-
// Wait for jobs
|
|
333
|
-
mSemaphore.Acquire();
|
|
334
|
-
|
|
335
|
-
{
|
|
336
|
-
JPH_PROFILE("Executing Jobs");
|
|
337
|
-
|
|
338
|
-
// Loop over the queue
|
|
339
|
-
while (head != mTail)
|
|
340
|
-
{
|
|
341
|
-
// Exchange any job pointer we find with a nullptr
|
|
342
|
-
atomic<Job *> &job = mQueue[head & (cQueueLength - 1)];
|
|
343
|
-
if (job.load() != nullptr)
|
|
344
|
-
{
|
|
345
|
-
Job *job_ptr = job.exchange(nullptr);
|
|
346
|
-
if (job_ptr != nullptr)
|
|
347
|
-
{
|
|
348
|
-
// And execute it
|
|
349
|
-
job_ptr->Execute();
|
|
350
|
-
job_ptr->Release();
|
|
351
|
-
}
|
|
352
|
-
}
|
|
353
|
-
head++;
|
|
354
|
-
}
|
|
355
|
-
}
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
// Call the thread exit function
|
|
359
|
-
mThreadExitFunction(inThreadIndex);
|
|
360
|
-
|
|
361
|
-
JPH_PROFILE_THREAD_END();
|
|
362
|
-
}
|
|
363
|
-
|
|
364
|
-
JPH_NAMESPACE_END
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
// Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
|
|
2
|
-
// SPDX-FileCopyrightText: 2021 Jorrit Rouwe
|
|
3
|
-
// SPDX-License-Identifier: MIT
|
|
4
|
-
|
|
5
|
-
#pragma once
|
|
6
|
-
|
|
7
|
-
#include <Jolt/Core/JobSystemWithBarrier.h>
|
|
8
|
-
#include <Jolt/Core/FixedSizeFreeList.h>
|
|
9
|
-
#include <Jolt/Core/Semaphore.h>
|
|
10
|
-
|
|
11
|
-
JPH_SUPPRESS_WARNINGS_STD_BEGIN
|
|
12
|
-
#include <thread>
|
|
13
|
-
JPH_SUPPRESS_WARNINGS_STD_END
|
|
14
|
-
|
|
15
|
-
JPH_NAMESPACE_BEGIN
|
|
16
|
-
|
|
17
|
-
// Things we're using from STL
|
|
18
|
-
using std::thread;
|
|
19
|
-
|
|
20
|
-
/// Implementation of a JobSystem using a thread pool
|
|
21
|
-
///
|
|
22
|
-
/// Note that this is considered an example implementation. It is expected that when you integrate
|
|
23
|
-
/// the physics engine into your own project that you'll provide your own implementation of the
|
|
24
|
-
/// JobSystem built on top of whatever job system your project uses.
|
|
25
|
-
class JPH_EXPORT JobSystemThreadPool final : public JobSystemWithBarrier
|
|
26
|
-
{
|
|
27
|
-
public:
|
|
28
|
-
JPH_OVERRIDE_NEW_DELETE
|
|
29
|
-
|
|
30
|
-
/// Creates a thread pool.
|
|
31
|
-
/// @see JobSystemThreadPool::Init
|
|
32
|
-
JobSystemThreadPool(uint inMaxJobs, uint inMaxBarriers, int inNumThreads = -1);
|
|
33
|
-
JobSystemThreadPool() = default;
|
|
34
|
-
virtual ~JobSystemThreadPool() override;
|
|
35
|
-
|
|
36
|
-
/// Functions to call when a thread is initialized or exits, must be set before calling Init()
|
|
37
|
-
using InitExitFunction = function<void(int)>;
|
|
38
|
-
void SetThreadInitFunction(const InitExitFunction &inInitFunction) { mThreadInitFunction = inInitFunction; }
|
|
39
|
-
void SetThreadExitFunction(const InitExitFunction &inExitFunction) { mThreadExitFunction = inExitFunction; }
|
|
40
|
-
|
|
41
|
-
/// Initialize the thread pool
|
|
42
|
-
/// @param inMaxJobs Max number of jobs that can be allocated at any time
|
|
43
|
-
/// @param inMaxBarriers Max number of barriers that can be allocated at any time
|
|
44
|
-
/// @param inNumThreads Number of threads to start (the number of concurrent jobs is 1 more because the main thread will also run jobs while waiting for a barrier to complete). Use -1 to auto detect the amount of CPU's.
|
|
45
|
-
void Init(uint inMaxJobs, uint inMaxBarriers, int inNumThreads = -1);
|
|
46
|
-
|
|
47
|
-
// See JobSystem
|
|
48
|
-
virtual int GetMaxConcurrency() const override { return int(mThreads.size()) + 1; }
|
|
49
|
-
virtual JobHandle CreateJob(const char *inName, ColorArg inColor, const JobFunction &inJobFunction, uint32 inNumDependencies = 0) override;
|
|
50
|
-
|
|
51
|
-
/// Change the max concurrency after initialization
|
|
52
|
-
void SetNumThreads(int inNumThreads) { StopThreads(); StartThreads(inNumThreads); }
|
|
53
|
-
|
|
54
|
-
protected:
|
|
55
|
-
// See JobSystem
|
|
56
|
-
virtual void QueueJob(Job *inJob) override;
|
|
57
|
-
virtual void QueueJobs(Job **inJobs, uint inNumJobs) override;
|
|
58
|
-
virtual void FreeJob(Job *inJob) override;
|
|
59
|
-
|
|
60
|
-
private:
|
|
61
|
-
/// Start/stop the worker threads
|
|
62
|
-
void StartThreads(int inNumThreads);
|
|
63
|
-
void StopThreads();
|
|
64
|
-
|
|
65
|
-
/// Entry point for a thread
|
|
66
|
-
void ThreadMain(int inThreadIndex);
|
|
67
|
-
|
|
68
|
-
/// Get the head of the thread that has processed the least amount of jobs
|
|
69
|
-
inline uint GetHead() const;
|
|
70
|
-
|
|
71
|
-
/// Internal helper function to queue a job
|
|
72
|
-
inline void QueueJobInternal(Job *inJob);
|
|
73
|
-
|
|
74
|
-
/// Functions to call when initializing or exiting a thread
|
|
75
|
-
InitExitFunction mThreadInitFunction = [](int) { };
|
|
76
|
-
InitExitFunction mThreadExitFunction = [](int) { };
|
|
77
|
-
|
|
78
|
-
/// Array of jobs (fixed size)
|
|
79
|
-
using AvailableJobs = FixedSizeFreeList<Job>;
|
|
80
|
-
AvailableJobs mJobs;
|
|
81
|
-
|
|
82
|
-
/// Threads running jobs
|
|
83
|
-
Array<thread> mThreads;
|
|
84
|
-
|
|
85
|
-
// The job queue
|
|
86
|
-
static constexpr uint32 cQueueLength = 1024;
|
|
87
|
-
static_assert(IsPowerOf2(cQueueLength)); // We do bit operations and require queue length to be a power of 2
|
|
88
|
-
atomic<Job *> mQueue[cQueueLength];
|
|
89
|
-
|
|
90
|
-
// Head and tail of the queue, do this value modulo cQueueLength - 1 to get the element in the mQueue array
|
|
91
|
-
atomic<uint> * mHeads = nullptr; ///< Per executing thread the head of the current queue
|
|
92
|
-
alignas(JPH_CACHE_LINE_SIZE) atomic<uint> mTail = 0; ///< Tail (write end) of the queue
|
|
93
|
-
|
|
94
|
-
// Semaphore used to signal worker threads that there is new work
|
|
95
|
-
Semaphore mSemaphore;
|
|
96
|
-
|
|
97
|
-
/// Boolean to indicate that we want to stop the job system
|
|
98
|
-
atomic<bool> mQuit = false;
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
JPH_NAMESPACE_END
|
|
@@ -1,230 +0,0 @@
|
|
|
1
|
-
// Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
|
|
2
|
-
// SPDX-FileCopyrightText: 2023 Jorrit Rouwe
|
|
3
|
-
// SPDX-License-Identifier: MIT
|
|
4
|
-
|
|
5
|
-
#include <Jolt/Jolt.h>
|
|
6
|
-
|
|
7
|
-
#include <Jolt/Core/JobSystemWithBarrier.h>
|
|
8
|
-
#include <Jolt/Core/Profiler.h>
|
|
9
|
-
|
|
10
|
-
JPH_SUPPRESS_WARNINGS_STD_BEGIN
|
|
11
|
-
#include <thread>
|
|
12
|
-
JPH_SUPPRESS_WARNINGS_STD_END
|
|
13
|
-
|
|
14
|
-
JPH_NAMESPACE_BEGIN
|
|
15
|
-
|
|
16
|
-
JobSystemWithBarrier::BarrierImpl::BarrierImpl()
|
|
17
|
-
{
|
|
18
|
-
for (atomic<Job *> &j : mJobs)
|
|
19
|
-
j = nullptr;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
JobSystemWithBarrier::BarrierImpl::~BarrierImpl()
|
|
23
|
-
{
|
|
24
|
-
JPH_ASSERT(IsEmpty());
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
void JobSystemWithBarrier::BarrierImpl::AddJob(const JobHandle &inJob)
|
|
28
|
-
{
|
|
29
|
-
JPH_PROFILE_FUNCTION();
|
|
30
|
-
|
|
31
|
-
bool release_semaphore = false;
|
|
32
|
-
|
|
33
|
-
// Set the barrier on the job, this returns true if the barrier was successfully set (otherwise the job is already done and we don't need to add it to our list)
|
|
34
|
-
Job *job = inJob.GetPtr();
|
|
35
|
-
if (job->SetBarrier(this))
|
|
36
|
-
{
|
|
37
|
-
// If the job can be executed we want to release the semaphore an extra time to allow the waiting thread to start executing it
|
|
38
|
-
mNumToAcquire++;
|
|
39
|
-
if (job->CanBeExecuted())
|
|
40
|
-
{
|
|
41
|
-
release_semaphore = true;
|
|
42
|
-
mNumToAcquire++;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
// Add the job to our job list
|
|
46
|
-
job->AddRef();
|
|
47
|
-
uint write_index = mJobWriteIndex++;
|
|
48
|
-
while (write_index - mJobReadIndex >= cMaxJobs)
|
|
49
|
-
{
|
|
50
|
-
JPH_ASSERT(false, "Barrier full, stalling!");
|
|
51
|
-
std::this_thread::sleep_for(std::chrono::microseconds(100));
|
|
52
|
-
}
|
|
53
|
-
mJobs[write_index & (cMaxJobs - 1)] = job;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
// Notify waiting thread that a new executable job is available
|
|
57
|
-
if (release_semaphore)
|
|
58
|
-
mSemaphore.Release();
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
void JobSystemWithBarrier::BarrierImpl::AddJobs(const JobHandle *inHandles, uint inNumHandles)
|
|
62
|
-
{
|
|
63
|
-
JPH_PROFILE_FUNCTION();
|
|
64
|
-
|
|
65
|
-
bool release_semaphore = false;
|
|
66
|
-
|
|
67
|
-
for (const JobHandle *handle = inHandles, *handles_end = inHandles + inNumHandles; handle < handles_end; ++handle)
|
|
68
|
-
{
|
|
69
|
-
// Set the barrier on the job, this returns true if the barrier was successfully set (otherwise the job is already done and we don't need to add it to our list)
|
|
70
|
-
Job *job = handle->GetPtr();
|
|
71
|
-
if (job->SetBarrier(this))
|
|
72
|
-
{
|
|
73
|
-
// If the job can be executed we want to release the semaphore an extra time to allow the waiting thread to start executing it
|
|
74
|
-
mNumToAcquire++;
|
|
75
|
-
if (!release_semaphore && job->CanBeExecuted())
|
|
76
|
-
{
|
|
77
|
-
release_semaphore = true;
|
|
78
|
-
mNumToAcquire++;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
// Add the job to our job list
|
|
82
|
-
job->AddRef();
|
|
83
|
-
uint write_index = mJobWriteIndex++;
|
|
84
|
-
while (write_index - mJobReadIndex >= cMaxJobs)
|
|
85
|
-
{
|
|
86
|
-
JPH_ASSERT(false, "Barrier full, stalling!");
|
|
87
|
-
std::this_thread::sleep_for(std::chrono::microseconds(100));
|
|
88
|
-
}
|
|
89
|
-
mJobs[write_index & (cMaxJobs - 1)] = job;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
// Notify waiting thread that a new executable job is available
|
|
94
|
-
if (release_semaphore)
|
|
95
|
-
mSemaphore.Release();
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
void JobSystemWithBarrier::BarrierImpl::OnJobFinished(Job *inJob)
|
|
99
|
-
{
|
|
100
|
-
JPH_PROFILE_FUNCTION();
|
|
101
|
-
|
|
102
|
-
mSemaphore.Release();
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
void JobSystemWithBarrier::BarrierImpl::Wait()
|
|
106
|
-
{
|
|
107
|
-
while (mNumToAcquire > 0)
|
|
108
|
-
{
|
|
109
|
-
{
|
|
110
|
-
JPH_PROFILE("Execute Jobs");
|
|
111
|
-
|
|
112
|
-
// Go through all jobs
|
|
113
|
-
bool has_executed;
|
|
114
|
-
do
|
|
115
|
-
{
|
|
116
|
-
has_executed = false;
|
|
117
|
-
|
|
118
|
-
// Loop through the jobs and erase jobs from the beginning of the list that are done
|
|
119
|
-
while (mJobReadIndex < mJobWriteIndex)
|
|
120
|
-
{
|
|
121
|
-
atomic<Job *> &job = mJobs[mJobReadIndex & (cMaxJobs - 1)];
|
|
122
|
-
Job *job_ptr = job.load();
|
|
123
|
-
if (job_ptr == nullptr || !job_ptr->IsDone())
|
|
124
|
-
break;
|
|
125
|
-
|
|
126
|
-
// Job is finished, release it
|
|
127
|
-
job_ptr->Release();
|
|
128
|
-
job = nullptr;
|
|
129
|
-
++mJobReadIndex;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
// Loop through the jobs and execute the first executable job
|
|
133
|
-
for (uint index = mJobReadIndex; index < mJobWriteIndex; ++index)
|
|
134
|
-
{
|
|
135
|
-
const atomic<Job *> &job = mJobs[index & (cMaxJobs - 1)];
|
|
136
|
-
Job *job_ptr = job.load();
|
|
137
|
-
if (job_ptr != nullptr && job_ptr->CanBeExecuted())
|
|
138
|
-
{
|
|
139
|
-
// This will only execute the job if it has not already executed
|
|
140
|
-
job_ptr->Execute();
|
|
141
|
-
has_executed = true;
|
|
142
|
-
break;
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
} while (has_executed);
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
// Wait for another thread to wake us when either there is more work to do or when all jobs have completed.
|
|
150
|
-
// When there have been multiple releases, we acquire them all at the same time to avoid needlessly spinning on executing jobs.
|
|
151
|
-
// Note that using GetValue is inherently unsafe since we can read a stale value, but this is not an issue here as this is the only
|
|
152
|
-
// place where we acquire the semaphore. Other threads only release it, so we can only read a value that is lower or equal to the actual value.
|
|
153
|
-
int num_to_acquire = max(1, mSemaphore.GetValue());
|
|
154
|
-
mSemaphore.Acquire(num_to_acquire);
|
|
155
|
-
mNumToAcquire -= num_to_acquire;
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
// All jobs should be done now, release them
|
|
159
|
-
while (mJobReadIndex < mJobWriteIndex)
|
|
160
|
-
{
|
|
161
|
-
atomic<Job *> &job = mJobs[mJobReadIndex & (cMaxJobs - 1)];
|
|
162
|
-
Job *job_ptr = job.load();
|
|
163
|
-
JPH_ASSERT(job_ptr != nullptr && job_ptr->IsDone());
|
|
164
|
-
job_ptr->Release();
|
|
165
|
-
job = nullptr;
|
|
166
|
-
++mJobReadIndex;
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
void JobSystemWithBarrier::Init(uint inMaxBarriers)
|
|
171
|
-
{
|
|
172
|
-
JPH_ASSERT(mBarriers == nullptr); // Already initialized?
|
|
173
|
-
|
|
174
|
-
// Init freelist of barriers
|
|
175
|
-
mMaxBarriers = inMaxBarriers;
|
|
176
|
-
mBarriers = new BarrierImpl [inMaxBarriers];
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
JobSystemWithBarrier::JobSystemWithBarrier(uint inMaxBarriers)
|
|
180
|
-
{
|
|
181
|
-
Init(inMaxBarriers);
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
JobSystemWithBarrier::~JobSystemWithBarrier()
|
|
185
|
-
{
|
|
186
|
-
// Ensure that none of the barriers are used
|
|
187
|
-
#ifdef JPH_ENABLE_ASSERTS
|
|
188
|
-
for (const BarrierImpl *b = mBarriers, *b_end = mBarriers + mMaxBarriers; b < b_end; ++b)
|
|
189
|
-
JPH_ASSERT(!b->mInUse);
|
|
190
|
-
#endif // JPH_ENABLE_ASSERTS
|
|
191
|
-
delete [] mBarriers;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
JobSystem::Barrier *JobSystemWithBarrier::CreateBarrier()
|
|
195
|
-
{
|
|
196
|
-
JPH_PROFILE_FUNCTION();
|
|
197
|
-
|
|
198
|
-
// Find the first unused barrier
|
|
199
|
-
for (uint32 index = 0; index < mMaxBarriers; ++index)
|
|
200
|
-
{
|
|
201
|
-
bool expected = false;
|
|
202
|
-
if (mBarriers[index].mInUse.compare_exchange_strong(expected, true))
|
|
203
|
-
return &mBarriers[index];
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
return nullptr;
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
void JobSystemWithBarrier::DestroyBarrier(Barrier *inBarrier)
|
|
210
|
-
{
|
|
211
|
-
JPH_PROFILE_FUNCTION();
|
|
212
|
-
|
|
213
|
-
// Check that no jobs are in the barrier
|
|
214
|
-
JPH_ASSERT(static_cast<BarrierImpl *>(inBarrier)->IsEmpty());
|
|
215
|
-
|
|
216
|
-
// Flag the barrier as unused
|
|
217
|
-
bool expected = true;
|
|
218
|
-
static_cast<BarrierImpl *>(inBarrier)->mInUse.compare_exchange_strong(expected, false);
|
|
219
|
-
JPH_ASSERT(expected);
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
void JobSystemWithBarrier::WaitForJobs(Barrier *inBarrier)
|
|
223
|
-
{
|
|
224
|
-
JPH_PROFILE_FUNCTION();
|
|
225
|
-
|
|
226
|
-
// Let our barrier implementation wait for the jobs
|
|
227
|
-
static_cast<BarrierImpl *>(inBarrier)->Wait();
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
JPH_NAMESPACE_END
|