@esengine/ecs-framework 2.2.21 → 2.3.0

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 (490) hide show
  1. package/bin/Core/DI/Decorators.d.ts +206 -0
  2. package/bin/Core/DI/Decorators.d.ts.map +1 -0
  3. package/bin/Core/DI/Decorators.js +253 -0
  4. package/bin/Core/DI/Decorators.js.map +1 -0
  5. package/bin/Core/DI/index.d.ts +8 -0
  6. package/bin/Core/DI/index.d.ts.map +1 -0
  7. package/bin/Core/DI/index.js +7 -0
  8. package/bin/Core/DI/index.js.map +1 -0
  9. package/bin/Core/Plugin.d.ts +112 -0
  10. package/bin/Core/Plugin.d.ts.map +1 -0
  11. package/bin/Core/Plugin.js +19 -0
  12. package/bin/Core/Plugin.js.map +1 -0
  13. package/bin/Core/PluginManager.d.ts +118 -0
  14. package/bin/Core/PluginManager.d.ts.map +1 -0
  15. package/bin/Core/PluginManager.js +229 -0
  16. package/bin/Core/PluginManager.js.map +1 -0
  17. package/bin/Core/ServiceContainer.d.ts +221 -0
  18. package/bin/Core/ServiceContainer.d.ts.map +1 -0
  19. package/bin/Core/ServiceContainer.js +352 -0
  20. package/bin/Core/ServiceContainer.js.map +1 -0
  21. package/bin/Core.d.ts +379 -0
  22. package/bin/Core.d.ts.map +1 -0
  23. package/bin/Core.js +553 -0
  24. package/bin/Core.js.map +1 -0
  25. package/bin/ECS/Component.d.ts +104 -0
  26. package/bin/ECS/Component.d.ts.map +1 -0
  27. package/bin/ECS/Component.js +105 -0
  28. package/bin/ECS/Component.js.map +1 -0
  29. package/bin/ECS/Components/HierarchyComponent.d.ts +46 -0
  30. package/bin/ECS/Components/HierarchyComponent.d.ts.map +1 -0
  31. package/bin/ECS/Components/HierarchyComponent.js +65 -0
  32. package/bin/ECS/Components/HierarchyComponent.js.map +1 -0
  33. package/bin/ECS/Components/index.d.ts +2 -0
  34. package/bin/ECS/Components/index.d.ts.map +1 -0
  35. package/bin/ECS/Components/index.js +2 -0
  36. package/bin/ECS/Components/index.js.map +1 -0
  37. package/bin/ECS/Core/ArchetypeSystem.d.ts +103 -0
  38. package/bin/ECS/Core/ArchetypeSystem.d.ts.map +1 -0
  39. package/bin/ECS/Core/ArchetypeSystem.js +244 -0
  40. package/bin/ECS/Core/ArchetypeSystem.js.map +1 -0
  41. package/bin/ECS/Core/CommandBuffer.d.ts +154 -0
  42. package/bin/ECS/Core/CommandBuffer.d.ts.map +1 -0
  43. package/bin/ECS/Core/CommandBuffer.js +244 -0
  44. package/bin/ECS/Core/CommandBuffer.js.map +1 -0
  45. package/bin/ECS/Core/ComponentPool.d.ts +139 -0
  46. package/bin/ECS/Core/ComponentPool.d.ts.map +1 -0
  47. package/bin/ECS/Core/ComponentPool.js +276 -0
  48. package/bin/ECS/Core/ComponentPool.js.map +1 -0
  49. package/bin/ECS/Core/ComponentStorage/ComponentRegistry.d.ts +127 -0
  50. package/bin/ECS/Core/ComponentStorage/ComponentRegistry.d.ts.map +1 -0
  51. package/bin/ECS/Core/ComponentStorage/ComponentRegistry.js +235 -0
  52. package/bin/ECS/Core/ComponentStorage/ComponentRegistry.js.map +1 -0
  53. package/bin/ECS/Core/ComponentStorage.d.ts +185 -0
  54. package/bin/ECS/Core/ComponentStorage.d.ts.map +1 -0
  55. package/bin/ECS/Core/ComponentStorage.js +321 -0
  56. package/bin/ECS/Core/ComponentStorage.js.map +1 -0
  57. package/bin/ECS/Core/EntityLifecyclePolicy.d.ts +26 -0
  58. package/bin/ECS/Core/EntityLifecyclePolicy.d.ts.map +1 -0
  59. package/bin/ECS/Core/EntityLifecyclePolicy.js +2 -0
  60. package/bin/ECS/Core/EntityLifecyclePolicy.js.map +1 -0
  61. package/bin/ECS/Core/EventBus.d.ts +210 -0
  62. package/bin/ECS/Core/EventBus.d.ts.map +1 -0
  63. package/bin/ECS/Core/EventBus.js +370 -0
  64. package/bin/ECS/Core/EventBus.js.map +1 -0
  65. package/bin/ECS/Core/EventSystem.d.ts +225 -0
  66. package/bin/ECS/Core/EventSystem.d.ts.map +1 -0
  67. package/bin/ECS/Core/EventSystem.js +448 -0
  68. package/bin/ECS/Core/EventSystem.js.map +1 -0
  69. package/bin/ECS/Core/Events/index.d.ts +3 -0
  70. package/bin/ECS/Core/Events/index.d.ts.map +1 -0
  71. package/bin/ECS/Core/Events/index.js +3 -0
  72. package/bin/ECS/Core/Events/index.js.map +1 -0
  73. package/bin/ECS/Core/FluentAPI/ComponentBuilder.d.ts +35 -0
  74. package/bin/ECS/Core/FluentAPI/ComponentBuilder.d.ts.map +1 -0
  75. package/bin/ECS/Core/FluentAPI/ComponentBuilder.js +48 -0
  76. package/bin/ECS/Core/FluentAPI/ComponentBuilder.js.map +1 -0
  77. package/bin/ECS/Core/FluentAPI/ECSFluentAPI.d.ts +135 -0
  78. package/bin/ECS/Core/FluentAPI/ECSFluentAPI.d.ts.map +1 -0
  79. package/bin/ECS/Core/FluentAPI/ECSFluentAPI.js +166 -0
  80. package/bin/ECS/Core/FluentAPI/ECSFluentAPI.js.map +1 -0
  81. package/bin/ECS/Core/FluentAPI/EntityBatchOperator.d.ts +58 -0
  82. package/bin/ECS/Core/FluentAPI/EntityBatchOperator.d.ts.map +1 -0
  83. package/bin/ECS/Core/FluentAPI/EntityBatchOperator.js +85 -0
  84. package/bin/ECS/Core/FluentAPI/EntityBatchOperator.js.map +1 -0
  85. package/bin/ECS/Core/FluentAPI/EntityBuilder.d.ts +110 -0
  86. package/bin/ECS/Core/FluentAPI/EntityBuilder.d.ts.map +1 -0
  87. package/bin/ECS/Core/FluentAPI/EntityBuilder.js +181 -0
  88. package/bin/ECS/Core/FluentAPI/EntityBuilder.js.map +1 -0
  89. package/bin/ECS/Core/FluentAPI/SceneBuilder.d.ts +53 -0
  90. package/bin/ECS/Core/FluentAPI/SceneBuilder.d.ts.map +1 -0
  91. package/bin/ECS/Core/FluentAPI/SceneBuilder.js +79 -0
  92. package/bin/ECS/Core/FluentAPI/SceneBuilder.js.map +1 -0
  93. package/bin/ECS/Core/FluentAPI/index.d.ts +6 -0
  94. package/bin/ECS/Core/FluentAPI/index.d.ts.map +1 -0
  95. package/bin/ECS/Core/FluentAPI/index.js +6 -0
  96. package/bin/ECS/Core/FluentAPI/index.js.map +1 -0
  97. package/bin/ECS/Core/FluentAPI.d.ts +2 -0
  98. package/bin/ECS/Core/FluentAPI.d.ts.map +1 -0
  99. package/bin/ECS/Core/FluentAPI.js +3 -0
  100. package/bin/ECS/Core/FluentAPI.js.map +1 -0
  101. package/bin/ECS/Core/Query/TypedQuery.d.ts +214 -0
  102. package/bin/ECS/Core/Query/TypedQuery.d.ts.map +1 -0
  103. package/bin/ECS/Core/Query/TypedQuery.js +294 -0
  104. package/bin/ECS/Core/Query/TypedQuery.js.map +1 -0
  105. package/bin/ECS/Core/Query/index.d.ts +3 -0
  106. package/bin/ECS/Core/Query/index.d.ts.map +1 -0
  107. package/bin/ECS/Core/Query/index.js +3 -0
  108. package/bin/ECS/Core/Query/index.js.map +1 -0
  109. package/bin/ECS/Core/QuerySystem.d.ts +458 -0
  110. package/bin/ECS/Core/QuerySystem.d.ts.map +1 -0
  111. package/bin/ECS/Core/QuerySystem.js +1069 -0
  112. package/bin/ECS/Core/QuerySystem.js.map +1 -0
  113. package/bin/ECS/Core/QueryTypes.d.ts +34 -0
  114. package/bin/ECS/Core/QueryTypes.d.ts.map +1 -0
  115. package/bin/ECS/Core/QueryTypes.js +13 -0
  116. package/bin/ECS/Core/QueryTypes.js.map +1 -0
  117. package/bin/ECS/Core/ReactiveQuery.d.ts +211 -0
  118. package/bin/ECS/Core/ReactiveQuery.d.ts.map +1 -0
  119. package/bin/ECS/Core/ReactiveQuery.js +401 -0
  120. package/bin/ECS/Core/ReactiveQuery.js.map +1 -0
  121. package/bin/ECS/Core/ReferenceTracker.d.ts +111 -0
  122. package/bin/ECS/Core/ReferenceTracker.d.ts.map +1 -0
  123. package/bin/ECS/Core/ReferenceTracker.js +254 -0
  124. package/bin/ECS/Core/ReferenceTracker.js.map +1 -0
  125. package/bin/ECS/Core/SoASerializer.d.ts +28 -0
  126. package/bin/ECS/Core/SoASerializer.d.ts.map +1 -0
  127. package/bin/ECS/Core/SoASerializer.js +85 -0
  128. package/bin/ECS/Core/SoASerializer.js.map +1 -0
  129. package/bin/ECS/Core/SoAStorage.d.ts +129 -0
  130. package/bin/ECS/Core/SoAStorage.d.ts.map +1 -0
  131. package/bin/ECS/Core/SoAStorage.js +685 -0
  132. package/bin/ECS/Core/SoAStorage.js.map +1 -0
  133. package/bin/ECS/Core/SoATypeRegistry.d.ts +50 -0
  134. package/bin/ECS/Core/SoATypeRegistry.d.ts.map +1 -0
  135. package/bin/ECS/Core/SoATypeRegistry.js +135 -0
  136. package/bin/ECS/Core/SoATypeRegistry.js.map +1 -0
  137. package/bin/ECS/Core/Storage/index.d.ts +4 -0
  138. package/bin/ECS/Core/Storage/index.d.ts.map +1 -0
  139. package/bin/ECS/Core/Storage/index.js +4 -0
  140. package/bin/ECS/Core/Storage/index.js.map +1 -0
  141. package/bin/ECS/Core/StorageDecorators.d.ts +20 -0
  142. package/bin/ECS/Core/StorageDecorators.d.ts.map +1 -0
  143. package/bin/ECS/Core/StorageDecorators.js +27 -0
  144. package/bin/ECS/Core/StorageDecorators.js.map +1 -0
  145. package/bin/ECS/CoreEvents.d.ts +131 -0
  146. package/bin/ECS/CoreEvents.d.ts.map +1 -0
  147. package/bin/ECS/CoreEvents.js +163 -0
  148. package/bin/ECS/CoreEvents.js.map +1 -0
  149. package/bin/ECS/Decorators/EntityRefDecorator.d.ts +46 -0
  150. package/bin/ECS/Decorators/EntityRefDecorator.d.ts.map +1 -0
  151. package/bin/ECS/Decorators/EntityRefDecorator.js +118 -0
  152. package/bin/ECS/Decorators/EntityRefDecorator.js.map +1 -0
  153. package/bin/ECS/Decorators/PropertyDecorator.d.ts +168 -0
  154. package/bin/ECS/Decorators/PropertyDecorator.d.ts.map +1 -0
  155. package/bin/ECS/Decorators/PropertyDecorator.js +40 -0
  156. package/bin/ECS/Decorators/PropertyDecorator.js.map +1 -0
  157. package/bin/ECS/Decorators/TypeDecorators.d.ts +124 -0
  158. package/bin/ECS/Decorators/TypeDecorators.d.ts.map +1 -0
  159. package/bin/ECS/Decorators/TypeDecorators.js +151 -0
  160. package/bin/ECS/Decorators/TypeDecorators.js.map +1 -0
  161. package/bin/ECS/Decorators/index.d.ts +7 -0
  162. package/bin/ECS/Decorators/index.d.ts.map +1 -0
  163. package/bin/ECS/Decorators/index.js +4 -0
  164. package/bin/ECS/Decorators/index.js.map +1 -0
  165. package/bin/ECS/Entity.d.ts +415 -0
  166. package/bin/ECS/Entity.d.ts.map +1 -0
  167. package/bin/ECS/Entity.js +683 -0
  168. package/bin/ECS/Entity.js.map +1 -0
  169. package/bin/ECS/EntityTags.d.ts +71 -0
  170. package/bin/ECS/EntityTags.d.ts.map +1 -0
  171. package/bin/ECS/EntityTags.js +82 -0
  172. package/bin/ECS/EntityTags.js.map +1 -0
  173. package/bin/ECS/IScene.d.ts +308 -0
  174. package/bin/ECS/IScene.d.ts.map +1 -0
  175. package/bin/ECS/IScene.js +2 -0
  176. package/bin/ECS/IScene.js.map +1 -0
  177. package/bin/ECS/Scene.d.ts +799 -0
  178. package/bin/ECS/Scene.d.ts.map +1 -0
  179. package/bin/ECS/Scene.js +1203 -0
  180. package/bin/ECS/Scene.js.map +1 -0
  181. package/bin/ECS/SceneManager.d.ts +197 -0
  182. package/bin/ECS/SceneManager.d.ts.map +1 -0
  183. package/bin/ECS/SceneManager.js +264 -0
  184. package/bin/ECS/SceneManager.js.map +1 -0
  185. package/bin/ECS/Serialization/ComponentSerializer.d.ts +106 -0
  186. package/bin/ECS/Serialization/ComponentSerializer.d.ts.map +1 -0
  187. package/bin/ECS/Serialization/ComponentSerializer.js +251 -0
  188. package/bin/ECS/Serialization/ComponentSerializer.js.map +1 -0
  189. package/bin/ECS/Serialization/EntitySerializer.d.ts +111 -0
  190. package/bin/ECS/Serialization/EntitySerializer.d.ts.map +1 -0
  191. package/bin/ECS/Serialization/EntitySerializer.js +155 -0
  192. package/bin/ECS/Serialization/EntitySerializer.js.map +1 -0
  193. package/bin/ECS/Serialization/IncrementalSerializer.d.ts +259 -0
  194. package/bin/ECS/Serialization/IncrementalSerializer.d.ts.map +1 -0
  195. package/bin/ECS/Serialization/IncrementalSerializer.js +500 -0
  196. package/bin/ECS/Serialization/IncrementalSerializer.js.map +1 -0
  197. package/bin/ECS/Serialization/SceneSerializer.d.ts +213 -0
  198. package/bin/ECS/Serialization/SceneSerializer.d.ts.map +1 -0
  199. package/bin/ECS/Serialization/SceneSerializer.js +387 -0
  200. package/bin/ECS/Serialization/SceneSerializer.js.map +1 -0
  201. package/bin/ECS/Serialization/SerializationDecorators.d.ts +136 -0
  202. package/bin/ECS/Serialization/SerializationDecorators.d.ts.map +1 -0
  203. package/bin/ECS/Serialization/SerializationDecorators.js +216 -0
  204. package/bin/ECS/Serialization/SerializationDecorators.js.map +1 -0
  205. package/bin/ECS/Serialization/VersionMigration.d.ts +156 -0
  206. package/bin/ECS/Serialization/VersionMigration.d.ts.map +1 -0
  207. package/bin/ECS/Serialization/VersionMigration.js +279 -0
  208. package/bin/ECS/Serialization/VersionMigration.js.map +1 -0
  209. package/bin/ECS/Serialization/index.d.ts +18 -0
  210. package/bin/ECS/Serialization/index.d.ts.map +1 -0
  211. package/bin/ECS/Serialization/index.js +18 -0
  212. package/bin/ECS/Serialization/index.js.map +1 -0
  213. package/bin/ECS/Systems/EntityCache.d.ts +114 -0
  214. package/bin/ECS/Systems/EntityCache.d.ts.map +1 -0
  215. package/bin/ECS/Systems/EntityCache.js +145 -0
  216. package/bin/ECS/Systems/EntityCache.js.map +1 -0
  217. package/bin/ECS/Systems/EntitySystem.d.ts +591 -0
  218. package/bin/ECS/Systems/EntitySystem.d.ts.map +1 -0
  219. package/bin/ECS/Systems/EntitySystem.js +1102 -0
  220. package/bin/ECS/Systems/EntitySystem.js.map +1 -0
  221. package/bin/ECS/Systems/HierarchySystem.d.ts +155 -0
  222. package/bin/ECS/Systems/HierarchySystem.d.ts.map +1 -0
  223. package/bin/ECS/Systems/HierarchySystem.js +498 -0
  224. package/bin/ECS/Systems/HierarchySystem.js.map +1 -0
  225. package/bin/ECS/Systems/IntervalSystem.d.ts +33 -0
  226. package/bin/ECS/Systems/IntervalSystem.d.ts.map +1 -0
  227. package/bin/ECS/Systems/IntervalSystem.js +50 -0
  228. package/bin/ECS/Systems/IntervalSystem.js.map +1 -0
  229. package/bin/ECS/Systems/PassiveSystem.d.ts +17 -0
  230. package/bin/ECS/Systems/PassiveSystem.d.ts.map +1 -0
  231. package/bin/ECS/Systems/PassiveSystem.js +19 -0
  232. package/bin/ECS/Systems/PassiveSystem.js.map +1 -0
  233. package/bin/ECS/Systems/ProcessingSystem.d.ts +21 -0
  234. package/bin/ECS/Systems/ProcessingSystem.d.ts.map +1 -0
  235. package/bin/ECS/Systems/ProcessingSystem.js +20 -0
  236. package/bin/ECS/Systems/ProcessingSystem.js.map +1 -0
  237. package/bin/ECS/Systems/WorkerEntitySystem.d.ts +313 -0
  238. package/bin/ECS/Systems/WorkerEntitySystem.d.ts.map +1 -0
  239. package/bin/ECS/Systems/WorkerEntitySystem.js +792 -0
  240. package/bin/ECS/Systems/WorkerEntitySystem.js.map +1 -0
  241. package/bin/ECS/Systems/index.d.ts +8 -0
  242. package/bin/ECS/Systems/index.d.ts.map +1 -0
  243. package/bin/ECS/Systems/index.js +8 -0
  244. package/bin/ECS/Systems/index.js.map +1 -0
  245. package/bin/ECS/TypedEntity.d.ts +192 -0
  246. package/bin/ECS/TypedEntity.d.ts.map +1 -0
  247. package/bin/ECS/TypedEntity.js +254 -0
  248. package/bin/ECS/TypedEntity.js.map +1 -0
  249. package/bin/ECS/Utils/BigIntCompatibility.d.ts +151 -0
  250. package/bin/ECS/Utils/BigIntCompatibility.d.ts.map +1 -0
  251. package/bin/ECS/Utils/BigIntCompatibility.js +476 -0
  252. package/bin/ECS/Utils/BigIntCompatibility.js.map +1 -0
  253. package/bin/ECS/Utils/BitMaskHashMap.d.ts +28 -0
  254. package/bin/ECS/Utils/BitMaskHashMap.d.ts.map +1 -0
  255. package/bin/ECS/Utils/BitMaskHashMap.js +127 -0
  256. package/bin/ECS/Utils/BitMaskHashMap.js.map +1 -0
  257. package/bin/ECS/Utils/Bits.d.ts +154 -0
  258. package/bin/ECS/Utils/Bits.d.ts.map +1 -0
  259. package/bin/ECS/Utils/Bits.js +331 -0
  260. package/bin/ECS/Utils/Bits.js.map +1 -0
  261. package/bin/ECS/Utils/ComponentSparseSet.d.ts +143 -0
  262. package/bin/ECS/Utils/ComponentSparseSet.d.ts.map +1 -0
  263. package/bin/ECS/Utils/ComponentSparseSet.js +347 -0
  264. package/bin/ECS/Utils/ComponentSparseSet.js.map +1 -0
  265. package/bin/ECS/Utils/EntityList.d.ts +115 -0
  266. package/bin/ECS/Utils/EntityList.d.ts.map +1 -0
  267. package/bin/ECS/Utils/EntityList.js +258 -0
  268. package/bin/ECS/Utils/EntityList.js.map +1 -0
  269. package/bin/ECS/Utils/EntityProcessorList.d.ts +56 -0
  270. package/bin/ECS/Utils/EntityProcessorList.d.ts.map +1 -0
  271. package/bin/ECS/Utils/EntityProcessorList.js +113 -0
  272. package/bin/ECS/Utils/EntityProcessorList.js.map +1 -0
  273. package/bin/ECS/Utils/IdentifierPool.d.ts +203 -0
  274. package/bin/ECS/Utils/IdentifierPool.d.ts.map +1 -0
  275. package/bin/ECS/Utils/IdentifierPool.js +325 -0
  276. package/bin/ECS/Utils/IdentifierPool.js.map +1 -0
  277. package/bin/ECS/Utils/Matcher.d.ts +171 -0
  278. package/bin/ECS/Utils/Matcher.d.ts.map +1 -0
  279. package/bin/ECS/Utils/Matcher.js +293 -0
  280. package/bin/ECS/Utils/Matcher.js.map +1 -0
  281. package/bin/ECS/Utils/SparseSet.d.ts +170 -0
  282. package/bin/ECS/Utils/SparseSet.d.ts.map +1 -0
  283. package/bin/ECS/Utils/SparseSet.js +280 -0
  284. package/bin/ECS/Utils/SparseSet.js.map +1 -0
  285. package/bin/ECS/Utils/index.d.ts +9 -0
  286. package/bin/ECS/Utils/index.d.ts.map +1 -0
  287. package/bin/ECS/Utils/index.js +10 -0
  288. package/bin/ECS/Utils/index.js.map +1 -0
  289. package/bin/ECS/World.d.ts +238 -0
  290. package/bin/ECS/World.d.ts.map +1 -0
  291. package/bin/ECS/World.js +416 -0
  292. package/bin/ECS/World.js.map +1 -0
  293. package/bin/ECS/WorldManager.d.ts +224 -0
  294. package/bin/ECS/WorldManager.d.ts.map +1 -0
  295. package/bin/ECS/WorldManager.js +365 -0
  296. package/bin/ECS/WorldManager.js.map +1 -0
  297. package/bin/ECS/index.d.ts +26 -0
  298. package/bin/ECS/index.d.ts.map +1 -0
  299. package/bin/ECS/index.js +21 -0
  300. package/bin/ECS/index.js.map +1 -0
  301. package/bin/Platform/IPlatformAdapter.d.ts +169 -0
  302. package/bin/Platform/IPlatformAdapter.d.ts.map +1 -0
  303. package/bin/Platform/IPlatformAdapter.js +2 -0
  304. package/bin/Platform/IPlatformAdapter.js.map +1 -0
  305. package/bin/Platform/PlatformDetector.d.ts +56 -0
  306. package/bin/Platform/PlatformDetector.d.ts.map +1 -0
  307. package/bin/Platform/PlatformDetector.js +247 -0
  308. package/bin/Platform/PlatformDetector.js.map +1 -0
  309. package/bin/Platform/PlatformManager.d.ts +50 -0
  310. package/bin/Platform/PlatformManager.d.ts.map +1 -0
  311. package/bin/Platform/PlatformManager.js +114 -0
  312. package/bin/Platform/PlatformManager.js.map +1 -0
  313. package/bin/Platform/index.d.ts +19 -0
  314. package/bin/Platform/index.d.ts.map +1 -0
  315. package/bin/Platform/index.js +29 -0
  316. package/bin/Platform/index.js.map +1 -0
  317. package/bin/Plugins/DebugPlugin.d.ts +156 -0
  318. package/bin/Plugins/DebugPlugin.d.ts.map +1 -0
  319. package/bin/Plugins/DebugPlugin.js +248 -0
  320. package/bin/Plugins/DebugPlugin.js.map +1 -0
  321. package/bin/Plugins/index.d.ts +2 -0
  322. package/bin/Plugins/index.d.ts.map +1 -0
  323. package/bin/Plugins/index.js +2 -0
  324. package/bin/Plugins/index.js.map +1 -0
  325. package/bin/Types/IUpdatable.d.ts +18 -0
  326. package/bin/Types/IUpdatable.d.ts.map +1 -0
  327. package/bin/Types/IUpdatable.js +7 -0
  328. package/bin/Types/IUpdatable.js.map +1 -0
  329. package/bin/Types/TypeHelpers.d.ts +238 -0
  330. package/bin/Types/TypeHelpers.d.ts.map +1 -0
  331. package/bin/Types/TypeHelpers.js +19 -0
  332. package/bin/Types/TypeHelpers.js.map +1 -0
  333. package/bin/Types/index.d.ts +466 -0
  334. package/bin/Types/index.d.ts.map +1 -0
  335. package/bin/Types/index.js +7 -0
  336. package/bin/Types/index.js.map +1 -0
  337. package/bin/Utils/BinarySerializer.d.ts +23 -0
  338. package/bin/Utils/BinarySerializer.d.ts.map +1 -0
  339. package/bin/Utils/BinarySerializer.js +100 -0
  340. package/bin/Utils/BinarySerializer.js.map +1 -0
  341. package/bin/Utils/Debug/AdvancedProfilerCollector.d.ts +153 -0
  342. package/bin/Utils/Debug/AdvancedProfilerCollector.d.ts.map +1 -0
  343. package/bin/Utils/Debug/AdvancedProfilerCollector.js +406 -0
  344. package/bin/Utils/Debug/AdvancedProfilerCollector.js.map +1 -0
  345. package/bin/Utils/Debug/ComponentDataCollector.d.ts +32 -0
  346. package/bin/Utils/Debug/ComponentDataCollector.d.ts.map +1 -0
  347. package/bin/Utils/Debug/ComponentDataCollector.js +250 -0
  348. package/bin/Utils/Debug/ComponentDataCollector.js.map +1 -0
  349. package/bin/Utils/Debug/DebugConfigService.d.ts +16 -0
  350. package/bin/Utils/Debug/DebugConfigService.d.ts.map +1 -0
  351. package/bin/Utils/Debug/DebugConfigService.js +42 -0
  352. package/bin/Utils/Debug/DebugConfigService.js.map +1 -0
  353. package/bin/Utils/Debug/DebugManager.d.ts +131 -0
  354. package/bin/Utils/Debug/DebugManager.d.ts.map +1 -0
  355. package/bin/Utils/Debug/DebugManager.js +848 -0
  356. package/bin/Utils/Debug/DebugManager.js.map +1 -0
  357. package/bin/Utils/Debug/EntityDataCollector.d.ts +115 -0
  358. package/bin/Utils/Debug/EntityDataCollector.d.ts.map +1 -0
  359. package/bin/Utils/Debug/EntityDataCollector.js +870 -0
  360. package/bin/Utils/Debug/EntityDataCollector.js.map +1 -0
  361. package/bin/Utils/Debug/PerformanceDataCollector.d.ts +31 -0
  362. package/bin/Utils/Debug/PerformanceDataCollector.d.ts.map +1 -0
  363. package/bin/Utils/Debug/PerformanceDataCollector.js +203 -0
  364. package/bin/Utils/Debug/PerformanceDataCollector.js.map +1 -0
  365. package/bin/Utils/Debug/SceneDataCollector.d.ts +18 -0
  366. package/bin/Utils/Debug/SceneDataCollector.d.ts.map +1 -0
  367. package/bin/Utils/Debug/SceneDataCollector.js +43 -0
  368. package/bin/Utils/Debug/SceneDataCollector.js.map +1 -0
  369. package/bin/Utils/Debug/SystemDataCollector.d.ts +14 -0
  370. package/bin/Utils/Debug/SystemDataCollector.d.ts.map +1 -0
  371. package/bin/Utils/Debug/SystemDataCollector.js +60 -0
  372. package/bin/Utils/Debug/SystemDataCollector.js.map +1 -0
  373. package/bin/Utils/Debug/WebSocketManager.d.ts +54 -0
  374. package/bin/Utils/Debug/WebSocketManager.d.ts.map +1 -0
  375. package/bin/Utils/Debug/WebSocketManager.js +141 -0
  376. package/bin/Utils/Debug/WebSocketManager.js.map +1 -0
  377. package/bin/Utils/Debug/index.d.ts +11 -0
  378. package/bin/Utils/Debug/index.d.ts.map +1 -0
  379. package/bin/Utils/Debug/index.js +10 -0
  380. package/bin/Utils/Debug/index.js.map +1 -0
  381. package/bin/Utils/Emitter.d.ts +61 -0
  382. package/bin/Utils/Emitter.d.ts.map +1 -0
  383. package/bin/Utils/Emitter.js +101 -0
  384. package/bin/Utils/Emitter.js.map +1 -0
  385. package/bin/Utils/Extensions/NumberExtension.d.ts +13 -0
  386. package/bin/Utils/Extensions/NumberExtension.d.ts.map +1 -0
  387. package/bin/Utils/Extensions/NumberExtension.js +17 -0
  388. package/bin/Utils/Extensions/NumberExtension.js.map +1 -0
  389. package/bin/Utils/Extensions/TypeUtils.d.ts +13 -0
  390. package/bin/Utils/Extensions/TypeUtils.d.ts.map +1 -0
  391. package/bin/Utils/Extensions/TypeUtils.js +15 -0
  392. package/bin/Utils/Extensions/TypeUtils.js.map +1 -0
  393. package/bin/Utils/Extensions/index.d.ts +3 -0
  394. package/bin/Utils/Extensions/index.d.ts.map +1 -0
  395. package/bin/Utils/Extensions/index.js +4 -0
  396. package/bin/Utils/Extensions/index.js.map +1 -0
  397. package/bin/Utils/GlobalManager.d.ts +29 -0
  398. package/bin/Utils/GlobalManager.d.ts.map +1 -0
  399. package/bin/Utils/GlobalManager.js +50 -0
  400. package/bin/Utils/GlobalManager.js.map +1 -0
  401. package/bin/Utils/Logger/ConsoleLogger.d.ts +74 -0
  402. package/bin/Utils/Logger/ConsoleLogger.d.ts.map +1 -0
  403. package/bin/Utils/Logger/ConsoleLogger.js +187 -0
  404. package/bin/Utils/Logger/ConsoleLogger.js.map +1 -0
  405. package/bin/Utils/Logger/Constants.d.ts +36 -0
  406. package/bin/Utils/Logger/Constants.d.ts.map +1 -0
  407. package/bin/Utils/Logger/Constants.js +40 -0
  408. package/bin/Utils/Logger/Constants.js.map +1 -0
  409. package/bin/Utils/Logger/LoggerManager.d.ts +91 -0
  410. package/bin/Utils/Logger/LoggerManager.d.ts.map +1 -0
  411. package/bin/Utils/Logger/LoggerManager.js +167 -0
  412. package/bin/Utils/Logger/LoggerManager.js.map +1 -0
  413. package/bin/Utils/Logger/Types.d.ts +40 -0
  414. package/bin/Utils/Logger/Types.d.ts.map +1 -0
  415. package/bin/Utils/Logger/Types.js +2 -0
  416. package/bin/Utils/Logger/Types.js.map +1 -0
  417. package/bin/Utils/Logger/index.d.ts +5 -0
  418. package/bin/Utils/Logger/index.d.ts.map +1 -0
  419. package/bin/Utils/Logger/index.js +5 -0
  420. package/bin/Utils/Logger/index.js.map +1 -0
  421. package/bin/Utils/PerformanceMonitor.d.ts +196 -0
  422. package/bin/Utils/PerformanceMonitor.d.ts.map +1 -0
  423. package/bin/Utils/PerformanceMonitor.js +244 -0
  424. package/bin/Utils/PerformanceMonitor.js.map +1 -0
  425. package/bin/Utils/Pool/IPoolable.d.ts +29 -0
  426. package/bin/Utils/Pool/IPoolable.d.ts.map +1 -0
  427. package/bin/Utils/Pool/IPoolable.js +2 -0
  428. package/bin/Utils/Pool/IPoolable.js.map +1 -0
  429. package/bin/Utils/Pool/Pool.d.ts +109 -0
  430. package/bin/Utils/Pool/Pool.d.ts.map +1 -0
  431. package/bin/Utils/Pool/Pool.js +238 -0
  432. package/bin/Utils/Pool/Pool.js.map +1 -0
  433. package/bin/Utils/Pool/PoolManager.d.ts +96 -0
  434. package/bin/Utils/Pool/PoolManager.d.ts.map +1 -0
  435. package/bin/Utils/Pool/PoolManager.js +199 -0
  436. package/bin/Utils/Pool/PoolManager.js.map +1 -0
  437. package/bin/Utils/Pool/index.d.ts +4 -0
  438. package/bin/Utils/Pool/index.d.ts.map +1 -0
  439. package/bin/Utils/Pool/index.js +4 -0
  440. package/bin/Utils/Pool/index.js.map +1 -0
  441. package/bin/Utils/Profiler/AutoProfiler.d.ts +160 -0
  442. package/bin/Utils/Profiler/AutoProfiler.d.ts.map +1 -0
  443. package/bin/Utils/Profiler/AutoProfiler.js +503 -0
  444. package/bin/Utils/Profiler/AutoProfiler.js.map +1 -0
  445. package/bin/Utils/Profiler/ProfilerSDK.d.ts +175 -0
  446. package/bin/Utils/Profiler/ProfilerSDK.d.ts.map +1 -0
  447. package/bin/Utils/Profiler/ProfilerSDK.js +727 -0
  448. package/bin/Utils/Profiler/ProfilerSDK.js.map +1 -0
  449. package/bin/Utils/Profiler/ProfilerTypes.d.ts +218 -0
  450. package/bin/Utils/Profiler/ProfilerTypes.d.ts.map +1 -0
  451. package/bin/Utils/Profiler/ProfilerTypes.js +47 -0
  452. package/bin/Utils/Profiler/ProfilerTypes.js.map +1 -0
  453. package/bin/Utils/Profiler/index.d.ts +8 -0
  454. package/bin/Utils/Profiler/index.d.ts.map +1 -0
  455. package/bin/Utils/Profiler/index.js +7 -0
  456. package/bin/Utils/Profiler/index.js.map +1 -0
  457. package/bin/Utils/Time.d.ts +47 -0
  458. package/bin/Utils/Time.d.ts.map +1 -0
  459. package/bin/Utils/Time.js +64 -0
  460. package/bin/Utils/Time.js.map +1 -0
  461. package/bin/Utils/Timers/ITimer.d.ts +16 -0
  462. package/bin/Utils/Timers/ITimer.d.ts.map +1 -0
  463. package/bin/Utils/Timers/ITimer.js +2 -0
  464. package/bin/Utils/Timers/ITimer.js.map +1 -0
  465. package/bin/Utils/Timers/Timer.d.ts +30 -0
  466. package/bin/Utils/Timers/Timer.d.ts.map +1 -0
  467. package/bin/Utils/Timers/Timer.js +58 -0
  468. package/bin/Utils/Timers/Timer.js.map +1 -0
  469. package/bin/Utils/Timers/TimerManager.d.ts +26 -0
  470. package/bin/Utils/Timers/TimerManager.d.ts.map +1 -0
  471. package/bin/Utils/Timers/TimerManager.js +48 -0
  472. package/bin/Utils/Timers/TimerManager.js.map +1 -0
  473. package/bin/Utils/index.d.ts +11 -0
  474. package/bin/Utils/index.d.ts.map +1 -0
  475. package/bin/Utils/index.js +11 -0
  476. package/bin/Utils/index.js.map +1 -0
  477. package/bin/index.d.ts +29 -0
  478. package/bin/index.d.ts.map +1 -0
  479. package/bin/index.js +36 -0
  480. package/bin/index.js.map +1 -0
  481. package/package.json +84 -47
  482. package/index.cjs +0 -2
  483. package/index.cjs.map +0 -1
  484. package/index.d.ts +0 -13129
  485. package/index.es5.js +0 -4
  486. package/index.es5.js.map +0 -1
  487. package/index.mjs +0 -2
  488. package/index.mjs.map +0 -1
  489. package/index.umd.js +0 -4
  490. package/index.umd.js.map +0 -1
@@ -0,0 +1,476 @@
1
+ /**
2
+ * 位枚举
3
+ */
4
+ export var SegmentPart;
5
+ (function (SegmentPart) {
6
+ SegmentPart[SegmentPart["LOW"] = 0] = "LOW";
7
+ SegmentPart[SegmentPart["HIGH"] = 1] = "HIGH";
8
+ })(SegmentPart || (SegmentPart = {}));
9
+ export class BitMask64Utils {
10
+ /**
11
+ * 根据位索引创建64位掩码
12
+ * @param bitIndex 位索引,范围 [0, 63]
13
+ * @returns 包含指定位设置为1的掩码
14
+ * @throws 当位索引超出范围时抛出错误
15
+ */
16
+ static create(bitIndex) {
17
+ if (bitIndex < 0) {
18
+ throw new Error(`Bit index ${bitIndex} out of range [0, ∞)`);
19
+ }
20
+ const mask = { base: [0, 0] };
21
+ BitMask64Utils.setBit(mask, bitIndex);
22
+ return mask;
23
+ }
24
+ /**
25
+ * 从32位数字创建64位掩码
26
+ * @param value 32位数字值
27
+ * @returns 低32位为输入值、高32位为0的掩码
28
+ */
29
+ static fromNumber(value) {
30
+ return { base: [value >>> 0, 0] };
31
+ }
32
+ /**
33
+ * 检查掩码是否包含任意指定的位
34
+ * @param mask 要检查的掩码
35
+ * @param bits 指定的位模式
36
+ * @returns 如果掩码包含bits中的任意位则返回true
37
+ */
38
+ static hasAny(mask, bits) {
39
+ const bitsBase = bits.base;
40
+ const maskBase = mask.base;
41
+ const bitsSegments = bits.segments;
42
+ const maskSegments = mask.segments;
43
+ const baseHasAny = (maskBase[SegmentPart.LOW] & bitsBase[SegmentPart.LOW]) !== 0 || (maskBase[SegmentPart.HIGH] & bitsBase[SegmentPart.HIGH]) !== 0;
44
+ // 基础区段就包含指定的位,或任意一个参数不含扩展区段,直接短路
45
+ if (baseHasAny || !bitsSegments || !maskSegments)
46
+ return baseHasAny;
47
+ // 额外检查扩展区域是否包含指定的位 - 如果bitsSegments[index]不存在,会被转为NaN,NaN的位运算始终返回0
48
+ return maskSegments.some((seg, index) => {
49
+ const bitsSeg = bitsSegments[index];
50
+ return bitsSeg && ((seg[SegmentPart.LOW] & bitsSeg[SegmentPart.LOW]) !== 0 || (seg[SegmentPart.HIGH] & bitsSeg[SegmentPart.HIGH]) !== 0);
51
+ });
52
+ }
53
+ /**
54
+ * 检查掩码是否包含所有指定的位
55
+ * @param mask 要检查的掩码
56
+ * @param bits 指定的位模式
57
+ * @returns 如果掩码包含bits中的所有位则返回true
58
+ */
59
+ static hasAll(mask, bits) {
60
+ const maskBase = mask.base;
61
+ const bitsBase = bits.base;
62
+ const maskSegments = mask.segments;
63
+ const bitsSegments = bits.segments;
64
+ const baseHasAll = (maskBase[SegmentPart.LOW] & bitsBase[SegmentPart.LOW]) === bitsBase[SegmentPart.LOW] && (maskBase[SegmentPart.HIGH] & bitsBase[SegmentPart.HIGH]) === bitsBase[SegmentPart.HIGH];
65
+ // 基础区域就不包含指定的位,或bits没有扩展区段,直接短路。
66
+ if (!baseHasAll || !bitsSegments)
67
+ return baseHasAll;
68
+ // 扩展区段的hasAll匹配逻辑
69
+ const maskSegmentsLength = maskSegments?.length ?? 0;
70
+ // 对mask/bits中都存在的区段,进行hasAll判断
71
+ if (maskSegments) {
72
+ for (let i = 0; i < Math.min(maskSegmentsLength, bitsSegments.length); i++) {
73
+ const maskSeg = maskSegments[i];
74
+ const bitsSeg = bitsSegments[i];
75
+ if ((maskSeg[SegmentPart.LOW] & bitsSeg[SegmentPart.LOW]) !== bitsSeg[SegmentPart.LOW] || (maskSeg[SegmentPart.HIGH] & bitsSeg[SegmentPart.HIGH]) !== bitsSeg[SegmentPart.HIGH]) {
76
+ // 存在不匹配的位,直接短路
77
+ return false;
78
+ }
79
+ }
80
+ }
81
+ // 对mask中不存在,但bits中存在的区段,进行isZero判断
82
+ for (let i = maskSegmentsLength; i < bitsSegments.length; i++) {
83
+ const bitsSeg = bitsSegments[i];
84
+ if (bitsSeg[SegmentPart.LOW] !== 0 || bitsSeg[SegmentPart.HIGH] !== 0) {
85
+ // 存在不为0的区段,直接短路
86
+ return false;
87
+ }
88
+ }
89
+ return true;
90
+ }
91
+ /**
92
+ * 检查掩码是否不包含任何指定的位
93
+ * @param mask 要检查的掩码
94
+ * @param bits 指定的位模式
95
+ * @returns 如果掩码不包含bits中的任何位则返回true
96
+ */
97
+ static hasNone(mask, bits) {
98
+ const maskBase = mask.base;
99
+ const bitsBase = bits.base;
100
+ const maskSegments = mask.segments;
101
+ const bitsSegments = bits.segments;
102
+ const baseHasNone = (maskBase[SegmentPart.LOW] & bitsBase[SegmentPart.LOW]) === 0 && (maskBase[SegmentPart.HIGH] & bitsBase[SegmentPart.HIGH]) === 0;
103
+ //不含扩展区域,或基础区域就包含指定的位,或bits不含拓展区段,直接短路。
104
+ if (!maskSegments || !baseHasNone || !bitsSegments)
105
+ return baseHasNone;
106
+ // 额外检查扩展区域是否都包含指定的位 - 此时bitsSegments存在,如果bitsSegments[index]不存在,会被转为NaN,NaN的位运算始终返回0
107
+ return maskSegments.every((seg, index) => {
108
+ const bitsSeg = bitsSegments[index];
109
+ if (!bitsSeg)
110
+ return true;
111
+ return (seg[SegmentPart.LOW] & bitsSeg[SegmentPart.LOW]) === 0 && (seg[SegmentPart.HIGH] & bitsSeg[SegmentPart.HIGH]) === 0;
112
+ });
113
+ }
114
+ /**
115
+ * 检查掩码是否为零
116
+ * @param mask 要检查的掩码
117
+ * @returns 如果掩码所有位都为0则返回true
118
+ */
119
+ static isZero(mask) {
120
+ const baseIsZero = mask.base[SegmentPart.LOW] === 0 && mask.base[SegmentPart.HIGH] === 0;
121
+ if (!mask.segments || !baseIsZero) {
122
+ // 不含扩展区域,或基础区域值就不为0,直接短路
123
+ return baseIsZero;
124
+ }
125
+ // 额外检查扩展区域是否都为0
126
+ return mask.segments.every((seg) => seg[SegmentPart.LOW] === 0 && seg[SegmentPart.HIGH] === 0);
127
+ }
128
+ /**
129
+ * 检查两个掩码是否相等
130
+ * @param a 第一个掩码
131
+ * @param b 第二个掩码
132
+ * @returns 如果两个掩码完全相等则返回true
133
+ */
134
+ static equals(a, b) {
135
+ const baseEquals = a.base[SegmentPart.LOW] === b.base[SegmentPart.LOW] && a.base[SegmentPart.HIGH] === b.base[SegmentPart.HIGH];
136
+ // base不相等,或ab都没有扩展区域位,直接返回base比较结果
137
+ if (!baseEquals || (!a.segments && !b.segments))
138
+ return baseEquals;
139
+ // 不能假设a,b的segments都存在或长度相同.
140
+ const aSegments = a.segments ?? [];
141
+ const bSegments = b.segments ?? [];
142
+ for (let i = 0; i < Math.max(aSegments.length, bSegments.length); i++) {
143
+ const aSeg = aSegments[i]; // 可能为undefined
144
+ const bSeg = bSegments[i]; // 可能为undefined
145
+ if (aSeg && !bSeg) {
146
+ //bSeg不存在,则必须要求aSeg全为0
147
+ if (aSeg[SegmentPart.LOW] !== 0 || aSeg[SegmentPart.HIGH] !== 0)
148
+ return false;
149
+ }
150
+ else if (!aSeg && bSeg) {
151
+ //aSeg不存在,则必须要求bSeg全为0
152
+ if (bSeg[SegmentPart.LOW] !== 0 || bSeg[SegmentPart.HIGH] !== 0)
153
+ return false;
154
+ }
155
+ else if (aSeg && bSeg) {
156
+ //理想状态:aSeg/bSeg都存在
157
+ if (aSeg[SegmentPart.LOW] !== bSeg[SegmentPart.LOW] || aSeg[SegmentPart.HIGH] !== bSeg[SegmentPart.HIGH])
158
+ return false;
159
+ }
160
+ }
161
+ return true;
162
+ }
163
+ /**
164
+ * 设置掩码中指定位为1,必要时自动扩展
165
+ * @param mask 要修改的掩码(原地修改)
166
+ * @param bitIndex 位索引,不小于零
167
+ * @throws 当位索引超出范围时抛出错误
168
+ */
169
+ static setBit(mask, bitIndex) {
170
+ if (bitIndex < 0) {
171
+ throw new Error(`Bit index ${bitIndex} out of range [0, 63]`);
172
+ }
173
+ const targetSeg = BitMask64Utils.getSegmentByBitIndex(mask, bitIndex);
174
+ const mod = bitIndex & 63; // bitIndex % 64 优化方案
175
+ if (mod < 32) {
176
+ targetSeg[SegmentPart.LOW] |= (1 << mod);
177
+ }
178
+ else {
179
+ targetSeg[SegmentPart.HIGH] |= (1 << (mod - 32));
180
+ }
181
+ }
182
+ /**
183
+ * 获取掩码中指定位,如果位超出当前掩码的区段长度,则直接返回0
184
+ * @param mask 掩码
185
+ * @param bitIndex 位索引,不小于零
186
+ */
187
+ static getBit(mask, bitIndex) {
188
+ if (bitIndex < 0) {
189
+ return false;
190
+ }
191
+ const targetSeg = BitMask64Utils.getSegmentByBitIndex(mask, bitIndex, false);
192
+ if (!targetSeg)
193
+ return false;
194
+ const mod = bitIndex & 63; // bitIndex % 64 优化方案
195
+ if (mod < 32) {
196
+ return (targetSeg[SegmentPart.LOW] & (1 << mod)) !== 0;
197
+ }
198
+ else {
199
+ return (targetSeg[SegmentPart.HIGH] & (1 << (mod - 32))) !== 0;
200
+ }
201
+ }
202
+ /**
203
+ * 清除掩码中指定位为0,如果位超出当前掩码的区段长度,则什么也不做
204
+ * @param mask 要修改的掩码(原地修改)
205
+ * @param bitIndex 位索引,不小于0
206
+ */
207
+ static clearBit(mask, bitIndex) {
208
+ if (bitIndex < 0) {
209
+ throw new Error(`Bit index ${bitIndex} out of range [0, 63]`);
210
+ }
211
+ const targetSeg = BitMask64Utils.getSegmentByBitIndex(mask, bitIndex, false);
212
+ if (!targetSeg)
213
+ return;
214
+ const mod = bitIndex & 63; // bitIndex % 64 优化方案
215
+ if (mod < 32) {
216
+ targetSeg[SegmentPart.LOW] &= ~(1 << mod);
217
+ }
218
+ else {
219
+ targetSeg[SegmentPart.HIGH] &= ~(1 << (mod - 32));
220
+ }
221
+ }
222
+ /**
223
+ * 对目标掩码执行按位或操作
224
+ * @param target 目标掩码(原地修改)
225
+ * @param other 用于按位或的掩码
226
+ */
227
+ static orInPlace(target, other) {
228
+ target.base[SegmentPart.LOW] |= other.base[SegmentPart.LOW];
229
+ target.base[SegmentPart.HIGH] |= other.base[SegmentPart.HIGH];
230
+ // 处理扩展段
231
+ const otherSegments = other.segments;
232
+ if (otherSegments && otherSegments.length > 0) {
233
+ if (!target.segments) {
234
+ target.segments = [];
235
+ }
236
+ const targetSegments = target.segments;
237
+ // 确保 target 有足够的段
238
+ while (targetSegments.length < otherSegments.length) {
239
+ targetSegments.push([0, 0]);
240
+ }
241
+ // 对每个段执行或操作
242
+ for (let i = 0; i < otherSegments.length; i++) {
243
+ const targetSeg = targetSegments[i];
244
+ const otherSeg = otherSegments[i];
245
+ targetSeg[SegmentPart.LOW] |= otherSeg[SegmentPart.LOW];
246
+ targetSeg[SegmentPart.HIGH] |= otherSeg[SegmentPart.HIGH];
247
+ }
248
+ }
249
+ }
250
+ /**
251
+ * 对目标掩码执行按位与操作
252
+ * @param target 目标掩码(原地修改)
253
+ * @param other 用于按位与的掩码
254
+ */
255
+ static andInPlace(target, other) {
256
+ target.base[SegmentPart.LOW] &= other.base[SegmentPart.LOW];
257
+ target.base[SegmentPart.HIGH] &= other.base[SegmentPart.HIGH];
258
+ // 处理扩展段
259
+ const otherSegments = other.segments;
260
+ if (otherSegments && otherSegments.length > 0) {
261
+ if (!target.segments) {
262
+ target.segments = [];
263
+ }
264
+ const targetSegments = target.segments;
265
+ // 确保 target 有足够的段
266
+ while (targetSegments.length < otherSegments.length) {
267
+ targetSegments.push([0, 0]);
268
+ }
269
+ // 对每个段执行与操作
270
+ for (let i = 0; i < otherSegments.length; i++) {
271
+ const targetSeg = targetSegments[i];
272
+ const otherSeg = otherSegments[i];
273
+ targetSeg[SegmentPart.LOW] &= otherSeg[SegmentPart.LOW];
274
+ targetSeg[SegmentPart.HIGH] &= otherSeg[SegmentPart.HIGH];
275
+ }
276
+ }
277
+ }
278
+ /**
279
+ * 对目标掩码执行按位异或操作
280
+ * @param target 目标掩码(原地修改)
281
+ * @param other 用于按位异或的掩码
282
+ */
283
+ static xorInPlace(target, other) {
284
+ target.base[SegmentPart.LOW] ^= other.base[SegmentPart.LOW];
285
+ target.base[SegmentPart.HIGH] ^= other.base[SegmentPart.HIGH];
286
+ // 处理扩展段
287
+ const otherSegments = other.segments;
288
+ if (!otherSegments || otherSegments.length == 0)
289
+ return;
290
+ if (!target.segments)
291
+ target.segments = [];
292
+ const targetSegments = target.segments;
293
+ // 确保 target 有足够的段
294
+ while (targetSegments.length < otherSegments.length) {
295
+ targetSegments.push([0, 0]);
296
+ }
297
+ // 对每个段执行异或操作
298
+ for (let i = 0; i < otherSegments.length; i++) {
299
+ const targetSeg = targetSegments[i];
300
+ const otherSeg = otherSegments[i];
301
+ targetSeg[SegmentPart.LOW] ^= otherSeg[SegmentPart.LOW];
302
+ targetSeg[SegmentPart.HIGH] ^= otherSeg[SegmentPart.HIGH];
303
+ }
304
+ }
305
+ /**
306
+ * 清除掩码的所有位为0
307
+ * @param mask 要清除的掩码(原地修改)
308
+ */
309
+ static clear(mask) {
310
+ mask.base[SegmentPart.LOW] = 0;
311
+ mask.base[SegmentPart.HIGH] = 0;
312
+ if (mask.segments) {
313
+ for (let i = 0; i < mask.segments.length; i++) {
314
+ const seg = mask.segments[i];
315
+ seg[SegmentPart.LOW] = 0;
316
+ seg[SegmentPart.HIGH] = 0;
317
+ }
318
+ }
319
+ }
320
+ /**
321
+ * 将源掩码的值复制到目标掩码,如果source包含扩展段,则target也会至少扩展到source扩展段的长度
322
+ * @param source 源掩码
323
+ * @param target 目标掩码(原地修改)
324
+ */
325
+ static copy(source, target) {
326
+ BitMask64Utils.clear(target);
327
+ target.base[SegmentPart.LOW] = source.base[SegmentPart.LOW];
328
+ target.base[SegmentPart.HIGH] = source.base[SegmentPart.HIGH];
329
+ // source没有扩展段,直接退出
330
+ if (!source.segments || source.segments.length == 0)
331
+ return;
332
+ // 没有拓展段,则直接复制数组
333
+ if (!target.segments) {
334
+ target.segments = source.segments.map((seg) => [...seg]);
335
+ return;
336
+ }
337
+ // source有扩展段,target扩展段不足,则补充长度
338
+ const copyLength = source.segments.length - target.segments.length;
339
+ for (let i = 0; i < copyLength; i++) {
340
+ target.segments.push([0, 0]);
341
+ }
342
+ // 逐个重写
343
+ const targetSegments = target.segments;
344
+ const sourceSegments = source.segments;
345
+ for (let i = 0; i < sourceSegments.length; i++) {
346
+ const targetSeg = targetSegments[i];
347
+ const sourSeg = sourceSegments[i];
348
+ targetSeg[SegmentPart.LOW] = sourSeg[SegmentPart.LOW];
349
+ targetSeg[SegmentPart.HIGH] = sourSeg[SegmentPart.HIGH];
350
+ }
351
+ }
352
+ /**
353
+ * 创建掩码的深拷贝
354
+ * @param mask 要拷贝的掩码
355
+ * @returns 新的掩码对象,内容与源掩码相同
356
+ */
357
+ static clone(mask) {
358
+ return {
359
+ base: mask.base.slice(),
360
+ ...(mask.segments && { segments: mask.segments.map((seg) => [...seg]) })
361
+ };
362
+ }
363
+ /**
364
+ * 将掩码转换为字符串表示,每个区段之间将使用空格分割。
365
+ * @param mask 要转换的掩码
366
+ * @param radix 进制,支持2(二进制)或16(十六进制),默认为2,其他的值被视为2
367
+ * @param printHead 打印头
368
+ * @returns 掩码的字符串表示,二进制不带前缀,十六进制带0x前缀
369
+ */
370
+ static toString(mask, radix = 2, printHead = false) {
371
+ if (radix != 2 && radix != 16)
372
+ radix = 2;
373
+ const totalLength = mask.segments?.length ?? 0;
374
+ let result = '';
375
+ if (printHead) {
376
+ let paddingLength = 0;
377
+ if (radix === 2) {
378
+ paddingLength = 64 + 1 + 1;
379
+ }
380
+ else {
381
+ paddingLength = 16 + 2 + 1;
382
+ }
383
+ for (let i = 0; i <= totalLength; i++) {
384
+ const title = i === 0 ? '0 (Base):' : `${i} (${64 * i}):`;
385
+ result += title.toString().padEnd(paddingLength);
386
+ }
387
+ result += '\n';
388
+ }
389
+ for (let i = -1; i < totalLength; i++) {
390
+ let segResult = '';
391
+ const bitMaskData = i == -1 ? mask.base : mask.segments[i];
392
+ const hi = bitMaskData[SegmentPart.HIGH];
393
+ const lo = bitMaskData[SegmentPart.LOW];
394
+ if (radix == 2) {
395
+ const hiBits = hi.toString(2).padStart(32, '0');
396
+ const loBits = lo.toString(2).padStart(32, '0');
397
+ segResult = hiBits + '_' + loBits; //高低位之间使用_隔离
398
+ }
399
+ else {
400
+ let hiBits = hi ? hi.toString(16).toUpperCase() : '';
401
+ if (printHead) {
402
+ // 存在标头,则输出高位之前需要补齐位数
403
+ hiBits = hiBits.padStart(8, '0');
404
+ }
405
+ let loBits = lo.toString(16).toUpperCase();
406
+ if (hiBits) {
407
+ // 存在高位 则输出低位之前需要补齐位数
408
+ loBits = loBits.padStart(8, '0');
409
+ }
410
+ segResult = '0x' + hiBits + loBits;
411
+ }
412
+ if (i === -1)
413
+ result += segResult;
414
+ else
415
+ result += ' ' + segResult; // 不同段之间使用空格隔离
416
+ }
417
+ return result;
418
+ }
419
+ /**
420
+ * 计算掩码中设置为1的位数
421
+ * @param mask 要计算的掩码
422
+ * @returns 掩码中1的位数
423
+ */
424
+ static popCount(mask) {
425
+ let count = 0;
426
+ for (let i = -1; i < (mask.segments?.length ?? 0); i++) {
427
+ const bitMaskData = i == -1 ? mask.base : mask.segments[i];
428
+ let lo = bitMaskData[SegmentPart.LOW];
429
+ let hi = bitMaskData[SegmentPart.HIGH];
430
+ while (lo) {
431
+ lo &= lo - 1;
432
+ count++;
433
+ }
434
+ while (hi) {
435
+ hi &= hi - 1;
436
+ count++;
437
+ }
438
+ }
439
+ return count;
440
+ }
441
+ /**
442
+ * 获取包含目标位的BitMask64Segment
443
+ * @param mask 要操作的掩码
444
+ * @param bitIndex 目标位
445
+ * @param createNewSegment 如果bitIndex超过了当前范围,是否自动补充扩展区域,默认为真
446
+ * @private
447
+ */
448
+ static getSegmentByBitIndex(mask, bitIndex, createNewSegment = true) {
449
+ if (bitIndex <= 63) {
450
+ // 基础位
451
+ return mask.base;
452
+ }
453
+ else {
454
+ // 扩展位
455
+ let segments = mask.segments;
456
+ if (!segments) {
457
+ if (!createNewSegment)
458
+ return null;
459
+ segments = mask.segments = [];
460
+ }
461
+ const targetSegIndex = (bitIndex >> 6) - 1; // Math.floor(bitIndex / 64) - 1的位运算优化
462
+ if (segments.length <= targetSegIndex) {
463
+ if (!createNewSegment)
464
+ return null;
465
+ const diff = targetSegIndex - segments.length + 1;
466
+ for (let i = 0; i < diff; i++) {
467
+ segments.push([0, 0]);
468
+ }
469
+ }
470
+ return segments[targetSegIndex] ?? null;
471
+ }
472
+ }
473
+ }
474
+ /** 零掩码常量,所有位都为0 */
475
+ BitMask64Utils.ZERO = { base: [0, 0] };
476
+ //# sourceMappingURL=BigIntCompatibility.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BigIntCompatibility.js","sourceRoot":"","sources":["../../../src/ECS/Utils/BigIntCompatibility.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ import { BitMask64Data } from './BigIntCompatibility';
2
+ /**
3
+ * 高性能 HashMap,使用BitMask64Data作为Key。内部计算两层哈希:
4
+ * - primaryHash: MurmurHash3(seed1) => 定位 bucket
5
+ * - secondaryHash: MurmurHash3(seed2) => 处理 bucket 内碰撞判定
6
+ *
7
+ * 理论上,在1e5数量数据规模下碰撞概率在数学意义上的可忽略。
8
+ * 在本地测试中,一千万次连续/随机BitMask64Data生成未发生一级哈希冲突,考虑到使用场景(原型系统、组件系统等)远达不到此数量级,因此可安全用于生产环境。
9
+ */
10
+ export declare class BitMaskHashMap<T> {
11
+ private buckets;
12
+ private _size;
13
+ constructor();
14
+ get size(): number;
15
+ get innerBuckets(): Map<number, [number, T][]>;
16
+ /** MurmurHash3 (32bit) 简化实现 */
17
+ private murmur32;
18
+ /** primaryHash + secondaryHash 计算 */
19
+ private getHashes;
20
+ set(key: BitMask64Data, value: T): this;
21
+ get(key: BitMask64Data): T | undefined;
22
+ has(key: BitMask64Data): boolean;
23
+ delete(key: BitMask64Data): boolean;
24
+ clear(): void;
25
+ entries(): IterableIterator<[BitMask64Data, T]>;
26
+ values(): IterableIterator<T>;
27
+ }
28
+ //# sourceMappingURL=BitMaskHashMap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BitMaskHashMap.d.ts","sourceRoot":"","sources":["../../../src/ECS/Utils/BitMaskHashMap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAItD;;;;;;;GAOG;AACH,qBAAa,cAAc,CAAC,CAAC;IACzB,OAAO,CAAC,OAAO,CAAyC;IACxD,OAAO,CAAC,KAAK,CAAK;;IAIlB,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,YAAY,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAE7C;IACD,+BAA+B;IAC/B,OAAO,CAAC,QAAQ;IAgChB,qCAAqC;IACrC,OAAO,CAAC,SAAS;IAMjB,GAAG,CAAC,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI;IAsBvC,GAAG,CAAC,GAAG,EAAE,aAAa,GAAG,CAAC,GAAG,SAAS;IAYtC,GAAG,CAAC,GAAG,EAAE,aAAa,GAAG,OAAO;IAIhC,MAAM,CAAC,GAAG,EAAE,aAAa,GAAG,OAAO;IAiBnC,KAAK,IAAI,IAAI;IAKZ,OAAO,IAAI,gBAAgB,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IAS/C,MAAM,IAAI,gBAAgB,CAAC,CAAC,CAAC;CAOjC"}
@@ -0,0 +1,127 @@
1
+ // FlatHashMapFast.ts
2
+ /**
3
+ * 高性能 HashMap,使用BitMask64Data作为Key。内部计算两层哈希:
4
+ * - primaryHash: MurmurHash3(seed1) => 定位 bucket
5
+ * - secondaryHash: MurmurHash3(seed2) => 处理 bucket 内碰撞判定
6
+ *
7
+ * 理论上,在1e5数量数据规模下碰撞概率在数学意义上的可忽略。
8
+ * 在本地测试中,一千万次连续/随机BitMask64Data生成未发生一级哈希冲突,考虑到使用场景(原型系统、组件系统等)远达不到此数量级,因此可安全用于生产环境。
9
+ */
10
+ export class BitMaskHashMap {
11
+ constructor() {
12
+ this.buckets = new Map();
13
+ this._size = 0;
14
+ }
15
+ get size() {
16
+ return this._size;
17
+ }
18
+ get innerBuckets() {
19
+ return this.buckets;
20
+ }
21
+ /** MurmurHash3 (32bit) 简化实现 */
22
+ murmur32(key, seed) {
23
+ let h = seed >>> 0;
24
+ const mix = (k) => {
25
+ k = Math.imul(k, 0xcc9e2d51) >>> 0; // 第一个 32 位魔术常数
26
+ k = (k << 15) | (k >>> 17);
27
+ k = Math.imul(k, 0x1b873593) >>> 0; // 第二个 32 位魔术常数
28
+ h ^= k;
29
+ h = (h << 13) | (h >>> 19);
30
+ h = (Math.imul(h, 5) + 0xe6546b64) >>> 0;
31
+ };
32
+ // base
33
+ mix(key.base[0] >>> 0);
34
+ mix(key.base[1] >>> 0);
35
+ // segments
36
+ if (key.segments) {
37
+ for (const seg of key.segments) {
38
+ mix(seg[0] >>> 0);
39
+ mix(seg[1] >>> 0);
40
+ }
41
+ }
42
+ h ^= (key.segments ? key.segments.length * 8 : 8);
43
+ h ^= h >>> 16;
44
+ h = Math.imul(h, 0x85ebca6b) >>> 0;
45
+ h ^= h >>> 13;
46
+ h = Math.imul(h, 0xc2b2ae35) >>> 0;
47
+ h ^= h >>> 16;
48
+ return h >>> 0;
49
+ }
50
+ /** primaryHash + secondaryHash 计算 */
51
+ getHashes(key) {
52
+ const primary = this.murmur32(key, 0x9747b28c); // seed1
53
+ const secondary = this.murmur32(key, 0x12345678); // seed2
54
+ return [primary, secondary];
55
+ }
56
+ set(key, value) {
57
+ const [primary, secondary] = this.getHashes(key);
58
+ let bucket = this.buckets.get(primary);
59
+ if (!bucket) {
60
+ bucket = [];
61
+ this.buckets.set(primary, bucket);
62
+ }
63
+ // 查找是否存在 secondaryHash
64
+ for (let i = 0; i < bucket.length; i++) {
65
+ if (bucket[i][0] === secondary) {
66
+ bucket[i][1] = value;
67
+ return this;
68
+ }
69
+ }
70
+ // 新增
71
+ bucket.push([secondary, value]);
72
+ this._size++;
73
+ return this;
74
+ }
75
+ get(key) {
76
+ const [primary, secondary] = this.getHashes(key);
77
+ const bucket = this.buckets.get(primary);
78
+ if (!bucket)
79
+ return undefined;
80
+ for (let i = 0; i < bucket.length; i++) {
81
+ if (bucket[i][0] === secondary) {
82
+ return bucket[i][1];
83
+ }
84
+ }
85
+ return undefined;
86
+ }
87
+ has(key) {
88
+ return this.get(key) !== undefined;
89
+ }
90
+ delete(key) {
91
+ const [primary, secondary] = this.getHashes(key);
92
+ const bucket = this.buckets.get(primary);
93
+ if (!bucket)
94
+ return false;
95
+ for (let i = 0; i < bucket.length; i++) {
96
+ if (bucket[i][0] === secondary) {
97
+ bucket.splice(i, 1);
98
+ this._size--;
99
+ if (bucket.length === 0) {
100
+ this.buckets.delete(primary);
101
+ }
102
+ return true;
103
+ }
104
+ }
105
+ return false;
106
+ }
107
+ clear() {
108
+ this.buckets.clear();
109
+ this._size = 0;
110
+ }
111
+ *entries() {
112
+ for (const [_, bucket] of this.buckets) {
113
+ for (const [_secondary, value] of bucket) {
114
+ // 无法还原原始 key(只存二级 hash),所以 entries 返回不了 key
115
+ yield [undefined, value];
116
+ }
117
+ }
118
+ }
119
+ *values() {
120
+ for (const bucket of this.buckets.values()) {
121
+ for (const [_, value] of bucket) {
122
+ yield value;
123
+ }
124
+ }
125
+ }
126
+ }
127
+ //# sourceMappingURL=BitMaskHashMap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BitMaskHashMap.js","sourceRoot":"","sources":["../../../src/ECS/Utils/BitMaskHashMap.ts"],"names":[],"mappings":"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"}