murow 0.0.60 → 0.0.71

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 (425) hide show
  1. package/README.md +52 -37
  2. package/dist/cjs/core/binary-codec/binary-codec.js +1 -0
  3. package/dist/cjs/core/binary-codec/index.js +1 -0
  4. package/dist/cjs/core/driver/driver.js +1 -0
  5. package/dist/cjs/core/driver/drivers/immediate.js +1 -0
  6. package/dist/cjs/core/driver/drivers/index.js +1 -0
  7. package/dist/cjs/core/driver/drivers/raf.js +1 -0
  8. package/dist/cjs/core/driver/drivers/timeout.js +1 -0
  9. package/dist/cjs/core/driver/index.js +1 -0
  10. package/dist/cjs/core/events/event-system.js +1 -0
  11. package/dist/cjs/core/events/index.js +1 -0
  12. package/dist/cjs/core/fixed-ticker/fixed-ticker.js +1 -0
  13. package/dist/cjs/core/fixed-ticker/index.js +1 -0
  14. package/dist/cjs/core/free-list/free-list.js +1 -0
  15. package/dist/cjs/core/free-list/index.js +1 -0
  16. package/dist/cjs/core/generate-id/generate-id.js +1 -0
  17. package/dist/cjs/core/generate-id/index.js +1 -0
  18. package/dist/cjs/core/index.js +1 -0
  19. package/dist/cjs/core/input/index.js +1 -0
  20. package/dist/cjs/core/input/manager.js +1 -0
  21. package/dist/cjs/core/input/sources/browser.js +1 -0
  22. package/dist/cjs/core/input/sources/index.js +1 -0
  23. package/dist/cjs/core/input/types.js +1 -0
  24. package/dist/cjs/core/lerp/index.js +1 -0
  25. package/dist/cjs/core/lerp/lerp.js +1 -0
  26. package/dist/cjs/core/navmesh/index.js +1 -0
  27. package/dist/cjs/core/navmesh/navmesh-worker-pool.js +1 -0
  28. package/dist/cjs/core/navmesh/navmesh.js +1 -0
  29. package/dist/cjs/core/navmesh/navmesh.worker.js +1 -0
  30. package/dist/cjs/core/pooled-codec/index.js +1 -0
  31. package/dist/cjs/core/pooled-codec/pooled-codec.js +1 -0
  32. package/dist/cjs/core/prediction/index.js +1 -0
  33. package/dist/cjs/core/prediction/prediction.js +1 -0
  34. package/dist/cjs/core/ray/index.js +1 -0
  35. package/dist/cjs/core/ray/ray-2d.js +1 -0
  36. package/dist/cjs/core/ray/ray-3d.js +1 -0
  37. package/dist/cjs/core/simple-rng/index.js +1 -0
  38. package/dist/cjs/core/simple-rng/simple-rng.js +1 -0
  39. package/dist/cjs/core/sparse-batcher/index.js +1 -0
  40. package/dist/cjs/core/sparse-batcher/sparse-batcher.js +1 -0
  41. package/dist/cjs/ecs/component-store.js +1 -0
  42. package/dist/cjs/ecs/component.js +1 -0
  43. package/dist/cjs/ecs/entity-handle.js +1 -0
  44. package/dist/cjs/ecs/index.js +1 -0
  45. package/dist/cjs/ecs/system-builder.js +1 -0
  46. package/dist/cjs/ecs/world-systems.js +1 -0
  47. package/dist/cjs/ecs/world.js +1 -0
  48. package/dist/cjs/game/index.js +1 -0
  49. package/dist/cjs/game/loop/index.js +1 -0
  50. package/dist/cjs/game/loop/loop.js +1 -0
  51. package/dist/cjs/index.js +1 -0
  52. package/dist/cjs/net/adapters/browser-websocket.js +1 -0
  53. package/dist/cjs/net/adapters/bun-websocket.js +1 -0
  54. package/dist/cjs/net/buffer-pool.js +1 -0
  55. package/dist/cjs/net/client.js +1 -0
  56. package/dist/cjs/net/index.js +1 -0
  57. package/dist/cjs/net/server.js +1 -0
  58. package/dist/cjs/net/types.js +1 -0
  59. package/dist/cjs/net/validators.js +1 -0
  60. package/dist/cjs/protocol/index.js +1 -0
  61. package/dist/cjs/protocol/intent/define-intent.js +1 -0
  62. package/dist/cjs/protocol/intent/index.js +1 -0
  63. package/dist/cjs/protocol/intent/intent-registry.js +1 -0
  64. package/dist/cjs/protocol/intent/intent.js +1 -0
  65. package/dist/cjs/protocol/rpc/define-rpc.js +1 -0
  66. package/dist/cjs/protocol/rpc/index.js +1 -0
  67. package/dist/cjs/protocol/rpc/rpc-registry.js +1 -0
  68. package/dist/cjs/protocol/rpc/rpc.js +1 -0
  69. package/dist/cjs/protocol/snapshot/index.js +1 -0
  70. package/dist/cjs/protocol/snapshot/snapshot-codec.js +1 -0
  71. package/dist/cjs/protocol/snapshot/snapshot-registry.js +1 -0
  72. package/dist/cjs/protocol/snapshot/snapshot.js +1 -0
  73. package/dist/cjs/renderer/base-2d-renderer.js +1 -0
  74. package/dist/cjs/renderer/base-3d-renderer.js +1 -0
  75. package/dist/cjs/renderer/base-renderer.js +1 -0
  76. package/dist/cjs/renderer/index.js +1 -0
  77. package/dist/cjs/renderer/types.js +1 -0
  78. package/dist/esm/core/binary-codec/binary-codec.js +1 -0
  79. package/dist/esm/core/binary-codec/index.js +1 -0
  80. package/dist/esm/core/driver/driver.js +1 -0
  81. package/dist/esm/core/driver/drivers/immediate.js +1 -0
  82. package/dist/esm/core/driver/drivers/index.js +1 -0
  83. package/dist/esm/core/driver/drivers/raf.js +1 -0
  84. package/dist/esm/core/driver/drivers/timeout.js +1 -0
  85. package/dist/esm/core/driver/index.js +1 -0
  86. package/dist/esm/core/events/event-system.js +1 -0
  87. package/dist/esm/core/events/index.js +1 -0
  88. package/dist/esm/core/fixed-ticker/fixed-ticker.js +1 -0
  89. package/dist/esm/core/fixed-ticker/index.js +1 -0
  90. package/dist/esm/core/free-list/free-list.js +1 -0
  91. package/dist/esm/core/free-list/index.js +1 -0
  92. package/dist/esm/core/generate-id/generate-id.js +1 -0
  93. package/dist/esm/core/generate-id/index.js +1 -0
  94. package/dist/esm/core/index.js +1 -0
  95. package/dist/esm/core/input/index.js +1 -0
  96. package/dist/esm/core/input/manager.js +1 -0
  97. package/dist/esm/core/input/sources/browser.js +1 -0
  98. package/dist/esm/core/input/sources/index.js +1 -0
  99. package/dist/esm/core/input/types.js +0 -0
  100. package/dist/esm/core/lerp/index.js +1 -0
  101. package/dist/esm/core/lerp/lerp.js +1 -0
  102. package/dist/esm/core/navmesh/index.js +1 -0
  103. package/dist/esm/core/navmesh/navmesh-worker-pool.js +1 -0
  104. package/dist/esm/core/navmesh/navmesh.js +1 -0
  105. package/dist/esm/core/navmesh/navmesh.worker.js +1 -0
  106. package/dist/esm/core/pooled-codec/index.js +1 -0
  107. package/dist/esm/core/pooled-codec/pooled-codec.js +1 -0
  108. package/dist/esm/core/prediction/index.js +1 -0
  109. package/dist/esm/core/prediction/prediction.js +1 -0
  110. package/dist/esm/core/ray/index.js +1 -0
  111. package/dist/esm/core/ray/ray-2d.js +1 -0
  112. package/dist/esm/core/ray/ray-3d.js +1 -0
  113. package/dist/esm/core/simple-rng/index.js +1 -0
  114. package/dist/esm/core/simple-rng/simple-rng.js +1 -0
  115. package/dist/esm/core/sparse-batcher/index.js +1 -0
  116. package/dist/esm/core/sparse-batcher/sparse-batcher.js +1 -0
  117. package/dist/esm/ecs/component-store.js +1 -0
  118. package/dist/esm/ecs/component.js +1 -0
  119. package/dist/esm/ecs/entity-handle.js +1 -0
  120. package/dist/esm/ecs/index.js +1 -0
  121. package/dist/esm/ecs/system-builder.js +1 -0
  122. package/dist/esm/ecs/world-systems.js +1 -0
  123. package/dist/esm/ecs/world.js +1 -0
  124. package/dist/esm/game/index.js +1 -0
  125. package/dist/esm/game/loop/index.js +1 -0
  126. package/dist/esm/game/loop/loop.js +1 -0
  127. package/dist/esm/index.js +1 -0
  128. package/dist/esm/net/adapters/browser-websocket.js +1 -0
  129. package/dist/esm/net/adapters/bun-websocket.js +1 -0
  130. package/dist/esm/net/buffer-pool.js +1 -0
  131. package/dist/esm/net/client.js +1 -0
  132. package/dist/esm/net/index.js +1 -0
  133. package/dist/esm/net/server.js +1 -0
  134. package/dist/esm/net/types.js +1 -0
  135. package/dist/esm/net/validators.js +1 -0
  136. package/dist/esm/protocol/index.js +1 -0
  137. package/dist/esm/protocol/intent/define-intent.js +1 -0
  138. package/dist/esm/protocol/intent/index.js +1 -0
  139. package/dist/esm/protocol/intent/intent-registry.js +1 -0
  140. package/dist/esm/protocol/intent/intent.js +0 -0
  141. package/dist/esm/protocol/rpc/define-rpc.js +1 -0
  142. package/dist/esm/protocol/rpc/index.js +1 -0
  143. package/dist/esm/protocol/rpc/rpc-registry.js +1 -0
  144. package/dist/esm/protocol/rpc/rpc.js +0 -0
  145. package/dist/esm/protocol/snapshot/index.js +1 -0
  146. package/dist/esm/protocol/snapshot/snapshot-codec.js +1 -0
  147. package/dist/esm/protocol/snapshot/snapshot-registry.js +1 -0
  148. package/dist/esm/protocol/snapshot/snapshot.js +1 -0
  149. package/dist/esm/renderer/base-2d-renderer.js +1 -0
  150. package/dist/esm/renderer/base-3d-renderer.js +1 -0
  151. package/dist/esm/renderer/base-renderer.js +1 -0
  152. package/dist/esm/renderer/index.js +1 -0
  153. package/dist/esm/renderer/types.js +0 -0
  154. package/dist/{core → types/core}/binary-codec/binary-codec.d.ts +4 -0
  155. package/dist/{core/loop → types/core/driver}/drivers/immediate.d.ts +1 -1
  156. package/dist/{core/loop → types/core/driver}/drivers/raf.d.ts +1 -1
  157. package/dist/{core/loop → types/core/driver}/drivers/timeout.d.ts +1 -1
  158. package/dist/{core/loop → types/core/driver}/index.d.ts +1 -1
  159. package/dist/{core → types/core}/events/event-system.d.ts +14 -33
  160. package/dist/{core → types/core}/fixed-ticker/fixed-ticker.d.ts +1 -1
  161. package/dist/types/core/free-list/free-list.d.ts +31 -0
  162. package/dist/types/core/free-list/index.d.ts +1 -0
  163. package/dist/{core → types/core}/index.d.ts +7 -1
  164. package/dist/types/core/input/index.d.ts +3 -0
  165. package/dist/types/core/input/manager.d.ts +56 -0
  166. package/dist/types/core/input/sources/browser.d.ts +9 -0
  167. package/dist/types/core/input/sources/index.d.ts +1 -0
  168. package/dist/types/core/input/types.d.ts +36 -0
  169. package/dist/{core → types/core}/navmesh/navmesh.d.ts +1 -21
  170. package/dist/types/core/ray/index.d.ts +2 -0
  171. package/dist/types/core/ray/ray-2d.d.ts +37 -0
  172. package/dist/types/core/ray/ray-3d.d.ts +42 -0
  173. package/dist/types/core/simple-rng/index.d.ts +1 -0
  174. package/dist/types/core/simple-rng/simple-rng.d.ts +36 -0
  175. package/dist/types/core/sparse-batcher/index.d.ts +1 -0
  176. package/dist/types/core/sparse-batcher/sparse-batcher.d.ts +55 -0
  177. package/dist/{ecs → types/ecs}/system-builder.d.ts +20 -9
  178. package/dist/{ecs → types/ecs}/world.d.ts +11 -0
  179. package/dist/types/game/index.d.ts +1 -0
  180. package/dist/types/game/loop/index.d.ts +1 -0
  181. package/dist/types/game/loop/loop.d.ts +175 -0
  182. package/dist/{index.d.ts → types/index.d.ts} +2 -0
  183. package/dist/{net → types/net}/index.d.ts +2 -2
  184. package/dist/{net → types/net}/server.d.ts +39 -19
  185. package/dist/{protocol → types/protocol}/intent/define-intent.d.ts +15 -0
  186. package/dist/{protocol → types/protocol}/intent/index.d.ts +1 -1
  187. package/dist/types/renderer/base-2d-renderer.d.ts +13 -0
  188. package/dist/types/renderer/base-3d-renderer.d.ts +10 -0
  189. package/dist/types/renderer/base-renderer.d.ts +21 -0
  190. package/dist/types/renderer/index.d.ts +4 -0
  191. package/dist/types/renderer/types.d.ts +79 -0
  192. package/dist/webgpu/cjs/index.js +6004 -0
  193. package/dist/webgpu/esm/index.js +5972 -0
  194. package/dist/webgpu/types/2d/animation.d.ts +97 -0
  195. package/dist/webgpu/types/2d/renderer.d.ts +55 -0
  196. package/dist/webgpu/types/2d/shader.d.ts +61 -0
  197. package/dist/webgpu/types/2d/sprite-accessor.d.ts +47 -0
  198. package/dist/webgpu/types/2d/sprite-accessor.test.d.ts +1 -0
  199. package/dist/webgpu/types/3d/gltf-skin-parser.d.ts +101 -0
  200. package/dist/webgpu/types/3d/morph-animation.d.ts +69 -0
  201. package/dist/webgpu/types/3d/morph-animation.test.d.ts +1 -0
  202. package/dist/webgpu/types/3d/renderer.d.ts +216 -0
  203. package/dist/webgpu/types/3d/shader.d.ts +136 -0
  204. package/dist/webgpu/types/3d/skeletal-animation-compute/index.d.ts +2 -0
  205. package/dist/webgpu/types/3d/skeletal-animation-compute/kernel.d.ts +8 -0
  206. package/dist/webgpu/types/3d/skeletal-animation-compute/packer.d.ts +32 -0
  207. package/dist/webgpu/types/3d/skeletal-animation.d.ts +90 -0
  208. package/dist/webgpu/types/camera/camera-2d.d.ts +53 -0
  209. package/dist/webgpu/types/camera/camera-2d.test.d.ts +1 -0
  210. package/dist/webgpu/types/camera/camera-3d.d.ts +81 -0
  211. package/dist/webgpu/types/camera/camera-3d.test.d.ts +1 -0
  212. package/dist/webgpu/types/camera/index.d.ts +2 -0
  213. package/dist/webgpu/types/compute/compute-builder.d.ts +123 -0
  214. package/dist/webgpu/types/compute/compute-builder.test.d.ts +1 -0
  215. package/dist/webgpu/types/core/constants.d.ts +59 -0
  216. package/dist/webgpu/types/core/constants.test.d.ts +1 -0
  217. package/dist/webgpu/types/core/index.d.ts +2 -0
  218. package/dist/webgpu/types/core/math.d.ts +37 -0
  219. package/dist/webgpu/types/core/types.d.ts +125 -0
  220. package/dist/webgpu/types/core/types.test.d.ts +1 -0
  221. package/dist/webgpu/types/geometry/built-in.d.ts +58 -0
  222. package/dist/webgpu/types/geometry/built-in.test.d.ts +1 -0
  223. package/dist/webgpu/types/geometry/geometry-builder.d.ts +281 -0
  224. package/dist/webgpu/types/geometry/geometry-builder.test.d.ts +1 -0
  225. package/dist/webgpu/types/geometry/index.d.ts +2 -0
  226. package/dist/webgpu/types/index.d.ts +32 -0
  227. package/dist/webgpu/types/particle/emitter.d.ts +36 -0
  228. package/dist/webgpu/types/shaders/index.d.ts +2 -0
  229. package/dist/webgpu/types/shaders/runtime-transpile.d.ts +18 -0
  230. package/dist/webgpu/types/shaders/sprite-2d.wgsl.d.ts +10 -0
  231. package/dist/webgpu/types/shaders/typegpu.d.ts +9 -0
  232. package/dist/webgpu/types/shaders/utils.d.ts +28 -0
  233. package/dist/webgpu/types/shaders/utils.test.d.ts +1 -0
  234. package/dist/webgpu/types/spritesheet/index.d.ts +1 -0
  235. package/dist/webgpu/types/spritesheet/spritesheet.d.ts +57 -0
  236. package/dist/webgpu/types/spritesheet/spritesheet.test.d.ts +1 -0
  237. package/package.json +96 -26
  238. package/dist/core/binary-codec/binary-codec.js +0 -354
  239. package/dist/core/binary-codec/index.js +0 -1
  240. package/dist/core/events/event-system.js +0 -88
  241. package/dist/core/events/index.js +0 -1
  242. package/dist/core/fixed-ticker/fixed-ticker.js +0 -101
  243. package/dist/core/fixed-ticker/index.js +0 -1
  244. package/dist/core/generate-id/generate-id.js +0 -25
  245. package/dist/core/generate-id/index.js +0 -1
  246. package/dist/core/index.js +0 -9
  247. package/dist/core/lerp/index.js +0 -1
  248. package/dist/core/lerp/lerp.js +0 -42
  249. package/dist/core/loop/drivers/immediate.js +0 -61
  250. package/dist/core/loop/drivers/index.js +0 -3
  251. package/dist/core/loop/drivers/raf.js +0 -62
  252. package/dist/core/loop/drivers/timeout.js +0 -71
  253. package/dist/core/loop/index.js +0 -2
  254. package/dist/core/loop/loop.js +0 -47
  255. package/dist/core/navmesh/index.js +0 -1
  256. package/dist/core/navmesh/navmesh-worker-pool.js +0 -180
  257. package/dist/core/navmesh/navmesh.js +0 -799
  258. package/dist/core/navmesh/navmesh.worker.js +0 -79
  259. package/dist/core/pooled-codec/index.js +0 -1
  260. package/dist/core/pooled-codec/pooled-codec.js +0 -410
  261. package/dist/core/prediction/index.js +0 -1
  262. package/dist/core/prediction/prediction.js +0 -99
  263. package/dist/core.esm.js +0 -1
  264. package/dist/core.js +0 -1
  265. package/dist/ecs/component-store.js +0 -175
  266. package/dist/ecs/component.js +0 -43
  267. package/dist/ecs/entity-handle.js +0 -515
  268. package/dist/ecs/example.js +0 -125
  269. package/dist/ecs/index.js +0 -4
  270. package/dist/ecs/system-builder.js +0 -180
  271. package/dist/ecs/system.d.ts +0 -63
  272. package/dist/ecs/system.js +0 -92
  273. package/dist/ecs/world-systems.js +0 -79
  274. package/dist/ecs/world.js +0 -684
  275. package/dist/index.js +0 -24
  276. package/dist/net/adapters/browser-websocket.js +0 -74
  277. package/dist/net/adapters/bun-websocket.js +0 -245
  278. package/dist/net/buffer-pool.js +0 -89
  279. package/dist/net/client.js +0 -586
  280. package/dist/net/index.js +0 -58
  281. package/dist/net/server.js +0 -938
  282. package/dist/net/types.js +0 -31
  283. package/dist/net/validators.js +0 -88
  284. package/dist/protocol/index.js +0 -92
  285. package/dist/protocol/intent/define-intent.js +0 -125
  286. package/dist/protocol/intent/index.js +0 -91
  287. package/dist/protocol/intent/intent-registry.js +0 -91
  288. package/dist/protocol/rpc/define-rpc.js +0 -84
  289. package/dist/protocol/rpc/index.js +0 -3
  290. package/dist/protocol/rpc/rpc-registry.js +0 -159
  291. package/dist/protocol/rpc/rpc.js +0 -12
  292. package/dist/protocol/snapshot/index.js +0 -43
  293. package/dist/protocol/snapshot/snapshot-codec.js +0 -67
  294. package/dist/protocol/snapshot/snapshot-registry.js +0 -168
  295. package/dist/protocol/snapshot/snapshot.js +0 -30
  296. package/src/core/binary-codec/README.md +0 -60
  297. package/src/core/binary-codec/binary-codec.test.ts +0 -300
  298. package/src/core/binary-codec/binary-codec.ts +0 -448
  299. package/src/core/binary-codec/index.ts +0 -1
  300. package/src/core/events/README.md +0 -47
  301. package/src/core/events/event-system.test.ts +0 -243
  302. package/src/core/events/event-system.ts +0 -140
  303. package/src/core/events/index.ts +0 -1
  304. package/src/core/fixed-ticker/README.md +0 -77
  305. package/src/core/fixed-ticker/fixed-ticker.test.ts +0 -151
  306. package/src/core/fixed-ticker/fixed-ticker.ts +0 -169
  307. package/src/core/fixed-ticker/index.ts +0 -1
  308. package/src/core/generate-id/README.md +0 -18
  309. package/src/core/generate-id/generate-id.test.ts +0 -79
  310. package/src/core/generate-id/generate-id.ts +0 -37
  311. package/src/core/generate-id/index.ts +0 -1
  312. package/src/core/index.ts +0 -9
  313. package/src/core/lerp/README.md +0 -79
  314. package/src/core/lerp/index.ts +0 -1
  315. package/src/core/lerp/lerp.test.ts +0 -90
  316. package/src/core/lerp/lerp.ts +0 -42
  317. package/src/core/loop/README.md +0 -97
  318. package/src/core/loop/drivers/immediate.ts +0 -66
  319. package/src/core/loop/drivers/index.ts +0 -3
  320. package/src/core/loop/drivers/raf.ts +0 -67
  321. package/src/core/loop/drivers/timeout.ts +0 -77
  322. package/src/core/loop/index.ts +0 -2
  323. package/src/core/loop/loop.test.ts +0 -414
  324. package/src/core/loop/loop.ts +0 -71
  325. package/src/core/navmesh/README.md +0 -164
  326. package/src/core/navmesh/index.ts +0 -1
  327. package/src/core/navmesh/navmesh-worker-pool.ts +0 -236
  328. package/src/core/navmesh/navmesh-workers.test.ts +0 -356
  329. package/src/core/navmesh/navmesh.test.ts +0 -344
  330. package/src/core/navmesh/navmesh.ts +0 -1047
  331. package/src/core/navmesh/navmesh.worker.ts +0 -147
  332. package/src/core/pooled-codec/README.md +0 -70
  333. package/src/core/pooled-codec/index.ts +0 -1
  334. package/src/core/pooled-codec/pooled-codec.test.ts +0 -862
  335. package/src/core/pooled-codec/pooled-codec.ts +0 -504
  336. package/src/core/prediction/README.md +0 -64
  337. package/src/core/prediction/index.ts +0 -1
  338. package/src/core/prediction/prediction.test.ts +0 -423
  339. package/src/core/prediction/prediction.ts +0 -112
  340. package/src/ecs/README.md +0 -427
  341. package/src/ecs/benchmark.test.ts +0 -1645
  342. package/src/ecs/component-store.ts +0 -198
  343. package/src/ecs/component.ts +0 -90
  344. package/src/ecs/entity-handle.test.ts +0 -393
  345. package/src/ecs/entity-handle.ts +0 -563
  346. package/src/ecs/example.ts +0 -152
  347. package/src/ecs/index.ts +0 -4
  348. package/src/ecs/system-builder.ts +0 -309
  349. package/src/ecs/system.ts +0 -111
  350. package/src/ecs/world-systems.ts +0 -83
  351. package/src/ecs/world.test.ts +0 -310
  352. package/src/ecs/world.ts +0 -828
  353. package/src/index.ts +0 -28
  354. package/src/net/README.md +0 -474
  355. package/src/net/adapters/browser-websocket.ts +0 -86
  356. package/src/net/adapters/bun-websocket.ts +0 -292
  357. package/src/net/buffer-pool.ts +0 -106
  358. package/src/net/client.test.ts +0 -807
  359. package/src/net/client.ts +0 -695
  360. package/src/net/index.ts +0 -60
  361. package/src/net/server.test.ts +0 -799
  362. package/src/net/server.ts +0 -1116
  363. package/src/net/types.ts +0 -228
  364. package/src/net/validators.ts +0 -104
  365. package/src/protocol/README.md +0 -469
  366. package/src/protocol/index.ts +0 -93
  367. package/src/protocol/intent/define-intent.test.ts +0 -397
  368. package/src/protocol/intent/define-intent.ts +0 -182
  369. package/src/protocol/intent/index.ts +0 -94
  370. package/src/protocol/intent/intent-registry.test.ts +0 -198
  371. package/src/protocol/intent/intent-registry.ts +0 -112
  372. package/src/protocol/intent/intent.ts +0 -12
  373. package/src/protocol/rpc/define-rpc.test.ts +0 -141
  374. package/src/protocol/rpc/define-rpc.ts +0 -113
  375. package/src/protocol/rpc/index.ts +0 -3
  376. package/src/protocol/rpc/rpc-registry.test.ts +0 -168
  377. package/src/protocol/rpc/rpc-registry.ts +0 -176
  378. package/src/protocol/rpc/rpc.ts +0 -37
  379. package/src/protocol/snapshot/index.ts +0 -45
  380. package/src/protocol/snapshot/snapshot-codec.test.ts +0 -138
  381. package/src/protocol/snapshot/snapshot-codec.ts +0 -87
  382. package/src/protocol/snapshot/snapshot-registry.test.ts +0 -310
  383. package/src/protocol/snapshot/snapshot-registry.ts +0 -201
  384. package/src/protocol/snapshot/snapshot.test.ts +0 -76
  385. package/src/protocol/snapshot/snapshot.ts +0 -41
  386. /package/dist/{core → types/core}/binary-codec/index.d.ts +0 -0
  387. /package/dist/{core/loop/loop.d.ts → types/core/driver/driver.d.ts} +0 -0
  388. /package/dist/{core/loop → types/core/driver}/drivers/index.d.ts +0 -0
  389. /package/dist/{core → types/core}/events/index.d.ts +0 -0
  390. /package/dist/{core → types/core}/fixed-ticker/index.d.ts +0 -0
  391. /package/dist/{core → types/core}/generate-id/generate-id.d.ts +0 -0
  392. /package/dist/{core → types/core}/generate-id/index.d.ts +0 -0
  393. /package/dist/{core → types/core}/lerp/index.d.ts +0 -0
  394. /package/dist/{core → types/core}/lerp/lerp.d.ts +0 -0
  395. /package/dist/{core → types/core}/navmesh/index.d.ts +0 -0
  396. /package/dist/{core → types/core}/navmesh/navmesh-worker-pool.d.ts +0 -0
  397. /package/dist/{core → types/core}/navmesh/navmesh.worker.d.ts +0 -0
  398. /package/dist/{core → types/core}/pooled-codec/index.d.ts +0 -0
  399. /package/dist/{core → types/core}/pooled-codec/pooled-codec.d.ts +0 -0
  400. /package/dist/{core → types/core}/prediction/index.d.ts +0 -0
  401. /package/dist/{core → types/core}/prediction/prediction.d.ts +0 -0
  402. /package/dist/{ecs → types/ecs}/component-store.d.ts +0 -0
  403. /package/dist/{ecs → types/ecs}/component.d.ts +0 -0
  404. /package/dist/{ecs → types/ecs}/entity-handle.d.ts +0 -0
  405. /package/dist/{ecs → types/ecs}/example.d.ts +0 -0
  406. /package/dist/{ecs → types/ecs}/index.d.ts +0 -0
  407. /package/dist/{ecs → types/ecs}/world-systems.d.ts +0 -0
  408. /package/dist/{net → types/net}/adapters/browser-websocket.d.ts +0 -0
  409. /package/dist/{net → types/net}/adapters/bun-websocket.d.ts +0 -0
  410. /package/dist/{net → types/net}/buffer-pool.d.ts +0 -0
  411. /package/dist/{net → types/net}/client.d.ts +0 -0
  412. /package/dist/{net → types/net}/types.d.ts +0 -0
  413. /package/dist/{net → types/net}/validators.d.ts +0 -0
  414. /package/dist/{protocol → types/protocol}/index.d.ts +0 -0
  415. /package/dist/{protocol → types/protocol}/intent/intent-registry.d.ts +0 -0
  416. /package/dist/{protocol → types/protocol}/intent/intent.d.ts +0 -0
  417. /package/dist/{protocol → types/protocol}/rpc/define-rpc.d.ts +0 -0
  418. /package/dist/{protocol → types/protocol}/rpc/index.d.ts +0 -0
  419. /package/dist/{protocol → types/protocol}/rpc/rpc-registry.d.ts +0 -0
  420. /package/dist/{protocol → types/protocol}/rpc/rpc.d.ts +0 -0
  421. /package/dist/{protocol → types/protocol}/snapshot/index.d.ts +0 -0
  422. /package/dist/{protocol → types/protocol}/snapshot/snapshot-codec.d.ts +0 -0
  423. /package/dist/{protocol → types/protocol}/snapshot/snapshot-registry.d.ts +0 -0
  424. /package/dist/{protocol → types/protocol}/snapshot/snapshot.d.ts +0 -0
  425. /package/dist/{protocol/intent/intent.js → webgpu/types/2d/animation.test.d.ts} +0 -0
@@ -1,79 +0,0 @@
1
- /**
2
- * NavMesh Worker - Offloads pathfinding to background thread
3
- *
4
- * Message Protocol:
5
- * - INIT: Initialize NavMesh with obstacles
6
- * - FIND_PATH: Request pathfinding (from, to)
7
- * - ADD_OBSTACLE: Add obstacle dynamically
8
- * - REMOVE_OBSTACLE: Remove obstacle dynamically
9
- * - MOVE_OBSTACLE: Move obstacle
10
- */
11
- import { NavMesh } from './navmesh';
12
- let navmesh = null;
13
- self.onmessage = (e) => {
14
- const msg = e.data;
15
- try {
16
- switch (msg.type) {
17
- case 'INIT': {
18
- navmesh = new NavMesh(msg.navType);
19
- if (msg.obstacles) {
20
- for (const obstacle of msg.obstacles) {
21
- navmesh.addObstacle(obstacle);
22
- }
23
- }
24
- self.postMessage({ type: 'READY' });
25
- break;
26
- }
27
- case 'FIND_PATH': {
28
- if (!navmesh) {
29
- throw new Error('NavMesh not initialized');
30
- }
31
- const start = performance.now();
32
- const path = navmesh.findPath({ from: msg.from, to: msg.to });
33
- const duration = performance.now() - start;
34
- const result = {
35
- type: 'PATH_RESULT',
36
- id: msg.id,
37
- path,
38
- duration,
39
- };
40
- self.postMessage(result);
41
- break;
42
- }
43
- case 'ADD_OBSTACLE': {
44
- if (!navmesh) {
45
- throw new Error('NavMesh not initialized');
46
- }
47
- const obstacleId = navmesh.addObstacle(msg.obstacle);
48
- const result = {
49
- type: 'OBSTACLE_ADDED',
50
- obstacleId,
51
- };
52
- self.postMessage(result);
53
- break;
54
- }
55
- case 'REMOVE_OBSTACLE': {
56
- if (!navmesh) {
57
- throw new Error('NavMesh not initialized');
58
- }
59
- navmesh.removeObstacle(msg.obstacleId);
60
- self.postMessage({ type: 'OBSTACLE_REMOVED' });
61
- break;
62
- }
63
- case 'MOVE_OBSTACLE': {
64
- if (!navmesh) {
65
- throw new Error('NavMesh not initialized');
66
- }
67
- navmesh.moveObstacle(msg.obstacleId, msg.pos);
68
- self.postMessage({ type: 'OBSTACLE_MOVED' });
69
- break;
70
- }
71
- }
72
- }
73
- catch (error) {
74
- self.postMessage({
75
- type: 'ERROR',
76
- error: error instanceof Error ? error.message : String(error)
77
- });
78
- }
79
- };
@@ -1 +0,0 @@
1
- export * from './pooled-codec';
@@ -1,410 +0,0 @@
1
- import { BinaryCodec } from "../binary-codec";
2
- /**
3
- * Generic object pool for reusing objects and minimizing allocations.
4
- * @template T Type of objects stored in the pool.
5
- */
6
- export class ObjectPool {
7
- /**
8
- * @param factory Function to create a new instance when the pool is empty.
9
- */
10
- constructor(factory) {
11
- this.factory = factory;
12
- this.pool = [];
13
- }
14
- /**
15
- * Acquire an object from the pool, or create a new one if empty.
16
- * @returns {T} The acquired object.
17
- */
18
- acquire() {
19
- return this.pool.pop() ?? this.factory();
20
- }
21
- /**
22
- * Return an object to the pool for reuse.
23
- * @param {T} obj Object to release.
24
- */
25
- release(obj) {
26
- this.pool.push(obj);
27
- }
28
- /**
29
- * Return multiple objects to the pool at once.
30
- * @param {T[]} objs Array of objects to release.
31
- */
32
- releaseAll(objs) {
33
- this.pool.push(...objs);
34
- }
35
- }
36
- /**
37
- * Pooled decoder for single objects or nested schemas.
38
- * @template T Type of object to decode.
39
- */
40
- export class PooledDecoder {
41
- /**
42
- * @param schema Schema or record describing the object structure.
43
- * @param initial Initial object used as template for pooling.
44
- */
45
- constructor(schema) {
46
- this.schema = schema;
47
- this.pool = new ObjectPool(() => this.createNil());
48
- }
49
- createNil() {
50
- const obj = {};
51
- for (const key of Object.keys(this.schema)) {
52
- const field = this.schema[key];
53
- obj[key] = "toNil" in field ? field.toNil() : undefined;
54
- }
55
- return obj;
56
- }
57
- /**
58
- * Decode a buffer into a pooled object.
59
- * @param {Uint8Array} buf Buffer to decode.
60
- * @returns {T} Decoded object.
61
- */
62
- decode(buf) {
63
- const obj = this.pool.acquire();
64
- this.decodeInto(buf, obj);
65
- return obj;
66
- }
67
- /**
68
- * Decode a buffer into a provided target object.
69
- * @param {Uint8Array} buf Buffer to decode.
70
- * @param {T} target Object to write decoded data into.
71
- */
72
- decodeInto(buf, target) {
73
- let offset = 0;
74
- for (const key of Object.keys(this.schema)) {
75
- const field = this.schema[key];
76
- if ("decodeAll" in field) {
77
- const result = field.decodeAll(buf.subarray(offset));
78
- target[key] = result.value;
79
- offset += result.bytesRead;
80
- }
81
- else if ("decodeField" in field) {
82
- // Use decodeField for ArrayField (returns { value, bytesRead })
83
- const result = field.decodeField(buf.subarray(offset));
84
- target[key] = result.value;
85
- offset += result.bytesRead;
86
- }
87
- else if ("decode" in field) {
88
- const result = field.decode(buf.subarray(offset));
89
- target[key] = result.value;
90
- offset += result.bytesRead;
91
- }
92
- else {
93
- // For primitive fields, calculate size and decode
94
- const fieldSize = field.size || 0;
95
- const fieldBuf = buf.subarray(offset, offset + fieldSize);
96
- BinaryCodec.decodeInto({ [key]: field }, fieldBuf, target);
97
- offset += fieldSize;
98
- }
99
- }
100
- }
101
- /**
102
- * Release a decoded object back to the pool.
103
- * @param {T} obj Object to release.
104
- */
105
- release(obj) {
106
- this.pool.release(obj);
107
- }
108
- }
109
- /**
110
- * Pooled decoder for arrays of objects.
111
- * @template T Type of object to decode.
112
- */
113
- export class PooledArrayDecoder {
114
- /**
115
- * @param schema Schema or record describing object structure.
116
- * @param initial Initial object used as template for pooling.
117
- */
118
- constructor(schema) {
119
- this.pooledDecoder = new PooledDecoder(schema);
120
- }
121
- /**
122
- * Decode multiple buffers into pooled objects.
123
- * @param {Uint8Array[]} buffers Array of buffers to decode.
124
- * @returns {T[]} Array of decoded objects.
125
- */
126
- decodeAll(buffers) {
127
- return buffers.map((b) => this.pooledDecoder.decode(b));
128
- }
129
- /**
130
- * Release multiple decoded objects back to the pool.
131
- * @param {T[]} objs Array of objects to release.
132
- */
133
- releaseAll(objs) {
134
- objs.forEach((o) => this.pooledDecoder.release(o));
135
- }
136
- }
137
- /**
138
- * Pooled encoder for single objects or nested schemas.
139
- * @template T Type of object to encode.
140
- */
141
- export class PooledEncoder {
142
- /**
143
- * @param schema Schema or record describing object structure.
144
- * @param bufferSize Size of buffer to allocate per encoding (default: 1024).
145
- */
146
- constructor(schema, bufferSize = 1024) {
147
- this.schema = schema;
148
- this.bufferSize = bufferSize;
149
- this.pool = new ObjectPool(() => new Uint8Array(bufferSize));
150
- }
151
- /**
152
- * Encode an object into a pooled buffer.
153
- * @param {T} obj Object to encode.
154
- * @returns {Uint8Array} Encoded buffer.
155
- */
156
- encode(obj) {
157
- const buf = this.pool.acquire();
158
- let offset = 0;
159
- for (const key of Object.keys(this.schema)) {
160
- const field = this.schema[key];
161
- if ("encode" in field) {
162
- const nested = field.encode(obj[key]);
163
- buf.set(nested, offset);
164
- offset += nested.length;
165
- }
166
- else if ("encodeAll" in field) {
167
- const nestedArr = field.encodeAll(obj[key]);
168
- let arrOffset = 0;
169
- for (const item of nestedArr) {
170
- buf.set(item, offset + arrOffset);
171
- arrOffset += item.length;
172
- }
173
- offset += arrOffset;
174
- }
175
- else {
176
- const tmp = BinaryCodec.encode({ [key]: field }, { [key]: obj[key] });
177
- buf.set(tmp, offset);
178
- offset += tmp.length;
179
- }
180
- }
181
- return buf.subarray(0, offset);
182
- }
183
- /**
184
- * Release a buffer back to the pool.
185
- * @param {Uint8Array} buf Buffer to release.
186
- */
187
- release(buf) {
188
- this.pool.release(buf);
189
- }
190
- }
191
- /**
192
- * Combined pooled encoder and decoder for a single schema.
193
- * Provides a convenient wrapper around PooledEncoder and PooledDecoder.
194
- * @template S Schema type
195
- */
196
- export class PooledCodec {
197
- /**
198
- * @param schema Schema describing the object structure.
199
- */
200
- constructor(schema) {
201
- this.schema = schema;
202
- this.encoder = new PooledEncoder(schema);
203
- this.decoder = new PooledDecoder(schema);
204
- }
205
- /**
206
- * Calculate the size in bytes needed to encode the data.
207
- * @param data Object to calculate size for.
208
- * @returns Size in bytes.
209
- */
210
- calculateSize(data) {
211
- let size = 0;
212
- for (const key of Object.keys(this.schema)) {
213
- const field = this.schema[key];
214
- if ("size" in field) {
215
- // Fixed-size primitive field
216
- size += field.size;
217
- }
218
- else if ("calculateSize" in field) {
219
- // Variable-size field (like arrays)
220
- size += field.calculateSize(data[key]);
221
- }
222
- }
223
- return size;
224
- }
225
- /**
226
- * Encode an object directly into a target buffer at the given offset.
227
- * This is a zero-copy operation - no intermediate buffers are allocated.
228
- * @param data Object to encode.
229
- * @param buffer Target buffer to write into.
230
- * @param offset Byte offset in the buffer to start writing.
231
- * @returns Number of bytes written.
232
- */
233
- encodeInto(data, buffer, offset) {
234
- const view = new DataView(buffer.buffer, buffer.byteOffset);
235
- let currentOffset = offset;
236
- for (const key of Object.keys(this.schema)) {
237
- const field = this.schema[key];
238
- if ("write" in field) {
239
- // Primitive field - direct write
240
- field.write(view, currentOffset, data[key]);
241
- currentOffset += field.size;
242
- }
243
- else if ("encodeInto" in field) {
244
- // Array or nested field - delegate to its encodeInto
245
- const bytesWritten = field.encodeInto(data[key], buffer, currentOffset);
246
- currentOffset += bytesWritten;
247
- }
248
- else if ("encode" in field) {
249
- // Fallback for fields that only have encode()
250
- const nested = field.encode(data[key]);
251
- buffer.set(nested, currentOffset);
252
- currentOffset += nested.length;
253
- }
254
- }
255
- return currentOffset - offset; // bytes written
256
- }
257
- /**
258
- * Encode an object into a pooled buffer.
259
- * @param data Object to encode.
260
- * @returns Encoded buffer.
261
- */
262
- encode(data) {
263
- return this.encoder.encode(data);
264
- }
265
- /**
266
- * Decode a buffer into a pooled object.
267
- * @param buf Buffer to decode.
268
- * @returns Decoded object.
269
- */
270
- decode(buf) {
271
- return this.decoder.decode(buf);
272
- }
273
- /**
274
- * Release a decoded object back to the pool.
275
- * @param obj Object to release.
276
- */
277
- release(obj) {
278
- this.decoder.release(obj);
279
- }
280
- /**
281
- * Creates an array field descriptor for use in schemas.
282
- * Encodes array length as u16 followed by each item.
283
- *
284
- * @template U Type of items in the array
285
- * @param itemSchema Schema for individual array items
286
- * @returns An array field descriptor that can be used in PooledCodec schemas
287
- *
288
- * @example
289
- * ```ts
290
- * const PlayerSchema = {
291
- * entityId: BinaryPrimitives.u32,
292
- * x: BinaryPrimitives.f32,
293
- * y: BinaryPrimitives.f32,
294
- * };
295
- *
296
- * const UpdateSchema = {
297
- * tick: BinaryPrimitives.u32,
298
- * players: PooledCodec.array(PlayerSchema),
299
- * };
300
- *
301
- * const codec = new PooledCodec(UpdateSchema);
302
- * ```
303
- */
304
- static array(itemSchema) {
305
- // Calculate item size once
306
- let itemSize = 0;
307
- for (const key of Object.keys(itemSchema)) {
308
- const field = itemSchema[key];
309
- itemSize += field.size || 0;
310
- }
311
- // Pool for encoding buffers (larger initial size to avoid allocations)
312
- const bufferPool = new ObjectPool(() => new Uint8Array(16384));
313
- // Pool for decoded objects to avoid allocations
314
- const objectPool = new ObjectPool(() => {
315
- const obj = {};
316
- for (const key of Object.keys(itemSchema)) {
317
- const field = itemSchema[key];
318
- obj[key] = ("toNil" in field ? field.toNil() : undefined);
319
- }
320
- return obj;
321
- });
322
- // Pool for result arrays to avoid allocations
323
- const arrayPool = new ObjectPool(() => []);
324
- // Reusable DataView for encoding
325
- let encodeView = null;
326
- // Reusable DataView for decoding
327
- let decodeView = null;
328
- return {
329
- __arrayType: undefined,
330
- calculateSize(items) {
331
- return 2 + (items.length * itemSize);
332
- },
333
- encodeInto(items, buffer, offset) {
334
- const view = new DataView(buffer.buffer, buffer.byteOffset);
335
- // Write array length
336
- view.setUint16(offset, items.length, false);
337
- let currentOffset = offset + 2;
338
- // Write each item directly into buffer
339
- for (const item of items) {
340
- for (const key of Object.keys(itemSchema)) {
341
- const field = itemSchema[key];
342
- field.write(view, currentOffset, item[key]);
343
- currentOffset += field.size;
344
- }
345
- }
346
- return currentOffset - offset; // bytes written
347
- },
348
- encode(items) {
349
- const totalSize = 2 + (items.length * itemSize);
350
- let buffer = bufferPool.acquire();
351
- // Grow buffer pool if needed (but keep the undersized buffer for next time)
352
- if (buffer.length < totalSize) {
353
- bufferPool.release(buffer);
354
- buffer = new Uint8Array(Math.max(totalSize, buffer.length * 2));
355
- }
356
- // Create or reuse DataView for this buffer
357
- if (!encodeView || encodeView.buffer !== buffer.buffer) {
358
- encodeView = new DataView(buffer.buffer, buffer.byteOffset);
359
- }
360
- // Write array length
361
- encodeView.setUint16(0, items.length, false);
362
- // Write each item directly into buffer (zero intermediate allocations)
363
- let offset = 2;
364
- for (const item of items) {
365
- for (const key of Object.keys(itemSchema)) {
366
- const field = itemSchema[key];
367
- field.write(encodeView, offset, item[key]);
368
- offset += field.size;
369
- }
370
- }
371
- // Create a copy to return (caller owns this memory)
372
- const result = new Uint8Array(offset);
373
- result.set(buffer.subarray(0, offset));
374
- // Return buffer to pool
375
- bufferPool.release(buffer);
376
- return result;
377
- },
378
- decodeField(buf) {
379
- // Read array length directly from buffer
380
- const length = (buf[0] << 8) | buf[1];
381
- // Acquire pooled array and resize if needed
382
- const items = arrayPool.acquire();
383
- items.length = length;
384
- // Create or reuse DataView for reading
385
- if (!decodeView || decodeView.buffer !== buf.buffer || decodeView.byteOffset !== buf.byteOffset) {
386
- decodeView = new DataView(buf.buffer, buf.byteOffset);
387
- }
388
- // Read each item using pooled objects
389
- let offset = 2;
390
- for (let i = 0; i < length; i++) {
391
- const item = objectPool.acquire();
392
- // Decode directly into pooled object
393
- for (const key of Object.keys(itemSchema)) {
394
- const field = itemSchema[key];
395
- item[key] = field.read(decodeView, offset);
396
- offset += field.size;
397
- }
398
- items[i] = item;
399
- }
400
- return { value: items, bytesRead: offset };
401
- },
402
- decode(buf) {
403
- return this.decodeField(buf).value;
404
- },
405
- toNil() {
406
- return [];
407
- }
408
- };
409
- }
410
- }
@@ -1 +0,0 @@
1
- export * from './prediction';
@@ -1,99 +0,0 @@
1
- /**
2
- * @template T
3
- * @description
4
- * Tracks client-side intents that have been sent to the server but not yet confirmed.
5
- * Used for prediction and reconciliation in a server-authoritative architecture.
6
- */
7
- export class IntentTracker {
8
- constructor() {
9
- this.tracker = new Map();
10
- }
11
- get size() {
12
- return this.tracker.size;
13
- }
14
- /**
15
- * Adds a new intent for a specific tick.
16
- * @param {number} tick - The tick number associated with the intent.
17
- * @param {T} intent - The intent data.
18
- */
19
- track(tick, intent) {
20
- if (!this.tracker.has(tick)) {
21
- this.tracker.set(tick, []);
22
- }
23
- this.tracker.get(tick).push(intent);
24
- return intent;
25
- }
26
- /**
27
- * Removes all intents up to and including a given tick.
28
- * Returns the remaining intents in ascending tick order.
29
- * @param {number} tick - The tick up to which intents should be dropped.
30
- * @returns {T[]} Array of remaining intents.
31
- */
32
- dropUpTo(tick) {
33
- const remaining = [];
34
- for (const [t, intents] of this.tracker) {
35
- if (t <= tick)
36
- this.tracker.delete(t);
37
- else
38
- remaining.push([t, intents]);
39
- }
40
- // sort by tick ascending
41
- remaining.sort(([a], [b]) => a - b);
42
- return remaining.map(([_, intents]) => intents).flat();
43
- }
44
- /**
45
- * Returns all currently tracked intents in ascending tick order.
46
- * @returns {T[]}
47
- */
48
- values() {
49
- return Array.from(this.tracker.entries())
50
- .sort(([a], [b]) => a - b)
51
- .map(([_, intents]) => intents)
52
- .flat();
53
- }
54
- }
55
- /**
56
- * @template T,U
57
- * @description
58
- * Handles client-side reconciliation of authoritative snapshots with unconfirmed intents.
59
- * Used for prediction correction in server-authoritative multiplayer games.
60
- */
61
- export class Reconciliator {
62
- /**
63
- * @param {Object} options - Callbacks for applying snapshot state and replaying intents.
64
- * @param {(snapshotState: U) => void} options.onLoadState - Called to load authoritative snapshot state.
65
- * @param {(remainingIntents: T[]) => void} options.onReplay - Called to reapply remaining intents for prediction.
66
- */
67
- constructor(options) {
68
- this.options = options;
69
- this.tracker = new IntentTracker();
70
- }
71
- /**
72
- * Adds a new intent to the tracker.
73
- * @param {number} tick - Tick number associated with the intent.
74
- * @param {T} intent - The intent data.
75
- */
76
- trackIntent(tick, intent) {
77
- this.tracker.track(tick, intent);
78
- }
79
- /**
80
- * Called when an authoritative snapshot is received from the server.
81
- * Resets client state and replays unconfirmed intents.
82
- * @param {Object} snapshot - The snapshot from the server.
83
- * @param {number} snapshot.tick - Tick number of the snapshot.
84
- * @param {U} snapshot.state - The authoritative state.
85
- */
86
- onSnapshot(snapshot) {
87
- // 1. Load authoritative state
88
- this.options.onLoadState(snapshot.state);
89
- // 2. Remove confirmed intents and get remaining
90
- const remainingIntents = this.tracker.dropUpTo(snapshot.tick);
91
- // 3. Only replay if there are actually remaining intents
92
- if (remainingIntents.length > 0) {
93
- this.options.onReplay(remainingIntents);
94
- }
95
- }
96
- replay(intents) {
97
- this.options.onReplay(intents);
98
- }
99
- }
package/dist/core.esm.js DELETED
@@ -1 +0,0 @@
1
- var J=Object.defineProperty;var Q=(l,e)=>()=>(l&&(e=l(l=0)),e);var ee=(l,e)=>{for(var t in e)J(l,t,{get:e[t],enumerable:!0})};var W={};ee(W,{NavMeshWorkerPool:()=>E});var E,j=Q(()=>{E=class{constructor(e,t,s="grid",r=[]){this.poolSize=e;this.workerPath=t;this.navType=s;this.obstacles=r;this.workers=[];this.nextWorkerIndex=0;this.requestId=0;this.pendingRequests=new Map;this.initialized=!1}async init(){if(this.initialized)return;let e=[];for(let t=0;t<this.poolSize;t++){let s=new Worker(this.workerPath,{type:"module"});s.onmessage=o=>{let n=o.data;if(n.type==="PATH_RESULT"){let i=this.pendingRequests.get(n.id);i&&(i.resolve(n.path),this.pendingRequests.delete(n.id))}else if(n.type==="ERROR")for(let[i,a]of this.pendingRequests.entries())a.reject(new Error(n.error)),this.pendingRequests.delete(i)},s.onerror=o=>{console.error("Worker error:",o);for(let[n,i]of this.pendingRequests.entries())i.reject(new Error("Worker error")),this.pendingRequests.delete(n)},this.workers.push(s);let r=new Promise(o=>{let n=i=>{i.data.type==="READY"&&(s.removeEventListener("message",n),o())};s.addEventListener("message",n)});s.postMessage({type:"INIT",navType:this.navType,obstacles:this.obstacles}),e.push(r)}await Promise.all(e),this.initialized=!0}async findPath(e,t){if(!this.initialized)throw new Error("Worker pool not initialized. Call init() first.");let s=this.requestId++,r=this.workers[this.nextWorkerIndex];return this.nextWorkerIndex=(this.nextWorkerIndex+1)%this.workers.length,new Promise((o,n)=>{this.pendingRequests.set(s,{id:s,from:e,to:t,resolve:o,reject:n}),r.postMessage({type:"FIND_PATH",id:s,from:e,to:t})})}async addObstacle(e){if(!this.initialized)throw new Error("Worker pool not initialized. Call init() first.");let t=this.workers.map(r=>new Promise(o=>{let n=i=>{i.data.type==="OBSTACLE_ADDED"&&(r.removeEventListener("message",n),o(i.data.obstacleId))};r.addEventListener("message",n),r.postMessage({type:"ADD_OBSTACLE",obstacle:e})}));return(await Promise.all(t))[0]}async removeObstacle(e){if(!this.initialized)throw new Error("Worker pool not initialized. Call init() first.");let t=this.workers.map(s=>new Promise(r=>{let o=n=>{n.data.type==="OBSTACLE_REMOVED"&&(s.removeEventListener("message",o),r())};s.addEventListener("message",o),s.postMessage({type:"REMOVE_OBSTACLE",obstacleId:e})}));await Promise.all(t)}async moveObstacle(e,t){if(!this.initialized)throw new Error("Worker pool not initialized. Call init() first.");let s=this.workers.map(r=>new Promise(o=>{let n=i=>{i.data.type==="OBSTACLE_MOVED"&&(r.removeEventListener("message",n),o())};r.addEventListener("message",n),r.postMessage({type:"MOVE_OBSTACLE",obstacleId:e,pos:t})}));await Promise.all(s)}terminate(){for(let e of this.workers)e.terminate();this.workers=[],this.pendingRequests.clear(),this.initialized=!1}get pendingCount(){return this.pendingRequests.size}get size(){return this.workers.length}}});var N=Symbol("schemaSize");function C(l){let e=l[N];if(e!==void 0)return e;let t=0;for(let s of Object.keys(l))t+=l[s].size;return l[N]=t,t}var S=class{static encodeInto(e,t){let s=C(e),r=new ArrayBuffer(s),o=new DataView(r),n=0;for(let i of Object.keys(e)){let a=e[i];a.write(o,n,t[i]),n+=a.size}return new Uint8Array(r)}static decodeInto(e,t,s){let r=C(e);if(t.byteLength<r)throw new RangeError(`Buffer too small: expected ${r} bytes, got ${t.byteLength}`);let o=new DataView(t.buffer,t.byteOffset,t.byteLength),n=0;for(let i of Object.keys(e)){let a=e[i];s[i]=a.read(o,n),n+=a.size}return s}},y=class{static{this.u8={size:1,write:(e,t,s)=>e.setUint8(t,s),read:(e,t)=>e.getUint8(t),toNil:()=>0}}static{this.u16={size:2,write:(e,t,s)=>e.setUint16(t,s,!1),read:(e,t)=>e.getUint16(t,!1),toNil:()=>0}}static{this.u32={size:4,write:(e,t,s)=>e.setUint32(t,s,!1),read:(e,t)=>e.getUint32(t,!1),toNil:()=>0}}static{this.i8={size:1,write:(e,t,s)=>e.setInt8(t,s),read:(e,t)=>e.getInt8(t),toNil:()=>0}}static{this.i16={size:2,write:(e,t,s)=>e.setInt16(t,s,!1),read:(e,t)=>e.getInt16(t,!1),toNil:()=>0}}static{this.i32={size:4,write:(e,t,s)=>e.setInt32(t,s,!1),read:(e,t)=>e.getInt32(t,!1),toNil:()=>0}}static{this.f32={size:4,write:(e,t,s)=>e.setFloat32(t,s,!1),read:(e,t)=>e.getFloat32(t,!1),toNil:()=>0}}static{this.f64={size:8,write:(e,t,s)=>e.setFloat64(t,s,!1),read:(e,t)=>e.getFloat64(t,!1),toNil:()=>0}}static{this.bool={size:1,write:(e,t,s)=>e.setUint8(t,s?1:0),read:(e,t)=>e.getUint8(t)!==0,toNil:()=>!1}}static string(e){return{size:e+2,write(t,s,r){let n=new TextEncoder().encode(r);if(n.length>e)throw new RangeError(`String too long, max ${e} bytes`);t.setUint16(s,n.length,!1);for(let i=0;i<n.length;i++)t.setUint8(s+2+i,n[i]);for(let i=n.length;i<e;i++)t.setUint8(s+2+i,0)},read(t,s){let r=t.getUint16(s,!1),o=new Uint8Array(r);for(let n=0;n<r;n++)o[n]=t.getUint8(s+2+n);return new TextDecoder().decode(o)},toNil:()=>""}}static{this.vec2={size:8,write(e,t,s){e.setFloat32(t,s.x,!1),e.setFloat32(t+4,s.y,!1)},read(e,t){return{x:e.getFloat32(t,!1),y:e.getFloat32(t+4,!1)}},toNil:()=>({x:0,y:0})}}static{this.vec3={size:12,write(e,t,s){e.setFloat32(t,s.x,!1),e.setFloat32(t+4,s.y,!1),e.setFloat32(t+8,s.z,!1)},read(e,t){return{x:e.getFloat32(t,!1),y:e.getFloat32(t+4,!1),z:e.getFloat32(t+8,!1)}},toNil:()=>({x:0,y:0,z:0})}}static{this.color={size:4,write(e,t,s){e.setUint8(t,s.r),e.setUint8(t+1,s.g),e.setUint8(t+2,s.b),e.setUint8(t+3,s.a)},read(e,t){return{r:e.getUint8(t),g:e.getUint8(t+1),b:e.getUint8(t+2),a:e.getUint8(t+3)}},toNil:()=>({r:0,g:0,b:0,a:0})}}static{this.f32_le={size:4,write:(e,t,s)=>e.setFloat32(t,s,!0),read:(e,t)=>e.getFloat32(t,!0),toNil:()=>0}}static{this.f64_le={size:8,write:(e,t,s)=>e.setFloat64(t,s,!0),read:(e,t)=>e.getFloat64(t,!0),toNil:()=>0}}static{this.u16_le={size:2,write:(e,t,s)=>e.setUint16(t,s,!0),read:(e,t)=>e.getUint16(t,!0),toNil:()=>0}}static{this.u32_le={size:4,write:(e,t,s)=>e.setUint32(t,s,!0),read:(e,t)=>e.getUint32(t,!0),toNil:()=>0}}static{this.i16_le={size:2,write:(e,t,s)=>e.setInt16(t,s,!0),read:(e,t)=>e.getInt16(t,!0),toNil:()=>0}}static{this.i32_le={size:4,write:(e,t,s)=>e.setInt32(t,s,!0),read:(e,t)=>e.getInt32(t,!0),toNil:()=>0}}static{this.vec2_le={size:8,write:(e,t,s)=>{e.setFloat32(t,s[0],!0),e.setFloat32(t+4,s[1],!0)},read:(e,t)=>[e.getFloat32(t,!0),e.getFloat32(t+4,!0)],toNil:()=>[0,0]}}static{this.vec3_le={size:12,write:(e,t,s)=>{e.setFloat32(t,s[0],!0),e.setFloat32(t+4,s[1],!0),e.setFloat32(t+8,s[2],!0)},read:(e,t)=>[e.getFloat32(t,!0),e.getFloat32(t+4,!0),e.getFloat32(t+8,!0)],toNil:()=>[0,0,0]}}static{this.vec4_le={size:16,write:(e,t,s)=>{e.setFloat32(t,s[0],!0),e.setFloat32(t+4,s[1],!0),e.setFloat32(t+8,s[2],!0),e.setFloat32(t+12,s[3],!0)},read:(e,t)=>[e.getFloat32(t,!0),e.getFloat32(t+4,!0),e.getFloat32(t+8,!0),e.getFloat32(t+12,!0)],toNil:()=>[0,0,0,0]}}},x=class extends S{static{this.u8=y.u8}static{this.u16=y.u16}static{this.u32=y.u32}static{this.i8=y.i8}static{this.i16=y.i16}static{this.i32=y.i32}static{this.f32=y.f32}static{this.bool=y.bool}static{this.string=y.string}static{this.vec2=y.vec2}static{this.vec3=y.vec3}static{this.color=y.color}static encode(e,t){return this.encodeInto(e,t)}static decode(e,t,s){return this.decodeInto(e,t,s)}};var D=class{constructor({events:e}){this.callbacks=new Map,this.events=e;for(let t of this.events)this.callbacks.set(t,new Set)}on(e,t){let s=this.callbacks.get(e);if(!s)return console.warn(`Event "${e}" does not exist.`);s.add(t)}once(e,t){let s=r=>{t(r),this.off(e,s)};this.on(e,s)}emit(e,t){let s=this.callbacks.get(e);if(!s)return console.warn(`Event "${e}" does not exist.`);for(let r of s)r(t)}off(e,t){let s=this.callbacks.get(e);if(!s)return console.warn(`Event "${e}" does not exist.`);s.delete(t)}clear(e){if(!e){this.callbacks.clear();for(let s of this.events)this.callbacks.set(s,new Set);return}let t=this.callbacks.get(e);if(!t)return console.warn(`Event "${e}" does not exist.`);t.clear()}};var _=class{constructor({rate:e,onTick:t}){this.accumulator=0;this._tickCount=0;this.rate=e,this.intervalMs=1e3/this.rate,this.onTick=t,this.maxTicksPerFrame=Math.max(1,Math.floor(e/2))}getTicks(e){this.accumulator+=e*1e3;let t=0;for(;this.accumulator>=this.intervalMs&&t<this.maxTicksPerFrame;)this.accumulator-=this.intervalMs,t++;let s=Math.floor(this.accumulator/this.intervalMs);return s>0&&this.onTickSkipped&&this.onTickSkipped(s),t}tick(e){let t=this.getTicks(e);for(let s=0;s<t;s++)this.onTick(1/this.rate,this._tickCount++)}get tickCount(){return this._tickCount}resetTickCount(){this._tickCount=0}get accumulatedTime(){return this.accumulator/1e3}get alpha(){return Math.min(this.accumulatedTime/(1/this.rate),1)}};function me(l={}){let{prefix:e="",size:t=16}=l,s=Math.max(t-e.length,8),r=Math.ceil(s/8),n=crypto.getRandomValues(new Uint32Array(r)).reduce((i,a)=>i+a.toString(16).padStart(8,"0"),"");return n=n.slice(0,s).padStart(s,"0"),`${e}${n}`}function xe(l,e,t){return l+(e-l)*t}var v=class{constructor(e){this.update=e;this.last=performance.now();this.running=!1;this.loop=()=>{if(!this.running)return;let e=performance.now(),t=(e-this.last)/1e3;this.last=e,this.update(t),setImmediate(this.loop)}}start(){this.running=!0,this.last=performance.now(),this.loop()}stop(){this.running=!1}};var w=class{constructor(e){this.update=e;this.last=performance.now();this.running=!1;this.rafId=null;this.loop=()=>{if(!this.running)return;let e=performance.now(),t=(e-this.last)/1e3;this.last=e,this.update(t),requestAnimationFrame(this.loop)}}start(){this.running=!0,this.last=performance.now(),this.rafId=requestAnimationFrame(this.loop)}stop(){this.running=!1,this.rafId!==null&&(cancelAnimationFrame(this.rafId),this.rafId=null)}};var te=1,T=class{constructor(e){this.update=e;this.last=performance.now();this.running=!1;this.loop=()=>{if(!this.running)return;let e=performance.now(),t=(e-this.last)/1e3;this.last=e,this.update(t),setTimeout(this.loop,te)}}start(){this.running=!0,this.last=performance.now(),this.loop()}stop(){this.running=!1}};function Ue(l,e){return l==="server-immediate"?new v(e):l==="server-timeout"?new T(e):new w(e)}var se=[{x:1,y:0},{x:-1,y:0},{x:0,y:1},{x:0,y:-1}],z=l=>({x:Math.floor(l.x),y:Math.floor(l.y)}),L=l=>({x:l.x+.5,y:l.y+.5}),re=(()=>{let l=1;return()=>l++})(),b=(l,e)=>l&65535|(e&65535)<<16,M=l=>({x:l<<16>>16,y:l>>16}),F=class{constructor(e){this.scoreFn=e;this.heap=[]}push(e){this.heap.push(e),this.bubbleUp(this.heap.length-1)}pop(){let e=this.heap[0],t=this.heap.pop();return this.heap.length>0&&t!==void 0&&(this.heap[0]=t,this.sinkDown(0)),e}get size(){return this.heap.length}bubbleUp(e){let t=this.heap[e],s=this.scoreFn(t);for(;e>0;){let r=(e+1>>1)-1,o=this.heap[r];if(s>=this.scoreFn(o))break;this.heap[r]=t,this.heap[e]=o,e=r}}sinkDown(e){let t=this.heap.length,s=this.heap[e],r=this.scoreFn(s);for(;;){let o=e+1<<1,n=o-1,i=null,a;if(n<t){let c=this.heap[n];a=this.scoreFn(c),a<r&&(i=n)}if(o<t){let c=this.heap[o];this.scoreFn(c)<(i===null?r:a)&&(i=o)}if(i===null)break;this.heap[e]=this.heap[i],this.heap[i]=s,e=i}}},P=class{constructor(e=1){this.grid=new Map;this.obstacleCells=new Map;this.cellSize=e}hash(e,t){let s=Math.floor(e/this.cellSize),r=Math.floor(t/this.cellSize);return b(s,r)}add(e,t){let s=this.getCellsForObstacle(t);for(let r of s)this.grid.has(r)||this.grid.set(r,new Set),this.grid.get(r).add(e);this.obstacleCells.set(e,s)}remove(e){let t=this.obstacleCells.get(e);if(t){for(let s of t){let r=this.grid.get(s);r&&(r.delete(e),r.size===0&&this.grid.delete(s))}this.obstacleCells.delete(e)}}query(e){let t=this.hash(e.x,e.y);return this.grid.get(t)||new Set}clear(){this.grid.clear(),this.obstacleCells.clear()}getCellsForObstacle(e){let t=new Set;if(e.type==="circle"){let s=e.radius,r=Math.floor((e.pos.x-s)/this.cellSize),o=Math.floor((e.pos.x+s)/this.cellSize),n=Math.floor((e.pos.y-s)/this.cellSize),i=Math.floor((e.pos.y+s)/this.cellSize);for(let a=r;a<=o;a++)for(let c=n;c<=i;c++)t.add(b(a,c))}else if(e.type==="rect"){let s=e.pos.x+e.size.x/2,r=e.pos.y+e.size.y/2,o=e.size.x/2,n=e.size.y/2,i=Math.sqrt(o*o+n*n),a=Math.floor((s-i)/this.cellSize),c=Math.floor((s+i)/this.cellSize),u=Math.floor((r-i)/this.cellSize),d=Math.floor((r+i)/this.cellSize);for(let h=a;h<=c;h++)for(let f=u;f<=d;f++)t.add(b(h,f))}else if(e.type==="polygon"){let s=B(e),r=Math.floor(s.minX/this.cellSize),o=Math.floor(s.maxX/this.cellSize),n=Math.floor(s.minY/this.cellSize),i=Math.floor(s.maxY/this.cellSize);for(let a=r;a<=o;a++)for(let c=n;c<=i;c++)t.add(b(a,c))}return t}};function Y(l,e){let t=l.x-e.pos.x,s=l.y-e.pos.y;return t*t+s*s<=e.radius*e.radius}function X(l,e){let t=e.pos.x+e.size.x/2,s=e.pos.y+e.size.y/2;if(e.rotation){let r=Math.cos(-e.rotation),o=Math.sin(-e.rotation),n=l.x-t,i=l.y-s,a=n*r-i*o,c=n*o+i*r;return Math.abs(a)<=e.size.x/2&&Math.abs(c)<=e.size.y/2}return l.x>=e.pos.x&&l.y>=e.pos.y&&l.x<=e.pos.x+e.size.x&&l.y<=e.pos.y+e.size.y}function K(l,e){let t=!1,s=e.points,r=e.rotation?Math.cos(e.rotation):1,o=e.rotation?Math.sin(e.rotation):0;for(let n=0,i=s.length-1;n<s.length;i=n++){let a=s[n].x,c=s[n].y,u=s[i].x,d=s[i].y;if(e.rotation){let f=a*r-c*o,m=a*o+c*r,p=u*r-d*o,k=u*o+d*r;a=f,c=m,u=p,d=k}a+=e.pos.x,c+=e.pos.y,u+=e.pos.x,d+=e.pos.y,c>l.y!=d>l.y&&l.x<(u-a)*(l.y-c)/(d-c)+a&&(t=!t)}return t}function B(l){let e=1/0,t=1/0,s=-1/0,r=-1/0,o=l.rotation?Math.cos(l.rotation):1,n=l.rotation?Math.sin(l.rotation):0;for(let i of l.points){let a=i.x,c=i.y;if(l.rotation){let u=a*o-c*n,d=a*n+c*o;a=u,c=d}a+=l.pos.x,c+=l.pos.y,e=Math.min(e,a),t=Math.min(t,c),s=Math.max(s,a),r=Math.max(r,c)}return{minX:e,minY:t,maxX:s,maxY:r}}var U=class{constructor(){this.items=new Map;this.spatial=new P(1);this._cachedItems=[];this.dirty=!0;this.version=0}add(e){let t=re(),s={...e,id:t};return this.items.set(t,s),this.spatial.add(t,s),this.dirty=!0,this.version++,t}move(e,t){let s=this.items.get(e);if(!s)return;this.spatial.remove(e);let r={...s,pos:{...t}};this.items.set(e,r),this.spatial.add(e,r),this.dirty=!0,this.version++}remove(e){this.spatial.remove(e),this.items.delete(e),this.dirty=!0,this.version++}at(e){let t=this.spatial.query(e);for(let s of t){let r=this.items.get(s);if(!(!r||r.solid===!1)&&(r.type==="circle"&&Y(e,r)||r.type==="rect"&&X(e,r)||r.type==="polygon"&&K(e,r)))return r}}get values(){return this.dirty?(this._cachedItems=[...this.items.values()],this.dirty=!1,this._cachedItems):this._cachedItems}},I=class{constructor(e){this.obstacles=e;this.blocked=new Set}rebuild(){this.blocked.clear();for(let e of this.obstacles.values)if(e.solid!==!1){if(e.type==="circle"){let t=Math.ceil(e.radius),s=Math.floor(e.pos.x),r=Math.floor(e.pos.y);for(let o=-t;o<=t;o++)for(let n=-t;n<=t;n++){let i=s+o,a=r+n,c={x:i+.5,y:a+.5};Y(c,e)&&this.blocked.add(b(i,a))}}else if(e.type==="rect"){let t=e.pos.x+e.size.x/2,s=e.pos.y+e.size.y/2,r=e.size.x/2,o=e.size.y/2,n=Math.sqrt(r*r+o*o),i=Math.floor(t-n),a=Math.ceil(t+n),c=Math.floor(s-n),u=Math.ceil(s+n);for(let d=i;d<=a;d++)for(let h=c;h<=u;h++){let f={x:d+.5,y:h+.5};X(f,e)&&this.blocked.add(b(d,h))}}else if(e.type==="polygon"){let t=B(e),s=Math.floor(t.minX),r=Math.ceil(t.maxX),o=Math.floor(t.minY),n=Math.ceil(t.maxY);for(let i=s;i<=r;i++)for(let a=o;a<=n;a++){let c={x:i+.5,y:a+.5};K(c,e)&&this.blocked.add(b(i,a))}}}}findPath(e,t){return $(z(e),z(t),(s,r)=>!this.blocked.has(b(s,r))).map(L)}},V=class{constructor(e){this.obstacles=e}rebuild(){}findPath(e,t){let s=Math.ceil(Math.hypot(t.x-e.x,t.y-e.y)*2),r=!1;for(let n=1;n<=s;n++){let i=n/s,a={x:e.x+(t.x-e.x)*i,y:e.y+(t.y-e.y)*i};if(this.obstacles.at(a)){r=!0;break}}return r?$(z(e),z(t),(n,i)=>{let a={x:n+.5,y:i+.5};return!this.obstacles.at(a)}).map(L):[e,t]}},q=class{constructor(e,t){this.type=e;this.lastVersion=-1;this.pendingPaths=0;this.AUTO_WORKER_THRESHOLD=20;this.obstacles=new U,this.options={workers:t?.workers??!1,workerPoolSize:t?.workerPoolSize??4,workerPath:t?.workerPath??"./navmesh.worker.js"},e==="grid"&&(this.grid=new I(this.obstacles)),e==="graph"&&(this.graph=new V(this.obstacles)),this.options.workers===!0&&this.initWorkerPool()}async initWorkerPool(){if(!this.workerPool)try{let{NavMeshWorkerPool:e}=await Promise.resolve().then(()=>(j(),W));this.workerPool=new e(this.options.workerPoolSize,this.options.workerPath,this.type,this.obstacles.values),await this.workerPool.init()}catch(e){console.warn("Failed to initialize worker pool, falling back to sync:",e),this.options.workers=!1}}shouldUseWorkers(){return this.options.workers===!1?!1:this.options.workers===!0?!0:this.pendingPaths>=this.AUTO_WORKER_THRESHOLD}addObstacle(e){return this.obstacles.add(e)}moveObstacle(e,t){this.obstacles.move(e,t)}removeObstacle(e){this.obstacles.remove(e)}getObstacles(){return this.obstacles.values}findPath({from:e,to:t}){return this.shouldUseWorkers()&&this.workerPool?(this.pendingPaths++,this.findPathAsync(e,t).finally(()=>{this.pendingPaths--})):(this.rebuild(),this.type==="grid"?this.grid.findPath(e,t):this.graph.findPath(e,t))}async findPathAsync(e,t){return this.options.workers==="auto"&&!this.workerPool&&await this.initWorkerPool(),this.workerPool?this.workerPool.findPath(e,t):(this.rebuild(),this.type==="grid"?this.grid.findPath(e,t):this.graph.findPath(e,t))}rebuild(){this.lastVersion!==this.obstacles.version&&(this.grid?.rebuild(),this.graph?.rebuild(),this.lastVersion=this.obstacles.version)}dispose(){this.workerPool&&(this.workerPool.terminate(),this.workerPool=void 0)}getWorkerStatus(){return{workersEnabled:this.options.workers,workerPoolActive:!!this.workerPool,pendingPaths:this.pendingPaths,usingWorkersNow:this.shouldUseWorkers()}}};function $(l,e,t){let s=new Map,r=new Map,o=new Set,n=new Set,i=d=>b(d.x,d.y),a=(d,h)=>Math.abs(d.x-h.x)+Math.abs(d.y-h.y),c=new F(d=>{let h=M(d);return r.get(d)+a(h,e)}),u=i(l);for(r.set(u,0),c.push(u),n.add(u);c.size>0;){let d=c.pop();n.delete(d);let h=M(d);if(h.x===e.x&&h.y===e.y)return ne(s,h);o.add(d);for(let f of se){let m={x:h.x+f.x,y:h.y+f.y};if(!t(m.x,m.y))continue;let p=i(m);if(o.has(p))continue;let k=r.get(d)+1;k<(r.get(p)??1/0)&&(r.set(p,k),s.set(p,d),n.has(p)||(c.push(p),n.add(p)))}}return[]}function ne(l,e){let t=[e],s=b(e.x,e.y);for(;l.has(s);)s=l.get(s),t.push(M(s));return t.reverse()}var g=class{constructor(e){this.factory=e;this.pool=[]}acquire(){return this.pool.pop()??this.factory()}release(e){this.pool.push(e)}releaseAll(e){this.pool.push(...e)}},O=class{constructor(e){this.schema=e;this.pool=new g(()=>this.createNil())}createNil(){let e={};for(let t of Object.keys(this.schema)){let s=this.schema[t];e[t]="toNil"in s?s.toNil():void 0}return e}decode(e){let t=this.pool.acquire();return this.decodeInto(e,t),t}decodeInto(e,t){let s=0;for(let r of Object.keys(this.schema)){let o=this.schema[r];if("decodeAll"in o){let n=o.decodeAll(e.subarray(s));t[r]=n.value,s+=n.bytesRead}else if("decodeField"in o){let n=o.decodeField(e.subarray(s));t[r]=n.value,s+=n.bytesRead}else if("decode"in o){let n=o.decode(e.subarray(s));t[r]=n.value,s+=n.bytesRead}else{let n=o.size||0,i=e.subarray(s,s+n);x.decodeInto({[r]:o},i,t),s+=n}}}release(e){this.pool.release(e)}},H=class{constructor(e){this.pooledDecoder=new O(e)}decodeAll(e){return e.map(t=>this.pooledDecoder.decode(t))}releaseAll(e){e.forEach(t=>this.pooledDecoder.release(t))}},A=class{constructor(e,t=1024){this.schema=e;this.bufferSize=t;this.pool=new g(()=>new Uint8Array(t))}encode(e){let t=this.pool.acquire(),s=0;for(let r of Object.keys(this.schema)){let o=this.schema[r];if("encode"in o){let n=o.encode(e[r]);t.set(n,s),s+=n.length}else if("encodeAll"in o){let n=o.encodeAll(e[r]),i=0;for(let a of n)t.set(a,s+i),i+=a.length;s+=i}else{let n=x.encode({[r]:o},{[r]:e[r]});t.set(n,s),s+=n.length}}return t.subarray(0,s)}release(e){this.pool.release(e)}},G=class{constructor(e){this.schema=e;this.encoder=new A(e),this.decoder=new O(e)}calculateSize(e){let t=0;for(let s of Object.keys(this.schema)){let r=this.schema[s];"size"in r?t+=r.size:"calculateSize"in r&&(t+=r.calculateSize(e[s]))}return t}encodeInto(e,t,s){let r=new DataView(t.buffer,t.byteOffset),o=s;for(let n of Object.keys(this.schema)){let i=this.schema[n];if("write"in i)i.write(r,o,e[n]),o+=i.size;else if("encodeInto"in i){let a=i.encodeInto(e[n],t,o);o+=a}else if("encode"in i){let a=i.encode(e[n]);t.set(a,o),o+=a.length}}return o-s}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}release(e){this.decoder.release(e)}static array(e){let t=0;for(let a of Object.keys(e)){let c=e[a];t+=c.size||0}let s=new g(()=>new Uint8Array(16384)),r=new g(()=>{let a={};for(let c of Object.keys(e)){let u=e[c];a[c]="toNil"in u?u.toNil():void 0}return a}),o=new g(()=>[]),n=null,i=null;return{__arrayType:void 0,calculateSize(a){return 2+a.length*t},encodeInto(a,c,u){let d=new DataView(c.buffer,c.byteOffset);d.setUint16(u,a.length,!1);let h=u+2;for(let f of a)for(let m of Object.keys(e)){let p=e[m];p.write(d,h,f[m]),h+=p.size}return h-u},encode(a){let c=2+a.length*t,u=s.acquire();u.length<c&&(s.release(u),u=new Uint8Array(Math.max(c,u.length*2))),(!n||n.buffer!==u.buffer)&&(n=new DataView(u.buffer,u.byteOffset)),n.setUint16(0,a.length,!1);let d=2;for(let f of a)for(let m of Object.keys(e)){let p=e[m];p.write(n,d,f[m]),d+=p.size}let h=new Uint8Array(d);return h.set(u.subarray(0,d)),s.release(u),h},decodeField(a){let c=a[0]<<8|a[1],u=o.acquire();u.length=c,(!i||i.buffer!==a.buffer||i.byteOffset!==a.byteOffset)&&(i=new DataView(a.buffer,a.byteOffset));let d=2;for(let h=0;h<c;h++){let f=r.acquire();for(let m of Object.keys(e)){let p=e[m];f[m]=p.read(i,d),d+=p.size}u[h]=f}return{value:u,bytesRead:d}},decode(a){return this.decodeField(a).value},toNil(){return[]}}}};var R=class{constructor(){this.tracker=new Map}get size(){return this.tracker.size}track(e,t){return this.tracker.has(e)||this.tracker.set(e,[]),this.tracker.get(e).push(t),t}dropUpTo(e){let t=[];for(let[s,r]of this.tracker)s<=e?this.tracker.delete(s):t.push([s,r]);return t.sort(([s],[r])=>s-r),t.map(([s,r])=>r).flat()}values(){return Array.from(this.tracker.entries()).sort(([e],[t])=>e-t).map(([e,t])=>t).flat()}},Z=class{constructor(e){this.options=e;this.tracker=new R}trackIntent(e,t){this.tracker.track(e,t)}onSnapshot(e){this.options.onLoadState(e.state);let t=this.tracker.dropUpTo(e.tick);t.length>0&&this.options.onReplay(t)}replay(e){this.options.onReplay(e)}};export{S as BaseBinaryCodec,x as BinaryCodec,y as BinaryPrimitives,D as EventSystem,_ as FixedTicker,v as ImmediateDriver,R as IntentTracker,q as NavMesh,g as ObjectPool,H as PooledArrayDecoder,G as PooledCodec,O as PooledDecoder,A as PooledEncoder,w as RafDriver,Z as Reconciliator,T as TimeoutDriver,Ue as createDriver,me as generateId,xe as lerp};