@dcl/ecs 7.21.1-22917715332.commit-e5d969d → 7.21.1-22918726402.commit-ee210ee

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 (256) hide show
  1. package/dist/components/extended/MeshCollider.d.ts +0 -8
  2. package/dist/components/extended/MeshCollider.js +0 -6
  3. package/dist/components/extended/MeshRenderer.d.ts +0 -8
  4. package/dist/components/extended/MeshRenderer.js +0 -5
  5. package/dist/components/extended/Tween.d.ts +48 -1
  6. package/dist/components/extended/Tween.js +66 -0
  7. package/dist/components/generated/PhysicsCombinedForce.gen.js +25 -0
  8. package/dist/components/generated/PhysicsCombinedImpulse.gen.js +25 -0
  9. package/dist/components/generated/component-names.gen.js +2 -11
  10. package/dist/components/generated/global.gen.d.ts +4 -22
  11. package/dist/components/generated/global.gen.js +2 -11
  12. package/dist/components/generated/index.gen.d.ts +8 -44
  13. package/dist/components/generated/index.gen.js +10 -55
  14. package/dist/components/generated/pb/decentraland/common/texture.gen.d.ts +0 -20
  15. package/dist/components/generated/pb/decentraland/common/texture.gen.js +0 -65
  16. package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +0 -2
  17. package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +1 -10
  18. package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +0 -43
  19. package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +1 -151
  20. package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -2
  21. package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -10
  22. package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +1 -37
  23. package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +1 -119
  24. package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -6
  25. package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -4
  26. package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +0 -19
  27. package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +1 -46
  28. package/dist/components/generated/pb/decentraland/sdk/components/input_modifier.gen.d.ts +2 -0
  29. package/dist/components/generated/pb/decentraland/sdk/components/input_modifier.gen.js +20 -0
  30. package/dist/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +0 -22
  31. package/dist/components/generated/pb/decentraland/sdk/components/material.gen.js +1 -57
  32. package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +0 -20
  33. package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +0 -56
  34. package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +3 -21
  35. package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +0 -56
  36. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.d.ts +25 -0
  37. package/dist/components/generated/pb/decentraland/sdk/components/{ui_scroll_result.gen.js → physics_combined_force.gen.js} +12 -12
  38. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.d.ts +28 -0
  39. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.js +51 -0
  40. package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +2 -8
  41. package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +0 -3
  42. package/dist/components/generated/pb/decentraland/sdk/components/raycast.gen.d.ts +0 -13
  43. package/dist/components/generated/pb/decentraland/sdk/components/raycast.gen.js +0 -30
  44. package/dist/components/generated/pb/decentraland/sdk/components/tween.gen.d.ts +21 -0
  45. package/dist/components/generated/pb/decentraland/sdk/components/tween.gen.js +99 -0
  46. package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +0 -4
  47. package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +0 -20
  48. package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +0 -35
  49. package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +0 -90
  50. package/dist/components/index.d.ts +12 -11
  51. package/dist/components/index.js +10 -13
  52. package/dist/components/manual/CreatedBy.d.ts +9 -0
  53. package/dist/components/manual/CreatedBy.js +8 -0
  54. package/dist/components/manual/Transform.d.ts +9 -0
  55. package/dist/components/manual/Transform.js +3 -3
  56. package/dist/components/types.d.ts +2 -3
  57. package/dist/engine/component.d.ts +52 -1
  58. package/dist/engine/entity.js +4 -2
  59. package/dist/engine/grow-only-value-set-component-definition.js +46 -3
  60. package/dist/engine/input.d.ts +0 -6
  61. package/dist/engine/input.js +4 -9
  62. package/dist/engine/lww-element-set-component-definition.d.ts +3 -1
  63. package/dist/engine/lww-element-set-component-definition.js +64 -12
  64. package/dist/index.d.ts +3 -2
  65. package/dist/index.js +2 -1
  66. package/dist/runtime/globals.d.ts +1 -2
  67. package/dist/runtime/globals.js +1 -2
  68. package/dist/serialization/crdt/authoritativePutComponent.d.ts +15 -0
  69. package/dist/serialization/crdt/authoritativePutComponent.js +47 -0
  70. package/dist/serialization/crdt/index.d.ts +1 -0
  71. package/dist/serialization/crdt/index.js +1 -0
  72. package/dist/serialization/crdt/types.d.ts +25 -3
  73. package/dist/serialization/crdt/types.js +3 -1
  74. package/dist/systems/crdt/index.d.ts +0 -1
  75. package/dist/systems/crdt/index.js +55 -146
  76. package/dist/systems/events.d.ts +1 -100
  77. package/dist/systems/events.js +65 -143
  78. package/dist/systems/raycast.d.ts +1 -3
  79. package/dist/systems/raycast.js +0 -2
  80. package/dist-cjs/components/extended/MeshCollider.d.ts +0 -8
  81. package/dist-cjs/components/extended/MeshCollider.js +0 -6
  82. package/dist-cjs/components/extended/MeshRenderer.d.ts +0 -8
  83. package/dist-cjs/components/extended/MeshRenderer.js +0 -5
  84. package/dist-cjs/components/extended/Tween.d.ts +48 -1
  85. package/dist-cjs/components/extended/Tween.js +66 -0
  86. package/dist-cjs/components/generated/PhysicsCombinedForce.gen.js +28 -0
  87. package/dist-cjs/components/generated/PhysicsCombinedImpulse.gen.js +28 -0
  88. package/dist-cjs/components/generated/component-names.gen.js +2 -11
  89. package/dist-cjs/components/generated/global.gen.d.ts +4 -22
  90. package/dist-cjs/components/generated/global.gen.js +3 -13
  91. package/dist-cjs/components/generated/index.gen.d.ts +8 -44
  92. package/dist-cjs/components/generated/index.gen.js +14 -68
  93. package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.d.ts +0 -20
  94. package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.js +1 -66
  95. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +0 -2
  96. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +1 -10
  97. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +0 -43
  98. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +2 -152
  99. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -2
  100. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -10
  101. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +1 -37
  102. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +2 -120
  103. package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -6
  104. package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -4
  105. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +0 -19
  106. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +1 -46
  107. package/dist-cjs/components/generated/pb/decentraland/sdk/components/input_modifier.gen.d.ts +2 -0
  108. package/dist-cjs/components/generated/pb/decentraland/sdk/components/input_modifier.gen.js +20 -0
  109. package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +0 -22
  110. package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.js +2 -58
  111. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +0 -20
  112. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +1 -57
  113. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +3 -21
  114. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +1 -57
  115. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.d.ts +25 -0
  116. package/dist-cjs/components/generated/pb/decentraland/sdk/components/{ui_scroll_result.gen.js → physics_combined_force.gen.js} +12 -12
  117. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.d.ts +28 -0
  118. package/dist-cjs/components/generated/pb/decentraland/sdk/components/{ui_canvas.gen.js → physics_combined_impulse.gen.js} +17 -26
  119. package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +2 -8
  120. package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +0 -3
  121. package/dist-cjs/components/generated/pb/decentraland/sdk/components/raycast.gen.d.ts +0 -13
  122. package/dist-cjs/components/generated/pb/decentraland/sdk/components/raycast.gen.js +1 -31
  123. package/dist-cjs/components/generated/pb/decentraland/sdk/components/tween.gen.d.ts +21 -0
  124. package/dist-cjs/components/generated/pb/decentraland/sdk/components/tween.gen.js +100 -1
  125. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +0 -4
  126. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +0 -20
  127. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +0 -35
  128. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +1 -91
  129. package/dist-cjs/components/index.d.ts +12 -11
  130. package/dist-cjs/components/index.js +13 -17
  131. package/dist-cjs/components/manual/CreatedBy.d.ts +9 -0
  132. package/dist-cjs/components/manual/CreatedBy.js +10 -0
  133. package/dist-cjs/components/manual/Transform.d.ts +9 -0
  134. package/dist-cjs/components/manual/Transform.js +3 -3
  135. package/dist-cjs/components/types.d.ts +2 -3
  136. package/dist-cjs/engine/component.d.ts +52 -1
  137. package/dist-cjs/engine/entity.js +4 -2
  138. package/dist-cjs/engine/grow-only-value-set-component-definition.js +45 -2
  139. package/dist-cjs/engine/input.d.ts +0 -6
  140. package/dist-cjs/engine/input.js +4 -9
  141. package/dist-cjs/engine/lww-element-set-component-definition.d.ts +3 -1
  142. package/dist-cjs/engine/lww-element-set-component-definition.js +67 -13
  143. package/dist-cjs/index.d.ts +3 -2
  144. package/dist-cjs/index.js +3 -2
  145. package/dist-cjs/runtime/globals.d.ts +1 -2
  146. package/dist-cjs/runtime/globals.js +1 -2
  147. package/dist-cjs/serialization/crdt/authoritativePutComponent.d.ts +15 -0
  148. package/dist-cjs/serialization/crdt/authoritativePutComponent.js +50 -0
  149. package/dist-cjs/serialization/crdt/index.d.ts +1 -0
  150. package/dist-cjs/serialization/crdt/index.js +1 -0
  151. package/dist-cjs/serialization/crdt/types.d.ts +25 -3
  152. package/dist-cjs/serialization/crdt/types.js +3 -1
  153. package/dist-cjs/systems/crdt/index.d.ts +0 -1
  154. package/dist-cjs/systems/crdt/index.js +55 -169
  155. package/dist-cjs/systems/events.d.ts +1 -100
  156. package/dist-cjs/systems/events.js +65 -143
  157. package/dist-cjs/systems/raycast.d.ts +1 -3
  158. package/dist-cjs/systems/raycast.js +0 -2
  159. package/package.json +2 -2
  160. package/dist/components/extended/AvatarEquippedData.d.ts +0 -10
  161. package/dist/components/extended/AvatarEquippedData.js +0 -15
  162. package/dist/components/extended/AvatarShape.d.ts +0 -10
  163. package/dist/components/extended/AvatarShape.js +0 -15
  164. package/dist/components/generated/AvatarLocomotionSettings.gen.d.ts +0 -1
  165. package/dist/components/generated/AvatarLocomotionSettings.gen.js +0 -25
  166. package/dist/components/generated/AvatarMovement.gen.d.ts +0 -1
  167. package/dist/components/generated/AvatarMovement.gen.js +0 -25
  168. package/dist/components/generated/AvatarMovementInfo.gen.d.ts +0 -1
  169. package/dist/components/generated/AvatarMovementInfo.gen.js +0 -25
  170. package/dist/components/generated/CameraLayer.gen.d.ts +0 -1
  171. package/dist/components/generated/CameraLayer.gen.js +0 -25
  172. package/dist/components/generated/CameraLayers.gen.d.ts +0 -1
  173. package/dist/components/generated/CameraLayers.gen.js +0 -25
  174. package/dist/components/generated/GlobalLight.gen.d.ts +0 -1
  175. package/dist/components/generated/GlobalLight.gen.js +0 -25
  176. package/dist/components/generated/GltfNode.gen.d.ts +0 -1
  177. package/dist/components/generated/GltfNode.gen.js +0 -25
  178. package/dist/components/generated/GltfNodeState.gen.d.ts +0 -1
  179. package/dist/components/generated/GltfNodeState.gen.js +0 -25
  180. package/dist/components/generated/TextureCamera.gen.d.ts +0 -1
  181. package/dist/components/generated/TextureCamera.gen.js +0 -25
  182. package/dist/components/generated/UiCanvas.gen.d.ts +0 -1
  183. package/dist/components/generated/UiCanvas.gen.js +0 -25
  184. package/dist/components/generated/UiScrollResult.gen.d.ts +0 -1
  185. package/dist/components/generated/UiScrollResult.gen.js +0 -25
  186. package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -29
  187. package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -93
  188. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.d.ts +0 -20
  189. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.js +0 -69
  190. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.d.ts +0 -32
  191. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.js +0 -126
  192. package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +0 -30
  193. package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +0 -104
  194. package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +0 -14
  195. package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +0 -50
  196. package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +0 -34
  197. package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.js +0 -61
  198. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +0 -50
  199. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +0 -41
  200. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +0 -27
  201. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +0 -59
  202. package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +0 -74
  203. package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +0 -191
  204. package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +0 -19
  205. package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.js +0 -60
  206. package/dist/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +0 -15
  207. package/dist/serialization/crdt/network/utils.d.ts +0 -9
  208. package/dist/serialization/crdt/network/utils.js +0 -60
  209. package/dist-cjs/components/extended/AvatarEquippedData.d.ts +0 -10
  210. package/dist-cjs/components/extended/AvatarEquippedData.js +0 -19
  211. package/dist-cjs/components/extended/AvatarShape.d.ts +0 -10
  212. package/dist-cjs/components/extended/AvatarShape.js +0 -19
  213. package/dist-cjs/components/generated/AvatarLocomotionSettings.gen.js +0 -28
  214. package/dist-cjs/components/generated/AvatarMovement.gen.js +0 -28
  215. package/dist-cjs/components/generated/AvatarMovementInfo.gen.js +0 -28
  216. package/dist-cjs/components/generated/CameraLayer.gen.js +0 -28
  217. package/dist-cjs/components/generated/CameraLayers.gen.d.ts +0 -1
  218. package/dist-cjs/components/generated/CameraLayers.gen.js +0 -28
  219. package/dist-cjs/components/generated/GlobalLight.gen.d.ts +0 -1
  220. package/dist-cjs/components/generated/GlobalLight.gen.js +0 -28
  221. package/dist-cjs/components/generated/GltfNode.gen.d.ts +0 -1
  222. package/dist-cjs/components/generated/GltfNode.gen.js +0 -28
  223. package/dist-cjs/components/generated/GltfNodeState.gen.d.ts +0 -1
  224. package/dist-cjs/components/generated/GltfNodeState.gen.js +0 -28
  225. package/dist-cjs/components/generated/TextureCamera.gen.d.ts +0 -1
  226. package/dist-cjs/components/generated/TextureCamera.gen.js +0 -28
  227. package/dist-cjs/components/generated/UiCanvas.gen.d.ts +0 -1
  228. package/dist-cjs/components/generated/UiCanvas.gen.js +0 -28
  229. package/dist-cjs/components/generated/UiScrollResult.gen.d.ts +0 -1
  230. package/dist-cjs/components/generated/UiScrollResult.gen.js +0 -28
  231. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -29
  232. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -99
  233. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.d.ts +0 -20
  234. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.js +0 -75
  235. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.d.ts +0 -32
  236. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.js +0 -132
  237. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +0 -30
  238. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +0 -110
  239. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +0 -14
  240. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +0 -56
  241. package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +0 -34
  242. package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.js +0 -67
  243. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +0 -50
  244. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +0 -47
  245. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +0 -27
  246. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +0 -65
  247. package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +0 -74
  248. package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +0 -197
  249. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +0 -19
  250. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +0 -15
  251. package/dist-cjs/serialization/crdt/network/utils.d.ts +0 -9
  252. package/dist-cjs/serialization/crdt/network/utils.js +0 -67
  253. /package/{dist-cjs/components/generated/AvatarMovementInfo.gen.d.ts → dist/components/generated/PhysicsCombinedForce.gen.d.ts} +0 -0
  254. /package/{dist-cjs/components/generated/CameraLayer.gen.d.ts → dist/components/generated/PhysicsCombinedImpulse.gen.d.ts} +0 -0
  255. /package/dist-cjs/components/generated/{AvatarLocomotionSettings.gen.d.ts → PhysicsCombinedForce.gen.d.ts} +0 -0
  256. /package/dist-cjs/components/generated/{AvatarMovement.gen.d.ts → PhysicsCombinedImpulse.gen.d.ts} +0 -0
@@ -1,7 +1,8 @@
1
1
  import { ReadWriteByteBuffer } from '../serialization/ByteBuffer';
2
- import { AppendValueOperation, CrdtMessageType } from '../serialization/crdt';
2
+ import { AppendValueOperation, CrdtMessageType, ProcessMessageResultType } from '../serialization/crdt';
3
3
  import { __DEV__ } from '../runtime/invariant';
4
4
  const emptyReadonlySet = freezeSet(new Set());
5
+ const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
5
6
  function frozenError() {
6
7
  throw new Error('The set is frozen');
7
8
  }
@@ -12,7 +13,7 @@ function freezeSet(set) {
12
13
  return set;
13
14
  }
14
15
  function sortByTimestamp(a, b) {
15
- return a.timestamp > b.timestamp ? 1 : -1;
16
+ return a.timestamp - b.timestamp;
16
17
  }
17
18
  /**
18
19
  * @internal
@@ -22,6 +23,7 @@ export function createValueSetComponentDefinitionFromSchema(componentName, compo
22
23
  const dirtyIterator = new Set();
23
24
  const queuedCommands = [];
24
25
  const onChangeCallbacks = new Map();
26
+ const validateCallbacks = new Map();
25
27
  // only sort the array if the latest (N) element has a timestamp <= N-1
26
28
  function shouldSort(row) {
27
29
  const len = row.raw.length;
@@ -80,8 +82,11 @@ export function createValueSetComponentDefinitionFromSchema(componentName, compo
80
82
  has(entity) {
81
83
  return data.has(entity);
82
84
  },
83
- entityDeleted(entity) {
85
+ entityDeleted(entity, markAsDirty) {
84
86
  data.delete(entity);
87
+ if (markAsDirty) {
88
+ // For grow-only sets, we don't need to mark as dirty since deletion doesn't generate CRDT messages
89
+ }
85
90
  },
86
91
  get(entity) {
87
92
  const values = data.get(entity);
@@ -152,6 +157,44 @@ export function createValueSetComponentDefinitionFromSchema(componentName, compo
152
157
  for (const cb of cbs) {
153
158
  cb(value);
154
159
  }
160
+ },
161
+ __dry_run_updateFromCrdt(_body) {
162
+ return ProcessMessageResultType.StateUpdatedData;
163
+ },
164
+ validateBeforeChange(entityOrCb, cb) {
165
+ if (arguments.length === 1) {
166
+ // Second overload: just callback (global validation)
167
+ validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
168
+ }
169
+ else {
170
+ if (cb) {
171
+ validateCallbacks.set(entityOrCb, cb);
172
+ }
173
+ }
174
+ },
175
+ __run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
176
+ const cb = entity && validateCallbacks.get(entity);
177
+ const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
178
+ const currentValue = [...this.get(entity).values()];
179
+ const value = { entity, currentValue: currentValue, newValue, senderAddress, createdBy };
180
+ const globalResult = globalCb?.(value) ?? true;
181
+ const entityResult = (globalResult && cb?.(value)) ?? true;
182
+ return globalResult && entityResult;
183
+ },
184
+ getCrdtState(entity) {
185
+ const row = data.get(entity);
186
+ if (!row || row.raw.length === 0) {
187
+ return null;
188
+ }
189
+ // For GrowOnlySet, we need to return the complete CRDT messages for all values
190
+ // This is complex because GrowOnlySet uses APPEND messages, not a single PUT
191
+ // For now, return null to indicate this component type doesn't support simple corrections
192
+ return null;
193
+ },
194
+ __forceUpdateFromCrdt(_msg) {
195
+ // GrowOnlySet doesn't support authoritative corrections in the same way as LWW
196
+ // since it uses APPEND_VALUE messages instead of PUT_COMPONENT messages
197
+ return [null, undefined];
155
198
  }
156
199
  };
157
200
  return ret;
@@ -32,12 +32,6 @@ export type IInputSystem = {
32
32
  * @returns the input command info or undefined if there is no command in the last tick-update
33
33
  */
34
34
  getInputCommand: (inputAction: InputAction, pointerEventType: PointerEventType, entity?: Entity) => PBPointerEventsResult | null;
35
- /**
36
- * @public
37
- * Get an ordered iterator over events received within the current frame.
38
- * @returns the iterator
39
- */
40
- getInputCommands: () => Generator<PBPointerEventsResult>;
41
35
  };
42
36
  /**
43
37
  * @public
@@ -118,8 +118,9 @@ export function createInputSystem(engine) {
118
118
  }
119
119
  if (!up || !down)
120
120
  return null;
121
- // If the DOWN command has happen before the UP commands, it means that that a clicked has happen
122
- if (down.timestamp < up.timestamp && timestampIsCurrentFrame(up.timestamp)) {
121
+ // If the DOWN command has happened before or at the same time as the UP command, a click has happened.
122
+ // Same-timestamp is possible when both events are produced within the same renderer tick.
123
+ if (down.timestamp <= up.timestamp && timestampIsCurrentFrame(up.timestamp)) {
123
124
  return { up, down };
124
125
  }
125
126
  return null;
@@ -185,17 +186,11 @@ export function createInputSystem(engine) {
185
186
  function isPressed(inputAction) {
186
187
  return globalState.buttonState.get(inputAction)?.state === 1 /* PointerEventType.PET_DOWN */;
187
188
  }
188
- function* getInputCommands() {
189
- for (let i = globalState.thisFrameCommands.length - 1; i >= 0; i--) {
190
- yield globalState.thisFrameCommands[i];
191
- }
192
- }
193
189
  return {
194
190
  isPressed,
195
191
  getClick,
196
192
  getInputCommand,
197
193
  isClicked,
198
- isTriggered,
199
- getInputCommands
194
+ isTriggered
200
195
  };
201
196
  }
@@ -1,8 +1,10 @@
1
1
  import { ISchema } from '../schemas';
2
2
  import { ByteBuffer } from '../serialization/ByteBuffer';
3
- import { PutComponentMessageBody, DeleteComponentMessageBody, CrdtMessageBody } from '../serialization/crdt';
3
+ import { PutComponentMessageBody, DeleteComponentMessageBody, ProcessMessageResultType, CrdtMessageBody, PutNetworkComponentMessageBody, DeleteComponentNetworkMessageBody, AuthoritativePutComponentMessageBody } from '../serialization/crdt';
4
4
  import { Entity } from './entity';
5
5
  export declare function incrementTimestamp(entity: Entity, timestamps: Map<Entity, number>): number;
6
6
  export declare function createDumpLwwFunctionFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (buffer: ByteBuffer, filterEntity?: ((entity: Entity) => boolean) | undefined) => void;
7
+ export declare function createCrdtRuleValidator(timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (message: PutComponentMessageBody | DeleteComponentMessageBody | PutNetworkComponentMessageBody | DeleteComponentNetworkMessageBody) => ProcessMessageResultType;
8
+ export declare function createForceUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (msg: AuthoritativePutComponentMessageBody) => [null, any];
7
9
  export declare function createUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (msg: CrdtMessageBody) => [null | PutComponentMessageBody | DeleteComponentMessageBody, any];
8
10
  export declare function createGetCrdtMessagesForLww(componentId: number, timestamps: Map<Entity, number>, dirtyIterator: Set<Entity>, schema: Pick<ISchema<any>, 'serialize'>, data: Map<Entity, unknown>): () => Generator<PutComponentMessageBody | DeleteComponentMessageBody, void, unknown>;
@@ -30,16 +30,12 @@ export function createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, d
30
30
  }
31
31
  };
32
32
  }
33
- export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
33
+ const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
34
+ export function createCrdtRuleValidator(timestamps, schema, data) {
34
35
  /**
35
- * Process the received message only if the lamport number recieved is higher
36
- * than the stored one. If its lower, we spread it to the network to correct the peer.
37
- * If they are equal, the bigger raw data wins.
38
-
39
- * Returns the recieved data if the lamport number was bigger than ours.
40
- * If it was an outdated message, then we return void
41
- * @public
42
- */
36
+ * Shared CRDT conflict resolution logic
37
+ * @public
38
+ */
43
39
  function crdtRuleForCurrentState(message) {
44
40
  const { entityId, timestamp } = message;
45
41
  const currentTimestamp = timestamps.get(entityId);
@@ -49,7 +45,6 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
49
45
  }
50
46
  // Outdated Message. Resend our state message through the wire.
51
47
  if (currentTimestamp > timestamp) {
52
- // console.log('2', currentTimestamp, timestamp)
53
48
  return ProcessMessageResultType.StateOutdatedTimestamp;
54
49
  }
55
50
  // Deletes are idempotent
@@ -66,7 +61,6 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
66
61
  currentDataGreater = dataCompare(null, message.data);
67
62
  }
68
63
  // Same data, same timestamp. Weirdo echo message.
69
- // console.log('3', currentDataGreater, writeBuffer.toBinary(), (message as any).data || null)
70
64
  if (currentDataGreater === 0) {
71
65
  return ProcessMessageResultType.NoChanges;
72
66
  }
@@ -75,10 +69,35 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
75
69
  return ProcessMessageResultType.StateOutdatedData;
76
70
  }
77
71
  else {
78
- // Curent data is lower
72
+ // Current data is lower
79
73
  return ProcessMessageResultType.StateUpdatedData;
80
74
  }
81
75
  }
76
+ return crdtRuleForCurrentState;
77
+ }
78
+ export function createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
79
+ /**
80
+ * Force update component state regardless of timestamp - used for server authoritative messages
81
+ */
82
+ return (msg) => {
83
+ const buffer = new ReadWriteByteBuffer(msg.data);
84
+ const deserializedValue = schema.deserialize(buffer);
85
+ data.set(msg.entityId, deserializedValue);
86
+ timestamps.set(msg.entityId, msg.timestamp);
87
+ return [null, deserializedValue];
88
+ };
89
+ }
90
+ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
91
+ /**
92
+ * Process the received message only if the lamport number recieved is higher
93
+ * than the stored one. If its lower, we spread it to the network to correct the peer.
94
+ * If they are equal, the bigger raw data wins.
95
+
96
+ * Returns the recieved data if the lamport number was bigger than ours.
97
+ * If it was an outdated message, then we return void
98
+ * @public
99
+ */
100
+ const crdtRuleForCurrentState = createCrdtRuleValidator(timestamps, schema, data);
82
101
  return (msg) => {
83
102
  /* istanbul ignore next */
84
103
  if (msg.type !== CrdtMessageType.PUT_COMPONENT &&
@@ -171,6 +190,7 @@ export function createComponentDefinitionFromSchema(componentName, componentId,
171
190
  const dirtyIterator = new Set();
172
191
  const timestamps = new Map();
173
192
  const onChangeCallbacks = new Map();
193
+ const validateCallbacks = new Map();
174
194
  return {
175
195
  get componentId() {
176
196
  return componentId;
@@ -262,7 +282,39 @@ export function createComponentDefinitionFromSchema(componentName, componentId,
262
282
  },
263
283
  getCrdtUpdates: createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data),
264
284
  updateFromCrdt: createUpdateLwwFromCrdt(componentId, timestamps, schema, data),
285
+ __forceUpdateFromCrdt: createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data),
286
+ __dry_run_updateFromCrdt: createCrdtRuleValidator(timestamps, schema, data),
265
287
  dumpCrdtStateToBuffer: createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, data),
288
+ validateBeforeChange(entityOrCb, cb) {
289
+ if (arguments.length === 1) {
290
+ // Second overload: just callback (global validation)
291
+ validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
292
+ }
293
+ else {
294
+ if (cb) {
295
+ validateCallbacks.set(entityOrCb, cb);
296
+ }
297
+ }
298
+ },
299
+ __run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
300
+ const cb = entity && validateCallbacks.get(entity);
301
+ const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
302
+ const currentValue = data.get(entity);
303
+ const value = { entity, currentValue, newValue, senderAddress, createdBy };
304
+ const globalResult = globalCb?.(value) ?? true;
305
+ const entityResult = (globalResult && cb?.(value)) ?? true;
306
+ return globalResult && entityResult;
307
+ },
308
+ getCrdtState(entity) {
309
+ const componentData = data.get(entity);
310
+ const timestamp = timestamps.get(entity);
311
+ if (componentData && timestamp !== undefined) {
312
+ const buffer = new ReadWriteByteBuffer();
313
+ schema.serialize(deepReadonly(componentData), buffer);
314
+ return { data: buffer.toBinary(), timestamp };
315
+ }
316
+ return null;
317
+ },
266
318
  onChange(entity, cb) {
267
319
  const cbs = onChangeCallbacks.get(entity) ?? [];
268
320
  cbs.push(cb);
package/dist/index.d.ts CHANGED
@@ -1,9 +1,9 @@
1
1
  export * from './engine';
2
2
  export * from './schemas';
3
+ export * from './runtime/globals';
3
4
  export * from './runtime/initialization';
4
5
  export * from './runtime/types';
5
6
  export * from './runtime/helpers';
6
- export * from './runtime/globals';
7
7
  export { cyclicParentingChecker } from './systems/cyclicParentingChecker';
8
8
  export * from './systems/events';
9
9
  export * from './systems/raycast';
@@ -14,7 +14,7 @@ export * from './systems/tween';
14
14
  export * from './systems/triggerArea';
15
15
  export * from './engine/entity';
16
16
  export * from './components/types';
17
- import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended } from './components/types';
17
+ import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended, ICreatedBy } from './components/types';
18
18
  import { NameComponent } from './components/manual/Name';
19
19
  import { TagsComponentDefinitionExtended } from './components/manual/Tags';
20
20
  export declare const Transform: TransformComponentExtended;
@@ -47,6 +47,7 @@ export declare const NetworkEntity: INetowrkEntity;
47
47
  * Tag a entity to be syncronized through comms
48
48
  */
49
49
  export declare const NetworkParent: INetowrkParent;
50
+ export declare const CreatedBy: ICreatedBy;
50
51
  export * from './components/generated/global.gen';
51
52
  export * from './components/generated/types.gen';
52
53
  export * from './serialization/crdt';
package/dist/index.js CHANGED
@@ -1,10 +1,10 @@
1
1
  // The order of the following imports matters. Please do not auto-sort
2
2
  export * from './engine';
3
3
  export * from './schemas';
4
+ export * from './runtime/globals';
4
5
  export * from './runtime/initialization';
5
6
  export * from './runtime/types';
6
7
  export * from './runtime/helpers';
7
- export * from './runtime/globals';
8
8
  export { cyclicParentingChecker } from './systems/cyclicParentingChecker';
9
9
  export * from './systems/events';
10
10
  export * from './systems/raycast';
@@ -51,6 +51,7 @@ export const NetworkEntity = /* @__PURE__*/ components.NetworkEntity(engine);
51
51
  * Tag a entity to be syncronized through comms
52
52
  */
53
53
  export const NetworkParent = /* @__PURE__*/ components.NetworkParent(engine);
54
+ export const CreatedBy = /* @__PURE__*/ components.CreatedBy(engine);
54
55
  // export components for global engine
55
56
  export * from './components/generated/global.gen';
56
57
  export * from './components/generated/types.gen';
@@ -1,6 +1,5 @@
1
1
  /**
2
- * Utilities for standardized globalThis access.
3
- * @public
2
+ * Internal utilities for standardized globalThis access.
4
3
  */
5
4
  /**
6
5
  * Type-safe globalThis property access.
@@ -1,6 +1,5 @@
1
1
  /**
2
- * Utilities for standardized globalThis access.
3
- * @public
2
+ * Internal utilities for standardized globalThis access.
4
3
  */
5
4
  /**
6
5
  * Type-safe globalThis property access.
@@ -0,0 +1,15 @@
1
+ import { Entity } from '../../engine/entity';
2
+ import { ByteBuffer } from '../ByteBuffer';
3
+ import { AuthoritativePutComponentMessage } from './types';
4
+ /**
5
+ * @public
6
+ */
7
+ export declare namespace AuthoritativePutComponentOperation {
8
+ const MESSAGE_HEADER_LENGTH = 16;
9
+ /**
10
+ * Call this function for an optimal writing data passing the ByteBuffer
11
+ * already allocated
12
+ */
13
+ function write(entity: Entity, timestamp: number, componentId: number, data: Uint8Array, buf: ByteBuffer): void;
14
+ function read(buf: ByteBuffer): AuthoritativePutComponentMessage | null;
15
+ }
@@ -0,0 +1,47 @@
1
+ import { CrdtMessageProtocol } from './crdtMessageProtocol';
2
+ import { CrdtMessageType, CRDT_MESSAGE_HEADER_LENGTH } from './types';
3
+ /**
4
+ * @public
5
+ */
6
+ export var AuthoritativePutComponentOperation;
7
+ (function (AuthoritativePutComponentOperation) {
8
+ AuthoritativePutComponentOperation.MESSAGE_HEADER_LENGTH = 16;
9
+ /**
10
+ * Call this function for an optimal writing data passing the ByteBuffer
11
+ * already allocated
12
+ */
13
+ function write(entity, timestamp, componentId, data, buf) {
14
+ // reserve the beginning
15
+ const startMessageOffset = buf.incrementWriteOffset(CRDT_MESSAGE_HEADER_LENGTH + AuthoritativePutComponentOperation.MESSAGE_HEADER_LENGTH);
16
+ // write body
17
+ buf.writeBuffer(data, false);
18
+ const messageLength = buf.currentWriteOffset() - startMessageOffset;
19
+ // Write CrdtMessage header
20
+ buf.setUint32(startMessageOffset, messageLength);
21
+ buf.setUint32(startMessageOffset + 4, CrdtMessageType.AUTHORITATIVE_PUT_COMPONENT);
22
+ // Write ComponentOperation header
23
+ buf.setUint32(startMessageOffset + 8, entity);
24
+ buf.setUint32(startMessageOffset + 12, componentId);
25
+ buf.setUint32(startMessageOffset + 16, timestamp);
26
+ const newLocal = messageLength - AuthoritativePutComponentOperation.MESSAGE_HEADER_LENGTH - CRDT_MESSAGE_HEADER_LENGTH;
27
+ buf.setUint32(startMessageOffset + 20, newLocal);
28
+ }
29
+ AuthoritativePutComponentOperation.write = write;
30
+ function read(buf) {
31
+ const header = CrdtMessageProtocol.readHeader(buf);
32
+ if (!header) {
33
+ return null;
34
+ }
35
+ if (header.type !== CrdtMessageType.AUTHORITATIVE_PUT_COMPONENT) {
36
+ throw new Error('AuthoritativePutComponentOperation tried to read another message type.');
37
+ }
38
+ return {
39
+ ...header,
40
+ entityId: buf.readUint32(),
41
+ componentId: buf.readUint32(),
42
+ timestamp: buf.readUint32(),
43
+ data: buf.readBuffer()
44
+ };
45
+ }
46
+ AuthoritativePutComponentOperation.read = read;
47
+ })(AuthoritativePutComponentOperation || (AuthoritativePutComponentOperation = {}));
@@ -7,3 +7,4 @@ export * from './network/deleteComponentNetwork';
7
7
  export * from './network/deleteEntityNetwork';
8
8
  export * from './types';
9
9
  export * from './crdtMessageProtocol';
10
+ export * from './authoritativePutComponent';
@@ -7,3 +7,4 @@ export * from './network/deleteComponentNetwork';
7
7
  export * from './network/deleteEntityNetwork';
8
8
  export * from './types';
9
9
  export * from './crdtMessageProtocol';
10
+ export * from './authoritativePutComponent';
@@ -11,7 +11,8 @@ export declare enum CrdtMessageType {
11
11
  PUT_COMPONENT_NETWORK = 5,
12
12
  DELETE_COMPONENT_NETWORK = 6,
13
13
  DELETE_ENTITY_NETWORK = 7,
14
- MAX_MESSAGE_TYPE = 8
14
+ AUTHORITATIVE_PUT_COMPONENT = 8,
15
+ MAX_MESSAGE_TYPE = 9
15
16
  }
16
17
  /**
17
18
  * Min length = 8 bytes
@@ -48,6 +49,23 @@ export type PutNetworkComponentMessageBody = Omit<PutComponentMessageBody, 'type
48
49
  type: CrdtMessageType.PUT_COMPONENT_NETWORK;
49
50
  networkId: number;
50
51
  };
52
+ /**
53
+ * Server authoritative message - identical to PutComponentMessageBody but with forced processing
54
+ * Min. length = header (8 bytes) + 16 bytes = 24 bytes
55
+ *
56
+ * @param entity - Uint32 number of the entity
57
+ * @param componentId - Uint32 number of id
58
+ * @param timestamp - Uint32 Lamport timestamp (server's authoritative timestamp)
59
+ * @param data - Uint8[] data of component => length(4 bytes) + block of bytes[0..length-1]
60
+ * @public
61
+ */
62
+ export type AuthoritativePutComponentMessageBody = {
63
+ type: CrdtMessageType.AUTHORITATIVE_PUT_COMPONENT;
64
+ entityId: Entity;
65
+ componentId: number;
66
+ timestamp: number;
67
+ data: Uint8Array;
68
+ };
51
69
  /**
52
70
  * Min. length = header (8 bytes) + 16 bytes = 24 bytes
53
71
  *
@@ -114,6 +132,10 @@ export type AppendValueMessage = CrdtMessageHeader & AppendValueMessageBody;
114
132
  * @public
115
133
  */
116
134
  export type PutComponentMessage = CrdtMessageHeader & PutComponentMessageBody;
135
+ /**
136
+ * @public
137
+ */
138
+ export type AuthoritativePutComponentMessage = CrdtMessageHeader & AuthoritativePutComponentMessageBody;
117
139
  /**
118
140
  * @public
119
141
  */
@@ -137,7 +159,7 @@ export type DeleteEntityNetworkMessage = CrdtMessageHeader & DeleteEntityNetwork
137
159
  /**
138
160
  * @public
139
161
  */
140
- export type CrdtMessage = PutComponentMessage | DeleteComponentMessage | AppendValueMessage | DeleteEntityMessage | PutNetworkComponentMessage | DeleteComponentNetworkMessage | DeleteEntityNetworkMessage;
162
+ export type CrdtMessage = PutComponentMessage | AuthoritativePutComponentMessage | DeleteComponentMessage | AppendValueMessage | DeleteEntityMessage | PutNetworkComponentMessage | DeleteComponentNetworkMessage | DeleteEntityNetworkMessage;
141
163
  /**
142
164
  * @public
143
165
  */
@@ -145,7 +167,7 @@ export type CrdtNetworkMessageBody = PutNetworkComponentMessageBody | DeleteComp
145
167
  /**
146
168
  * @public
147
169
  */
148
- export type CrdtMessageBody = PutComponentMessageBody | DeleteComponentMessageBody | DeleteEntityMessageBody | AppendValueMessageBody | CrdtNetworkMessageBody;
170
+ export type CrdtMessageBody = PutComponentMessageBody | AuthoritativePutComponentMessageBody | DeleteComponentMessageBody | DeleteEntityMessageBody | AppendValueMessageBody | CrdtNetworkMessageBody;
149
171
  export declare enum ProcessMessageResultType {
150
172
  /**
151
173
  * Typical message and new state set.
@@ -13,7 +13,9 @@ export var CrdtMessageType;
13
13
  CrdtMessageType[CrdtMessageType["PUT_COMPONENT_NETWORK"] = 5] = "PUT_COMPONENT_NETWORK";
14
14
  CrdtMessageType[CrdtMessageType["DELETE_COMPONENT_NETWORK"] = 6] = "DELETE_COMPONENT_NETWORK";
15
15
  CrdtMessageType[CrdtMessageType["DELETE_ENTITY_NETWORK"] = 7] = "DELETE_ENTITY_NETWORK";
16
- CrdtMessageType[CrdtMessageType["MAX_MESSAGE_TYPE"] = 8] = "MAX_MESSAGE_TYPE";
16
+ // Server authoritative operation - forces component state regardless of timestamp
17
+ CrdtMessageType[CrdtMessageType["AUTHORITATIVE_PUT_COMPONENT"] = 8] = "AUTHORITATIVE_PUT_COMPONENT";
18
+ CrdtMessageType[CrdtMessageType["MAX_MESSAGE_TYPE"] = 9] = "MAX_MESSAGE_TYPE";
17
19
  })(CrdtMessageType || (CrdtMessageType = {}));
18
20
  /**
19
21
  * @public
@@ -1,7 +1,6 @@
1
1
  import { Entity } from '../../engine/entity';
2
2
  import type { ComponentDefinition } from '../../engine';
3
3
  import { CrdtMessageType } from '../../serialization/crdt/types';
4
- export declare const LIVEKIT_MAX_SIZE = 12;
5
4
  /**
6
5
  * @public
7
6
  */