@adobe/data 0.9.0 → 0.9.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 (969) hide show
  1. package/dist/debug-type-test.js +12 -0
  2. package/dist/debug-type-test.js.map +1 -0
  3. package/dist/ecs/database/archetype-type-safety-test.d.ts +21 -0
  4. package/dist/ecs/database/archetype-type-safety-test.js +36 -0
  5. package/dist/ecs/database/archetype-type-safety-test.js.map +1 -0
  6. package/dist/ecs/database/calculate-system-order.d.ts +10 -0
  7. package/dist/ecs/database/calculate-system-order.js +152 -26
  8. package/dist/ecs/database/calculate-system-order.js.map +1 -1
  9. package/dist/ecs/database/calculate-system-order.test.js +228 -0
  10. package/dist/ecs/database/calculate-system-order.test.js.map +1 -1
  11. package/dist/ecs/database/create-database-schema-test.js +150 -0
  12. package/dist/ecs/database/create-database-schema-test.js.map +1 -0
  13. package/dist/ecs/database/create-plugin-v2.d.ts +79 -0
  14. package/dist/ecs/database/create-plugin-v2.js +68 -0
  15. package/dist/ecs/database/create-plugin-v2.js.map +1 -0
  16. package/dist/ecs/database/create-plugin-v2.test.js +362 -0
  17. package/dist/ecs/database/create-plugin-v2.test.js.map +1 -0
  18. package/dist/ecs/database/create-plugin.OLD.d.ts +138 -0
  19. package/dist/ecs/database/create-plugin.OLD.js +59 -0
  20. package/dist/ecs/database/create-plugin.OLD.js.map +1 -0
  21. package/dist/ecs/database/create-plugin.d.ts +2 -0
  22. package/dist/ecs/database/create-plugin.js.map +1 -1
  23. package/dist/ecs/database/create-plugin.test.js +2 -0
  24. package/dist/ecs/database/create-plugin.test.js.map +1 -1
  25. package/dist/ecs/database/database-with-systems.test.js +292 -0
  26. package/dist/ecs/database/database-with-systems.test.js.map +1 -0
  27. package/dist/ecs/database/database.d.ts +7 -0
  28. package/dist/ecs/database/database.js.map +1 -1
  29. package/dist/ecs/database/database.plugin.create.test.OLD.js +601 -0
  30. package/dist/ecs/database/database.plugin.create.test.OLD.js.map +1 -0
  31. package/dist/ecs/database/database.plugin.create.test.js +321 -0
  32. package/dist/ecs/database/database.plugin.create.test.js.map +1 -0
  33. package/dist/ecs/database/database.plugin.test.js +90 -0
  34. package/dist/ecs/database/database.plugin.test.js.map +1 -0
  35. package/dist/ecs/database/database.test copy.js +199 -0
  36. package/dist/ecs/database/database.test copy.js.map +1 -0
  37. package/dist/ecs/database/multi-param-inference-poc.test.js +96 -0
  38. package/dist/ecs/database/multi-param-inference-poc.test.js.map +1 -0
  39. package/dist/ecs/database/old-plugin-create-with-dependencies-array.d.ts +61 -0
  40. package/dist/ecs/database/old-plugin-create-with-dependencies-array.js +76 -0
  41. package/dist/ecs/database/old-plugin-create-with-dependencies-array.js.map +1 -0
  42. package/dist/ecs/database/overload-inference-poc.test.js +109 -0
  43. package/dist/ecs/database/overload-inference-poc.test.js.map +1 -0
  44. package/dist/ecs/database/public/create-database.d.ts +1 -0
  45. package/dist/ecs/database/schedule-type-check-demo.d.ts +10 -0
  46. package/dist/ecs/database/schedule-type-check-demo.js +71 -0
  47. package/dist/ecs/database/schedule-type-check-demo.js.map +1 -0
  48. package/dist/ecs/database/test-archetype-validation.d.ts +9 -0
  49. package/dist/ecs/database/test-archetype-validation.js +14 -0
  50. package/dist/ecs/database/test-archetype-validation.js.map +1 -0
  51. package/dist/ecs/database/test-exactkeys.js +17 -0
  52. package/dist/ecs/database/test-exactkeys.js.map +1 -0
  53. package/dist/ecs/database/transactional-store/coalesce-transactions.test.js +3 -3
  54. package/dist/ecs/database/transactional-store/coalesce-transactions.test.js.map +1 -1
  55. package/dist/ecs/database/type-inference-demo.d.ts +75 -0
  56. package/dist/ecs/database/type-inference-demo.js +73 -0
  57. package/dist/ecs/database/type-inference-demo.js.map +1 -0
  58. package/dist/ecs/database/type-inference-poc.test.js +73 -0
  59. package/dist/ecs/database/type-inference-poc.test.js.map +1 -0
  60. package/dist/ecs/index.d.ts +3 -0
  61. package/dist/ecs/index.js +2 -0
  62. package/dist/ecs/index.js.map +1 -1
  63. package/dist/ecs/plugins/scheduler/create-scheduler-plugin.d.ts +8 -0
  64. package/dist/ecs/plugins/scheduler/create-scheduler-plugin.js +54 -0
  65. package/dist/ecs/plugins/scheduler/create-scheduler-plugin.js.map +1 -0
  66. package/dist/ecs/plugins/scheduler/create-scheduler-plugin.test.js +198 -0
  67. package/dist/ecs/plugins/scheduler/create-scheduler-plugin.test.js.map +1 -0
  68. package/dist/ecs/plugins/scheduler/scheduler.d.ts +2 -3
  69. package/dist/ecs/plugins/scheduler/scheduler.js +2 -2
  70. package/dist/ecs/plugins/scheduler/scheduler.js.map +1 -1
  71. package/dist/ecs/plugins/scheduler/type-inference-test.js +2 -0
  72. package/dist/ecs/plugins/scheduler/type-inference-test.js.map +1 -0
  73. package/dist/ecs/store/entity-functions.d.ts +7 -0
  74. package/dist/ecs/store/entity-functions.js +2 -0
  75. package/dist/ecs/store/entity-functions.js.map +1 -0
  76. package/dist/ecs/store/functions.d.ts +2 -0
  77. package/dist/ecs/store/functions.js +2 -0
  78. package/dist/ecs/store/functions.js.map +1 -0
  79. package/dist/ecs/system/system-declaration.d.ts +7 -0
  80. package/dist/{math/aabb/functions.js → ecs/system/system-declaration.js} +1 -1
  81. package/dist/ecs/system/system-declaration.js.map +1 -0
  82. package/dist/ecs/system/system-declarations.d.ts +4 -0
  83. package/dist/ecs/system/system-declarations.js +23 -0
  84. package/dist/ecs/system/system-declarations.js.map +1 -0
  85. package/dist/ecs/system/system-factory/public/create copy.d.ts +12 -0
  86. package/dist/ecs/system/system-factory/public/create copy.js +8 -0
  87. package/dist/ecs/system/system-factory/public/create copy.js.map +1 -0
  88. package/dist/ecs/system/system-factory/public/create.d.ts +12 -0
  89. package/dist/ecs/system/system-factory/public/create.js +8 -0
  90. package/dist/ecs/system/system-factory/public/create.js.map +1 -0
  91. package/dist/ecs/system/system-factory/public/create.test.js +42 -0
  92. package/dist/ecs/system/system-factory/public/create.test.js.map +1 -0
  93. package/dist/ecs/system/system-factory/public/index.d.ts +1 -0
  94. package/dist/ecs/system/system-factory/public/index.js +2 -0
  95. package/dist/ecs/system/system-factory/public/index.js.map +1 -0
  96. package/dist/ecs/system/system-factory/system-factory.d.ts +17 -0
  97. package/dist/ecs/{store/public/schema/schema.js → system/system-factory/system-factory.js} +2 -2
  98. package/dist/ecs/system/system-factory/system-factory.js.map +1 -0
  99. package/dist/ecs/system/system-factory.d.ts +9 -0
  100. package/dist/{math/picking/pick-result.js → ecs/system/system-factory.js} +1 -1
  101. package/dist/ecs/system/system-factory.js.map +1 -0
  102. package/dist/ecs/system/system-interface.d.ts +5 -0
  103. package/dist/ecs/system/system-interface.js +2 -0
  104. package/dist/ecs/system/system-interface.js.map +1 -0
  105. package/dist/ecs/system/system.d.ts +4 -0
  106. package/dist/ecs/{store/constants/types.js → system/system.js} +1 -1
  107. package/dist/ecs/system/system.js.map +1 -0
  108. package/dist/ecs/system/systems-type.d.ts +2 -0
  109. package/dist/ecs/system/systems-type.js +2 -0
  110. package/dist/ecs/system/systems-type.js.map +1 -0
  111. package/dist/ecs/system/systems.d.ts +2 -0
  112. package/dist/ecs/{store/public/types.js → system/systems.js} +1 -1
  113. package/dist/ecs/system/systems.js.map +1 -0
  114. package/dist/ecs/system/world-schema/public/create.d.ts +12 -0
  115. package/dist/ecs/system/world-schema/public/create.js +8 -0
  116. package/dist/ecs/system/world-schema/public/create.js.map +1 -0
  117. package/dist/ecs/system/world-schema/public/create.test.js +42 -0
  118. package/dist/ecs/system/world-schema/public/create.test.js.map +1 -0
  119. package/dist/ecs/system/world-schema/public/index.d.ts +1 -0
  120. package/dist/ecs/system/world-schema/public/index.js +2 -0
  121. package/dist/ecs/system/world-schema/public/index.js.map +1 -0
  122. package/dist/ecs/system/world-schema/system-factory.d.ts +17 -0
  123. package/dist/ecs/system/world-schema/system-factory.js +23 -0
  124. package/dist/ecs/system/world-schema/system-factory.js.map +1 -0
  125. package/dist/ecs/world/calculate-system-order.d.ts +18 -0
  126. package/dist/ecs/world/calculate-system-order.js +113 -0
  127. package/dist/ecs/world/calculate-system-order.js.map +1 -0
  128. package/dist/ecs/world/calculate-system-order.test.js +168 -0
  129. package/dist/ecs/world/calculate-system-order.test.js.map +1 -0
  130. package/dist/ecs/world/create-world-schema-test.js +294 -0
  131. package/dist/ecs/world/create-world-schema-test.js.map +1 -0
  132. package/dist/ecs/world/create-world-type-test.js +129 -0
  133. package/dist/ecs/world/create-world-type-test.js.map +1 -0
  134. package/dist/ecs/world/create-world.d.ts +17 -5
  135. package/dist/ecs/world/create-world.js +75 -108
  136. package/dist/ecs/world/create-world.js.map +1 -1
  137. package/dist/ecs/world/create-world.test.js +227 -434
  138. package/dist/ecs/world/create-world.test.js.map +1 -1
  139. package/dist/ecs/world/public/world-schema/public/create.d.ts +12 -0
  140. package/dist/ecs/world/public/world-schema/public/create.js +8 -0
  141. package/dist/ecs/world/public/world-schema/public/create.js.map +1 -0
  142. package/dist/ecs/world/public/world-schema/public/create.test.js +42 -0
  143. package/dist/ecs/world/public/world-schema/public/create.test.js.map +1 -0
  144. package/dist/ecs/world/public/world-schema/public/index.d.ts +1 -0
  145. package/dist/ecs/world/public/world-schema/public/index.js +2 -0
  146. package/dist/ecs/world/public/world-schema/public/index.js.map +1 -0
  147. package/dist/ecs/world/public/world-schema/world-schema.d.ts +17 -0
  148. package/dist/ecs/{store/public/schema/public.js → world/public/world-schema/world-schema.js} +2 -2
  149. package/dist/ecs/world/public/world-schema/world-schema.js.map +1 -0
  150. package/dist/ecs/world/system-declaration.d.ts +1 -0
  151. package/dist/ecs/world/system-declaration.js +23 -0
  152. package/dist/ecs/world/system-declaration.js.map +1 -0
  153. package/dist/ecs/world/system-schedule-typing-test.js +83 -0
  154. package/dist/ecs/world/system-schedule-typing-test.js.map +1 -0
  155. package/dist/ecs/world/world-schema/public/create.d.ts +12 -0
  156. package/dist/ecs/world/world-schema/public/create.js +10 -0
  157. package/dist/ecs/world/world-schema/public/create.js.map +1 -0
  158. package/dist/ecs/world/world-schema/public/create.test.js +41 -0
  159. package/dist/ecs/world/world-schema/public/create.test.js.map +1 -0
  160. package/dist/ecs/world/world-schema/public/index.d.ts +1 -0
  161. package/dist/ecs/world/world-schema/public/index.js +2 -0
  162. package/dist/ecs/world/world-schema/public/index.js.map +1 -0
  163. package/dist/ecs/world/world-schema/system-factory.d.ts +17 -0
  164. package/dist/ecs/world/world-schema/system-factory.js +23 -0
  165. package/dist/ecs/world/world-schema/system-factory.js.map +1 -0
  166. package/dist/ecs/world/world-schema/world-schema.d.ts +17 -16
  167. package/dist/ecs/world/world-schema/world-schema.js +1 -1
  168. package/dist/ecs/world/world-schema/world-schema.js.map +1 -1
  169. package/dist/ecs/world/world.d.ts +85 -10
  170. package/dist/ecs/world/world.js +80 -1
  171. package/dist/ecs/world/world.js.map +1 -1
  172. package/dist/ecs/world/world.test.js +176 -0
  173. package/dist/ecs/world/world.test.js.map +1 -0
  174. package/dist/old-ecs/ecs/ecs.test.js +1 -0
  175. package/dist/old-ecs/ecs/ecs.test.js.map +1 -1
  176. package/dist/samples/todo/services/state-service/create-todo-database.d.ts +2 -2
  177. package/dist/samples/todo/services/state-service/create-todo-store.d.ts +1 -1
  178. package/dist/tsconfig.tsbuildinfo +1 -1
  179. package/package.json +1 -1
  180. package/dist/blob/download-handle.d.ts +0 -4
  181. package/dist/blob/download-handle.js +0 -2
  182. package/dist/blob/download-handle.js.map +0 -1
  183. package/dist/blob/upload-handle.d.ts +0 -4
  184. package/dist/blob/upload-handle.js +0 -2
  185. package/dist/blob/upload-handle.js.map +0 -1
  186. package/dist/ecs/database/create-database.d.ts +0 -7
  187. package/dist/ecs/database/create-database.js +0 -186
  188. package/dist/ecs/database/create-database.js.map +0 -1
  189. package/dist/ecs/database/create-database.test.js +0 -903
  190. package/dist/ecs/database/create-database.test.js.map +0 -1
  191. package/dist/ecs/database/replicate.d.ts +0 -9
  192. package/dist/ecs/database/replicate.js +0 -66
  193. package/dist/ecs/database/replicate.js.map +0 -1
  194. package/dist/ecs/database/replicate.test.js +0 -235
  195. package/dist/ecs/database/replicate.test.js.map +0 -1
  196. package/dist/ecs/database/transactional-store/coalesce-transactions.d.ts +0 -16
  197. package/dist/ecs/database/transactional-store/coalesce-transactions.js +0 -140
  198. package/dist/ecs/database/transactional-store/coalesce-transactions.js.map +0 -1
  199. package/dist/ecs/database/transactional-store/entity-id-preservation.test.js +0 -106
  200. package/dist/ecs/database/transactional-store/entity-id-preservation.test.js.map +0 -1
  201. package/dist/ecs/entity/entity.d.ts +0 -8
  202. package/dist/ecs/entity/entity.js +0 -3
  203. package/dist/ecs/entity/entity.js.map +0 -1
  204. package/dist/ecs/entity/u32.d.ts +0 -8
  205. package/dist/ecs/entity/u32.js +0 -24
  206. package/dist/ecs/entity/u32.js.map +0 -1
  207. package/dist/ecs/store/constants/functions.d.ts +0 -14
  208. package/dist/ecs/store/constants/functions.js +0 -31
  209. package/dist/ecs/store/constants/functions.js.map +0 -1
  210. package/dist/ecs/store/constants/index.d.ts +0 -2
  211. package/dist/ecs/store/constants/index.js +0 -24
  212. package/dist/ecs/store/constants/index.js.map +0 -1
  213. package/dist/ecs/store/constants/types.d.ts +0 -18
  214. package/dist/ecs/store/constants/types.js.map +0 -1
  215. package/dist/ecs/store/create-store.d.ts +0 -8
  216. package/dist/ecs/store/create-store.js +0 -126
  217. package/dist/ecs/store/create-store.js.map +0 -1
  218. package/dist/ecs/store/create-store.test.js +0 -725
  219. package/dist/ecs/store/create-store.test.js.map +0 -1
  220. package/dist/ecs/store/public/create-from-schema.d.ts +0 -6
  221. package/dist/ecs/store/public/create-from-schema.js +0 -26
  222. package/dist/ecs/store/public/create-from-schema.js.map +0 -1
  223. package/dist/ecs/store/public/index.d.ts +0 -3
  224. package/dist/ecs/store/public/index.js +0 -25
  225. package/dist/ecs/store/public/index.js.map +0 -1
  226. package/dist/ecs/store/public/readonly.d.ts +0 -19
  227. package/dist/ecs/store/public/readonly.js +0 -2
  228. package/dist/ecs/store/public/readonly.js.map +0 -1
  229. package/dist/ecs/store/public/schema/create-from-schema.d.ts +0 -6
  230. package/dist/ecs/store/public/schema/create-from-schema.js +0 -26
  231. package/dist/ecs/store/public/schema/create-from-schema.js.map +0 -1
  232. package/dist/ecs/store/public/schema/create.d.ts +0 -10
  233. package/dist/ecs/store/public/schema/create.js +0 -25
  234. package/dist/ecs/store/public/schema/create.js.map +0 -1
  235. package/dist/ecs/store/public/schema/createFromSchema.d.ts +0 -6
  236. package/dist/ecs/store/public/schema/createFromSchema.js +0 -5
  237. package/dist/ecs/store/public/schema/createFromSchema.js.map +0 -1
  238. package/dist/ecs/store/public/schema/public.d.ts +0 -1
  239. package/dist/ecs/store/public/schema/public.js.map +0 -1
  240. package/dist/ecs/store/public/schema/schema.d.ts +0 -11
  241. package/dist/ecs/store/public/schema/schema.js.map +0 -1
  242. package/dist/ecs/store/public/types.d.ts +0 -11
  243. package/dist/ecs/store/public/types.js.map +0 -1
  244. package/dist/ecs/store/store-schema/create-store-schema-test.js +0 -33
  245. package/dist/ecs/store/store-schema/create-store-schema-test.js.map +0 -1
  246. package/dist/ecs/store/store-schema/create-store-schema.js +0 -45
  247. package/dist/ecs/store/store-schema/create-store-schema.js.map +0 -1
  248. package/dist/ecs/store/store-schema/index.js +0 -21
  249. package/dist/ecs/store/store-schema/index.js.map +0 -1
  250. package/dist/ecs/store/store-schema/store-schema.js +0 -57
  251. package/dist/ecs/store/store-schema/store-schema.js.map +0 -1
  252. package/dist/ecs/world/index.d.ts +0 -5
  253. package/dist/ecs/world/index.js +0 -27
  254. package/dist/ecs/world/index.js.map +0 -1
  255. package/dist/ecs/world/system-phase.d.ts +0 -5
  256. package/dist/ecs/world/system-phase.js +0 -14
  257. package/dist/ecs/world/system-phase.js.map +0 -1
  258. package/dist/ecs/world/system.d.ts +0 -25
  259. package/dist/ecs/world/system.js +0 -2
  260. package/dist/ecs/world/system.js.map +0 -1
  261. package/dist/ecs/world/world-schema/create-world-schema-test.js +0 -55
  262. package/dist/ecs/world/world-schema/create-world-schema-test.js.map +0 -1
  263. package/dist/ecs/world/world-schema/create-world-schema.d.ts +0 -19
  264. package/dist/ecs/world/world-schema/create-world-schema.js +0 -33
  265. package/dist/ecs/world/world-schema/create-world-schema.js.map +0 -1
  266. package/dist/ecs/world/world-schema/index.d.ts +0 -2
  267. package/dist/ecs/world/world-schema/index.js +0 -24
  268. package/dist/ecs/world/world-schema/index.js.map +0 -1
  269. package/dist/graphics/camera/camera.d.ts +0 -62
  270. package/dist/graphics/camera/camera.js +0 -17
  271. package/dist/graphics/camera/camera.js.map +0 -1
  272. package/dist/graphics/camera/index.d.ts +0 -4
  273. package/dist/graphics/camera/index.js +0 -5
  274. package/dist/graphics/camera/index.js.map +0 -1
  275. package/dist/graphics/camera/screen-to-world-ray.d.ts +0 -12
  276. package/dist/graphics/camera/screen-to-world-ray.js +0 -49
  277. package/dist/graphics/camera/screen-to-world-ray.js.map +0 -1
  278. package/dist/graphics/camera/screen-to-world-ray.test.js +0 -171
  279. package/dist/graphics/camera/screen-to-world-ray.test.js.map +0 -1
  280. package/dist/graphics/camera/to-view-projection.d.ts +0 -3
  281. package/dist/graphics/camera/to-view-projection.js +0 -8
  282. package/dist/graphics/camera/to-view-projection.js.map +0 -1
  283. package/dist/graphics/camera/world-to-screen.d.ts +0 -12
  284. package/dist/graphics/camera/world-to-screen.js +0 -38
  285. package/dist/graphics/camera/world-to-screen.js.map +0 -1
  286. package/dist/graphics/camera/world-to-screen.test.js +0 -124
  287. package/dist/graphics/camera/world-to-screen.test.js.map +0 -1
  288. package/dist/graphics/create-struct-gpu-buffer.d.ts +0 -7
  289. package/dist/graphics/create-struct-gpu-buffer.js +0 -17
  290. package/dist/graphics/create-struct-gpu-buffer.js.map +0 -1
  291. package/dist/graphics/extract-wgsl-bindings.d.ts +0 -5
  292. package/dist/graphics/extract-wgsl-bindings.js +0 -10
  293. package/dist/graphics/extract-wgsl-bindings.js.map +0 -1
  294. package/dist/graphics/frame.js +0 -15
  295. package/dist/graphics/frame.js.map +0 -1
  296. package/dist/graphics/get-web-gpu-device-and-context.js +0 -24
  297. package/dist/graphics/get-web-gpu-device-and-context.js.map +0 -1
  298. package/dist/graphics/graphics-context.js +0 -7
  299. package/dist/graphics/graphics-context.js.map +0 -1
  300. package/dist/graphics/index.d.ts +0 -5
  301. package/dist/graphics/index.js +0 -5
  302. package/dist/graphics/index.js.map +0 -1
  303. package/dist/graphics/to-gpu-buffer.d.ts +0 -2
  304. package/dist/graphics/to-gpu-buffer.js +0 -14
  305. package/dist/graphics/to-gpu-buffer.js.map +0 -1
  306. package/dist/internal/array-buffer-like/grow.d.ts +0 -1
  307. package/dist/internal/array-buffer-like/grow.js +0 -9
  308. package/dist/internal/array-buffer-like/grow.js.map +0 -1
  309. package/dist/math/aabb/aabb.d.ts +0 -3
  310. package/dist/math/aabb/aabb.js +0 -2
  311. package/dist/math/aabb/aabb.js.map +0 -1
  312. package/dist/math/aabb/constants/functions.d.ts +0 -15
  313. package/dist/math/aabb/constants/functions.js +0 -76
  314. package/dist/math/aabb/constants/functions.js.map +0 -1
  315. package/dist/math/aabb/constants/index.d.ts +0 -3
  316. package/dist/math/aabb/constants/index.js +0 -25
  317. package/dist/math/aabb/constants/index.js.map +0 -1
  318. package/dist/math/aabb/constants/layout.d.ts +0 -1
  319. package/dist/math/aabb/constants/layout.js +0 -25
  320. package/dist/math/aabb/constants/layout.js.map +0 -1
  321. package/dist/math/aabb/constants/schema.d.ts +0 -33
  322. package/dist/math/aabb/constants/schema.js +0 -37
  323. package/dist/math/aabb/constants/schema.js.map +0 -1
  324. package/dist/math/aabb/functions.js.map +0 -1
  325. package/dist/math/aabb/lineIntersection.d.ts +0 -10
  326. package/dist/math/aabb/lineIntersection.js +0 -42
  327. package/dist/math/aabb/lineIntersection.js.map +0 -1
  328. package/dist/math/aabb-face/aabb-face.d.ts +0 -4
  329. package/dist/math/aabb-face/aabb-face.js +0 -23
  330. package/dist/math/aabb-face/aabb-face.js.map +0 -1
  331. package/dist/math/aabb-face/aabb-face.test.js +0 -54
  332. package/dist/math/aabb-face/aabb-face.test.js.map +0 -1
  333. package/dist/math/aabb-face/constants/functions.d.ts +0 -47
  334. package/dist/math/aabb-face/constants/functions.js +0 -148
  335. package/dist/math/aabb-face/constants/functions.js.map +0 -1
  336. package/dist/math/aabb-face/constants/index.d.ts +0 -2
  337. package/dist/math/aabb-face/constants/index.js +0 -24
  338. package/dist/math/aabb-face/constants/index.js.map +0 -1
  339. package/dist/math/aabb-face/constants/schema.d.ts +0 -5
  340. package/dist/math/aabb-face/constants/schema.js +0 -27
  341. package/dist/math/aabb-face/constants/schema.js.map +0 -1
  342. package/dist/math/aabb-face/face.d.ts +0 -51
  343. package/dist/math/aabb-face/face.js +0 -110
  344. package/dist/math/aabb-face/face.js.map +0 -1
  345. package/dist/math/aabb-face/face.test.js +0 -94
  346. package/dist/math/aabb-face/face.test.js.map +0 -1
  347. package/dist/math/aabb-face/functions.d.ts +0 -47
  348. package/dist/math/aabb-face/functions.js +0 -148
  349. package/dist/math/aabb-face/functions.js.map +0 -1
  350. package/dist/math/aabb-face/index.d.ts +0 -4
  351. package/dist/math/aabb-face/index.js +0 -23
  352. package/dist/math/aabb-face/index.js.map +0 -1
  353. package/dist/math/aabb-face/public.d.ts +0 -2
  354. package/dist/math/aabb-face/public.js +0 -24
  355. package/dist/math/aabb-face/public.js.map +0 -1
  356. package/dist/math/aabb-face/schema.d.ts +0 -5
  357. package/dist/math/aabb-face/schema.js +0 -27
  358. package/dist/math/aabb-face/schema.js.map +0 -1
  359. package/dist/math/box/box.d.ts +0 -50
  360. package/dist/math/box/box.js +0 -23
  361. package/dist/math/box/box.js.map +0 -1
  362. package/dist/math/f32/constants/index.d.ts +0 -1
  363. package/dist/math/f32/constants/index.js +0 -23
  364. package/dist/math/f32/constants/index.js.map +0 -1
  365. package/dist/math/f32/constants/schema.d.ts +0 -5
  366. package/dist/math/f32/constants/schema.js +0 -24
  367. package/dist/math/f32/constants/schema.js.map +0 -1
  368. package/dist/math/f32/f32.d.ts +0 -4
  369. package/dist/math/f32/f32.js +0 -23
  370. package/dist/math/f32/f32.js.map +0 -1
  371. package/dist/math/face/face.d.ts +0 -51
  372. package/dist/math/face/face.js +0 -110
  373. package/dist/math/face/face.js.map +0 -1
  374. package/dist/math/face/face.test.js +0 -94
  375. package/dist/math/face/face.test.js.map +0 -1
  376. package/dist/math/i32/constants/index.d.ts +0 -1
  377. package/dist/math/i32/constants/index.js +0 -23
  378. package/dist/math/i32/constants/index.js.map +0 -1
  379. package/dist/math/i32/constants/schema.d.ts +0 -6
  380. package/dist/math/i32/constants/schema.js +0 -24
  381. package/dist/math/i32/constants/schema.js.map +0 -1
  382. package/dist/math/i32/i32.d.ts +0 -4
  383. package/dist/math/i32/i32.js +0 -23
  384. package/dist/math/i32/i32.js.map +0 -1
  385. package/dist/math/line2/constants/functions.d.ts +0 -5
  386. package/dist/math/line2/constants/functions.js +0 -61
  387. package/dist/math/line2/constants/functions.js.map +0 -1
  388. package/dist/math/line2/constants/index.d.ts +0 -3
  389. package/dist/math/line2/constants/index.js +0 -25
  390. package/dist/math/line2/constants/index.js.map +0 -1
  391. package/dist/math/line2/constants/layout.d.ts +0 -1
  392. package/dist/math/line2/constants/layout.js +0 -25
  393. package/dist/math/line2/constants/layout.js.map +0 -1
  394. package/dist/math/line2/constants/schema.d.ts +0 -33
  395. package/dist/math/line2/constants/schema.js +0 -37
  396. package/dist/math/line2/constants/schema.js.map +0 -1
  397. package/dist/math/line2/line2.d.ts +0 -4
  398. package/dist/math/line2/line2.js +0 -23
  399. package/dist/math/line2/line2.js.map +0 -1
  400. package/dist/math/line3/constants/functions.d.ts +0 -17
  401. package/dist/math/line3/constants/functions.js +0 -70
  402. package/dist/math/line3/constants/functions.js.map +0 -1
  403. package/dist/math/line3/constants/index.d.ts +0 -3
  404. package/dist/math/line3/constants/index.js +0 -25
  405. package/dist/math/line3/constants/index.js.map +0 -1
  406. package/dist/math/line3/constants/layout.d.ts +0 -1
  407. package/dist/math/line3/constants/layout.js +0 -25
  408. package/dist/math/line3/constants/layout.js.map +0 -1
  409. package/dist/math/line3/constants/schema.d.ts +0 -33
  410. package/dist/math/line3/constants/schema.js +0 -37
  411. package/dist/math/line3/constants/schema.js.map +0 -1
  412. package/dist/math/line3/line3.d.ts +0 -4
  413. package/dist/math/line3/line3.js +0 -23
  414. package/dist/math/line3/line3.js.map +0 -1
  415. package/dist/math/mat4x4/constants/functions.d.ts +0 -23
  416. package/dist/math/mat4x4/constants/functions.js +0 -236
  417. package/dist/math/mat4x4/constants/functions.js.map +0 -1
  418. package/dist/math/mat4x4/constants/index.d.ts +0 -3
  419. package/dist/math/mat4x4/constants/index.js +0 -25
  420. package/dist/math/mat4x4/constants/index.js.map +0 -1
  421. package/dist/math/mat4x4/constants/layout.d.ts +0 -1
  422. package/dist/math/mat4x4/constants/layout.js +0 -25
  423. package/dist/math/mat4x4/constants/layout.js.map +0 -1
  424. package/dist/math/mat4x4/constants/schema.d.ts +0 -11
  425. package/dist/math/mat4x4/constants/schema.js +0 -30
  426. package/dist/math/mat4x4/constants/schema.js.map +0 -1
  427. package/dist/math/mat4x4/mat4x4.d.ts +0 -26
  428. package/dist/math/mat4x4/mat4x4.js +0 -45
  429. package/dist/math/mat4x4/mat4x4.js.map +0 -1
  430. package/dist/math/picking/face.js +0 -2
  431. package/dist/math/picking/face.js.map +0 -1
  432. package/dist/math/picking/get-closest-entity-to-line.d.ts +0 -4
  433. package/dist/math/picking/get-closest-entity-to-line.js +0 -30
  434. package/dist/math/picking/get-closest-entity-to-line.js.map +0 -1
  435. package/dist/math/picking/get-closest-entity-to-point.d.ts +0 -4
  436. package/dist/math/picking/get-closest-entity-to-point.js +0 -27
  437. package/dist/math/picking/get-closest-entity-to-point.js.map +0 -1
  438. package/dist/math/picking/get-intersecting-entities.d.ts +0 -12
  439. package/dist/math/picking/get-intersecting-entities.js +0 -15
  440. package/dist/math/picking/get-intersecting-entities.js.map +0 -1
  441. package/dist/math/picking/getClosestEntityToLine.d.ts +0 -4
  442. package/dist/math/picking/getClosestEntityToLine.js +0 -29
  443. package/dist/math/picking/getClosestEntityToLine.js.map +0 -1
  444. package/dist/math/picking/getClosestEntityToPoint.d.ts +0 -4
  445. package/dist/math/picking/getClosestEntityToPoint.js +0 -27
  446. package/dist/math/picking/getClosestEntityToPoint.js.map +0 -1
  447. package/dist/math/picking/getIntersectingEntities.d.ts +0 -12
  448. package/dist/math/picking/getIntersectingEntities.js +0 -15
  449. package/dist/math/picking/getIntersectingEntities.js.map +0 -1
  450. package/dist/math/picking/index.d.ts +0 -5
  451. package/dist/math/picking/index.js +0 -27
  452. package/dist/math/picking/index.js.map +0 -1
  453. package/dist/math/picking/pick-from-tables.d.ts +0 -19
  454. package/dist/math/picking/pick-from-tables.js +0 -63
  455. package/dist/math/picking/pick-from-tables.js.map +0 -1
  456. package/dist/math/picking/pick-result.d.ts +0 -12
  457. package/dist/math/picking/pick-result.js.map +0 -1
  458. package/dist/math/plane/constants/functions.d.ts +0 -16
  459. package/dist/math/plane/constants/functions.js +0 -54
  460. package/dist/math/plane/constants/functions.js.map +0 -1
  461. package/dist/math/plane/constants/index.d.ts +0 -3
  462. package/dist/math/plane/constants/index.js +0 -25
  463. package/dist/math/plane/constants/index.js.map +0 -1
  464. package/dist/math/plane/constants/layout.d.ts +0 -1
  465. package/dist/math/plane/constants/layout.js +0 -25
  466. package/dist/math/plane/constants/layout.js.map +0 -1
  467. package/dist/math/plane/constants/schema.d.ts +0 -24
  468. package/dist/math/plane/constants/schema.js +0 -33
  469. package/dist/math/plane/constants/schema.js.map +0 -1
  470. package/dist/math/plane/plane.d.ts +0 -4
  471. package/dist/math/plane/plane.js +0 -23
  472. package/dist/math/plane/plane.js.map +0 -1
  473. package/dist/math/quat/constants/index.d.ts +0 -3
  474. package/dist/math/quat/constants/index.js +0 -25
  475. package/dist/math/quat/constants/index.js.map +0 -1
  476. package/dist/math/quat/constants/layout.d.ts +0 -1
  477. package/dist/math/quat/constants/layout.js +0 -25
  478. package/dist/math/quat/constants/layout.js.map +0 -1
  479. package/dist/math/quat/constants/schema.d.ts +0 -11
  480. package/dist/math/quat/constants/schema.js +0 -30
  481. package/dist/math/quat/constants/schema.js.map +0 -1
  482. package/dist/math/quat/quat.d.ts +0 -4
  483. package/dist/math/quat/quat.js +0 -23
  484. package/dist/math/quat/quat.js.map +0 -1
  485. package/dist/math/transform/debug-inverse.js +0 -28
  486. package/dist/math/transform/debug-inverse.js.map +0 -1
  487. package/dist/math/transform/debug-quat.js +0 -23
  488. package/dist/math/transform/debug-quat.js.map +0 -1
  489. package/dist/math/transform/debug-test.js +0 -34
  490. package/dist/math/transform/debug-test.js.map +0 -1
  491. package/dist/math/transform/transform.d.ts +0 -58
  492. package/dist/math/transform/transform.js +0 -101
  493. package/dist/math/transform/transform.js.map +0 -1
  494. package/dist/math/transform/transform.test.d.ts +0 -1
  495. package/dist/math/transform/transform.test.js +0 -309
  496. package/dist/math/transform/transform.test.js.map +0 -1
  497. package/dist/math/u32/constants/index.d.ts +0 -1
  498. package/dist/math/u32/constants/index.js +0 -23
  499. package/dist/math/u32/constants/index.js.map +0 -1
  500. package/dist/math/u32/constants/schema.d.ts +0 -6
  501. package/dist/math/u32/constants/schema.js +0 -24
  502. package/dist/math/u32/constants/schema.js.map +0 -1
  503. package/dist/math/u32/u32.d.ts +0 -4
  504. package/dist/math/u32/u32.js +0 -23
  505. package/dist/math/u32/u32.js.map +0 -1
  506. package/dist/math/vec2/constants/functions.d.ts +0 -48
  507. package/dist/math/vec2/constants/functions.js +0 -104
  508. package/dist/math/vec2/constants/functions.js.map +0 -1
  509. package/dist/math/vec2/constants/index.d.ts +0 -3
  510. package/dist/math/vec2/constants/index.js +0 -25
  511. package/dist/math/vec2/constants/index.js.map +0 -1
  512. package/dist/math/vec2/constants/layout.d.ts +0 -1
  513. package/dist/math/vec2/constants/layout.js +0 -25
  514. package/dist/math/vec2/constants/layout.js.map +0 -1
  515. package/dist/math/vec2/constants/schema.d.ts +0 -11
  516. package/dist/math/vec2/constants/schema.js +0 -30
  517. package/dist/math/vec2/constants/schema.js.map +0 -1
  518. package/dist/math/vec2/functions/abs.d.ts +0 -2
  519. package/dist/math/vec2/functions/abs.js +0 -23
  520. package/dist/math/vec2/functions/abs.js.map +0 -1
  521. package/dist/math/vec2/functions/acos.d.ts +0 -2
  522. package/dist/math/vec2/functions/acos.js +0 -23
  523. package/dist/math/vec2/functions/acos.js.map +0 -1
  524. package/dist/math/vec2/functions/acosh.d.ts +0 -2
  525. package/dist/math/vec2/functions/acosh.js +0 -23
  526. package/dist/math/vec2/functions/acosh.js.map +0 -1
  527. package/dist/math/vec2/functions/add.d.ts +0 -2
  528. package/dist/math/vec2/functions/add.js +0 -23
  529. package/dist/math/vec2/functions/add.js.map +0 -1
  530. package/dist/math/vec2/functions/asin.d.ts +0 -2
  531. package/dist/math/vec2/functions/asin.js +0 -23
  532. package/dist/math/vec2/functions/asin.js.map +0 -1
  533. package/dist/math/vec2/functions/asinh.d.ts +0 -2
  534. package/dist/math/vec2/functions/asinh.js +0 -23
  535. package/dist/math/vec2/functions/asinh.js.map +0 -1
  536. package/dist/math/vec2/functions/atan.d.ts +0 -2
  537. package/dist/math/vec2/functions/atan.js +0 -23
  538. package/dist/math/vec2/functions/atan.js.map +0 -1
  539. package/dist/math/vec2/functions/atanh.d.ts +0 -2
  540. package/dist/math/vec2/functions/atanh.js +0 -23
  541. package/dist/math/vec2/functions/atanh.js.map +0 -1
  542. package/dist/math/vec2/functions/ceil.d.ts +0 -2
  543. package/dist/math/vec2/functions/ceil.js +0 -23
  544. package/dist/math/vec2/functions/ceil.js.map +0 -1
  545. package/dist/math/vec2/functions/clamp.d.ts +0 -2
  546. package/dist/math/vec2/functions/clamp.js +0 -25
  547. package/dist/math/vec2/functions/clamp.js.map +0 -1
  548. package/dist/math/vec2/functions/cos.d.ts +0 -2
  549. package/dist/math/vec2/functions/cos.js +0 -23
  550. package/dist/math/vec2/functions/cos.js.map +0 -1
  551. package/dist/math/vec2/functions/cosh.d.ts +0 -2
  552. package/dist/math/vec2/functions/cosh.js +0 -23
  553. package/dist/math/vec2/functions/cosh.js.map +0 -1
  554. package/dist/math/vec2/functions/distance.d.ts +0 -2
  555. package/dist/math/vec2/functions/distance.js +0 -25
  556. package/dist/math/vec2/functions/distance.js.map +0 -1
  557. package/dist/math/vec2/functions/dot.d.ts +0 -2
  558. package/dist/math/vec2/functions/dot.js +0 -23
  559. package/dist/math/vec2/functions/dot.js.map +0 -1
  560. package/dist/math/vec2/functions/exp-2.d.ts +0 -2
  561. package/dist/math/vec2/functions/exp-2.js +0 -23
  562. package/dist/math/vec2/functions/exp-2.js.map +0 -1
  563. package/dist/math/vec2/functions/exp.d.ts +0 -2
  564. package/dist/math/vec2/functions/exp.js +0 -23
  565. package/dist/math/vec2/functions/exp.js.map +0 -1
  566. package/dist/math/vec2/functions/face-forward.d.ts +0 -2
  567. package/dist/math/vec2/functions/face-forward.js +0 -25
  568. package/dist/math/vec2/functions/face-forward.js.map +0 -1
  569. package/dist/math/vec2/functions/floor.d.ts +0 -2
  570. package/dist/math/vec2/functions/floor.js +0 -23
  571. package/dist/math/vec2/functions/floor.js.map +0 -1
  572. package/dist/math/vec2/functions/fract.d.ts +0 -2
  573. package/dist/math/vec2/functions/fract.js +0 -23
  574. package/dist/math/vec2/functions/fract.js.map +0 -1
  575. package/dist/math/vec2/functions/functions.d.ts +0 -48
  576. package/dist/math/vec2/functions/functions.js +0 -104
  577. package/dist/math/vec2/functions/functions.js.map +0 -1
  578. package/dist/math/vec2/functions/index.d.ts +0 -3
  579. package/dist/math/vec2/functions/index.js +0 -25
  580. package/dist/math/vec2/functions/index.js.map +0 -1
  581. package/dist/math/vec2/functions/layout.d.ts +0 -1
  582. package/dist/math/vec2/functions/layout.js +0 -25
  583. package/dist/math/vec2/functions/layout.js.map +0 -1
  584. package/dist/math/vec2/functions/length.d.ts +0 -2
  585. package/dist/math/vec2/functions/length.js +0 -23
  586. package/dist/math/vec2/functions/length.js.map +0 -1
  587. package/dist/math/vec2/functions/log-2.d.ts +0 -2
  588. package/dist/math/vec2/functions/log-2.js +0 -23
  589. package/dist/math/vec2/functions/log-2.js.map +0 -1
  590. package/dist/math/vec2/functions/log.d.ts +0 -2
  591. package/dist/math/vec2/functions/log.js +0 -23
  592. package/dist/math/vec2/functions/log.js.map +0 -1
  593. package/dist/math/vec2/functions/max.d.ts +0 -2
  594. package/dist/math/vec2/functions/max.js +0 -23
  595. package/dist/math/vec2/functions/max.js.map +0 -1
  596. package/dist/math/vec2/functions/min.d.ts +0 -2
  597. package/dist/math/vec2/functions/min.js +0 -23
  598. package/dist/math/vec2/functions/min.js.map +0 -1
  599. package/dist/math/vec2/functions/mix.d.ts +0 -2
  600. package/dist/math/vec2/functions/mix.js +0 -26
  601. package/dist/math/vec2/functions/mix.js.map +0 -1
  602. package/dist/math/vec2/functions/mod.d.ts +0 -2
  603. package/dist/math/vec2/functions/mod.js +0 -26
  604. package/dist/math/vec2/functions/mod.js.map +0 -1
  605. package/dist/math/vec2/functions/modf.d.ts +0 -5
  606. package/dist/math/vec2/functions/modf.js +0 -26
  607. package/dist/math/vec2/functions/modf.js.map +0 -1
  608. package/dist/math/vec2/functions/negate.d.ts +0 -2
  609. package/dist/math/vec2/functions/negate.js +0 -23
  610. package/dist/math/vec2/functions/negate.js.map +0 -1
  611. package/dist/math/vec2/functions/normalize.d.ts +0 -2
  612. package/dist/math/vec2/functions/normalize.js +0 -28
  613. package/dist/math/vec2/functions/normalize.js.map +0 -1
  614. package/dist/math/vec2/functions/pow.d.ts +0 -2
  615. package/dist/math/vec2/functions/pow.js +0 -26
  616. package/dist/math/vec2/functions/pow.js.map +0 -1
  617. package/dist/math/vec2/functions/reflect.d.ts +0 -2
  618. package/dist/math/vec2/functions/reflect.js +0 -29
  619. package/dist/math/vec2/functions/reflect.js.map +0 -1
  620. package/dist/math/vec2/functions/refract.d.ts +0 -2
  621. package/dist/math/vec2/functions/refract.js +0 -34
  622. package/dist/math/vec2/functions/refract.js.map +0 -1
  623. package/dist/math/vec2/functions/round.d.ts +0 -2
  624. package/dist/math/vec2/functions/round.js +0 -23
  625. package/dist/math/vec2/functions/round.js.map +0 -1
  626. package/dist/math/vec2/functions/scale.d.ts +0 -2
  627. package/dist/math/vec2/functions/scale.js +0 -23
  628. package/dist/math/vec2/functions/scale.js.map +0 -1
  629. package/dist/math/vec2/functions/schema.d.ts +0 -11
  630. package/dist/math/vec2/functions/schema.js +0 -30
  631. package/dist/math/vec2/functions/schema.js.map +0 -1
  632. package/dist/math/vec2/functions/sign.d.ts +0 -2
  633. package/dist/math/vec2/functions/sign.js +0 -23
  634. package/dist/math/vec2/functions/sign.js.map +0 -1
  635. package/dist/math/vec2/functions/sin.d.ts +0 -2
  636. package/dist/math/vec2/functions/sin.js +0 -23
  637. package/dist/math/vec2/functions/sin.js.map +0 -1
  638. package/dist/math/vec2/functions/sinh.d.ts +0 -2
  639. package/dist/math/vec2/functions/sinh.js +0 -23
  640. package/dist/math/vec2/functions/sinh.js.map +0 -1
  641. package/dist/math/vec2/functions/smooth-step.d.ts +0 -2
  642. package/dist/math/vec2/functions/smooth-step.js +0 -27
  643. package/dist/math/vec2/functions/smooth-step.js.map +0 -1
  644. package/dist/math/vec2/functions/sqrt.d.ts +0 -2
  645. package/dist/math/vec2/functions/sqrt.js +0 -23
  646. package/dist/math/vec2/functions/sqrt.js.map +0 -1
  647. package/dist/math/vec2/functions/step.d.ts +0 -2
  648. package/dist/math/vec2/functions/step.js +0 -26
  649. package/dist/math/vec2/functions/step.js.map +0 -1
  650. package/dist/math/vec2/functions/subtract.d.ts +0 -2
  651. package/dist/math/vec2/functions/subtract.js +0 -23
  652. package/dist/math/vec2/functions/subtract.js.map +0 -1
  653. package/dist/math/vec2/functions/tan.d.ts +0 -2
  654. package/dist/math/vec2/functions/tan.js +0 -23
  655. package/dist/math/vec2/functions/tan.js.map +0 -1
  656. package/dist/math/vec2/functions/tanh.d.ts +0 -2
  657. package/dist/math/vec2/functions/tanh.js +0 -23
  658. package/dist/math/vec2/functions/tanh.js.map +0 -1
  659. package/dist/math/vec2/functions/trunc.d.ts +0 -2
  660. package/dist/math/vec2/functions/trunc.js +0 -23
  661. package/dist/math/vec2/functions/trunc.js.map +0 -1
  662. package/dist/math/vec2/vec2.d.ts +0 -4
  663. package/dist/math/vec2/vec2.js +0 -23
  664. package/dist/math/vec2/vec2.js.map +0 -1
  665. package/dist/math/vec3/constants/functions.d.ts +0 -59
  666. package/dist/math/vec3/constants/functions.js +0 -159
  667. package/dist/math/vec3/constants/functions.js.map +0 -1
  668. package/dist/math/vec3/constants/index.d.ts +0 -3
  669. package/dist/math/vec3/constants/index.js +0 -25
  670. package/dist/math/vec3/constants/index.js.map +0 -1
  671. package/dist/math/vec3/constants/layout.d.ts +0 -1
  672. package/dist/math/vec3/constants/layout.js +0 -25
  673. package/dist/math/vec3/constants/layout.js.map +0 -1
  674. package/dist/math/vec3/constants/schema.d.ts +0 -11
  675. package/dist/math/vec3/constants/schema.js +0 -30
  676. package/dist/math/vec3/constants/schema.js.map +0 -1
  677. package/dist/math/vec3/functions/abs.d.ts +0 -2
  678. package/dist/math/vec3/functions/abs.js +0 -23
  679. package/dist/math/vec3/functions/abs.js.map +0 -1
  680. package/dist/math/vec3/functions/acos.d.ts +0 -2
  681. package/dist/math/vec3/functions/acos.js +0 -23
  682. package/dist/math/vec3/functions/acos.js.map +0 -1
  683. package/dist/math/vec3/functions/acosh.d.ts +0 -2
  684. package/dist/math/vec3/functions/acosh.js +0 -23
  685. package/dist/math/vec3/functions/acosh.js.map +0 -1
  686. package/dist/math/vec3/functions/add.d.ts +0 -2
  687. package/dist/math/vec3/functions/add.js +0 -27
  688. package/dist/math/vec3/functions/add.js.map +0 -1
  689. package/dist/math/vec3/functions/asin.d.ts +0 -2
  690. package/dist/math/vec3/functions/asin.js +0 -23
  691. package/dist/math/vec3/functions/asin.js.map +0 -1
  692. package/dist/math/vec3/functions/asinh.d.ts +0 -2
  693. package/dist/math/vec3/functions/asinh.js +0 -23
  694. package/dist/math/vec3/functions/asinh.js.map +0 -1
  695. package/dist/math/vec3/functions/atan.d.ts +0 -2
  696. package/dist/math/vec3/functions/atan.js +0 -23
  697. package/dist/math/vec3/functions/atan.js.map +0 -1
  698. package/dist/math/vec3/functions/atanh.d.ts +0 -2
  699. package/dist/math/vec3/functions/atanh.js +0 -23
  700. package/dist/math/vec3/functions/atanh.js.map +0 -1
  701. package/dist/math/vec3/functions/ceil.d.ts +0 -2
  702. package/dist/math/vec3/functions/ceil.js +0 -23
  703. package/dist/math/vec3/functions/ceil.js.map +0 -1
  704. package/dist/math/vec3/functions/clamp.d.ts +0 -2
  705. package/dist/math/vec3/functions/clamp.js +0 -25
  706. package/dist/math/vec3/functions/clamp.js.map +0 -1
  707. package/dist/math/vec3/functions/cos.d.ts +0 -2
  708. package/dist/math/vec3/functions/cos.js +0 -23
  709. package/dist/math/vec3/functions/cos.js.map +0 -1
  710. package/dist/math/vec3/functions/cosh.d.ts +0 -2
  711. package/dist/math/vec3/functions/cosh.js +0 -23
  712. package/dist/math/vec3/functions/cosh.js.map +0 -1
  713. package/dist/math/vec3/functions/cross.d.ts +0 -2
  714. package/dist/math/vec3/functions/cross.js +0 -27
  715. package/dist/math/vec3/functions/cross.js.map +0 -1
  716. package/dist/math/vec3/functions/distance-squared.d.ts +0 -2
  717. package/dist/math/vec3/functions/distance-squared.js +0 -28
  718. package/dist/math/vec3/functions/distance-squared.js.map +0 -1
  719. package/dist/math/vec3/functions/distance.d.ts +0 -2
  720. package/dist/math/vec3/functions/distance.js +0 -25
  721. package/dist/math/vec3/functions/distance.js.map +0 -1
  722. package/dist/math/vec3/functions/dot.d.ts +0 -2
  723. package/dist/math/vec3/functions/dot.js +0 -23
  724. package/dist/math/vec3/functions/dot.js.map +0 -1
  725. package/dist/math/vec3/functions/equals.d.ts +0 -2
  726. package/dist/math/vec3/functions/equals.js +0 -23
  727. package/dist/math/vec3/functions/equals.js.map +0 -1
  728. package/dist/math/vec3/functions/exp-2.d.ts +0 -2
  729. package/dist/math/vec3/functions/exp-2.js +0 -23
  730. package/dist/math/vec3/functions/exp-2.js.map +0 -1
  731. package/dist/math/vec3/functions/exp.d.ts +0 -2
  732. package/dist/math/vec3/functions/exp.js +0 -23
  733. package/dist/math/vec3/functions/exp.js.map +0 -1
  734. package/dist/math/vec3/functions/face-forward.d.ts +0 -2
  735. package/dist/math/vec3/functions/face-forward.js +0 -25
  736. package/dist/math/vec3/functions/face-forward.js.map +0 -1
  737. package/dist/math/vec3/functions/floor.d.ts +0 -2
  738. package/dist/math/vec3/functions/floor.js +0 -23
  739. package/dist/math/vec3/functions/floor.js.map +0 -1
  740. package/dist/math/vec3/functions/fract.d.ts +0 -2
  741. package/dist/math/vec3/functions/fract.js +0 -27
  742. package/dist/math/vec3/functions/fract.js.map +0 -1
  743. package/dist/math/vec3/functions/index.d.ts +0 -54
  744. package/dist/math/vec3/functions/index.js +0 -76
  745. package/dist/math/vec3/functions/index.js.map +0 -1
  746. package/dist/math/vec3/functions/layout.d.ts +0 -1
  747. package/dist/math/vec3/functions/layout.js +0 -25
  748. package/dist/math/vec3/functions/layout.js.map +0 -1
  749. package/dist/math/vec3/functions/length-squared.d.ts +0 -2
  750. package/dist/math/vec3/functions/length-squared.js +0 -23
  751. package/dist/math/vec3/functions/length-squared.js.map +0 -1
  752. package/dist/math/vec3/functions/length.d.ts +0 -2
  753. package/dist/math/vec3/functions/length.js +0 -23
  754. package/dist/math/vec3/functions/length.js.map +0 -1
  755. package/dist/math/vec3/functions/log-2.d.ts +0 -2
  756. package/dist/math/vec3/functions/log-2.js +0 -23
  757. package/dist/math/vec3/functions/log-2.js.map +0 -1
  758. package/dist/math/vec3/functions/log.d.ts +0 -2
  759. package/dist/math/vec3/functions/log.js +0 -23
  760. package/dist/math/vec3/functions/log.js.map +0 -1
  761. package/dist/math/vec3/functions/max.d.ts +0 -2
  762. package/dist/math/vec3/functions/max.js +0 -27
  763. package/dist/math/vec3/functions/max.js.map +0 -1
  764. package/dist/math/vec3/functions/min.d.ts +0 -2
  765. package/dist/math/vec3/functions/min.js +0 -27
  766. package/dist/math/vec3/functions/min.js.map +0 -1
  767. package/dist/math/vec3/functions/mix.d.ts +0 -2
  768. package/dist/math/vec3/functions/mix.js +0 -27
  769. package/dist/math/vec3/functions/mix.js.map +0 -1
  770. package/dist/math/vec3/functions/mod.d.ts +0 -2
  771. package/dist/math/vec3/functions/mod.js +0 -27
  772. package/dist/math/vec3/functions/mod.js.map +0 -1
  773. package/dist/math/vec3/functions/modf.d.ts +0 -5
  774. package/dist/math/vec3/functions/modf.js +0 -26
  775. package/dist/math/vec3/functions/modf.js.map +0 -1
  776. package/dist/math/vec3/functions/multiply.d.ts +0 -5
  777. package/dist/math/vec3/functions/multiply.js +0 -30
  778. package/dist/math/vec3/functions/multiply.js.map +0 -1
  779. package/dist/math/vec3/functions/negate.d.ts +0 -2
  780. package/dist/math/vec3/functions/negate.js +0 -23
  781. package/dist/math/vec3/functions/negate.js.map +0 -1
  782. package/dist/math/vec3/functions/normalize.d.ts +0 -2
  783. package/dist/math/vec3/functions/normalize.js +0 -28
  784. package/dist/math/vec3/functions/normalize.js.map +0 -1
  785. package/dist/math/vec3/functions/one.d.ts +0 -2
  786. package/dist/math/vec3/functions/one.js +0 -23
  787. package/dist/math/vec3/functions/one.js.map +0 -1
  788. package/dist/math/vec3/functions/pow.d.ts +0 -2
  789. package/dist/math/vec3/functions/pow.js +0 -27
  790. package/dist/math/vec3/functions/pow.js.map +0 -1
  791. package/dist/math/vec3/functions/random.d.ts +0 -2
  792. package/dist/math/vec3/functions/random.js +0 -25
  793. package/dist/math/vec3/functions/random.js.map +0 -1
  794. package/dist/math/vec3/functions/reflect.d.ts +0 -2
  795. package/dist/math/vec3/functions/reflect.js +0 -29
  796. package/dist/math/vec3/functions/reflect.js.map +0 -1
  797. package/dist/math/vec3/functions/refract.d.ts +0 -2
  798. package/dist/math/vec3/functions/refract.js +0 -34
  799. package/dist/math/vec3/functions/refract.js.map +0 -1
  800. package/dist/math/vec3/functions/round.d.ts +0 -2
  801. package/dist/math/vec3/functions/round.js +0 -23
  802. package/dist/math/vec3/functions/round.js.map +0 -1
  803. package/dist/math/vec3/functions/scale.d.ts +0 -2
  804. package/dist/math/vec3/functions/scale.js +0 -23
  805. package/dist/math/vec3/functions/scale.js.map +0 -1
  806. package/dist/math/vec3/functions/schema.d.ts +0 -11
  807. package/dist/math/vec3/functions/schema.js +0 -30
  808. package/dist/math/vec3/functions/schema.js.map +0 -1
  809. package/dist/math/vec3/functions/sign.d.ts +0 -2
  810. package/dist/math/vec3/functions/sign.js +0 -23
  811. package/dist/math/vec3/functions/sign.js.map +0 -1
  812. package/dist/math/vec3/functions/sin.d.ts +0 -2
  813. package/dist/math/vec3/functions/sin.js +0 -23
  814. package/dist/math/vec3/functions/sin.js.map +0 -1
  815. package/dist/math/vec3/functions/sinh.d.ts +0 -2
  816. package/dist/math/vec3/functions/sinh.js +0 -23
  817. package/dist/math/vec3/functions/sinh.js.map +0 -1
  818. package/dist/math/vec3/functions/smooth-step.d.ts +0 -2
  819. package/dist/math/vec3/functions/smooth-step.js +0 -32
  820. package/dist/math/vec3/functions/smooth-step.js.map +0 -1
  821. package/dist/math/vec3/functions/sqrt.d.ts +0 -2
  822. package/dist/math/vec3/functions/sqrt.js +0 -23
  823. package/dist/math/vec3/functions/sqrt.js.map +0 -1
  824. package/dist/math/vec3/functions/step.d.ts +0 -2
  825. package/dist/math/vec3/functions/step.js +0 -27
  826. package/dist/math/vec3/functions/step.js.map +0 -1
  827. package/dist/math/vec3/functions/subtract.d.ts +0 -2
  828. package/dist/math/vec3/functions/subtract.js +0 -27
  829. package/dist/math/vec3/functions/subtract.js.map +0 -1
  830. package/dist/math/vec3/functions/tan.d.ts +0 -2
  831. package/dist/math/vec3/functions/tan.js +0 -23
  832. package/dist/math/vec3/functions/tan.js.map +0 -1
  833. package/dist/math/vec3/functions/tanh.d.ts +0 -2
  834. package/dist/math/vec3/functions/tanh.js +0 -23
  835. package/dist/math/vec3/functions/tanh.js.map +0 -1
  836. package/dist/math/vec3/functions/trunc.d.ts +0 -2
  837. package/dist/math/vec3/functions/trunc.js +0 -23
  838. package/dist/math/vec3/functions/trunc.js.map +0 -1
  839. package/dist/math/vec3/functions/zero.d.ts +0 -2
  840. package/dist/math/vec3/functions/zero.js +0 -23
  841. package/dist/math/vec3/functions/zero.js.map +0 -1
  842. package/dist/math/vec3/vec3.d.ts +0 -4
  843. package/dist/math/vec3/vec3.js +0 -23
  844. package/dist/math/vec3/vec3.js.map +0 -1
  845. package/dist/math/vec4/constants/functions.d.ts +0 -49
  846. package/dist/math/vec4/constants/functions.js +0 -150
  847. package/dist/math/vec4/constants/functions.js.map +0 -1
  848. package/dist/math/vec4/constants/index.d.ts +0 -3
  849. package/dist/math/vec4/constants/index.js +0 -25
  850. package/dist/math/vec4/constants/index.js.map +0 -1
  851. package/dist/math/vec4/constants/layout.d.ts +0 -1
  852. package/dist/math/vec4/constants/layout.js +0 -25
  853. package/dist/math/vec4/constants/layout.js.map +0 -1
  854. package/dist/math/vec4/constants/schema.d.ts +0 -11
  855. package/dist/math/vec4/constants/schema.js +0 -30
  856. package/dist/math/vec4/constants/schema.js.map +0 -1
  857. package/dist/math/vec4/functions/abs.d.ts +0 -2
  858. package/dist/math/vec4/functions/abs.js +0 -23
  859. package/dist/math/vec4/functions/abs.js.map +0 -1
  860. package/dist/math/vec4/functions/ceil.d.ts +0 -2
  861. package/dist/math/vec4/functions/ceil.js +0 -23
  862. package/dist/math/vec4/functions/ceil.js.map +0 -1
  863. package/dist/math/vec4/functions/clamp.d.ts +0 -2
  864. package/dist/math/vec4/functions/clamp.js +0 -25
  865. package/dist/math/vec4/functions/clamp.js.map +0 -1
  866. package/dist/math/vec4/functions/floor.d.ts +0 -2
  867. package/dist/math/vec4/functions/floor.js +0 -23
  868. package/dist/math/vec4/functions/floor.js.map +0 -1
  869. package/dist/math/vec4/functions/layout.d.ts +0 -1
  870. package/dist/math/vec4/functions/layout.js +0 -25
  871. package/dist/math/vec4/functions/layout.js.map +0 -1
  872. package/dist/math/vec4/functions/max.d.ts +0 -2
  873. package/dist/math/vec4/functions/max.js +0 -28
  874. package/dist/math/vec4/functions/max.js.map +0 -1
  875. package/dist/math/vec4/functions/min.d.ts +0 -2
  876. package/dist/math/vec4/functions/min.js +0 -28
  877. package/dist/math/vec4/functions/min.js.map +0 -1
  878. package/dist/math/vec4/functions/round.d.ts +0 -2
  879. package/dist/math/vec4/functions/round.js +0 -23
  880. package/dist/math/vec4/functions/round.js.map +0 -1
  881. package/dist/math/vec4/functions/schema.d.ts +0 -11
  882. package/dist/math/vec4/functions/schema.js +0 -30
  883. package/dist/math/vec4/functions/schema.js.map +0 -1
  884. package/dist/math/vec4/functions/trunc.d.ts +0 -2
  885. package/dist/math/vec4/functions/trunc.js +0 -23
  886. package/dist/math/vec4/functions/trunc.js.map +0 -1
  887. package/dist/math/vec4/vec4.d.ts +0 -4
  888. package/dist/math/vec4/vec4.js +0 -23
  889. package/dist/math/vec4/vec4.js.map +0 -1
  890. package/dist/observe/create-observable-event.d.ts +0 -10
  891. package/dist/observe/create-observable-event.js +0 -22
  892. package/dist/observe/create-observable-event.js.map +0 -1
  893. package/dist/observe/create-observable-state.d.ts +0 -7
  894. package/dist/observe/create-observable-state.js +0 -27
  895. package/dist/observe/create-observable-state.js.map +0 -1
  896. package/dist/observe/types.d.ts +0 -17
  897. package/dist/observe/types.js +0 -2
  898. package/dist/observe/types.js.map +0 -1
  899. package/dist/old-ecs/privacy/helper-functions.d.ts +0 -43
  900. package/dist/old-ecs/privacy/helper-functions.js +0 -76
  901. package/dist/old-ecs/privacy/helper-functions.js.map +0 -1
  902. package/dist/old-ecs/privacy/helper-functions.test.d.ts +0 -1
  903. package/dist/old-ecs/privacy/helper-functions.test.js +0 -173
  904. package/dist/old-ecs/privacy/helper-functions.test.js.map +0 -1
  905. package/dist/schema/boolean.d.ts +0 -3
  906. package/dist/schema/boolean.js +0 -25
  907. package/dist/schema/boolean.js.map +0 -1
  908. package/dist/schema/f32.d.ts +0 -6
  909. package/dist/schema/f32.js +0 -6
  910. package/dist/schema/f32.js.map +0 -1
  911. package/dist/schema/f64.d.ts +0 -6
  912. package/dist/schema/f64.js +0 -6
  913. package/dist/schema/f64.js.map +0 -1
  914. package/dist/schema/i32.d.ts +0 -7
  915. package/dist/schema/i32.js +0 -7
  916. package/dist/schema/i32.js.map +0 -1
  917. package/dist/schema/schema/index.d.ts +0 -2
  918. package/dist/schema/schema/index.js +0 -23
  919. package/dist/schema/schema/index.js.map +0 -1
  920. package/dist/schema/schema/nullable.d.ts +0 -6
  921. package/dist/schema/schema/nullable.js +0 -6
  922. package/dist/schema/schema/nullable.js.map +0 -1
  923. package/dist/schema/schema/public.d.ts +0 -3
  924. package/dist/schema/schema/public.js +0 -25
  925. package/dist/schema/schema/public.js.map +0 -1
  926. package/dist/schema/schema/to-vertex-buffer-layout.d.ts +0 -56
  927. package/dist/schema/schema/to-vertex-buffer-layout.js +0 -143
  928. package/dist/schema/schema/to-vertex-buffer-layout.js.map +0 -1
  929. package/dist/schema/schema/types.d.ts +0 -150
  930. package/dist/schema/schema/types.js +0 -34
  931. package/dist/schema/schema/types.js.map +0 -1
  932. package/dist/schema/time.d.ts +0 -7
  933. package/dist/schema/time.js +0 -24
  934. package/dist/schema/time.js.map +0 -1
  935. package/dist/schema/true.d.ts +0 -6
  936. package/dist/schema/true.js +0 -2
  937. package/dist/schema/true.js.map +0 -1
  938. package/dist/schema/u32.d.ts +0 -7
  939. package/dist/schema/u32.js +0 -7
  940. package/dist/schema/u32.js.map +0 -1
  941. package/dist/table/constants/functions.d.ts +0 -3
  942. package/dist/table/constants/functions.js +0 -34
  943. package/dist/table/constants/functions.js.map +0 -1
  944. package/dist/table/constants/index.d.ts +0 -1
  945. package/dist/table/constants/index.js +0 -23
  946. package/dist/table/constants/index.js.map +0 -1
  947. /package/dist/{ecs/database/create-database.test.d.ts → debug-type-test.d.ts} +0 -0
  948. /package/dist/ecs/database/{replicate.test.d.ts → create-database-schema-test.d.ts} +0 -0
  949. /package/dist/ecs/database/{transactional-store/coalesce-transactions.test.d.ts → create-plugin-v2.test.d.ts} +0 -0
  950. /package/dist/ecs/database/{transactional-store/entity-id-preservation.test.d.ts → database-with-systems.test.d.ts} +0 -0
  951. /package/dist/ecs/{store/create-store.test.d.ts → database/database.plugin.create.test.OLD.d.ts} +0 -0
  952. /package/dist/ecs/{store/store-schema/create-store-schema-test.d.ts → database/database.plugin.create.test.d.ts} +0 -0
  953. /package/dist/ecs/{store/store-schema/create-store-schema.d.ts → database/database.plugin.test.d.ts} +0 -0
  954. /package/dist/ecs/{store/store-schema/index.d.ts → database/database.test copy.d.ts} +0 -0
  955. /package/dist/ecs/{store/store-schema/store-schema.d.ts → database/multi-param-inference-poc.test.d.ts} +0 -0
  956. /package/dist/ecs/{world/world-schema/create-world-schema-test.d.ts → database/overload-inference-poc.test.d.ts} +0 -0
  957. /package/dist/{graphics/camera/screen-to-world-ray.test.d.ts → ecs/database/test-exactkeys.d.ts} +0 -0
  958. /package/dist/{graphics/camera/world-to-screen.test.d.ts → ecs/database/type-inference-poc.test.d.ts} +0 -0
  959. /package/dist/{graphics/frame.d.ts → ecs/plugins/scheduler/create-scheduler-plugin.test.d.ts} +0 -0
  960. /package/dist/{graphics/get-web-gpu-device-and-context.d.ts → ecs/plugins/scheduler/type-inference-test.d.ts} +0 -0
  961. /package/dist/{graphics/graphics-context.d.ts → ecs/system/system-factory/public/create.test.d.ts} +0 -0
  962. /package/dist/{math/aabb-face/aabb-face.test.d.ts → ecs/system/world-schema/public/create.test.d.ts} +0 -0
  963. /package/dist/{math/aabb-face/face.test.d.ts → ecs/world/calculate-system-order.test.d.ts} +0 -0
  964. /package/dist/{math/aabb/functions.d.ts → ecs/world/create-world-schema-test.d.ts} +0 -0
  965. /package/dist/{math/face/face.test.d.ts → ecs/world/create-world-type-test.d.ts} +0 -0
  966. /package/dist/{math/picking/face.d.ts → ecs/world/public/world-schema/public/create.test.d.ts} +0 -0
  967. /package/dist/{math/transform/debug-inverse.d.ts → ecs/world/system-schedule-typing-test.d.ts} +0 -0
  968. /package/dist/{math/transform/debug-quat.d.ts → ecs/world/world-schema/public/create.test.d.ts} +0 -0
  969. /package/dist/{math/transform/debug-test.d.ts → ecs/world/world.test.d.ts} +0 -0
@@ -1,725 +0,0 @@
1
- /*MIT License
2
-
3
- © Copyright 2025 Adobe. All rights reserved.
4
-
5
- Permission is hereby granted, free of charge, to any person obtaining a copy
6
- of this software and associated documentation files (the "Software"), to deal
7
- in the Software without restriction, including without limitation the rights
8
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- copies of the Software, and to permit persons to whom the Software is
10
- furnished to do so, subject to the following conditions:
11
-
12
- The above copyright notice and this permission notice shall be included in all
13
- copies or substantial portions of the Software.
14
-
15
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- SOFTWARE.*/
22
- import { describe, it, expect } from "vitest";
23
- import { createStore } from "./create-store.js";
24
- import { createCoreTestSuite, positionSchema, healthSchema, nameSchema } from "./core/create-core.test.js";
25
- import { F32 } from "../../math/f32/index.js";
26
- import { Time } from "../../schema/index.js";
27
- describe("createStore", () => {
28
- // Test that store passes all core functionality tests
29
- createCoreTestSuite("Store core functionality", (componentSchemas) => createStore({ components: componentSchemas, resources: {}, archetypes: {} }));
30
- // Select function tests
31
- describe("Select functionality", () => {
32
- const velocitySchema = {
33
- type: "object",
34
- properties: {
35
- x: F32.schema,
36
- y: F32.schema,
37
- z: F32.schema,
38
- }
39
- };
40
- it("should select entities from single archetype", () => {
41
- const store = createStore({ components: {
42
- position: positionSchema,
43
- health: healthSchema,
44
- name: nameSchema,
45
- }, resources: {}, archetypes: {} });
46
- // Create entities in a single archetype
47
- const archetype = store.ensureArchetype(["id", "position", "health"]);
48
- const entity1 = archetype.insert({
49
- position: { x: 1, y: 2, z: 3 },
50
- health: { current: 100, max: 100 }
51
- });
52
- const entity2 = archetype.insert({
53
- position: { x: 4, y: 5, z: 6 },
54
- health: { current: 50, max: 100 }
55
- });
56
- // Select entities with position and health
57
- const entities = store.select(["position", "health"]);
58
- expect(entities).toHaveLength(2);
59
- expect(entities).toContain(entity1);
60
- expect(entities).toContain(entity2);
61
- });
62
- it("should select entities spanning multiple archetypes", () => {
63
- const store = createStore({ components: {
64
- position: positionSchema,
65
- health: healthSchema,
66
- name: nameSchema,
67
- velocity: velocitySchema,
68
- }, resources: {}, archetypes: {} });
69
- // Create entities in different archetypes
70
- const positionOnlyArchetype = store.ensureArchetype(["id", "position"]);
71
- const entity1 = positionOnlyArchetype.insert({
72
- position: { x: 1, y: 2, z: 3 }
73
- });
74
- const entity2 = positionOnlyArchetype.insert({
75
- position: { x: 4, y: 5, z: 6 }
76
- });
77
- const healthOnlyArchetype = store.ensureArchetype(["id", "health"]);
78
- const entity3 = healthOnlyArchetype.insert({
79
- health: { current: 100, max: 100 }
80
- });
81
- const positionHealthArchetype = store.ensureArchetype(["id", "position", "health"]);
82
- const entity4 = positionHealthArchetype.insert({
83
- position: { x: 0, y: 0, z: 0 },
84
- health: { current: 50, max: 100 }
85
- });
86
- const velocityArchetype = store.ensureArchetype(["id", "velocity"]);
87
- const entity5 = velocityArchetype.insert({
88
- velocity: { x: 1, y: 0, z: 0 }
89
- });
90
- // Select all entities with position component (should span 2 archetypes)
91
- const positionEntities = store.select(["position"]);
92
- expect(positionEntities).toHaveLength(3);
93
- expect(positionEntities).toContain(entity1);
94
- expect(positionEntities).toContain(entity2);
95
- expect(positionEntities).toContain(entity4);
96
- expect(positionEntities).not.toContain(entity3);
97
- expect(positionEntities).not.toContain(entity5);
98
- // Select all entities with health component (should span 2 archetypes)
99
- const healthEntities = store.select(["health"]);
100
- expect(healthEntities).toHaveLength(2);
101
- expect(healthEntities).toContain(entity3);
102
- expect(healthEntities).toContain(entity4);
103
- expect(healthEntities).not.toContain(entity1);
104
- expect(healthEntities).not.toContain(entity2);
105
- expect(healthEntities).not.toContain(entity5);
106
- // Select entities with both position and health (should be only 1 archetype)
107
- const bothEntities = store.select(["position", "health"]);
108
- expect(bothEntities).toHaveLength(1);
109
- expect(bothEntities).toContain(entity4);
110
- expect(bothEntities).not.toContain(entity1);
111
- expect(bothEntities).not.toContain(entity2);
112
- expect(bothEntities).not.toContain(entity3);
113
- expect(bothEntities).not.toContain(entity5);
114
- });
115
- it("should select entities with exclude option", () => {
116
- const store = createStore({ components: {
117
- position: positionSchema,
118
- health: healthSchema,
119
- name: nameSchema,
120
- }, resources: {}, archetypes: {} });
121
- // Create entities in different archetypes
122
- const positionOnlyArchetype = store.ensureArchetype(["id", "position"]);
123
- const entity1 = positionOnlyArchetype.insert({
124
- position: { x: 1, y: 2, z: 3 }
125
- });
126
- const positionHealthArchetype = store.ensureArchetype(["id", "position", "health"]);
127
- const entity2 = positionHealthArchetype.insert({
128
- position: { x: 0, y: 0, z: 0 },
129
- health: { current: 50, max: 100 }
130
- });
131
- // Select entities with position but exclude health
132
- const positionOnlyEntities = store.select(["position"], { exclude: ["health"] });
133
- expect(positionOnlyEntities).toHaveLength(1);
134
- expect(positionOnlyEntities).toContain(entity1);
135
- expect(positionOnlyEntities).not.toContain(entity2);
136
- });
137
- it("should return empty array when no entities match", () => {
138
- const store = createStore({ components: {
139
- position: positionSchema,
140
- health: healthSchema,
141
- }, resources: {}, archetypes: {} });
142
- // Create entity with only position
143
- const archetype = store.ensureArchetype(["id", "position"]);
144
- archetype.insert({ position: { x: 1, y: 2, z: 3 } });
145
- // Select entities with health (should be empty)
146
- const entities = store.select(["health"]);
147
- expect(entities).toHaveLength(0);
148
- });
149
- it("should handle complex multi-archetype scenarios", () => {
150
- const store = createStore({ components: {
151
- position: positionSchema,
152
- health: healthSchema,
153
- name: nameSchema,
154
- velocity: velocitySchema,
155
- }, resources: {}, archetypes: {} });
156
- // Create entities across many different archetypes
157
- const archetype1 = store.ensureArchetype(["id", "position"]);
158
- const entity1 = archetype1.insert({ position: { x: 1, y: 2, z: 3 } });
159
- const entity2 = archetype1.insert({ position: { x: 4, y: 5, z: 6 } });
160
- const archetype2 = store.ensureArchetype(["id", "health"]);
161
- const entity3 = archetype2.insert({ health: { current: 100, max: 100 } });
162
- const archetype3 = store.ensureArchetype(["id", "position", "health"]);
163
- const entity4 = archetype3.insert({
164
- position: { x: 0, y: 0, z: 0 },
165
- health: { current: 50, max: 100 }
166
- });
167
- const entity5 = archetype3.insert({
168
- position: { x: 10, y: 20, z: 30 },
169
- health: { current: 75, max: 100 }
170
- });
171
- const archetype4 = store.ensureArchetype(["id", "name"]);
172
- const entity6 = archetype4.insert({ name: "Player1" });
173
- const archetype5 = store.ensureArchetype(["id", "position", "name"]);
174
- const entity7 = archetype5.insert({
175
- position: { x: 100, y: 200, z: 300 },
176
- name: "Player2"
177
- });
178
- const archetype6 = store.ensureArchetype(["id", "position", "health", "name"]);
179
- const entity8 = archetype6.insert({
180
- position: { x: 500, y: 600, z: 700 },
181
- health: { current: 25, max: 100 },
182
- name: "Player3"
183
- });
184
- // Test various selection scenarios
185
- const positionEntities = store.select(["position"]);
186
- expect(positionEntities).toHaveLength(6);
187
- expect(positionEntities).toContain(entity1);
188
- expect(positionEntities).toContain(entity2);
189
- expect(positionEntities).toContain(entity4);
190
- expect(positionEntities).toContain(entity5);
191
- expect(positionEntities).toContain(entity7);
192
- expect(positionEntities).toContain(entity8);
193
- const nameEntities = store.select(["name"]);
194
- expect(nameEntities).toHaveLength(3);
195
- expect(nameEntities).toContain(entity6);
196
- expect(nameEntities).toContain(entity7);
197
- expect(nameEntities).toContain(entity8);
198
- const positionNameEntities = store.select(["position", "name"]);
199
- expect(positionNameEntities).toHaveLength(2);
200
- expect(positionNameEntities).toContain(entity7);
201
- expect(positionNameEntities).toContain(entity8);
202
- const allThreeEntities = store.select(["position", "health", "name"]);
203
- expect(allThreeEntities).toHaveLength(1);
204
- expect(allThreeEntities).toContain(entity8);
205
- // Test exclusion
206
- const positionWithoutHealth = store.select(["position"], { exclude: ["health"] });
207
- expect(positionWithoutHealth).toHaveLength(3);
208
- expect(positionWithoutHealth).toContain(entity1);
209
- expect(positionWithoutHealth).toContain(entity2);
210
- expect(positionWithoutHealth).toContain(entity7);
211
- expect(positionWithoutHealth).not.toContain(entity4);
212
- expect(positionWithoutHealth).not.toContain(entity5);
213
- expect(positionWithoutHealth).not.toContain(entity8);
214
- });
215
- it("should maintain entity order across archetypes", () => {
216
- const store = createStore({ components: {
217
- position: positionSchema,
218
- health: healthSchema,
219
- }, resources: {}, archetypes: {} });
220
- // Create entities in different archetypes
221
- const archetype1 = store.ensureArchetype(["id", "position"]);
222
- const entity1 = archetype1.insert({ position: { x: 1, y: 2, z: 3 } });
223
- const entity2 = archetype1.insert({ position: { x: 4, y: 5, z: 6 } });
224
- const archetype2 = store.ensureArchetype(["id", "health"]);
225
- const entity3 = archetype2.insert({ health: { current: 100, max: 100 } });
226
- const archetype3 = store.ensureArchetype(["id", "position", "health"]);
227
- const entity4 = archetype3.insert({
228
- position: { x: 0, y: 0, z: 0 },
229
- health: { current: 50, max: 100 }
230
- });
231
- // Select all entities with position
232
- const entities = store.select(["position"]);
233
- expect(entities).toHaveLength(3);
234
- // Verify all expected entities are present (order may vary)
235
- expect(entities).toContain(entity1);
236
- expect(entities).toContain(entity2);
237
- expect(entities).toContain(entity4);
238
- expect(entities).not.toContain(entity3);
239
- });
240
- it("should handle empty store", () => {
241
- const store = createStore({ components: {
242
- position: positionSchema,
243
- health: healthSchema,
244
- }, resources: {}, archetypes: {} });
245
- const entities = store.select(["position"]);
246
- expect(entities).toHaveLength(0);
247
- });
248
- it("should work with resources as components", () => {
249
- const store = createStore({ components: {
250
- position: positionSchema,
251
- health: healthSchema,
252
- }, resources: {
253
- time: { default: { delta: 0.016, elapsed: 0 } }
254
- }, archetypes: {} });
255
- // Create some entities
256
- const archetype = store.ensureArchetype(["id", "position"]);
257
- const entity = archetype.insert({ position: { x: 1, y: 2, z: 3 } });
258
- // Select entities with time component (should include the resource entity)
259
- const timeEntities = store.select(["time"]);
260
- expect(timeEntities).toHaveLength(1);
261
- // The resource entity should be included in time queries
262
- const timeArchetypes = store.queryArchetypes(["time"]);
263
- expect(timeArchetypes).toHaveLength(1);
264
- });
265
- });
266
- // Store-specific resource tests
267
- describe("Resource functionality", () => {
268
- const timeSchema = {
269
- type: "object",
270
- properties: {
271
- delta: F32.schema,
272
- elapsed: F32.schema,
273
- }
274
- };
275
- it("should create store with resources", () => {
276
- const store = createStore({ components: { position: positionSchema }, resources: {
277
- time: { default: { delta: 0.016, elapsed: 0 } },
278
- config: { default: { debug: false, volume: 1.0 } }
279
- }, archetypes: {} });
280
- expect(store).toBeDefined();
281
- expect(store.resources).toBeDefined();
282
- expect(store.resources.time).toBeDefined();
283
- expect(store.resources.config).toBeDefined();
284
- });
285
- it("should initialize resources with default values", () => {
286
- const defaultTime = { delta: 0.016, elapsed: 0 };
287
- const defaultConfig = { debug: false, volume: 1.0 };
288
- const store = createStore({ components: { position: positionSchema }, resources: {
289
- time: { default: defaultTime },
290
- config: { default: defaultConfig }
291
- }, archetypes: {} });
292
- expect(store.resources.time).toEqual(defaultTime);
293
- expect(store.resources.config).toEqual(defaultConfig);
294
- });
295
- it("should allow reading resource values", () => {
296
- const store = createStore({ components: { position: positionSchema }, resources: {
297
- time: { default: { delta: 0.016, elapsed: 0 } },
298
- config: { default: { debug: false, volume: 1.0 } }
299
- }, archetypes: {} });
300
- expect(store.resources.time.delta).toBe(0.016);
301
- expect(store.resources.time.elapsed).toBe(0);
302
- expect(store.resources.config.debug).toBe(false);
303
- expect(store.resources.config.volume).toBe(1.0);
304
- });
305
- it("should allow updating resource values", () => {
306
- const store = createStore({ components: { position: positionSchema }, resources: {
307
- time: { default: { delta: 0.016, elapsed: 0 } },
308
- config: { default: { debug: false, volume: 1.0 } }
309
- }, archetypes: {} });
310
- // Update time
311
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
312
- expect(store.resources.time.delta).toBe(0.033);
313
- expect(store.resources.time.elapsed).toBe(1.5);
314
- // Update config
315
- store.resources.config = { debug: true, volume: 0.5 };
316
- expect(store.resources.config.debug).toBe(true);
317
- expect(store.resources.config.volume).toBe(0.5);
318
- });
319
- it("should maintain resource values across updates", () => {
320
- const store = createStore({ components: { position: positionSchema }, resources: {
321
- time: { default: { delta: 0.016, elapsed: 0 } },
322
- config: { default: { debug: false, volume: 1.0 } }
323
- }, archetypes: {} });
324
- // Update multiple times
325
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
326
- store.resources.time = { delta: 0.025, elapsed: 2.0 };
327
- store.resources.config = { debug: true, volume: 0.5 };
328
- // Verify final values
329
- expect(store.resources.time).toEqual({ delta: 0.025, elapsed: 2.0 });
330
- expect(store.resources.config).toEqual({ debug: true, volume: 0.5 });
331
- });
332
- it("should handle nested resource updates", () => {
333
- const store = createStore({ components: { position: positionSchema }, resources: {
334
- time: { default: { delta: 0.016, elapsed: 0 } }
335
- }, archetypes: {} });
336
- // Update individual properties
337
- const newTime = { delta: 0.033, elapsed: 1.5 };
338
- store.resources.time = newTime;
339
- expect(store.resources.time.delta).toBe(newTime.delta);
340
- expect(store.resources.time.elapsed).toBe(newTime.elapsed);
341
- });
342
- it("should work with empty resource object", () => {
343
- const store = createStore({ components: { position: positionSchema }, resources: {}, archetypes: {} });
344
- expect(store.resources).toBeDefined();
345
- expect(Object.keys(store.resources)).toHaveLength(0);
346
- });
347
- it("should handle multiple resources independently", () => {
348
- const store = createStore({ components: { position: positionSchema }, resources: {
349
- time: { default: { delta: 0.016, elapsed: 0 } },
350
- config: { default: { debug: false, volume: 1.0 } },
351
- score: { default: 0 }
352
- }, archetypes: {} });
353
- // Update each resource independently
354
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
355
- store.resources.config = { debug: true, volume: 0.5 };
356
- store.resources.score = 100;
357
- // Verify all resources maintain their values
358
- expect(store.resources.time).toEqual({ delta: 0.033, elapsed: 1.5 });
359
- expect(store.resources.config).toEqual({ debug: true, volume: 0.5 });
360
- expect(store.resources.score).toBe(100);
361
- });
362
- it("should allow querying resources as components", () => {
363
- const store = createStore({ components: {
364
- position: positionSchema,
365
- time: timeSchema
366
- }, resources: {
367
- time: { default: { delta: 0.016, elapsed: 0 } }
368
- }, archetypes: {} });
369
- // Resources should be queryable as components
370
- const timeArchetypes = store.queryArchetypes(["time"]);
371
- expect(timeArchetypes).toHaveLength(1);
372
- expect(timeArchetypes[0].components.has("time")).toBe(true);
373
- });
374
- it("should maintain resource singleton behavior", () => {
375
- const store = createStore({ components: {
376
- position: positionSchema,
377
- time: timeSchema
378
- }, resources: {
379
- time: { default: { delta: 0.016, elapsed: 0 } }
380
- }, archetypes: {} });
381
- // Resources should be queryable as components
382
- const timeArchetypes = store.queryArchetypes(["time"]);
383
- expect(timeArchetypes).toHaveLength(1);
384
- // Resources should maintain their values
385
- expect(store.resources.time).toEqual({ delta: 0.016, elapsed: 0 });
386
- // Update and verify
387
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
388
- expect(store.resources.time).toEqual({ delta: 0.033, elapsed: 1.5 });
389
- });
390
- it("should handle primitive resource values", () => {
391
- const store = createStore({ components: { position: positionSchema }, resources: {
392
- score: { default: 0 },
393
- name: { default: "Player1" },
394
- active: { default: true }
395
- }, archetypes: {} });
396
- expect(store.resources.score).toBe(0);
397
- expect(store.resources.name).toBe("Player1");
398
- expect(store.resources.active).toBe(true);
399
- // Update primitive values
400
- store.resources.score = 100;
401
- store.resources.name = "Player2";
402
- store.resources.active = false;
403
- expect(store.resources.score).toBe(100);
404
- expect(store.resources.name).toBe("Player2");
405
- expect(store.resources.active).toBe(false);
406
- });
407
- it("should handle complex resource objects", () => {
408
- const complexResource = {
409
- nested: {
410
- deep: {
411
- value: 42,
412
- array: [1, 2, 3],
413
- flag: true
414
- }
415
- },
416
- count: 0
417
- };
418
- const store = createStore({ components: { position: positionSchema }, resources: { complex: { default: complexResource } }, archetypes: {} });
419
- expect(store.resources.complex).toEqual(complexResource);
420
- // Update complex resource
421
- const updatedComplex = {
422
- nested: {
423
- deep: {
424
- value: 100,
425
- array: [4, 5, 6],
426
- flag: false
427
- }
428
- },
429
- count: 10
430
- };
431
- store.resources.complex = updatedComplex;
432
- expect(store.resources.complex).toEqual(updatedComplex);
433
- });
434
- it("should handle array resource schemas", () => {
435
- const store = createStore({ components: { position: positionSchema }, resources: {
436
- tags: {
437
- type: "array",
438
- items: { type: "string" },
439
- default: ["player", "active"]
440
- }
441
- }, archetypes: {} });
442
- expect(store.resources.tags).toEqual(["player", "active"]);
443
- // Update array resource
444
- store.resources.tags = ["enemy", "boss", "elite"];
445
- expect(store.resources.tags).toEqual(["enemy", "boss", "elite"]);
446
- });
447
- });
448
- describe("Archetype functionality", () => {
449
- it("should create store with archetypes", () => {
450
- const store = createStore({ components: {
451
- name: { type: "string" },
452
- health: { type: "number" },
453
- enabled: { type: "boolean" },
454
- }, resources: {}, archetypes: {
455
- Player: ["name", "health"],
456
- } });
457
- const entity = store.archetypes.Player.insert({
458
- name: "test",
459
- health: 100,
460
- });
461
- expect(store.archetypes.Player.columns.name.get(entity)).toEqual("test");
462
- expect(store.archetypes.Player.columns.health.get(entity)).toEqual(100);
463
- });
464
- });
465
- // TimeSchema round-trip test
466
- describe("TimeSchema functionality", () => {
467
- it("should store and retrieve Date.now() value correctly", () => {
468
- const store = createStore({ components: {
469
- timestamp: Time.schema,
470
- }, resources: {}, archetypes: {} });
471
- // Create entity with current timestamp
472
- const now = Date.now();
473
- const archetype = store.ensureArchetype(["id", "timestamp"]);
474
- const entity = archetype.insert({ timestamp: now });
475
- // Query for the entity
476
- const entities = store.select(["timestamp"]);
477
- expect(entities).toHaveLength(1);
478
- expect(entities[0]).toBe(entity);
479
- // Read the stored value and verify it matches original
480
- const storedData = store.read(entity);
481
- expect(storedData).not.toBeNull();
482
- expect(storedData.timestamp).toBe(now);
483
- });
484
- });
485
- // Serialization/Deserialization tests
486
- describe("toData/fromData functionality", () => {
487
- it("should serialize and deserialize store with resources correctly", () => {
488
- const store = createStore({ components: {
489
- position: positionSchema,
490
- health: healthSchema,
491
- }, resources: {
492
- time: { default: { delta: 0.016, elapsed: 0 } },
493
- config: { default: { debug: false, volume: 1.0 } }
494
- }, archetypes: {} });
495
- // Add some entities
496
- const archetype = store.ensureArchetype(["id", "position", "health"]);
497
- const entity1 = archetype.insert({
498
- position: { x: 1, y: 2, z: 3 },
499
- health: { current: 100, max: 100 }
500
- });
501
- const entity2 = archetype.insert({
502
- position: { x: 4, y: 5, z: 6 },
503
- health: { current: 50, max: 100 }
504
- });
505
- // Update resources
506
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
507
- store.resources.config = { debug: true, volume: 0.5 };
508
- // Serialize the store
509
- const serializedData = store.toData();
510
- // Create a new store with the same schemas and restore
511
- const newStore = createStore({ components: {
512
- position: positionSchema,
513
- health: healthSchema,
514
- }, resources: {
515
- time: { default: { delta: 0.016, elapsed: 0 } },
516
- config: { default: { debug: false, volume: 1.0 } }
517
- }, archetypes: {} });
518
- newStore.fromData(serializedData);
519
- // Verify entities are restored
520
- const restoredEntities = newStore.select(["position", "health"]);
521
- expect(restoredEntities).toHaveLength(2);
522
- // Verify entity data is correct
523
- const restoredData1 = newStore.read(restoredEntities[0]);
524
- const restoredData2 = newStore.read(restoredEntities[1]);
525
- expect(restoredData1).toEqual({
526
- id: restoredEntities[0],
527
- position: { x: 1, y: 2, z: 3 },
528
- health: { current: 100, max: 100 }
529
- });
530
- expect(restoredData2).toEqual({
531
- id: restoredEntities[1],
532
- position: { x: 4, y: 5, z: 6 },
533
- health: { current: 50, max: 100 }
534
- });
535
- // Verify resources are restored
536
- expect(newStore.resources.time).toEqual({ delta: 0.033, elapsed: 1.5 });
537
- expect(newStore.resources.config).toEqual({ debug: true, volume: 0.5 });
538
- });
539
- it("should create new resources when restoring to store with additional resources", () => {
540
- // Create original store with only one resource
541
- const originalStore = createStore({ components: {
542
- position: positionSchema,
543
- }, resources: {
544
- time: { default: { delta: 0.016, elapsed: 0 } }
545
- }, archetypes: {} });
546
- // Add some entities and update resource
547
- const archetype = originalStore.ensureArchetype(["id", "position"]);
548
- archetype.insert({ position: { x: 1, y: 2, z: 3 } });
549
- originalStore.resources.time = { delta: 0.033, elapsed: 1.5 };
550
- // Serialize the store
551
- const serializedData = originalStore.toData();
552
- // Create new store with additional resources
553
- // Note: This is a limitation - when restoring to a store with different archetype structure,
554
- // entity locations may not be preserved correctly due to archetype ID shifts.
555
- // In practice, stores should be restored to compatible configurations.
556
- const newStore = createStore({ components: {
557
- position: positionSchema,
558
- }, resources: {
559
- time: { default: { delta: 0.016, elapsed: 0 } },
560
- config: { default: { debug: false, volume: 1.0 } },
561
- score: { default: 0 }
562
- }, archetypes: {} });
563
- // Restore from serialized data
564
- newStore.fromData(serializedData);
565
- // Verify original resource is restored
566
- expect(newStore.resources.time).toEqual({ delta: 0.033, elapsed: 1.5 });
567
- // Verify new resources are created with default values
568
- expect(newStore.resources.config).toEqual({ debug: false, volume: 1.0 });
569
- expect(newStore.resources.score).toBe(0);
570
- // Verify new resources are writable
571
- newStore.resources.config = { debug: true, volume: 0.5 };
572
- newStore.resources.score = 100;
573
- expect(newStore.resources.config).toEqual({ debug: true, volume: 0.5 });
574
- expect(newStore.resources.score).toBe(100);
575
- // Note: Due to archetype ID shifts when adding new resources,
576
- // the original entity may not be preserved correctly.
577
- // This is a limitation of the current serialization approach.
578
- // In practice, stores should be restored to compatible configurations.
579
- });
580
- it("should handle restoring to store with fewer resources", () => {
581
- // Create original store with multiple resources
582
- const originalStore = createStore({ components: {
583
- position: positionSchema,
584
- }, resources: {
585
- time: { default: { delta: 0.016, elapsed: 0 } },
586
- config: { default: { debug: false, volume: 1.0 } },
587
- score: { default: 0 }
588
- }, archetypes: {} });
589
- // Add entities and update resources
590
- const archetype = originalStore.ensureArchetype(["id", "position"]);
591
- const entity = archetype.insert({ position: { x: 1, y: 2, z: 3 } });
592
- originalStore.resources.time = { delta: 0.033, elapsed: 1.5 };
593
- originalStore.resources.config = { debug: true, volume: 0.5 };
594
- originalStore.resources.score = 100;
595
- // Serialize the store
596
- const serializedData = originalStore.toData();
597
- // Create new store with only one resource
598
- const newStore = createStore({ components: {
599
- position: positionSchema,
600
- }, resources: {
601
- time: { default: { delta: 0.016, elapsed: 0 } }
602
- }, archetypes: {} });
603
- // Restore from serialized data
604
- newStore.fromData(serializedData);
605
- // Verify the remaining resource is restored
606
- expect(newStore.resources.time).toEqual({ delta: 0.033, elapsed: 1.5 });
607
- // Verify only the time resource exists
608
- expect(newStore.resources).toHaveProperty('time');
609
- expect(newStore.resources).not.toHaveProperty('config');
610
- expect(newStore.resources).not.toHaveProperty('score');
611
- // Verify entity is still there
612
- const restoredEntities = newStore.select(["position"]);
613
- expect(restoredEntities).toHaveLength(1);
614
- const restoredData = newStore.read(restoredEntities[0]);
615
- expect(restoredData).toEqual({
616
- id: restoredEntities[0],
617
- position: { x: 1, y: 2, z: 3 }
618
- });
619
- });
620
- it("should preserve resource getter/setter functionality after restoration", () => {
621
- const store = createStore({ components: {
622
- position: positionSchema,
623
- }, resources: {
624
- time: { default: { delta: 0.016, elapsed: 0 } }
625
- }, archetypes: {} });
626
- // Update resource
627
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
628
- // Serialize and deserialize
629
- const serializedData = store.toData();
630
- const newStore = createStore({ components: {
631
- position: positionSchema,
632
- }, resources: {
633
- time: { default: { delta: 0.016, elapsed: 0 } }
634
- }, archetypes: {} });
635
- newStore.fromData(serializedData);
636
- // Verify resource is restored
637
- expect(newStore.resources.time).toEqual({ delta: 0.033, elapsed: 1.5 });
638
- // Verify getter/setter still works
639
- newStore.resources.time = { delta: 0.025, elapsed: 2.0 };
640
- expect(newStore.resources.time).toEqual({ delta: 0.025, elapsed: 2.0 });
641
- // Verify the underlying archetype is updated
642
- const timeArchetypes = newStore.queryArchetypes(["time"]);
643
- expect(timeArchetypes).toHaveLength(1);
644
- expect(timeArchetypes[0].rowCount).toBe(1);
645
- expect(timeArchetypes[0].columns.time.get(0)).toEqual({ delta: 0.025, elapsed: 2.0 });
646
- });
647
- it("should handle complex resource objects during serialization", () => {
648
- const complexResource = {
649
- nested: {
650
- deep: {
651
- value: 42,
652
- array: [1, 2, 3],
653
- flag: true
654
- }
655
- },
656
- count: 0
657
- };
658
- const store = createStore({ components: {
659
- position: positionSchema,
660
- }, resources: {
661
- complex: { default: complexResource }
662
- }, archetypes: {} });
663
- // Update complex resource
664
- const updatedComplex = {
665
- nested: {
666
- deep: {
667
- value: 100,
668
- array: [4, 5, 6],
669
- flag: false
670
- }
671
- },
672
- count: 10
673
- };
674
- store.resources.complex = updatedComplex;
675
- // Add some entities
676
- const archetype = store.ensureArchetype(["id", "position"]);
677
- archetype.insert({ position: { x: 1, y: 2, z: 3 } });
678
- // Serialize and deserialize
679
- const serializedData = store.toData();
680
- const newStore = createStore({ components: {
681
- position: positionSchema,
682
- }, resources: {
683
- complex: { default: complexResource }
684
- }, archetypes: {} });
685
- newStore.fromData(serializedData);
686
- // Verify complex resource is restored correctly
687
- expect(newStore.resources.complex).toEqual(updatedComplex);
688
- // Verify it's still writable
689
- const newComplex = { ...updatedComplex, count: 20 };
690
- newStore.resources.complex = newComplex;
691
- expect(newStore.resources.complex).toEqual(newComplex);
692
- });
693
- it("should handle empty resource schemas during restoration", () => {
694
- // Create store with resources
695
- const store = createStore({ components: {
696
- position: positionSchema,
697
- }, resources: {
698
- time: { default: { delta: 0.016, elapsed: 0 } }
699
- }, archetypes: {} });
700
- // Add entities and update resource
701
- const archetype = store.ensureArchetype(["id", "position"]);
702
- archetype.insert({ position: { x: 1, y: 2, z: 3 } });
703
- store.resources.time = { delta: 0.033, elapsed: 1.5 };
704
- // Serialize
705
- const serializedData = store.toData();
706
- // Create new store with no resources
707
- const newStore = createStore({ components: {
708
- position: positionSchema,
709
- }, resources: {}, archetypes: {} });
710
- // Restore - should not crash and should preserve entities
711
- newStore.fromData(serializedData);
712
- // Verify entities are preserved
713
- const restoredEntities = newStore.select(["position"]);
714
- expect(restoredEntities).toHaveLength(1);
715
- const restoredData = newStore.read(restoredEntities[0]);
716
- expect(restoredData).toEqual({
717
- id: restoredEntities[0],
718
- position: { x: 1, y: 2, z: 3 }
719
- });
720
- // Verify no resources exist
721
- expect(Object.keys(newStore.resources)).toHaveLength(0);
722
- });
723
- });
724
- });
725
- //# sourceMappingURL=create-store.test.js.map