@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.
Files changed (494) hide show
  1. package/native/shared/build.rs +137 -6
  2. package/package.json +4 -11
  3. package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/build.gradle +0 -51
  4. package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/src/main/AndroidManifest.xml +0 -20
  5. package/native/third_party/JoltPhysics/Build/Android/PerformanceTest/src/main/cpp/CMakeLists.txt +0 -20
  6. package/native/third_party/JoltPhysics/Build/Android/UnitTests/build.gradle +0 -51
  7. package/native/third_party/JoltPhysics/Build/Android/UnitTests/src/main/AndroidManifest.xml +0 -20
  8. package/native/third_party/JoltPhysics/Build/Android/UnitTests/src/main/cpp/CMakeLists.txt +0 -20
  9. package/native/third_party/JoltPhysics/Build/Android/build.gradle +0 -17
  10. package/native/third_party/JoltPhysics/Build/Android/gradle/wrapper/gradle-wrapper.jar +0 -0
  11. package/native/third_party/JoltPhysics/Build/Android/gradle/wrapper/gradle-wrapper.properties +0 -5
  12. package/native/third_party/JoltPhysics/Build/Android/gradle.properties +0 -21
  13. package/native/third_party/JoltPhysics/Build/Android/gradlew +0 -185
  14. package/native/third_party/JoltPhysics/Build/Android/gradlew.bat +0 -89
  15. package/native/third_party/JoltPhysics/Build/Android/settings.gradle +0 -10
  16. package/native/third_party/JoltPhysics/Build/CMakeLists.txt +0 -449
  17. package/native/third_party/JoltPhysics/Build/README.md +0 -250
  18. package/native/third_party/JoltPhysics/Build/cmake_linux_clang_gcc.sh +0 -28
  19. package/native/third_party/JoltPhysics/Build/cmake_linux_emscripten.sh +0 -19
  20. package/native/third_party/JoltPhysics/Build/cmake_linux_mingw.sh +0 -19
  21. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl.bat +0 -3
  22. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_32bit.bat +0 -3
  23. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_arm.bat +0 -3
  24. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_arm_32bit.bat +0 -4
  25. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_cross_platform_deterministic.bat +0 -3
  26. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_double.bat +0 -3
  27. package/native/third_party/JoltPhysics/Build/cmake_vs2022_cl_no_object_stream.bat +0 -3
  28. package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang.bat +0 -10
  29. package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang_cross_platform_deterministic.bat +0 -10
  30. package/native/third_party/JoltPhysics/Build/cmake_vs2022_clang_double.bat +0 -10
  31. package/native/third_party/JoltPhysics/Build/cmake_vs2022_uwp.bat +0 -5
  32. package/native/third_party/JoltPhysics/Build/cmake_vs2022_uwp_arm.bat +0 -5
  33. package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl.bat +0 -3
  34. package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl_cross_platform_deterministic.bat +0 -3
  35. package/native/third_party/JoltPhysics/Build/cmake_vs2026_cl_double.bat +0 -3
  36. package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang.bat +0 -10
  37. package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang_cross_platform_deterministic.bat +0 -10
  38. package/native/third_party/JoltPhysics/Build/cmake_vs2026_clang_double.bat +0 -10
  39. package/native/third_party/JoltPhysics/Build/cmake_windows_mingw.sh +0 -19
  40. package/native/third_party/JoltPhysics/Build/cmake_xcode_ios.sh +0 -4
  41. package/native/third_party/JoltPhysics/Build/cmake_xcode_macos.sh +0 -4
  42. package/native/third_party/JoltPhysics/Build/iOS/JoltViewerInfo.plist +0 -34
  43. package/native/third_party/JoltPhysics/Build/iOS/SamplesInfo.plist +0 -34
  44. package/native/third_party/JoltPhysics/Build/iOS/UnitTestsInfo.plist +0 -34
  45. package/native/third_party/JoltPhysics/Build/macOS/icon.icns +0 -0
  46. package/native/third_party/JoltPhysics/Build/macos_install_vulkan_sdk.sh +0 -13
  47. package/native/third_party/JoltPhysics/Build/ubuntu24_install_vulkan_sdk.sh +0 -4
  48. package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeBuilder.cpp +0 -242
  49. package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeBuilder.h +0 -121
  50. package/native/third_party/JoltPhysics/Jolt/AABBTree/AABBTreeToBuffer.h +0 -296
  51. package/native/third_party/JoltPhysics/Jolt/AABBTree/NodeCodec/NodeCodecQuadTreeHalfFloat.h +0 -323
  52. package/native/third_party/JoltPhysics/Jolt/AABBTree/TriangleCodec/TriangleCodecIndexed8BitPackSOA4Flags.h +0 -555
  53. package/native/third_party/JoltPhysics/Jolt/ConfigurationString.h +0 -112
  54. package/native/third_party/JoltPhysics/Jolt/Core/ARMNeon.h +0 -94
  55. package/native/third_party/JoltPhysics/Jolt/Core/Array.h +0 -713
  56. package/native/third_party/JoltPhysics/Jolt/Core/Atomics.h +0 -44
  57. package/native/third_party/JoltPhysics/Jolt/Core/BinaryHeap.h +0 -96
  58. package/native/third_party/JoltPhysics/Jolt/Core/ByteBuffer.h +0 -74
  59. package/native/third_party/JoltPhysics/Jolt/Core/Color.cpp +0 -38
  60. package/native/third_party/JoltPhysics/Jolt/Core/Color.h +0 -98
  61. package/native/third_party/JoltPhysics/Jolt/Core/Core.h +0 -652
  62. package/native/third_party/JoltPhysics/Jolt/Core/FPControlWord.h +0 -143
  63. package/native/third_party/JoltPhysics/Jolt/Core/FPException.h +0 -96
  64. package/native/third_party/JoltPhysics/Jolt/Core/FPFlushDenormals.h +0 -43
  65. package/native/third_party/JoltPhysics/Jolt/Core/Factory.cpp +0 -92
  66. package/native/third_party/JoltPhysics/Jolt/Core/Factory.h +0 -54
  67. package/native/third_party/JoltPhysics/Jolt/Core/FixedSizeFreeList.h +0 -122
  68. package/native/third_party/JoltPhysics/Jolt/Core/FixedSizeFreeList.inl +0 -215
  69. package/native/third_party/JoltPhysics/Jolt/Core/HashCombine.h +0 -234
  70. package/native/third_party/JoltPhysics/Jolt/Core/HashTable.h +0 -876
  71. package/native/third_party/JoltPhysics/Jolt/Core/InsertionSort.h +0 -58
  72. package/native/third_party/JoltPhysics/Jolt/Core/IssueReporting.cpp +0 -27
  73. package/native/third_party/JoltPhysics/Jolt/Core/IssueReporting.h +0 -38
  74. package/native/third_party/JoltPhysics/Jolt/Core/JobSystem.h +0 -311
  75. package/native/third_party/JoltPhysics/Jolt/Core/JobSystem.inl +0 -56
  76. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemSingleThreaded.cpp +0 -65
  77. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemSingleThreaded.h +0 -62
  78. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemThreadPool.cpp +0 -364
  79. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemThreadPool.h +0 -101
  80. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemWithBarrier.cpp +0 -230
  81. package/native/third_party/JoltPhysics/Jolt/Core/JobSystemWithBarrier.h +0 -85
  82. package/native/third_party/JoltPhysics/Jolt/Core/LinearCurve.cpp +0 -51
  83. package/native/third_party/JoltPhysics/Jolt/Core/LinearCurve.h +0 -67
  84. package/native/third_party/JoltPhysics/Jolt/Core/LockFreeHashMap.h +0 -182
  85. package/native/third_party/JoltPhysics/Jolt/Core/LockFreeHashMap.inl +0 -351
  86. package/native/third_party/JoltPhysics/Jolt/Core/Memory.cpp +0 -85
  87. package/native/third_party/JoltPhysics/Jolt/Core/Memory.h +0 -85
  88. package/native/third_party/JoltPhysics/Jolt/Core/Mutex.h +0 -223
  89. package/native/third_party/JoltPhysics/Jolt/Core/MutexArray.h +0 -98
  90. package/native/third_party/JoltPhysics/Jolt/Core/NonCopyable.h +0 -18
  91. package/native/third_party/JoltPhysics/Jolt/Core/Profiler.cpp +0 -677
  92. package/native/third_party/JoltPhysics/Jolt/Core/Profiler.h +0 -301
  93. package/native/third_party/JoltPhysics/Jolt/Core/Profiler.inl +0 -90
  94. package/native/third_party/JoltPhysics/Jolt/Core/QuickSort.h +0 -137
  95. package/native/third_party/JoltPhysics/Jolt/Core/RTTI.cpp +0 -149
  96. package/native/third_party/JoltPhysics/Jolt/Core/RTTI.h +0 -436
  97. package/native/third_party/JoltPhysics/Jolt/Core/Reference.h +0 -244
  98. package/native/third_party/JoltPhysics/Jolt/Core/Result.h +0 -174
  99. package/native/third_party/JoltPhysics/Jolt/Core/STLAlignedAllocator.h +0 -72
  100. package/native/third_party/JoltPhysics/Jolt/Core/STLAllocator.h +0 -127
  101. package/native/third_party/JoltPhysics/Jolt/Core/STLLocalAllocator.h +0 -170
  102. package/native/third_party/JoltPhysics/Jolt/Core/STLTempAllocator.h +0 -80
  103. package/native/third_party/JoltPhysics/Jolt/Core/ScopeExit.h +0 -49
  104. package/native/third_party/JoltPhysics/Jolt/Core/Semaphore.cpp +0 -135
  105. package/native/third_party/JoltPhysics/Jolt/Core/Semaphore.h +0 -68
  106. package/native/third_party/JoltPhysics/Jolt/Core/StaticArray.h +0 -329
  107. package/native/third_party/JoltPhysics/Jolt/Core/StreamIn.h +0 -120
  108. package/native/third_party/JoltPhysics/Jolt/Core/StreamOut.h +0 -97
  109. package/native/third_party/JoltPhysics/Jolt/Core/StreamUtils.h +0 -168
  110. package/native/third_party/JoltPhysics/Jolt/Core/StreamWrapper.h +0 -53
  111. package/native/third_party/JoltPhysics/Jolt/Core/StridedPtr.h +0 -63
  112. package/native/third_party/JoltPhysics/Jolt/Core/StringTools.cpp +0 -101
  113. package/native/third_party/JoltPhysics/Jolt/Core/StringTools.h +0 -38
  114. package/native/third_party/JoltPhysics/Jolt/Core/TempAllocator.h +0 -209
  115. package/native/third_party/JoltPhysics/Jolt/Core/TickCounter.cpp +0 -37
  116. package/native/third_party/JoltPhysics/Jolt/Core/TickCounter.h +0 -58
  117. package/native/third_party/JoltPhysics/Jolt/Core/UnorderedMap.h +0 -80
  118. package/native/third_party/JoltPhysics/Jolt/Core/UnorderedSet.h +0 -32
  119. package/native/third_party/JoltPhysics/Jolt/Geometry/AABox.h +0 -313
  120. package/native/third_party/JoltPhysics/Jolt/Geometry/AABox4.h +0 -224
  121. package/native/third_party/JoltPhysics/Jolt/Geometry/ClipPoly.h +0 -200
  122. package/native/third_party/JoltPhysics/Jolt/Geometry/ClosestPoint.h +0 -498
  123. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder.cpp +0 -1467
  124. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder.h +0 -276
  125. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder2D.cpp +0 -335
  126. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexHullBuilder2D.h +0 -105
  127. package/native/third_party/JoltPhysics/Jolt/Geometry/ConvexSupport.h +0 -188
  128. package/native/third_party/JoltPhysics/Jolt/Geometry/EPAConvexHullBuilder.h +0 -845
  129. package/native/third_party/JoltPhysics/Jolt/Geometry/EPAPenetrationDepth.h +0 -557
  130. package/native/third_party/JoltPhysics/Jolt/Geometry/Ellipse.h +0 -77
  131. package/native/third_party/JoltPhysics/Jolt/Geometry/GJKClosestPoint.h +0 -945
  132. package/native/third_party/JoltPhysics/Jolt/Geometry/IndexedTriangle.h +0 -130
  133. package/native/third_party/JoltPhysics/Jolt/Geometry/Indexify.cpp +0 -222
  134. package/native/third_party/JoltPhysics/Jolt/Geometry/Indexify.h +0 -19
  135. package/native/third_party/JoltPhysics/Jolt/Geometry/MortonCode.h +0 -40
  136. package/native/third_party/JoltPhysics/Jolt/Geometry/OrientedBox.cpp +0 -178
  137. package/native/third_party/JoltPhysics/Jolt/Geometry/OrientedBox.h +0 -39
  138. package/native/third_party/JoltPhysics/Jolt/Geometry/Plane.h +0 -104
  139. package/native/third_party/JoltPhysics/Jolt/Geometry/RayAABox.h +0 -241
  140. package/native/third_party/JoltPhysics/Jolt/Geometry/RayCapsule.h +0 -37
  141. package/native/third_party/JoltPhysics/Jolt/Geometry/RayCylinder.h +0 -101
  142. package/native/third_party/JoltPhysics/Jolt/Geometry/RaySphere.h +0 -96
  143. package/native/third_party/JoltPhysics/Jolt/Geometry/RayTriangle.h +0 -158
  144. package/native/third_party/JoltPhysics/Jolt/Geometry/Sphere.h +0 -72
  145. package/native/third_party/JoltPhysics/Jolt/Geometry/Triangle.h +0 -34
  146. package/native/third_party/JoltPhysics/Jolt/Jolt.cmake +0 -703
  147. package/native/third_party/JoltPhysics/Jolt/Jolt.h +0 -16
  148. package/native/third_party/JoltPhysics/Jolt/Jolt.natvis +0 -116
  149. package/native/third_party/JoltPhysics/Jolt/Math/BVec16.h +0 -99
  150. package/native/third_party/JoltPhysics/Jolt/Math/BVec16.inl +0 -177
  151. package/native/third_party/JoltPhysics/Jolt/Math/DMat44.h +0 -158
  152. package/native/third_party/JoltPhysics/Jolt/Math/DMat44.inl +0 -310
  153. package/native/third_party/JoltPhysics/Jolt/Math/DVec3.h +0 -291
  154. package/native/third_party/JoltPhysics/Jolt/Math/DVec3.inl +0 -941
  155. package/native/third_party/JoltPhysics/Jolt/Math/Double3.h +0 -48
  156. package/native/third_party/JoltPhysics/Jolt/Math/DynMatrix.h +0 -31
  157. package/native/third_party/JoltPhysics/Jolt/Math/EigenValueSymmetric.h +0 -177
  158. package/native/third_party/JoltPhysics/Jolt/Math/FindRoot.h +0 -42
  159. package/native/third_party/JoltPhysics/Jolt/Math/Float2.h +0 -36
  160. package/native/third_party/JoltPhysics/Jolt/Math/Float3.h +0 -50
  161. package/native/third_party/JoltPhysics/Jolt/Math/Float4.h +0 -44
  162. package/native/third_party/JoltPhysics/Jolt/Math/GaussianElimination.h +0 -102
  163. package/native/third_party/JoltPhysics/Jolt/Math/HalfFloat.h +0 -208
  164. package/native/third_party/JoltPhysics/Jolt/Math/Mat44.h +0 -243
  165. package/native/third_party/JoltPhysics/Jolt/Math/Mat44.inl +0 -952
  166. package/native/third_party/JoltPhysics/Jolt/Math/Math.h +0 -208
  167. package/native/third_party/JoltPhysics/Jolt/Math/MathTypes.h +0 -32
  168. package/native/third_party/JoltPhysics/Jolt/Math/Matrix.h +0 -259
  169. package/native/third_party/JoltPhysics/Jolt/Math/Quat.h +0 -268
  170. package/native/third_party/JoltPhysics/Jolt/Math/Quat.inl +0 -406
  171. package/native/third_party/JoltPhysics/Jolt/Math/Real.h +0 -44
  172. package/native/third_party/JoltPhysics/Jolt/Math/Swizzle.h +0 -19
  173. package/native/third_party/JoltPhysics/Jolt/Math/Trigonometry.h +0 -79
  174. package/native/third_party/JoltPhysics/Jolt/Math/UVec4.h +0 -232
  175. package/native/third_party/JoltPhysics/Jolt/Math/UVec4.inl +0 -636
  176. package/native/third_party/JoltPhysics/Jolt/Math/Vec3.cpp +0 -71
  177. package/native/third_party/JoltPhysics/Jolt/Math/Vec3.h +0 -308
  178. package/native/third_party/JoltPhysics/Jolt/Math/Vec3.inl +0 -942
  179. package/native/third_party/JoltPhysics/Jolt/Math/Vec4.h +0 -320
  180. package/native/third_party/JoltPhysics/Jolt/Math/Vec4.inl +0 -1152
  181. package/native/third_party/JoltPhysics/Jolt/Math/Vector.h +0 -211
  182. package/native/third_party/JoltPhysics/Jolt/ObjectStream/GetPrimitiveTypeOfType.h +0 -54
  183. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStream.cpp +0 -38
  184. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStream.h +0 -337
  185. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryIn.cpp +0 -252
  186. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryIn.h +0 -57
  187. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryOut.cpp +0 -165
  188. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamBinaryOut.h +0 -57
  189. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamIn.cpp +0 -635
  190. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamIn.h +0 -148
  191. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamOut.cpp +0 -166
  192. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamOut.h +0 -101
  193. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextIn.cpp +0 -418
  194. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextIn.h +0 -55
  195. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextOut.cpp +0 -255
  196. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTextOut.h +0 -62
  197. package/native/third_party/JoltPhysics/Jolt/ObjectStream/ObjectStreamTypes.h +0 -26
  198. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttribute.h +0 -111
  199. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttributeEnum.h +0 -67
  200. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableAttributeTyped.h +0 -60
  201. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableObject.cpp +0 -15
  202. package/native/third_party/JoltPhysics/Jolt/ObjectStream/SerializableObject.h +0 -170
  203. package/native/third_party/JoltPhysics/Jolt/ObjectStream/TypeDeclarations.cpp +0 -70
  204. package/native/third_party/JoltPhysics/Jolt/ObjectStream/TypeDeclarations.h +0 -45
  205. package/native/third_party/JoltPhysics/Jolt/Physics/Body/AllowedDOFs.h +0 -68
  206. package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.cpp +0 -426
  207. package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.h +0 -452
  208. package/native/third_party/JoltPhysics/Jolt/Physics/Body/Body.inl +0 -197
  209. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyAccess.h +0 -68
  210. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyActivationListener.h +0 -28
  211. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyCreationSettings.cpp +0 -234
  212. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyCreationSettings.h +0 -124
  213. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyFilter.h +0 -130
  214. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyID.h +0 -101
  215. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyInterface.cpp +0 -1099
  216. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyInterface.h +0 -324
  217. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLock.h +0 -111
  218. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLockInterface.h +0 -134
  219. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyLockMulti.h +0 -120
  220. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyManager.cpp +0 -1220
  221. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyManager.h +0 -403
  222. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyPair.h +0 -36
  223. package/native/third_party/JoltPhysics/Jolt/Physics/Body/BodyType.h +0 -19
  224. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MassProperties.cpp +0 -185
  225. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MassProperties.h +0 -58
  226. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.cpp +0 -92
  227. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.h +0 -308
  228. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionProperties.inl +0 -178
  229. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionQuality.h +0 -31
  230. package/native/third_party/JoltPhysics/Jolt/Physics/Body/MotionType.h +0 -17
  231. package/native/third_party/JoltPhysics/Jolt/Physics/Character/Character.cpp +0 -354
  232. package/native/third_party/JoltPhysics/Jolt/Physics/Character/Character.h +0 -159
  233. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterBase.cpp +0 -59
  234. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterBase.h +0 -157
  235. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterID.h +0 -98
  236. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterVirtual.cpp +0 -1933
  237. package/native/third_party/JoltPhysics/Jolt/Physics/Character/CharacterVirtual.h +0 -752
  238. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/AABoxCast.h +0 -20
  239. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ActiveEdgeMode.h +0 -17
  240. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ActiveEdges.h +0 -114
  241. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BackFaceMode.h +0 -16
  242. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhase.cpp +0 -16
  243. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhase.h +0 -109
  244. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseBruteForce.cpp +0 -313
  245. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseBruteForce.h +0 -38
  246. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayer.h +0 -148
  247. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayerInterfaceMask.h +0 -92
  248. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseLayerInterfaceTable.h +0 -64
  249. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuadTree.cpp +0 -629
  250. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuadTree.h +0 -108
  251. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/BroadPhaseQuery.h +0 -56
  252. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/ObjectVsBroadPhaseLayerFilterMask.h +0 -35
  253. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/ObjectVsBroadPhaseLayerFilterTable.h +0 -66
  254. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/QuadTree.cpp +0 -1768
  255. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/BroadPhase/QuadTree.h +0 -389
  256. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastConvexVsTriangles.cpp +0 -107
  257. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastConvexVsTriangles.h +0 -46
  258. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastResult.h +0 -37
  259. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastSphereVsTriangles.cpp +0 -223
  260. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CastSphereVsTriangles.h +0 -49
  261. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollectFacesMode.h +0 -16
  262. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideConvexVsTriangles.cpp +0 -155
  263. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideConvexVsTriangles.h +0 -56
  264. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollidePointResult.h +0 -25
  265. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideShape.h +0 -106
  266. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideShapeVsShapePerLeaf.h +0 -94
  267. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSoftBodyVertexIterator.h +0 -110
  268. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSoftBodyVerticesVsTriangles.h +0 -102
  269. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSphereVsTriangles.cpp +0 -121
  270. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollideSphereVsTriangles.h +0 -50
  271. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionCollector.h +0 -109
  272. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionCollectorImpl.h +0 -219
  273. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionDispatch.cpp +0 -107
  274. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionDispatch.h +0 -97
  275. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionGroup.cpp +0 -35
  276. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/CollisionGroup.h +0 -97
  277. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ContactListener.h +0 -143
  278. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/EstimateCollisionResponse.cpp +0 -213
  279. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/EstimateCollisionResponse.h +0 -48
  280. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilter.cpp +0 -32
  281. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilter.h +0 -46
  282. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilterTable.cpp +0 -38
  283. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/GroupFilterTable.h +0 -130
  284. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/InternalEdgeRemovingCollector.h +0 -279
  285. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ManifoldBetweenTwoFaces.cpp +0 -271
  286. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ManifoldBetweenTwoFaces.h +0 -44
  287. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseQuery.cpp +0 -448
  288. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseQuery.h +0 -77
  289. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseStats.cpp +0 -62
  290. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/NarrowPhaseStats.h +0 -110
  291. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayer.h +0 -111
  292. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayerPairFilterMask.h +0 -52
  293. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ObjectLayerPairFilterTable.h +0 -78
  294. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterial.cpp +0 -35
  295. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterial.h +0 -57
  296. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterialSimple.cpp +0 -38
  297. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/PhysicsMaterialSimple.h +0 -37
  298. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/RayCast.h +0 -87
  299. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/BoxShape.cpp +0 -318
  300. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/BoxShape.h +0 -115
  301. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CapsuleShape.cpp +0 -438
  302. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CapsuleShape.h +0 -129
  303. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShape.cpp +0 -433
  304. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShape.h +0 -354
  305. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CompoundShapeVisitors.h +0 -461
  306. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexHullShape.cpp +0 -1311
  307. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexHullShape.h +0 -202
  308. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexShape.cpp +0 -566
  309. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ConvexShape.h +0 -150
  310. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CylinderShape.cpp +0 -418
  311. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/CylinderShape.h +0 -126
  312. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/DecoratedShape.cpp +0 -87
  313. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/DecoratedShape.h +0 -80
  314. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/EmptyShape.cpp +0 -64
  315. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/EmptyShape.h +0 -75
  316. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/GetTrianglesContext.h +0 -248
  317. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/HeightFieldShape.cpp +0 -2754
  318. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/HeightFieldShape.h +0 -380
  319. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MeshShape.cpp +0 -1305
  320. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MeshShape.h +0 -228
  321. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MutableCompoundShape.cpp +0 -596
  322. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/MutableCompoundShape.h +0 -176
  323. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/OffsetCenterOfMassShape.cpp +0 -217
  324. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/OffsetCenterOfMassShape.h +0 -140
  325. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PlaneShape.cpp +0 -541
  326. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PlaneShape.h +0 -147
  327. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/PolyhedronSubmergedVolumeCalculator.h +0 -319
  328. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/RotatedTranslatedShape.cpp +0 -333
  329. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/RotatedTranslatedShape.h +0 -161
  330. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaleHelpers.h +0 -83
  331. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaledShape.cpp +0 -238
  332. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/ScaledShape.h +0 -145
  333. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/Shape.cpp +0 -325
  334. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/Shape.h +0 -466
  335. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SphereShape.cpp +0 -347
  336. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SphereShape.h +0 -125
  337. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/StaticCompoundShape.cpp +0 -674
  338. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/StaticCompoundShape.h +0 -139
  339. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SubShapeID.h +0 -138
  340. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/SubShapeIDPair.h +0 -65
  341. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.cpp +0 -453
  342. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.gliffy +0 -1
  343. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCapsuleShape.h +0 -135
  344. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCylinderShape.cpp +0 -691
  345. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TaperedCylinderShape.h +0 -132
  346. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TriangleShape.cpp +0 -430
  347. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/Shape/TriangleShape.h +0 -143
  348. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ShapeCast.h +0 -173
  349. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/ShapeFilter.h +0 -73
  350. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SimShapeFilter.h +0 -40
  351. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SimShapeFilterWrapper.h +0 -58
  352. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/SortReverseAndStore.h +0 -48
  353. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/TransformedShape.cpp +0 -180
  354. package/native/third_party/JoltPhysics/Jolt/Physics/Collision/TransformedShape.h +0 -194
  355. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/CalculateSolverSteps.h +0 -70
  356. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConeConstraint.cpp +0 -246
  357. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConeConstraint.h +0 -133
  358. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/Constraint.cpp +0 -73
  359. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/Constraint.h +0 -243
  360. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintManager.cpp +0 -289
  361. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintManager.h +0 -100
  362. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/AngleConstraintPart.h +0 -257
  363. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/AxisConstraintPart.h +0 -682
  364. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/DualAxisConstraintPart.h +0 -276
  365. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/GearConstraintPart.h +0 -195
  366. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/HingeRotationConstraintPart.h +0 -222
  367. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/IndependentAxisConstraintPart.h +0 -246
  368. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/PointConstraintPart.h +0 -239
  369. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RackAndPinionConstraintPart.h +0 -196
  370. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RotationEulerConstraintPart.h +0 -283
  371. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/RotationQuatConstraintPart.h +0 -246
  372. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/SpringPart.h +0 -169
  373. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ConstraintPart/SwingTwistConstraintPart.h +0 -597
  374. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ContactConstraintManager.cpp +0 -1804
  375. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/ContactConstraintManager.h +0 -524
  376. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/DistanceConstraint.cpp +0 -266
  377. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/DistanceConstraint.h +0 -120
  378. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/FixedConstraint.cpp +0 -215
  379. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/FixedConstraint.h +0 -96
  380. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/GearConstraint.cpp +0 -188
  381. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/GearConstraint.h +0 -116
  382. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/HingeConstraint.cpp +0 -443
  383. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/HingeConstraint.h +0 -205
  384. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/MotorSettings.cpp +0 -43
  385. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/MotorSettings.h +0 -66
  386. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraint.cpp +0 -458
  387. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraint.h +0 -191
  388. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPath.cpp +0 -85
  389. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPath.h +0 -76
  390. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPathHermite.cpp +0 -308
  391. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PathConstraintPathHermite.h +0 -54
  392. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PointConstraint.cpp +0 -157
  393. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PointConstraint.h +0 -94
  394. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PulleyConstraint.cpp +0 -253
  395. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/PulleyConstraint.h +0 -137
  396. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/RackAndPinionConstraint.cpp +0 -189
  397. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/RackAndPinionConstraint.h +0 -118
  398. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SixDOFConstraint.cpp +0 -900
  399. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SixDOFConstraint.h +0 -289
  400. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SliderConstraint.cpp +0 -501
  401. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SliderConstraint.h +0 -198
  402. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SpringSettings.cpp +0 -35
  403. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SpringSettings.h +0 -70
  404. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SwingTwistConstraint.cpp +0 -524
  405. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/SwingTwistConstraint.h +0 -197
  406. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/TwoBodyConstraint.cpp +0 -56
  407. package/native/third_party/JoltPhysics/Jolt/Physics/Constraints/TwoBodyConstraint.h +0 -65
  408. package/native/third_party/JoltPhysics/Jolt/Physics/DeterminismLog.cpp +0 -17
  409. package/native/third_party/JoltPhysics/Jolt/Physics/DeterminismLog.h +0 -159
  410. package/native/third_party/JoltPhysics/Jolt/Physics/EActivation.h +0 -16
  411. package/native/third_party/JoltPhysics/Jolt/Physics/EPhysicsUpdateError.h +0 -37
  412. package/native/third_party/JoltPhysics/Jolt/Physics/IslandBuilder.cpp +0 -492
  413. package/native/third_party/JoltPhysics/Jolt/Physics/IslandBuilder.h +0 -144
  414. package/native/third_party/JoltPhysics/Jolt/Physics/LargeIslandSplitter.cpp +0 -582
  415. package/native/third_party/JoltPhysics/Jolt/Physics/LargeIslandSplitter.h +0 -187
  416. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsLock.h +0 -169
  417. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsScene.cpp +0 -261
  418. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsScene.h +0 -104
  419. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSettings.h +0 -125
  420. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsStepListener.h +0 -37
  421. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSystem.cpp +0 -2915
  422. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsSystem.h +0 -391
  423. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsUpdateContext.cpp +0 -25
  424. package/native/third_party/JoltPhysics/Jolt/Physics/PhysicsUpdateContext.h +0 -176
  425. package/native/third_party/JoltPhysics/Jolt/Physics/Ragdoll/Ragdoll.cpp +0 -744
  426. package/native/third_party/JoltPhysics/Jolt/Physics/Ragdoll/Ragdoll.h +0 -245
  427. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyContactListener.h +0 -55
  428. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyCreationSettings.cpp +0 -128
  429. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyCreationSettings.h +0 -75
  430. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyManifold.h +0 -74
  431. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyMotionProperties.cpp +0 -1501
  432. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyMotionProperties.h +0 -333
  433. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyShape.cpp +0 -354
  434. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyShape.h +0 -73
  435. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodySharedSettings.cpp +0 -1487
  436. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodySharedSettings.h +0 -390
  437. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyUpdateContext.h +0 -63
  438. package/native/third_party/JoltPhysics/Jolt/Physics/SoftBody/SoftBodyVertex.h +0 -36
  439. package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorder.h +0 -136
  440. package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorderImpl.cpp +0 -90
  441. package/native/third_party/JoltPhysics/Jolt/Physics/StateRecorderImpl.h +0 -50
  442. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/MotorcycleController.cpp +0 -306
  443. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/MotorcycleController.h +0 -119
  444. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/TrackedVehicleController.cpp +0 -547
  445. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/TrackedVehicleController.h +0 -169
  446. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleAntiRollBar.cpp +0 -33
  447. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleAntiRollBar.h +0 -33
  448. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleCollisionTester.cpp +0 -376
  449. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleCollisionTester.h +0 -146
  450. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleConstraint.cpp +0 -703
  451. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleConstraint.h +0 -252
  452. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleController.cpp +0 -17
  453. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleController.h +0 -87
  454. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleDifferential.cpp +0 -81
  455. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleDifferential.h +0 -39
  456. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleEngine.cpp +0 -122
  457. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleEngine.h +0 -93
  458. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTrack.cpp +0 -52
  459. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTrack.h +0 -56
  460. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTransmission.cpp +0 -159
  461. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/VehicleTransmission.h +0 -87
  462. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/Wheel.cpp +0 -93
  463. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/Wheel.h +0 -148
  464. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/WheeledVehicleController.cpp +0 -866
  465. package/native/third_party/JoltPhysics/Jolt/Physics/Vehicle/WheeledVehicleController.h +0 -205
  466. package/native/third_party/JoltPhysics/Jolt/RegisterTypes.cpp +0 -204
  467. package/native/third_party/JoltPhysics/Jolt/RegisterTypes.h +0 -29
  468. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRenderer.cpp +0 -1107
  469. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRenderer.h +0 -383
  470. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererPlayback.cpp +0 -168
  471. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererPlayback.h +0 -48
  472. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererRecorder.cpp +0 -158
  473. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererRecorder.h +0 -130
  474. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererSimple.cpp +0 -80
  475. package/native/third_party/JoltPhysics/Jolt/Renderer/DebugRendererSimple.h +0 -88
  476. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletalAnimation.cpp +0 -165
  477. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletalAnimation.h +0 -91
  478. package/native/third_party/JoltPhysics/Jolt/Skeleton/Skeleton.cpp +0 -82
  479. package/native/third_party/JoltPhysics/Jolt/Skeleton/Skeleton.h +0 -72
  480. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonMapper.cpp +0 -237
  481. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonMapper.h +0 -145
  482. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonPose.cpp +0 -87
  483. package/native/third_party/JoltPhysics/Jolt/Skeleton/SkeletonPose.h +0 -82
  484. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitter.cpp +0 -73
  485. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitter.h +0 -84
  486. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterBinning.cpp +0 -139
  487. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterBinning.h +0 -52
  488. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterMean.cpp +0 -43
  489. package/native/third_party/JoltPhysics/Jolt/TriangleSplitter/TriangleSplitterMean.h +0 -28
  490. package/native/third_party/JoltPhysics/LICENSE +0 -7
  491. package/native/third_party/JoltPhysics/README.md +0 -173
  492. package/native/third_party/bloom_jolt/CMakeLists.txt +0 -87
  493. package/native/third_party/bloom_jolt/include/bloom_jolt.h +0 -519
  494. package/native/third_party/bloom_jolt/src/bloom_jolt.cpp +0 -1780
@@ -1,845 +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
- // Define to validate the integrity of the hull structure
8
- //#define JPH_EPA_CONVEX_BUILDER_VALIDATE
9
-
10
- // Define to draw the building of the hull for debugging purposes
11
- //#define JPH_EPA_CONVEX_BUILDER_DRAW
12
-
13
- #include <Jolt/Core/NonCopyable.h>
14
- #include <Jolt/Core/BinaryHeap.h>
15
-
16
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
17
- #include <Jolt/Renderer/DebugRenderer.h>
18
- #include <Jolt/Core/StringTools.h>
19
- #endif
20
-
21
- JPH_NAMESPACE_BEGIN
22
-
23
- /// A convex hull builder specifically made for the EPA penetration depth calculation. It trades accuracy for speed and will simply abort of the hull forms defects due to numerical precision problems.
24
- class EPAConvexHullBuilder : public NonCopyable
25
- {
26
- private:
27
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
28
- /// Factor to scale convex hull when debug drawing the construction process
29
- static constexpr Real cDrawScale = 10;
30
- #endif
31
-
32
- public:
33
- // Due to the Euler characteristic (https://en.wikipedia.org/wiki/Euler_characteristic) we know that Vertices - Edges + Faces = 2
34
- // In our case we only have triangles and they are always fully connected, so each edge is shared exactly between 2 faces: Edges = Faces * 3 / 2
35
- // Substituting: Vertices = Faces / 2 + 2 which is approximately Faces / 2.
36
- static constexpr int cMaxTriangles = 256; ///< Max triangles in hull
37
- static constexpr int cMaxPoints = cMaxTriangles / 2; ///< Max number of points in hull
38
-
39
- // Constants
40
- static constexpr int cMaxEdgeLength = 128; ///< Max number of edges in FindEdge
41
- static constexpr float cMinTriangleArea = 1.0e-10f; ///< Minimum area of a triangle before, if smaller than this it will not be added to the priority queue
42
- static constexpr float cBarycentricEpsilon = 1.0e-3f; ///< Epsilon value used to determine if a point is in the interior of a triangle
43
-
44
- // Forward declare
45
- class Triangle;
46
-
47
- /// Class that holds the information of an edge
48
- class Edge
49
- {
50
- public:
51
- /// Information about neighbouring triangle
52
- Triangle * mNeighbourTriangle; ///< Triangle that neighbours this triangle
53
- int mNeighbourEdge; ///< Index in mEdge that specifies edge that this Edge is connected to
54
-
55
- int mStartIdx; ///< Vertex index in mPositions that indicates the start vertex of this edge
56
- };
57
-
58
- using Edges = StaticArray<Edge, cMaxEdgeLength>;
59
- using NewTriangles = StaticArray<Triangle *, cMaxEdgeLength>;
60
-
61
- /// Class that holds the information of one triangle
62
- class Triangle : public NonCopyable
63
- {
64
- public:
65
- /// Constructor
66
- inline Triangle(int inIdx0, int inIdx1, int inIdx2, const Vec3 *inPositions);
67
-
68
- /// Check if triangle is facing inPosition
69
- inline bool IsFacing(Vec3Arg inPosition) const
70
- {
71
- JPH_ASSERT(!mRemoved);
72
- return mNormal.Dot(inPosition - mCentroid) > 0.0f;
73
- }
74
-
75
- /// Check if triangle is facing the origin
76
- inline bool IsFacingOrigin() const
77
- {
78
- JPH_ASSERT(!mRemoved);
79
- return mNormal.Dot(mCentroid) < 0.0f;
80
- }
81
-
82
- /// Get the next edge of edge inIndex
83
- inline const Edge & GetNextEdge(int inIndex) const
84
- {
85
- return mEdge[(inIndex + 1) % 3];
86
- }
87
-
88
- Edge mEdge[3]; ///< 3 edges of this triangle
89
- Vec3 mNormal; ///< Normal of this triangle, length is 2 times area of triangle
90
- Vec3 mCentroid; ///< Center of the triangle
91
- float mClosestLenSq = FLT_MAX; ///< Closest distance^2 from origin to triangle
92
- float mLambda[2]; ///< Barycentric coordinates of closest point to origin on triangle
93
- bool mLambdaRelativeTo0; ///< How to calculate the closest point, true: y0 + l0 * (y1 - y0) + l1 * (y2 - y0), false: y1 + l0 * (y0 - y1) + l1 * (y2 - y1)
94
- bool mClosestPointInterior = false; ///< Flag that indicates that the closest point from this triangle to the origin is an interior point
95
- bool mRemoved = false; ///< Flag that indicates that triangle has been removed
96
- bool mInQueue = false; ///< Flag that indicates that this triangle was placed in the sorted heap (stays true after it is popped because the triangle is freed by the main EPA algorithm loop)
97
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
98
- int mIteration; ///< Iteration that this triangle was created
99
- #endif
100
- };
101
-
102
- /// Factory that creates triangles in a fixed size buffer
103
- class TriangleFactory : public NonCopyable
104
- {
105
- private:
106
- /// Struct that stores both a triangle or a next pointer in case the triangle is unused
107
- union alignas(Triangle) Block
108
- {
109
- uint8 mTriangle[sizeof(Triangle)];
110
- Block * mNextFree;
111
- };
112
-
113
- /// Storage for triangle data
114
- Block mTriangles[cMaxTriangles]; ///< Storage for triangles
115
- Block * mNextFree = nullptr; ///< List of free triangles
116
- int mHighWatermark = 0; ///< High water mark for used triangles (if mNextFree == nullptr we can take one from here)
117
-
118
- public:
119
- /// Return all triangles to the free pool
120
- void Clear()
121
- {
122
- mNextFree = nullptr;
123
- mHighWatermark = 0;
124
- }
125
-
126
- /// Allocate a new triangle with 3 indexes
127
- Triangle * CreateTriangle(int inIdx0, int inIdx1, int inIdx2, const Vec3 *inPositions)
128
- {
129
- Triangle *t;
130
- if (mNextFree != nullptr)
131
- {
132
- // Entry available from the free list
133
- t = reinterpret_cast<Triangle *>(&mNextFree->mTriangle);
134
- mNextFree = mNextFree->mNextFree;
135
- }
136
- else
137
- {
138
- // Allocate from never used before triangle store
139
- if (mHighWatermark >= cMaxTriangles)
140
- return nullptr; // Buffer full
141
- t = reinterpret_cast<Triangle *>(&mTriangles[mHighWatermark].mTriangle);
142
- ++mHighWatermark;
143
- }
144
-
145
- // Call constructor
146
- new (t) Triangle(inIdx0, inIdx1, inIdx2, inPositions);
147
-
148
- return t;
149
- }
150
-
151
- /// Free a triangle
152
- void FreeTriangle(Triangle *inT)
153
- {
154
- // Destruct triangle
155
- inT->~Triangle();
156
- #ifdef JPH_DEBUG
157
- memset(inT, 0xcd, sizeof(Triangle));
158
- #endif
159
-
160
- // Add triangle to the free list
161
- Block *tu = reinterpret_cast<Block *>(inT);
162
- tu->mNextFree = mNextFree;
163
- mNextFree = tu;
164
- }
165
- };
166
-
167
- // Typedefs
168
- using PointsBase = StaticArray<Vec3, cMaxPoints>;
169
- using Triangles = StaticArray<Triangle *, cMaxTriangles>;
170
-
171
- /// Specialized points list that allows direct access to the size
172
- class Points : public PointsBase
173
- {
174
- public:
175
- size_type & GetSizeRef()
176
- {
177
- return mSize;
178
- }
179
- };
180
-
181
- /// Specialized triangles list that keeps them sorted on closest distance to origin
182
- class TriangleQueue : public Triangles
183
- {
184
- public:
185
- /// Function to sort triangles on closest distance to origin
186
- static bool sTriangleSorter(const Triangle *inT1, const Triangle *inT2)
187
- {
188
- return inT1->mClosestLenSq > inT2->mClosestLenSq;
189
- }
190
-
191
- /// Add triangle to the list
192
- void push_back(Triangle *inT)
193
- {
194
- // Add to base
195
- Triangles::push_back(inT);
196
-
197
- // Mark in queue
198
- inT->mInQueue = true;
199
-
200
- // Resort heap
201
- BinaryHeapPush(begin(), end(), sTriangleSorter);
202
- }
203
-
204
- /// Peek the next closest triangle without removing it
205
- Triangle * PeekClosest()
206
- {
207
- return front();
208
- }
209
-
210
- /// Get next closest triangle
211
- Triangle * PopClosest()
212
- {
213
- // Move closest to end
214
- BinaryHeapPop(begin(), end(), sTriangleSorter);
215
-
216
- // Remove last triangle
217
- Triangle *t = back();
218
- pop_back();
219
- return t;
220
- }
221
- };
222
-
223
- /// Constructor
224
- explicit EPAConvexHullBuilder(const Points &inPositions) :
225
- mPositions(inPositions)
226
- {
227
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
228
- mIteration = 0;
229
- mOffset = RVec3::sZero();
230
- #endif
231
- }
232
-
233
- /// Initialize the hull with 3 points
234
- void Initialize(int inIdx1, int inIdx2, int inIdx3)
235
- {
236
- // Release triangles
237
- mFactory.Clear();
238
-
239
- // Create triangles (back to back)
240
- Triangle *t1 = CreateTriangle(inIdx1, inIdx2, inIdx3);
241
- Triangle *t2 = CreateTriangle(inIdx1, inIdx3, inIdx2);
242
-
243
- // Link triangles edges
244
- sLinkTriangle(t1, 0, t2, 2);
245
- sLinkTriangle(t1, 1, t2, 1);
246
- sLinkTriangle(t1, 2, t2, 0);
247
-
248
- // Always add both triangles to the priority queue
249
- mTriangleQueue.push_back(t1);
250
- mTriangleQueue.push_back(t2);
251
-
252
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
253
- // Draw current state
254
- DrawState();
255
-
256
- // Increment iteration counter
257
- ++mIteration;
258
- #endif
259
- }
260
-
261
- /// Check if there's another triangle to process from the queue
262
- bool HasNextTriangle() const
263
- {
264
- return !mTriangleQueue.empty();
265
- }
266
-
267
- /// Access to the next closest triangle to the origin (won't remove it from the queue).
268
- Triangle * PeekClosestTriangleInQueue()
269
- {
270
- return mTriangleQueue.PeekClosest();
271
- }
272
-
273
- /// Access to the next closest triangle to the origin and remove it from the queue.
274
- Triangle * PopClosestTriangleFromQueue()
275
- {
276
- return mTriangleQueue.PopClosest();
277
- }
278
-
279
- /// Find the triangle on which inPosition is the furthest to the front
280
- /// Note this function works as long as all points added have been added with AddPoint(..., FLT_MAX).
281
- Triangle * FindFacingTriangle(Vec3Arg inPosition, float &outBestDistSq)
282
- {
283
- Triangle *best = nullptr;
284
- float best_dist_sq = 0.0f;
285
-
286
- for (Triangle *t : mTriangleQueue)
287
- if (!t->mRemoved)
288
- {
289
- float dot = t->mNormal.Dot(inPosition - t->mCentroid);
290
- if (dot > 0.0f)
291
- {
292
- float dist_sq = dot * dot / t->mNormal.LengthSq();
293
- if (dist_sq > best_dist_sq)
294
- {
295
- best = t;
296
- best_dist_sq = dist_sq;
297
- }
298
- }
299
- }
300
-
301
- outBestDistSq = best_dist_sq;
302
- return best;
303
- }
304
-
305
- /// Add a new point to the convex hull
306
- bool AddPoint(Triangle *inFacingTriangle, int inIdx, float inClosestDistSq, NewTriangles &outTriangles)
307
- {
308
- // Get position
309
- Vec3 pos = mPositions[inIdx];
310
-
311
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
312
- // Draw new support point
313
- DrawMarker(pos, Color::sYellow, 1.0f);
314
- #endif
315
-
316
- #ifdef JPH_EPA_CONVEX_BUILDER_VALIDATE
317
- // Check if structure is intact
318
- ValidateTriangles();
319
- #endif
320
-
321
- // Find edge of convex hull of triangles that are not facing the new vertex w
322
- Edges edges;
323
- if (!FindEdge(inFacingTriangle, pos, edges))
324
- return false;
325
-
326
- // Create new triangles
327
- int num_edges = edges.size();
328
- for (int i = 0; i < num_edges; ++i)
329
- {
330
- // Create new triangle
331
- Triangle *nt = CreateTriangle(edges[i].mStartIdx, edges[(i + 1) % num_edges].mStartIdx, inIdx);
332
- if (nt == nullptr)
333
- return false;
334
- outTriangles.push_back(nt);
335
-
336
- // Check if we need to put this triangle in the priority queue
337
- if ((nt->mClosestPointInterior && nt->mClosestLenSq < inClosestDistSq) // For the main algorithm
338
- || nt->mClosestLenSq < 0.0f) // For when the origin is not inside the hull yet
339
- mTriangleQueue.push_back(nt);
340
- }
341
-
342
- // Link edges
343
- for (int i = 0; i < num_edges; ++i)
344
- {
345
- sLinkTriangle(outTriangles[i], 0, edges[i].mNeighbourTriangle, edges[i].mNeighbourEdge);
346
- sLinkTriangle(outTriangles[i], 1, outTriangles[(i + 1) % num_edges], 2);
347
- }
348
-
349
- #ifdef JPH_EPA_CONVEX_BUILDER_VALIDATE
350
- // Check if structure is intact
351
- ValidateTriangles();
352
- #endif
353
-
354
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
355
- // Draw state of the hull
356
- DrawState();
357
-
358
- // Increment iteration counter
359
- ++mIteration;
360
- #endif
361
-
362
- return true;
363
- }
364
-
365
- /// Free a triangle
366
- void FreeTriangle(Triangle *inT)
367
- {
368
- #ifdef JPH_ENABLE_ASSERTS
369
- // Make sure that this triangle is not connected
370
- JPH_ASSERT(inT->mRemoved);
371
- for (const Edge &e : inT->mEdge)
372
- JPH_ASSERT(e.mNeighbourTriangle == nullptr);
373
- #endif
374
-
375
- #if defined(JPH_EPA_CONVEX_BUILDER_VALIDATE) || defined(JPH_EPA_CONVEX_BUILDER_DRAW)
376
- // Remove from list of all triangles
377
- Triangles::iterator i = std::find(mTriangles.begin(), mTriangles.end(), inT);
378
- JPH_ASSERT(i != mTriangles.end());
379
- mTriangles.erase(i);
380
- #endif
381
-
382
- mFactory.FreeTriangle(inT);
383
- }
384
-
385
- private:
386
- /// Create a new triangle
387
- Triangle * CreateTriangle(int inIdx1, int inIdx2, int inIdx3)
388
- {
389
- // Call provider to create triangle
390
- Triangle *t = mFactory.CreateTriangle(inIdx1, inIdx2, inIdx3, mPositions.data());
391
- if (t == nullptr)
392
- return nullptr;
393
-
394
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
395
- // Remember iteration counter
396
- t->mIteration = mIteration;
397
- #endif
398
-
399
- #if defined(JPH_EPA_CONVEX_BUILDER_VALIDATE) || defined(JPH_EPA_CONVEX_BUILDER_DRAW)
400
- // Add to list of triangles for debugging purposes
401
- mTriangles.push_back(t);
402
- #endif
403
-
404
- return t;
405
- }
406
-
407
- /// Link triangle edge to other triangle edge
408
- static void sLinkTriangle(Triangle *inT1, int inEdge1, Triangle *inT2, int inEdge2)
409
- {
410
- JPH_ASSERT(inEdge1 >= 0 && inEdge1 < 3);
411
- JPH_ASSERT(inEdge2 >= 0 && inEdge2 < 3);
412
- Edge &e1 = inT1->mEdge[inEdge1];
413
- Edge &e2 = inT2->mEdge[inEdge2];
414
-
415
- // Check not connected yet
416
- JPH_ASSERT(e1.mNeighbourTriangle == nullptr);
417
- JPH_ASSERT(e2.mNeighbourTriangle == nullptr);
418
-
419
- // Check vertices match
420
- JPH_ASSERT(e1.mStartIdx == inT2->GetNextEdge(inEdge2).mStartIdx);
421
- JPH_ASSERT(e2.mStartIdx == inT1->GetNextEdge(inEdge1).mStartIdx);
422
-
423
- // Link up
424
- e1.mNeighbourTriangle = inT2;
425
- e1.mNeighbourEdge = inEdge2;
426
- e2.mNeighbourTriangle = inT1;
427
- e2.mNeighbourEdge = inEdge1;
428
- }
429
-
430
- /// Unlink this triangle
431
- void UnlinkTriangle(Triangle *inT)
432
- {
433
- // Unlink from neighbours
434
- for (int i = 0; i < 3; ++i)
435
- {
436
- Edge &edge = inT->mEdge[i];
437
- if (edge.mNeighbourTriangle != nullptr)
438
- {
439
- Edge &neighbour_edge = edge.mNeighbourTriangle->mEdge[edge.mNeighbourEdge];
440
-
441
- // Validate that neighbour points to us
442
- JPH_ASSERT(neighbour_edge.mNeighbourTriangle == inT);
443
- JPH_ASSERT(neighbour_edge.mNeighbourEdge == i);
444
-
445
- // Unlink
446
- neighbour_edge.mNeighbourTriangle = nullptr;
447
- edge.mNeighbourTriangle = nullptr;
448
- }
449
- }
450
-
451
- // If this triangle is not in the priority queue, we can delete it now
452
- if (!inT->mInQueue)
453
- FreeTriangle(inT);
454
- }
455
-
456
- /// Given one triangle that faces inVertex, find the edges of the triangles that are not facing inVertex.
457
- /// Will flag all those triangles for removal.
458
- bool FindEdge(Triangle *inFacingTriangle, Vec3Arg inVertex, Edges &outEdges)
459
- {
460
- // Assert that we were given an empty array
461
- JPH_ASSERT(outEdges.empty());
462
-
463
- // Should start with a facing triangle
464
- JPH_ASSERT(inFacingTriangle->IsFacing(inVertex));
465
-
466
- // Flag as removed
467
- inFacingTriangle->mRemoved = true;
468
-
469
- // Instead of recursing, we build our own stack with the information we need
470
- struct StackEntry
471
- {
472
- Triangle * mTriangle;
473
- int mEdge;
474
- int mIter;
475
- };
476
- StackEntry stack[cMaxEdgeLength];
477
- int cur_stack_pos = 0;
478
-
479
- // Start with the triangle / edge provided
480
- stack[0].mTriangle = inFacingTriangle;
481
- stack[0].mEdge = 0;
482
- stack[0].mIter = -1; // Start with edge 0 (is incremented below before use)
483
-
484
- // Next index that we expect to find, if we don't then there are 'islands'
485
- int next_expected_start_idx = -1;
486
-
487
- for (;;)
488
- {
489
- StackEntry &cur_entry = stack[cur_stack_pos];
490
-
491
- // Next iteration
492
- if (++cur_entry.mIter >= 3)
493
- {
494
- // This triangle needs to be removed, unlink it now
495
- UnlinkTriangle(cur_entry.mTriangle);
496
-
497
- // Pop from stack
498
- if (--cur_stack_pos < 0)
499
- break;
500
- }
501
- else
502
- {
503
- // Visit neighbour
504
- Edge &e = cur_entry.mTriangle->mEdge[(cur_entry.mEdge + cur_entry.mIter) % 3];
505
- Triangle *n = e.mNeighbourTriangle;
506
- if (n != nullptr && !n->mRemoved)
507
- {
508
- // Check if vertex is on the front side of this triangle
509
- if (n->IsFacing(inVertex))
510
- {
511
- // Vertex on front, this triangle needs to be removed
512
- n->mRemoved = true;
513
-
514
- // Add element to the stack of elements to visit
515
- cur_stack_pos++;
516
- JPH_ASSERT(cur_stack_pos < cMaxEdgeLength);
517
- StackEntry &new_entry = stack[cur_stack_pos];
518
- new_entry.mTriangle = n;
519
- new_entry.mEdge = e.mNeighbourEdge;
520
- new_entry.mIter = 0; // Is incremented before use, we don't need to test this edge again since we came from it
521
- }
522
- else
523
- {
524
- // Detect if edge doesn't connect to previous edge, if this happens we have found and 'island' which means
525
- // the newly added point is so close to the triangles of the hull that we classified some (nearly) coplanar
526
- // triangles as before and some behind the point. At this point we just abort adding the point because
527
- // we've reached numerical precision.
528
- // Note that we do not need to test if the first and last edge connect, since when there are islands
529
- // there should be at least 2 disconnects.
530
- if (e.mStartIdx != next_expected_start_idx && next_expected_start_idx != -1)
531
- return false;
532
-
533
- // Next expected index is the start index of our neighbour's edge
534
- next_expected_start_idx = n->mEdge[e.mNeighbourEdge].mStartIdx;
535
-
536
- // Vertex behind, keep edge
537
- outEdges.push_back(e);
538
- }
539
- }
540
- }
541
- }
542
-
543
- // Assert that we have a fully connected loop
544
- JPH_ASSERT(outEdges.empty() || outEdges[0].mStartIdx == next_expected_start_idx);
545
-
546
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
547
- // Draw edge of facing triangles
548
- for (int i = 0; i < (int)outEdges.size(); ++i)
549
- {
550
- RVec3 edge_start = cDrawScale * (mOffset + mPositions[outEdges[i].mStartIdx]);
551
- DebugRenderer::sInstance->DrawArrow(edge_start, cDrawScale * (mOffset + mPositions[outEdges[(i + 1) % outEdges.size()].mStartIdx]), Color::sYellow, 0.01f);
552
- DebugRenderer::sInstance->DrawText3D(edge_start, ConvertToString(outEdges[i].mStartIdx), Color::sWhite);
553
- }
554
-
555
- // Draw the state with the facing triangles removed
556
- DrawState();
557
- #endif
558
-
559
- // When we start with two triangles facing away from each other and adding a point that is on the plane,
560
- // sometimes we consider the point in front of both causing both triangles to be removed resulting in an empty edge list.
561
- // In this case we fail to add the point which will result in no collision reported (the shapes are contacting in 1 point so there's 0 penetration)
562
- return outEdges.size() >= 3;
563
- }
564
-
565
- #ifdef JPH_EPA_CONVEX_BUILDER_VALIDATE
566
- /// Check consistency of 1 triangle
567
- void ValidateTriangle(const Triangle *inT) const
568
- {
569
- if (inT->mRemoved)
570
- {
571
- // Validate that removed triangles are not connected to anything
572
- for (const Edge &my_edge : inT->mEdge)
573
- JPH_ASSERT(my_edge.mNeighbourTriangle == nullptr);
574
- }
575
- else
576
- {
577
- for (int i = 0; i < 3; ++i)
578
- {
579
- const Edge &my_edge = inT->mEdge[i];
580
-
581
- // Assert that we have a neighbour
582
- const Triangle *nb = my_edge.mNeighbourTriangle;
583
- JPH_ASSERT(nb != nullptr);
584
-
585
- if (nb != nullptr)
586
- {
587
- // Assert that our neighbours edge points to us
588
- const Edge &nb_edge = nb->mEdge[my_edge.mNeighbourEdge];
589
- JPH_ASSERT(nb_edge.mNeighbourTriangle == inT);
590
- JPH_ASSERT(nb_edge.mNeighbourEdge == i);
591
-
592
- // Assert that the next edge of the neighbour points to the same vertex as this edge's vertex
593
- const Edge &nb_next_edge = nb->GetNextEdge(my_edge.mNeighbourEdge);
594
- JPH_ASSERT(nb_next_edge.mStartIdx == my_edge.mStartIdx);
595
-
596
- // Assert that my next edge points to the same vertex as my neighbours vertex
597
- const Edge &my_next_edge = inT->GetNextEdge(i);
598
- JPH_ASSERT(my_next_edge.mStartIdx == nb_edge.mStartIdx);
599
- }
600
- }
601
- }
602
- }
603
-
604
- /// Check consistency of all triangles
605
- void ValidateTriangles() const
606
- {
607
- for (const Triangle *t : mTriangles)
608
- ValidateTriangle(t);
609
- }
610
- #endif
611
-
612
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
613
- public:
614
- /// Draw state of algorithm
615
- void DrawState()
616
- {
617
- // Draw origin
618
- DebugRenderer::sInstance->DrawCoordinateSystem(RMat44::sTranslation(cDrawScale * mOffset), 1.0f);
619
-
620
- // Draw triangles
621
- for (const Triangle *t : mTriangles)
622
- if (!t->mRemoved)
623
- {
624
- // Calculate the triangle vertices
625
- RVec3 p1 = cDrawScale * (mOffset + mPositions[t->mEdge[0].mStartIdx]);
626
- RVec3 p2 = cDrawScale * (mOffset + mPositions[t->mEdge[1].mStartIdx]);
627
- RVec3 p3 = cDrawScale * (mOffset + mPositions[t->mEdge[2].mStartIdx]);
628
-
629
- // Draw triangle
630
- DebugRenderer::sInstance->DrawTriangle(p1, p2, p3, Color::sGetDistinctColor(t->mIteration));
631
- DebugRenderer::sInstance->DrawWireTriangle(p1, p2, p3, Color::sGrey);
632
-
633
- // Draw normal
634
- RVec3 centroid = cDrawScale * (mOffset + t->mCentroid);
635
- float len = t->mNormal.Length();
636
- if (len > 0.0f)
637
- DebugRenderer::sInstance->DrawArrow(centroid, centroid + t->mNormal / len, Color::sDarkGreen, 0.01f);
638
- }
639
-
640
- // Determine max position
641
- float min_x = FLT_MAX;
642
- float max_x = -FLT_MAX;
643
- for (Vec3 p : mPositions)
644
- {
645
- min_x = min(min_x, p.GetX());
646
- max_x = max(max_x, p.GetX());
647
- }
648
-
649
- // Offset to the right
650
- mOffset += Vec3(max_x - min_x + 0.5f, 0.0f, 0.0f);
651
- }
652
-
653
- /// Draw a label to indicate the next stage in the algorithm
654
- void DrawLabel(const string_view &inText)
655
- {
656
- DebugRenderer::sInstance->DrawText3D(cDrawScale * mOffset, inText, Color::sWhite, 0.1f * cDrawScale);
657
-
658
- mOffset += Vec3(5.0f, 0.0f, 0.0f);
659
- }
660
-
661
- /// Draw geometry for debugging purposes
662
- void DrawGeometry(const DebugRenderer::GeometryRef &inGeometry, ColorArg inColor)
663
- {
664
- RMat44 origin = RMat44::sScale(Vec3::sReplicate(cDrawScale)) * RMat44::sTranslation(mOffset);
665
- DebugRenderer::sInstance->DrawGeometry(origin, inGeometry->mBounds.Transformed(origin), inGeometry->mBounds.GetExtent().LengthSq(), inColor, inGeometry);
666
-
667
- mOffset += Vec3(inGeometry->mBounds.GetSize().GetX(), 0, 0);
668
- }
669
-
670
- /// Draw a triangle for debugging purposes
671
- void DrawWireTriangle(const Triangle &inTriangle, ColorArg inColor)
672
- {
673
- RVec3 prev = cDrawScale * (mOffset + mPositions[inTriangle.mEdge[2].mStartIdx]);
674
- for (const Edge &edge : inTriangle.mEdge)
675
- {
676
- RVec3 cur = cDrawScale * (mOffset + mPositions[edge.mStartIdx]);
677
- DebugRenderer::sInstance->DrawArrow(prev, cur, inColor, 0.01f);
678
- prev = cur;
679
- }
680
- }
681
-
682
- /// Draw a marker for debugging purposes
683
- void DrawMarker(Vec3Arg inPosition, ColorArg inColor, float inSize)
684
- {
685
- DebugRenderer::sInstance->DrawMarker(cDrawScale * (mOffset + inPosition), inColor, inSize);
686
- }
687
-
688
- /// Draw an arrow for debugging purposes
689
- void DrawArrow(Vec3Arg inFrom, Vec3Arg inTo, ColorArg inColor, float inArrowSize)
690
- {
691
- DebugRenderer::sInstance->DrawArrow(cDrawScale * (mOffset + inFrom), cDrawScale * (mOffset + inTo), inColor, inArrowSize);
692
- }
693
- #endif
694
-
695
- private:
696
- TriangleFactory mFactory; ///< Factory to create new triangles and remove old ones
697
- const Points & mPositions; ///< List of positions (some of them are part of the hull)
698
- TriangleQueue mTriangleQueue; ///< List of triangles that are part of the hull that still need to be checked (if !mRemoved)
699
-
700
- #if defined(JPH_EPA_CONVEX_BUILDER_VALIDATE) || defined(JPH_EPA_CONVEX_BUILDER_DRAW)
701
- Triangles mTriangles; ///< The list of all triangles in this hull (for debug purposes)
702
- #endif
703
-
704
- #ifdef JPH_EPA_CONVEX_BUILDER_DRAW
705
- int mIteration; ///< Number of iterations we've had so far (for debug purposes)
706
- RVec3 mOffset; ///< Offset to use for state drawing
707
- #endif
708
- };
709
-
710
- // The determinant that is calculated in the Triangle constructor is really sensitive
711
- // to numerical round off, disable the fmadd instructions to maintain precision.
712
- JPH_PRECISE_MATH_ON
713
-
714
- EPAConvexHullBuilder::Triangle::Triangle(int inIdx0, int inIdx1, int inIdx2, const Vec3 *inPositions)
715
- {
716
- // Fill in indexes
717
- JPH_ASSERT(inIdx0 != inIdx1 && inIdx0 != inIdx2 && inIdx1 != inIdx2);
718
- mEdge[0].mStartIdx = inIdx0;
719
- mEdge[1].mStartIdx = inIdx1;
720
- mEdge[2].mStartIdx = inIdx2;
721
-
722
- // Clear links
723
- mEdge[0].mNeighbourTriangle = nullptr;
724
- mEdge[1].mNeighbourTriangle = nullptr;
725
- mEdge[2].mNeighbourTriangle = nullptr;
726
-
727
- // Get vertex positions
728
- Vec3 y0 = inPositions[inIdx0];
729
- Vec3 y1 = inPositions[inIdx1];
730
- Vec3 y2 = inPositions[inIdx2];
731
-
732
- // Calculate centroid
733
- mCentroid = (y0 + y1 + y2) / 3.0f;
734
-
735
- // Calculate edges
736
- Vec3 y10 = y1 - y0;
737
- Vec3 y20 = y2 - y0;
738
- Vec3 y21 = y2 - y1;
739
-
740
- // The most accurate normal is calculated by using the two shortest edges
741
- // See: https://box2d.org/posts/2014/01/troublesome-triangle/
742
- // The difference in normals is most pronounced when one edge is much smaller than the others (in which case the other 2 must have roughly the same length).
743
- // Therefore we can suffice by just picking the shortest from 2 edges and use that with the 3rd edge to calculate the normal.
744
- // We first check which of the edges is shorter.
745
- float y20_dot_y20 = y20.Dot(y20);
746
- float y21_dot_y21 = y21.Dot(y21);
747
- if (y20_dot_y20 < y21_dot_y21)
748
- {
749
- // We select the edges y10 and y20
750
- mNormal = y10.Cross(y20);
751
-
752
- // Check if triangle is degenerate
753
- float normal_len_sq = mNormal.LengthSq();
754
- if (normal_len_sq > cMinTriangleArea)
755
- {
756
- // Determine distance between triangle and origin: distance = (centroid - origin) . normal / |normal|
757
- // Note that this way of calculating the closest point is much more accurate than first calculating barycentric coordinates and then calculating the closest
758
- // point based on those coordinates. Note that we preserve the sign of the distance to check on which side the origin is.
759
- float c_dot_n = mCentroid.Dot(mNormal);
760
- mClosestLenSq = abs(c_dot_n) * c_dot_n / normal_len_sq;
761
-
762
- // Calculate closest point to origin using barycentric coordinates:
763
- //
764
- // v = y0 + l0 * (y1 - y0) + l1 * (y2 - y0)
765
- // v . (y1 - y0) = 0
766
- // v . (y2 - y0) = 0
767
- //
768
- // Written in matrix form:
769
- //
770
- // | y10.y10 y20.y10 | | l0 | = | -y0.y10 |
771
- // | y10.y20 y20.y20 | | l1 | | -y0.y20 |
772
- //
773
- // (y10 = y1 - y0 etc.)
774
- //
775
- // Cramers rule to invert matrix:
776
- float y10_dot_y10 = y10.LengthSq();
777
- float y10_dot_y20 = y10.Dot(y20);
778
- float determinant = y10_dot_y10 * y20_dot_y20 - y10_dot_y20 * y10_dot_y20;
779
- if (determinant > 0.0f) // If determinant == 0 then the system is linearly dependent and the triangle is degenerate, since y10.10 * y20.y20 > y10.y20^2 it should also be > 0
780
- {
781
- float y0_dot_y10 = y0.Dot(y10);
782
- float y0_dot_y20 = y0.Dot(y20);
783
- float l0 = (y10_dot_y20 * y0_dot_y20 - y20_dot_y20 * y0_dot_y10) / determinant;
784
- float l1 = (y10_dot_y20 * y0_dot_y10 - y10_dot_y10 * y0_dot_y20) / determinant;
785
- mLambda[0] = l0;
786
- mLambda[1] = l1;
787
- mLambdaRelativeTo0 = true;
788
-
789
- // Check if closest point is interior to the triangle. For a convex hull which contains the origin each face must contain the origin, but because
790
- // our faces are triangles, we can have multiple coplanar triangles and only 1 will have the origin as an interior point. We want to use this triangle
791
- // to calculate the contact points because it gives the most accurate results, so we will only add these triangles to the priority queue.
792
- if (l0 > -cBarycentricEpsilon && l1 > -cBarycentricEpsilon && l0 + l1 < 1.0f + cBarycentricEpsilon)
793
- mClosestPointInterior = true;
794
- }
795
- }
796
- }
797
- else
798
- {
799
- // We select the edges y10 and y21
800
- mNormal = y10.Cross(y21);
801
-
802
- // Check if triangle is degenerate
803
- float normal_len_sq = mNormal.LengthSq();
804
- if (normal_len_sq > cMinTriangleArea)
805
- {
806
- // Again calculate distance between triangle and origin
807
- float c_dot_n = mCentroid.Dot(mNormal);
808
- mClosestLenSq = abs(c_dot_n) * c_dot_n / normal_len_sq;
809
-
810
- // Calculate closest point to origin using barycentric coordinates but this time using y1 as the reference vertex
811
- //
812
- // v = y1 + l0 * (y0 - y1) + l1 * (y2 - y1)
813
- // v . (y0 - y1) = 0
814
- // v . (y2 - y1) = 0
815
- //
816
- // Written in matrix form:
817
- //
818
- // | y10.y10 -y21.y10 | | l0 | = | y1.y10 |
819
- // | -y10.y21 y21.y21 | | l1 | | -y1.y21 |
820
- //
821
- // Cramers rule to invert matrix:
822
- float y10_dot_y10 = y10.LengthSq();
823
- float y10_dot_y21 = y10.Dot(y21);
824
- float determinant = y10_dot_y10 * y21_dot_y21 - y10_dot_y21 * y10_dot_y21;
825
- if (determinant > 0.0f)
826
- {
827
- float y1_dot_y10 = y1.Dot(y10);
828
- float y1_dot_y21 = y1.Dot(y21);
829
- float l0 = (y21_dot_y21 * y1_dot_y10 - y10_dot_y21 * y1_dot_y21) / determinant;
830
- float l1 = (y10_dot_y21 * y1_dot_y10 - y10_dot_y10 * y1_dot_y21) / determinant;
831
- mLambda[0] = l0;
832
- mLambda[1] = l1;
833
- mLambdaRelativeTo0 = false;
834
-
835
- // Again check if the closest point is inside the triangle
836
- if (l0 > -cBarycentricEpsilon && l1 > -cBarycentricEpsilon && l0 + l1 < 1.0f + cBarycentricEpsilon)
837
- mClosestPointInterior = true;
838
- }
839
- }
840
- }
841
- }
842
-
843
- JPH_PRECISE_MATH_OFF
844
-
845
- JPH_NAMESPACE_END