@dcl/ecs 7.22.6-25007982108.commit-83012ab → 7.22.6-25321038582.commit-63ddb3f
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.
- package/dist/components/extended/MeshCollider.d.ts +0 -8
- package/dist/components/extended/MeshCollider.js +0 -6
- package/dist/components/extended/MeshRenderer.d.ts +0 -8
- package/dist/components/extended/MeshRenderer.js +0 -5
- package/dist/components/extended/ParticleSystem.d.ts +24 -0
- package/dist/components/extended/ParticleSystem.js +23 -0
- package/dist/components/extended/Tween.d.ts +48 -1
- package/dist/components/extended/Tween.js +66 -0
- package/dist/components/generated/component-names.gen.js +0 -11
- package/dist/components/generated/global.gen.d.ts +0 -22
- package/dist/components/generated/global.gen.js +0 -11
- package/dist/components/generated/index.gen.d.ts +0 -44
- package/dist/components/generated/index.gen.js +0 -55
- package/dist/components/generated/pb/decentraland/common/texture.gen.d.ts +0 -20
- package/dist/components/generated/pb/decentraland/common/texture.gen.js +0 -65
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +0 -2
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +1 -10
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +0 -43
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +1 -151
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -2
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -10
- package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +1 -37
- package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +1 -119
- package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -6
- package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -4
- package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +0 -19
- package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +1 -46
- package/dist/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +0 -22
- package/dist/components/generated/pb/decentraland/sdk/components/material.gen.js +1 -57
- package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +0 -20
- package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +0 -56
- package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +3 -21
- package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +0 -56
- package/dist/components/generated/pb/decentraland/sdk/components/particle_system.gen.d.ts +14 -1
- package/dist/components/generated/pb/decentraland/sdk/components/particle_system.gen.js +42 -4
- package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +2 -8
- package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +0 -3
- package/dist/components/generated/pb/decentraland/sdk/components/raycast.gen.d.ts +0 -13
- package/dist/components/generated/pb/decentraland/sdk/components/raycast.gen.js +0 -30
- package/dist/components/generated/pb/decentraland/sdk/components/ui_input.gen.d.ts +0 -2
- package/dist/components/generated/pb/decentraland/sdk/components/ui_input.gen.js +0 -10
- package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +0 -4
- package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +0 -20
- package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +0 -35
- package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +0 -90
- package/dist/components/generated/types.gen.d.ts +1 -0
- package/dist/components/generated/types.gen.js +1 -0
- package/dist/components/index.d.ts +14 -11
- package/dist/components/index.js +13 -13
- package/dist/components/manual/CreatedBy.d.ts +9 -0
- package/dist/components/manual/CreatedBy.js +8 -0
- package/dist/components/manual/Transform.d.ts +22 -0
- package/dist/components/manual/Transform.js +11 -3
- package/dist/components/types.d.ts +3 -3
- package/dist/engine/component.d.ts +52 -1
- package/dist/engine/entity.js +4 -2
- package/dist/engine/grow-only-value-set-component-definition.js +46 -3
- package/dist/engine/input.d.ts +0 -6
- package/dist/engine/input.js +4 -9
- package/dist/engine/lww-element-set-component-definition.d.ts +5 -3
- package/dist/engine/lww-element-set-component-definition.js +87 -18
- package/dist/index.d.ts +5 -2
- package/dist/index.js +5 -1
- package/dist/runtime/globals.d.ts +1 -2
- package/dist/runtime/globals.js +1 -2
- package/dist/runtime/helpers/index.d.ts +1 -0
- package/dist/runtime/helpers/index.js +1 -0
- package/dist/runtime/helpers/tree.d.ts +6 -0
- package/dist/runtime/helpers/tree.js +2 -2
- package/dist/runtime/helpers/vectors.js +36 -0
- package/dist/runtime/initialization/index.d.ts +7 -0
- package/dist/runtime/initialization/index.js +6 -0
- package/dist/serialization/crdt/authoritativePutComponent.d.ts +15 -0
- package/dist/serialization/crdt/authoritativePutComponent.js +47 -0
- package/dist/serialization/crdt/index.d.ts +1 -0
- package/dist/serialization/crdt/index.js +1 -0
- package/dist/serialization/crdt/types.d.ts +25 -3
- package/dist/serialization/crdt/types.js +3 -1
- package/dist/systems/crdt/index.d.ts +0 -1
- package/dist/systems/crdt/index.js +55 -146
- package/dist/systems/events.d.ts +25 -59
- package/dist/systems/events.js +129 -145
- package/dist/systems/physics-force.js +140 -0
- package/dist/systems/physics-impulse.d.ts +12 -0
- package/dist/systems/physics-impulse.js +85 -0
- package/dist/systems/physics.d.ts +77 -0
- package/dist/systems/physics.js +18 -0
- package/dist/systems/raycast.d.ts +1 -3
- package/dist/systems/raycast.js +0 -2
- package/dist-cjs/components/extended/MeshCollider.d.ts +0 -8
- package/dist-cjs/components/extended/MeshCollider.js +0 -6
- package/dist-cjs/components/extended/MeshRenderer.d.ts +0 -8
- package/dist-cjs/components/extended/MeshRenderer.js +0 -5
- package/dist-cjs/components/extended/ParticleSystem.d.ts +24 -0
- package/dist-cjs/components/extended/ParticleSystem.js +28 -0
- package/dist-cjs/components/extended/Tween.d.ts +48 -1
- package/dist-cjs/components/extended/Tween.js +66 -0
- package/dist-cjs/components/generated/component-names.gen.js +0 -11
- package/dist-cjs/components/generated/global.gen.d.ts +0 -22
- package/dist-cjs/components/generated/global.gen.js +2 -13
- package/dist-cjs/components/generated/index.gen.d.ts +0 -44
- package/dist-cjs/components/generated/index.gen.js +2 -68
- package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.d.ts +0 -20
- package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.js +1 -66
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +0 -2
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +1 -10
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +0 -43
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +2 -152
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -2
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -10
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +1 -37
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +2 -120
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -6
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -4
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +0 -19
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +1 -46
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +0 -22
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.js +2 -58
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +0 -20
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +1 -57
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +3 -21
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +1 -57
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/particle_system.gen.d.ts +14 -1
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/particle_system.gen.js +43 -5
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +2 -8
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +0 -3
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/raycast.gen.d.ts +0 -13
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/raycast.gen.js +1 -31
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_input.gen.d.ts +0 -2
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_input.gen.js +0 -10
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +0 -4
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +0 -20
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +0 -35
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +1 -91
- package/dist-cjs/components/generated/types.gen.d.ts +1 -0
- package/dist-cjs/components/generated/types.gen.js +3 -0
- package/dist-cjs/components/index.d.ts +14 -11
- package/dist-cjs/components/index.js +17 -17
- package/dist-cjs/components/manual/CreatedBy.d.ts +9 -0
- package/dist-cjs/components/manual/CreatedBy.js +10 -0
- package/dist-cjs/components/manual/Transform.d.ts +22 -0
- package/dist-cjs/components/manual/Transform.js +34 -3
- package/dist-cjs/components/types.d.ts +3 -3
- package/dist-cjs/engine/component.d.ts +52 -1
- package/dist-cjs/engine/entity.js +4 -2
- package/dist-cjs/engine/grow-only-value-set-component-definition.js +45 -2
- package/dist-cjs/engine/input.d.ts +0 -6
- package/dist-cjs/engine/input.js +4 -9
- package/dist-cjs/engine/lww-element-set-component-definition.d.ts +5 -3
- package/dist-cjs/engine/lww-element-set-component-definition.js +90 -19
- package/dist-cjs/index.d.ts +5 -2
- package/dist-cjs/index.js +6 -2
- package/dist-cjs/runtime/globals.d.ts +1 -2
- package/dist-cjs/runtime/globals.js +1 -2
- package/dist-cjs/runtime/helpers/index.d.ts +1 -0
- package/dist-cjs/runtime/helpers/index.js +1 -0
- package/dist-cjs/runtime/helpers/tree.d.ts +6 -0
- package/dist-cjs/runtime/helpers/tree.js +3 -2
- package/dist-cjs/runtime/helpers/vectors.js +39 -0
- package/dist-cjs/runtime/initialization/index.d.ts +7 -0
- package/dist-cjs/runtime/initialization/index.js +7 -1
- package/dist-cjs/serialization/crdt/authoritativePutComponent.d.ts +15 -0
- package/dist-cjs/serialization/crdt/authoritativePutComponent.js +50 -0
- package/dist-cjs/serialization/crdt/index.d.ts +1 -0
- package/dist-cjs/serialization/crdt/index.js +1 -0
- package/dist-cjs/serialization/crdt/types.d.ts +25 -3
- package/dist-cjs/serialization/crdt/types.js +3 -1
- package/dist-cjs/systems/crdt/index.d.ts +0 -1
- package/dist-cjs/systems/crdt/index.js +55 -169
- package/dist-cjs/systems/events.d.ts +25 -59
- package/dist-cjs/systems/events.js +129 -145
- package/dist-cjs/systems/physics-force.js +167 -0
- package/dist-cjs/systems/physics-impulse.d.ts +12 -0
- package/dist-cjs/systems/physics-impulse.js +112 -0
- package/dist-cjs/systems/physics.d.ts +77 -0
- package/dist-cjs/systems/physics.js +23 -0
- package/dist-cjs/systems/raycast.d.ts +1 -3
- package/dist-cjs/systems/raycast.js +0 -2
- package/package.json +3 -2
- package/dist/components/extended/AvatarEquippedData.d.ts +0 -10
- package/dist/components/extended/AvatarEquippedData.js +0 -15
- package/dist/components/extended/AvatarShape.d.ts +0 -10
- package/dist/components/extended/AvatarShape.js +0 -15
- package/dist/components/generated/AvatarLocomotionSettings.gen.d.ts +0 -1
- package/dist/components/generated/AvatarLocomotionSettings.gen.js +0 -25
- package/dist/components/generated/AvatarMovement.gen.d.ts +0 -1
- package/dist/components/generated/AvatarMovement.gen.js +0 -25
- package/dist/components/generated/AvatarMovementInfo.gen.d.ts +0 -1
- package/dist/components/generated/AvatarMovementInfo.gen.js +0 -25
- package/dist/components/generated/CameraLayer.gen.d.ts +0 -1
- package/dist/components/generated/CameraLayer.gen.js +0 -25
- package/dist/components/generated/CameraLayers.gen.d.ts +0 -1
- package/dist/components/generated/CameraLayers.gen.js +0 -25
- package/dist/components/generated/GlobalLight.gen.d.ts +0 -1
- package/dist/components/generated/GlobalLight.gen.js +0 -25
- package/dist/components/generated/GltfNode.gen.d.ts +0 -1
- package/dist/components/generated/GltfNode.gen.js +0 -25
- package/dist/components/generated/GltfNodeState.gen.d.ts +0 -1
- package/dist/components/generated/GltfNodeState.gen.js +0 -25
- package/dist/components/generated/TextureCamera.gen.d.ts +0 -1
- package/dist/components/generated/TextureCamera.gen.js +0 -25
- package/dist/components/generated/UiCanvas.gen.d.ts +0 -1
- package/dist/components/generated/UiCanvas.gen.js +0 -25
- package/dist/components/generated/UiScrollResult.gen.d.ts +0 -1
- package/dist/components/generated/UiScrollResult.gen.js +0 -25
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -29
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -93
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.d.ts +0 -20
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.js +0 -69
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.d.ts +0 -32
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.js +0 -126
- package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +0 -30
- package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +0 -104
- package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +0 -14
- package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +0 -50
- package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +0 -34
- package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.js +0 -61
- package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +0 -50
- package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +0 -41
- package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +0 -27
- package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +0 -59
- package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +0 -74
- package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +0 -191
- package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +0 -19
- package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.js +0 -60
- package/dist/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +0 -15
- package/dist/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.js +0 -42
- package/dist/serialization/crdt/network/utils.d.ts +0 -9
- package/dist/serialization/crdt/network/utils.js +0 -60
- package/dist-cjs/components/extended/AvatarEquippedData.d.ts +0 -10
- package/dist-cjs/components/extended/AvatarEquippedData.js +0 -19
- package/dist-cjs/components/extended/AvatarShape.d.ts +0 -10
- package/dist-cjs/components/extended/AvatarShape.js +0 -19
- package/dist-cjs/components/generated/AvatarLocomotionSettings.gen.js +0 -28
- package/dist-cjs/components/generated/AvatarMovement.gen.js +0 -28
- package/dist-cjs/components/generated/AvatarMovementInfo.gen.js +0 -28
- package/dist-cjs/components/generated/CameraLayer.gen.js +0 -28
- package/dist-cjs/components/generated/CameraLayers.gen.d.ts +0 -1
- package/dist-cjs/components/generated/CameraLayers.gen.js +0 -28
- package/dist-cjs/components/generated/GlobalLight.gen.d.ts +0 -1
- package/dist-cjs/components/generated/GlobalLight.gen.js +0 -28
- package/dist-cjs/components/generated/GltfNode.gen.d.ts +0 -1
- package/dist-cjs/components/generated/GltfNode.gen.js +0 -28
- package/dist-cjs/components/generated/GltfNodeState.gen.d.ts +0 -1
- package/dist-cjs/components/generated/GltfNodeState.gen.js +0 -28
- package/dist-cjs/components/generated/TextureCamera.gen.d.ts +0 -1
- package/dist-cjs/components/generated/TextureCamera.gen.js +0 -28
- package/dist-cjs/components/generated/UiCanvas.gen.d.ts +0 -1
- package/dist-cjs/components/generated/UiCanvas.gen.js +0 -28
- package/dist-cjs/components/generated/UiScrollResult.gen.d.ts +0 -1
- package/dist-cjs/components/generated/UiScrollResult.gen.js +0 -28
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -29
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -99
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.d.ts +0 -20
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.js +0 -75
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.d.ts +0 -32
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.js +0 -132
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +0 -30
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +0 -110
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +0 -14
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +0 -56
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +0 -34
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.js +0 -67
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +0 -50
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +0 -47
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +0 -27
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +0 -65
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +0 -74
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +0 -197
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +0 -19
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.js +0 -66
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +0 -15
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.js +0 -48
- package/dist-cjs/serialization/crdt/network/utils.d.ts +0 -9
- package/dist-cjs/serialization/crdt/network/utils.js +0 -67
- /package/{dist-cjs/components/generated/AvatarMovementInfo.gen.d.ts → dist/runtime/helpers/vectors.d.ts} +0 -0
- /package/{dist-cjs/components/generated/CameraLayer.gen.d.ts → dist/systems/physics-force.d.ts} +0 -0
- /package/dist-cjs/{components/generated/AvatarLocomotionSettings.gen.d.ts → runtime/helpers/vectors.d.ts} +0 -0
- /package/dist-cjs/{components/generated/AvatarMovement.gen.d.ts → systems/physics-force.d.ts} +0 -0
|
@@ -5,6 +5,7 @@ const ByteBuffer_1 = require("../serialization/ByteBuffer");
|
|
|
5
5
|
const crdt_1 = require("../serialization/crdt");
|
|
6
6
|
const invariant_1 = require("../runtime/invariant");
|
|
7
7
|
const emptyReadonlySet = freezeSet(new Set());
|
|
8
|
+
const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
|
|
8
9
|
function frozenError() {
|
|
9
10
|
throw new Error('The set is frozen');
|
|
10
11
|
}
|
|
@@ -15,7 +16,7 @@ function freezeSet(set) {
|
|
|
15
16
|
return set;
|
|
16
17
|
}
|
|
17
18
|
function sortByTimestamp(a, b) {
|
|
18
|
-
return a.timestamp
|
|
19
|
+
return a.timestamp - b.timestamp;
|
|
19
20
|
}
|
|
20
21
|
/**
|
|
21
22
|
* @internal
|
|
@@ -25,6 +26,7 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
|
|
|
25
26
|
const dirtyIterator = new Set();
|
|
26
27
|
const queuedCommands = [];
|
|
27
28
|
const onChangeCallbacks = new Map();
|
|
29
|
+
const validateCallbacks = new Map();
|
|
28
30
|
// only sort the array if the latest (N) element has a timestamp <= N-1
|
|
29
31
|
function shouldSort(row) {
|
|
30
32
|
const len = row.raw.length;
|
|
@@ -83,8 +85,11 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
|
|
|
83
85
|
has(entity) {
|
|
84
86
|
return data.has(entity);
|
|
85
87
|
},
|
|
86
|
-
entityDeleted(entity) {
|
|
88
|
+
entityDeleted(entity, markAsDirty) {
|
|
87
89
|
data.delete(entity);
|
|
90
|
+
if (markAsDirty) {
|
|
91
|
+
// For grow-only sets, we don't need to mark as dirty since deletion doesn't generate CRDT messages
|
|
92
|
+
}
|
|
88
93
|
},
|
|
89
94
|
get(entity) {
|
|
90
95
|
const values = data.get(entity);
|
|
@@ -155,6 +160,44 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
|
|
|
155
160
|
for (const cb of cbs) {
|
|
156
161
|
cb(value);
|
|
157
162
|
}
|
|
163
|
+
},
|
|
164
|
+
__dry_run_updateFromCrdt(_body) {
|
|
165
|
+
return crdt_1.ProcessMessageResultType.StateUpdatedData;
|
|
166
|
+
},
|
|
167
|
+
validateBeforeChange(entityOrCb, cb) {
|
|
168
|
+
if (arguments.length === 1) {
|
|
169
|
+
// Second overload: just callback (global validation)
|
|
170
|
+
validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
if (cb) {
|
|
174
|
+
validateCallbacks.set(entityOrCb, cb);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
},
|
|
178
|
+
__run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
|
|
179
|
+
const cb = entity && validateCallbacks.get(entity);
|
|
180
|
+
const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
|
|
181
|
+
const currentValue = [...this.get(entity).values()];
|
|
182
|
+
const value = { entity, currentValue: currentValue, newValue, senderAddress, createdBy };
|
|
183
|
+
const globalResult = globalCb?.(value) ?? true;
|
|
184
|
+
const entityResult = (globalResult && cb?.(value)) ?? true;
|
|
185
|
+
return globalResult && entityResult;
|
|
186
|
+
},
|
|
187
|
+
getCrdtState(entity) {
|
|
188
|
+
const row = data.get(entity);
|
|
189
|
+
if (!row || row.raw.length === 0) {
|
|
190
|
+
return null;
|
|
191
|
+
}
|
|
192
|
+
// For GrowOnlySet, we need to return the complete CRDT messages for all values
|
|
193
|
+
// This is complex because GrowOnlySet uses APPEND messages, not a single PUT
|
|
194
|
+
// For now, return null to indicate this component type doesn't support simple corrections
|
|
195
|
+
return null;
|
|
196
|
+
},
|
|
197
|
+
__forceUpdateFromCrdt(_msg) {
|
|
198
|
+
// GrowOnlySet doesn't support authoritative corrections in the same way as LWW
|
|
199
|
+
// since it uses APPEND_VALUE messages instead of PUT_COMPONENT messages
|
|
200
|
+
return [null, undefined];
|
|
158
201
|
}
|
|
159
202
|
};
|
|
160
203
|
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
|
package/dist-cjs/engine/input.js
CHANGED
|
@@ -144,8 +144,9 @@ function createInputSystem(engine) {
|
|
|
144
144
|
}
|
|
145
145
|
if (!up || !down)
|
|
146
146
|
return null;
|
|
147
|
-
// If the DOWN command has
|
|
148
|
-
|
|
147
|
+
// If the DOWN command has happened before or at the same time as the UP command, a click has happened.
|
|
148
|
+
// Same-timestamp is possible when both events are produced within the same renderer tick.
|
|
149
|
+
if (down.timestamp <= up.timestamp && timestampIsCurrentFrame(up.timestamp)) {
|
|
149
150
|
return { up, down };
|
|
150
151
|
}
|
|
151
152
|
return null;
|
|
@@ -211,18 +212,12 @@ function createInputSystem(engine) {
|
|
|
211
212
|
function isPressed(inputAction) {
|
|
212
213
|
return globalState.buttonState.get(inputAction)?.state === 1 /* PointerEventType.PET_DOWN */;
|
|
213
214
|
}
|
|
214
|
-
function* getInputCommands() {
|
|
215
|
-
for (let i = globalState.thisFrameCommands.length - 1; i >= 0; i--) {
|
|
216
|
-
yield globalState.thisFrameCommands[i];
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
215
|
return {
|
|
220
216
|
isPressed,
|
|
221
217
|
getClick,
|
|
222
218
|
getInputCommand,
|
|
223
219
|
isClicked,
|
|
224
|
-
isTriggered
|
|
225
|
-
getInputCommands
|
|
220
|
+
isTriggered
|
|
226
221
|
};
|
|
227
222
|
}
|
|
228
223
|
exports.createInputSystem = createInputSystem;
|
|
@@ -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
|
|
8
|
-
export declare function
|
|
7
|
+
export declare function createCrdtRuleValidator(timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>, lastSentData: Map<Entity, Uint8Array>): (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];
|
|
9
|
+
export declare function createUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>, lastSentData: Map<Entity, Uint8Array>): (msg: CrdtMessageBody) => [null | PutComponentMessageBody | DeleteComponentMessageBody, any];
|
|
10
|
+
export declare function createGetCrdtMessagesForLww(componentId: number, timestamps: Map<Entity, number>, dirtyIterator: Set<Entity>, schema: Pick<ISchema<any>, 'serialize'>, data: Map<Entity, unknown>, lastSentData: Map<Entity, Uint8Array>): () => Generator<PutComponentMessageBody | DeleteComponentMessageBody, void, unknown>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createComponentDefinitionFromSchema = exports.createGetCrdtMessagesForLww = exports.createUpdateLwwFromCrdt = exports.createDumpLwwFunctionFromCrdt = exports.incrementTimestamp = void 0;
|
|
3
|
+
exports.createComponentDefinitionFromSchema = exports.createGetCrdtMessagesForLww = exports.createUpdateLwwFromCrdt = exports.createForceUpdateLwwFromCrdt = exports.createCrdtRuleValidator = exports.createDumpLwwFunctionFromCrdt = exports.incrementTimestamp = void 0;
|
|
4
4
|
const ByteBuffer_1 = require("../serialization/ByteBuffer");
|
|
5
5
|
const crdt_1 = require("../serialization/crdt");
|
|
6
6
|
const utils_1 = require("../systems/crdt/utils");
|
|
@@ -35,16 +35,12 @@ function createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, data) {
|
|
|
35
35
|
};
|
|
36
36
|
}
|
|
37
37
|
exports.createDumpLwwFunctionFromCrdt = createDumpLwwFunctionFromCrdt;
|
|
38
|
-
|
|
38
|
+
const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
|
|
39
|
+
function createCrdtRuleValidator(timestamps, schema, data, lastSentData) {
|
|
39
40
|
/**
|
|
40
|
-
*
|
|
41
|
-
*
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
* Returns the recieved data if the lamport number was bigger than ours.
|
|
45
|
-
* If it was an outdated message, then we return void
|
|
46
|
-
* @public
|
|
47
|
-
*/
|
|
41
|
+
* Shared CRDT conflict resolution logic
|
|
42
|
+
* @public
|
|
43
|
+
*/
|
|
48
44
|
function crdtRuleForCurrentState(message) {
|
|
49
45
|
const { entityId, timestamp } = message;
|
|
50
46
|
const currentTimestamp = timestamps.get(entityId);
|
|
@@ -54,7 +50,6 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
|
54
50
|
}
|
|
55
51
|
// Outdated Message. Resend our state message through the wire.
|
|
56
52
|
if (currentTimestamp > timestamp) {
|
|
57
|
-
// console.log('2', currentTimestamp, timestamp)
|
|
58
53
|
return crdt_1.ProcessMessageResultType.StateOutdatedTimestamp;
|
|
59
54
|
}
|
|
60
55
|
// Deletes are idempotent
|
|
@@ -71,7 +66,6 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
|
71
66
|
currentDataGreater = (0, utils_1.dataCompare)(null, message.data);
|
|
72
67
|
}
|
|
73
68
|
// Same data, same timestamp. Weirdo echo message.
|
|
74
|
-
// console.log('3', currentDataGreater, writeBuffer.toBinary(), (message as any).data || null)
|
|
75
69
|
if (currentDataGreater === 0) {
|
|
76
70
|
return crdt_1.ProcessMessageResultType.NoChanges;
|
|
77
71
|
}
|
|
@@ -80,10 +74,37 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
|
80
74
|
return crdt_1.ProcessMessageResultType.StateOutdatedData;
|
|
81
75
|
}
|
|
82
76
|
else {
|
|
83
|
-
//
|
|
77
|
+
// Current data is lower
|
|
84
78
|
return crdt_1.ProcessMessageResultType.StateUpdatedData;
|
|
85
79
|
}
|
|
86
80
|
}
|
|
81
|
+
return crdtRuleForCurrentState;
|
|
82
|
+
}
|
|
83
|
+
exports.createCrdtRuleValidator = createCrdtRuleValidator;
|
|
84
|
+
function createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
85
|
+
/**
|
|
86
|
+
* Force update component state regardless of timestamp - used for server authoritative messages
|
|
87
|
+
*/
|
|
88
|
+
return (msg) => {
|
|
89
|
+
const buffer = new ByteBuffer_1.ReadWriteByteBuffer(msg.data);
|
|
90
|
+
const deserializedValue = schema.deserialize(buffer);
|
|
91
|
+
data.set(msg.entityId, deserializedValue);
|
|
92
|
+
timestamps.set(msg.entityId, msg.timestamp);
|
|
93
|
+
return [null, deserializedValue];
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
exports.createForceUpdateLwwFromCrdt = createForceUpdateLwwFromCrdt;
|
|
97
|
+
function createUpdateLwwFromCrdt(componentId, timestamps, schema, data, lastSentData) {
|
|
98
|
+
/**
|
|
99
|
+
* Process the received message only if the lamport number recieved is higher
|
|
100
|
+
* than the stored one. If its lower, we spread it to the network to correct the peer.
|
|
101
|
+
* If they are equal, the bigger raw data wins.
|
|
102
|
+
|
|
103
|
+
* Returns the recieved data if the lamport number was bigger than ours.
|
|
104
|
+
* If it was an outdated message, then we return void
|
|
105
|
+
* @public
|
|
106
|
+
*/
|
|
107
|
+
const crdtRuleForCurrentState = createCrdtRuleValidator(timestamps, schema, data, lastSentData);
|
|
87
108
|
return (msg) => {
|
|
88
109
|
/* istanbul ignore next */
|
|
89
110
|
if (msg.type !== crdt_1.CrdtMessageType.PUT_COMPONENT &&
|
|
@@ -101,9 +122,11 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
|
101
122
|
if (msg.type === crdt_1.CrdtMessageType.PUT_COMPONENT || msg.type === crdt_1.CrdtMessageType.PUT_COMPONENT_NETWORK) {
|
|
102
123
|
const buf = new ByteBuffer_1.ReadWriteByteBuffer(msg.data);
|
|
103
124
|
data.set(entity, schema.deserialize(buf));
|
|
125
|
+
lastSentData.set(entity, new Uint8Array(msg.data));
|
|
104
126
|
}
|
|
105
127
|
else {
|
|
106
128
|
data.delete(entity);
|
|
129
|
+
lastSentData.delete(entity);
|
|
107
130
|
}
|
|
108
131
|
return [null, data.get(entity)];
|
|
109
132
|
}
|
|
@@ -140,23 +163,34 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
|
140
163
|
};
|
|
141
164
|
}
|
|
142
165
|
exports.createUpdateLwwFromCrdt = createUpdateLwwFromCrdt;
|
|
143
|
-
function createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data) {
|
|
166
|
+
function createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data, lastSentData) {
|
|
144
167
|
return function* () {
|
|
168
|
+
const writeBuffer = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
145
169
|
for (const entity of dirtyIterator) {
|
|
146
|
-
const newTimestamp = incrementTimestamp(entity, timestamps);
|
|
147
170
|
if (data.has(entity)) {
|
|
148
|
-
|
|
171
|
+
writeBuffer.resetBuffer();
|
|
149
172
|
schema.serialize(data.get(entity), writeBuffer);
|
|
173
|
+
// Compare against last-sent snapshot using the zero-copy subarray view.
|
|
174
|
+
// Only allocate a copy when bytes actually differ.
|
|
175
|
+
const previousBytes = lastSentData.get(entity);
|
|
176
|
+
if (previousBytes && (0, utils_1.dataCompare)(writeBuffer.toBinary(), previousBytes) === 0) {
|
|
177
|
+
continue;
|
|
178
|
+
}
|
|
179
|
+
const currentBytes = writeBuffer.toCopiedBinary();
|
|
180
|
+
const newTimestamp = incrementTimestamp(entity, timestamps);
|
|
181
|
+
lastSentData.set(entity, currentBytes);
|
|
150
182
|
const msg = {
|
|
151
183
|
type: crdt_1.CrdtMessageType.PUT_COMPONENT,
|
|
152
184
|
componentId,
|
|
153
185
|
entityId: entity,
|
|
154
|
-
data:
|
|
186
|
+
data: currentBytes,
|
|
155
187
|
timestamp: newTimestamp
|
|
156
188
|
};
|
|
157
189
|
yield msg;
|
|
158
190
|
}
|
|
159
191
|
else {
|
|
192
|
+
lastSentData.delete(entity);
|
|
193
|
+
const newTimestamp = incrementTimestamp(entity, timestamps);
|
|
160
194
|
const msg = {
|
|
161
195
|
type: crdt_1.CrdtMessageType.DELETE_COMPONENT,
|
|
162
196
|
componentId,
|
|
@@ -177,7 +211,9 @@ function createComponentDefinitionFromSchema(componentName, componentId, schema)
|
|
|
177
211
|
const data = new Map();
|
|
178
212
|
const dirtyIterator = new Set();
|
|
179
213
|
const timestamps = new Map();
|
|
214
|
+
const lastSentData = new Map();
|
|
180
215
|
const onChangeCallbacks = new Map();
|
|
216
|
+
const validateCallbacks = new Map();
|
|
181
217
|
return {
|
|
182
218
|
get componentId() {
|
|
183
219
|
return componentId;
|
|
@@ -198,12 +234,14 @@ function createComponentDefinitionFromSchema(componentName, componentId, schema)
|
|
|
198
234
|
if (data.delete(entity) && markAsDirty) {
|
|
199
235
|
dirtyIterator.add(entity);
|
|
200
236
|
}
|
|
237
|
+
lastSentData.delete(entity);
|
|
201
238
|
return component || null;
|
|
202
239
|
},
|
|
203
240
|
entityDeleted(entity, markAsDirty) {
|
|
204
241
|
if (data.delete(entity) && markAsDirty) {
|
|
205
242
|
dirtyIterator.add(entity);
|
|
206
243
|
}
|
|
244
|
+
lastSentData.delete(entity);
|
|
207
245
|
},
|
|
208
246
|
getOrNull(entity) {
|
|
209
247
|
const component = data.get(entity);
|
|
@@ -230,6 +268,7 @@ function createComponentDefinitionFromSchema(componentName, componentId, schema)
|
|
|
230
268
|
const usedValue = value === undefined ? schema.create() : schema.extend ? schema.extend(value) : value;
|
|
231
269
|
data.set(entity, usedValue);
|
|
232
270
|
dirtyIterator.add(entity);
|
|
271
|
+
lastSentData.delete(entity);
|
|
233
272
|
return usedValue;
|
|
234
273
|
},
|
|
235
274
|
getMutableOrNull(entity) {
|
|
@@ -267,9 +306,41 @@ function createComponentDefinitionFromSchema(componentName, componentId, schema)
|
|
|
267
306
|
yield entity;
|
|
268
307
|
}
|
|
269
308
|
},
|
|
270
|
-
getCrdtUpdates: createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data),
|
|
271
|
-
updateFromCrdt: createUpdateLwwFromCrdt(componentId, timestamps, schema, data),
|
|
309
|
+
getCrdtUpdates: createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data, lastSentData),
|
|
310
|
+
updateFromCrdt: createUpdateLwwFromCrdt(componentId, timestamps, schema, data, lastSentData),
|
|
311
|
+
__forceUpdateFromCrdt: createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data),
|
|
312
|
+
__dry_run_updateFromCrdt: createCrdtRuleValidator(timestamps, schema, data, lastSentData),
|
|
272
313
|
dumpCrdtStateToBuffer: createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, data),
|
|
314
|
+
validateBeforeChange(entityOrCb, cb) {
|
|
315
|
+
if (arguments.length === 1) {
|
|
316
|
+
// Second overload: just callback (global validation)
|
|
317
|
+
validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
|
|
318
|
+
}
|
|
319
|
+
else {
|
|
320
|
+
if (cb) {
|
|
321
|
+
validateCallbacks.set(entityOrCb, cb);
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
},
|
|
325
|
+
__run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
|
|
326
|
+
const cb = entity && validateCallbacks.get(entity);
|
|
327
|
+
const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
|
|
328
|
+
const currentValue = data.get(entity);
|
|
329
|
+
const value = { entity, currentValue, newValue, senderAddress, createdBy };
|
|
330
|
+
const globalResult = globalCb?.(value) ?? true;
|
|
331
|
+
const entityResult = (globalResult && cb?.(value)) ?? true;
|
|
332
|
+
return globalResult && entityResult;
|
|
333
|
+
},
|
|
334
|
+
getCrdtState(entity) {
|
|
335
|
+
const componentData = data.get(entity);
|
|
336
|
+
const timestamp = timestamps.get(entity);
|
|
337
|
+
if (componentData && timestamp !== undefined) {
|
|
338
|
+
const buffer = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
339
|
+
schema.serialize((0, readonly_1.deepReadonly)(componentData), buffer);
|
|
340
|
+
return { data: buffer.toBinary(), timestamp };
|
|
341
|
+
}
|
|
342
|
+
return null;
|
|
343
|
+
},
|
|
273
344
|
onChange(entity, cb) {
|
|
274
345
|
const cbs = onChangeCallbacks.get(entity) ?? [];
|
|
275
346
|
cbs.push(cb);
|
package/dist-cjs/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';
|
|
@@ -12,9 +12,10 @@ export * from './systems/assetLoad';
|
|
|
12
12
|
export * from './systems/async-task';
|
|
13
13
|
export * from './systems/tween';
|
|
14
14
|
export * from './systems/triggerArea';
|
|
15
|
+
export * from './systems/physics';
|
|
15
16
|
export * from './engine/entity';
|
|
16
17
|
export * from './components/types';
|
|
17
|
-
import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended } from './components/types';
|
|
18
|
+
import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended, ParticleSystemComponentDefinitionExtended, ICreatedBy } from './components/types';
|
|
18
19
|
import { NameComponent } from './components/manual/Name';
|
|
19
20
|
import { TagsComponentDefinitionExtended } from './components/manual/Tags';
|
|
20
21
|
export declare const Transform: TransformComponentExtended;
|
|
@@ -31,6 +32,7 @@ export declare const VirtualCamera: VirtualCameraComponentDefinitionExtended;
|
|
|
31
32
|
export declare const InputModifier: InputModifierComponentDefinitionExtended;
|
|
32
33
|
export declare const LightSource: LightSourceComponentDefinitionExtended;
|
|
33
34
|
export declare const TriggerArea: TriggerAreaComponentDefinitionExtended;
|
|
35
|
+
export declare const ParticleSystem: ParticleSystemComponentDefinitionExtended;
|
|
34
36
|
/**
|
|
35
37
|
* @alpha
|
|
36
38
|
* This is going to be used for sync components through a server.
|
|
@@ -47,6 +49,7 @@ export declare const NetworkEntity: INetowrkEntity;
|
|
|
47
49
|
* Tag a entity to be syncronized through comms
|
|
48
50
|
*/
|
|
49
51
|
export declare const NetworkParent: INetowrkParent;
|
|
52
|
+
export declare const CreatedBy: ICreatedBy;
|
|
50
53
|
export * from './components/generated/global.gen';
|
|
51
54
|
export * from './components/generated/types.gen';
|
|
52
55
|
export * from './serialization/crdt';
|
package/dist-cjs/index.js
CHANGED
|
@@ -26,14 +26,14 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
26
26
|
return result;
|
|
27
27
|
};
|
|
28
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.Tags = exports.Name = exports.MeshCollider = exports.MeshRenderer = exports.Material = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Transform = exports.components = exports.cyclicParentingChecker = void 0;
|
|
29
|
+
exports.CreatedBy = exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.ParticleSystem = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.Tags = exports.Name = exports.MeshCollider = exports.MeshRenderer = exports.Material = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Transform = exports.components = exports.cyclicParentingChecker = void 0;
|
|
30
30
|
// The order of the following imports matters. Please do not auto-sort
|
|
31
31
|
__exportStar(require("./engine"), exports);
|
|
32
32
|
__exportStar(require("./schemas"), exports);
|
|
33
|
+
__exportStar(require("./runtime/globals"), exports);
|
|
33
34
|
__exportStar(require("./runtime/initialization"), exports);
|
|
34
35
|
__exportStar(require("./runtime/types"), exports);
|
|
35
36
|
__exportStar(require("./runtime/helpers"), exports);
|
|
36
|
-
__exportStar(require("./runtime/globals"), exports);
|
|
37
37
|
var cyclicParentingChecker_1 = require("./systems/cyclicParentingChecker");
|
|
38
38
|
Object.defineProperty(exports, "cyclicParentingChecker", { enumerable: true, get: function () { return cyclicParentingChecker_1.cyclicParentingChecker; } });
|
|
39
39
|
__exportStar(require("./systems/events"), exports);
|
|
@@ -43,6 +43,7 @@ __exportStar(require("./systems/assetLoad"), exports);
|
|
|
43
43
|
__exportStar(require("./systems/async-task"), exports);
|
|
44
44
|
__exportStar(require("./systems/tween"), exports);
|
|
45
45
|
__exportStar(require("./systems/triggerArea"), exports);
|
|
46
|
+
__exportStar(require("./systems/physics"), exports);
|
|
46
47
|
__exportStar(require("./engine/entity"), exports);
|
|
47
48
|
__exportStar(require("./components/types"), exports);
|
|
48
49
|
// @internal
|
|
@@ -64,6 +65,8 @@ exports.VirtualCamera = components.VirtualCamera(initialization_1.engine);
|
|
|
64
65
|
exports.InputModifier = components.InputModifier(initialization_1.engine);
|
|
65
66
|
exports.LightSource = components.LightSource(initialization_1.engine);
|
|
66
67
|
exports.TriggerArea = components.TriggerArea(initialization_1.engine);
|
|
68
|
+
exports.ParticleSystem =
|
|
69
|
+
/* @__PURE__*/ components.ParticleSystem(initialization_1.engine);
|
|
67
70
|
/**
|
|
68
71
|
* @alpha
|
|
69
72
|
* This is going to be used for sync components through a server.
|
|
@@ -80,6 +83,7 @@ exports.NetworkEntity = components.NetworkEntity(initialization_1.engine);
|
|
|
80
83
|
* Tag a entity to be syncronized through comms
|
|
81
84
|
*/
|
|
82
85
|
exports.NetworkParent = components.NetworkParent(initialization_1.engine);
|
|
86
|
+
exports.CreatedBy = components.CreatedBy(initialization_1.engine);
|
|
83
87
|
// export components for global engine
|
|
84
88
|
__exportStar(require("./components/generated/global.gen"), exports);
|
|
85
89
|
__exportStar(require("./components/generated/types.gen"), exports);
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
/**
|
|
3
|
-
*
|
|
4
|
-
* @public
|
|
3
|
+
* Internal utilities for standardized globalThis access.
|
|
5
4
|
*/
|
|
6
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
6
|
exports.setGlobalPolyfill = exports.getGlobal = void 0;
|
|
@@ -17,5 +17,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
exports.createTimers = void 0;
|
|
18
18
|
__exportStar(require("./coordinates"), exports);
|
|
19
19
|
__exportStar(require("./tree"), exports);
|
|
20
|
+
__exportStar(require("./vectors"), exports);
|
|
20
21
|
var timers_1 = require("./timers");
|
|
21
22
|
Object.defineProperty(exports, "createTimers", { enumerable: true, get: function () { return timers_1.createTimers; } });
|
|
@@ -2,6 +2,12 @@ import { Entity } from '../../engine/entity';
|
|
|
2
2
|
import { ComponentDefinition, IEngine } from '../../engine';
|
|
3
3
|
import { Vector3Type } from '../../schemas/custom/Vector3';
|
|
4
4
|
import { QuaternionType } from '../../schemas/custom/Quaternion';
|
|
5
|
+
/**
|
|
6
|
+
* @public
|
|
7
|
+
* Rotate a vector by a quaternion
|
|
8
|
+
* Uses the formula: v' = q * v * q^(-1), optimized version
|
|
9
|
+
*/
|
|
10
|
+
export declare function rotateVectorByQuaternion(v: Vector3Type, q: QuaternionType): Vector3Type;
|
|
5
11
|
/**
|
|
6
12
|
* Get an iterator of entities that follow a tree structure for a component
|
|
7
13
|
* @public
|
|
@@ -23,7 +23,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.getWorldRotation = exports.getWorldPosition = exports.getEntitiesWithParent = exports.removeEntityWithChildren = exports.getComponentEntityTree = void 0;
|
|
26
|
+
exports.getWorldRotation = exports.getWorldPosition = exports.getEntitiesWithParent = exports.removeEntityWithChildren = exports.getComponentEntityTree = exports.rotateVectorByQuaternion = void 0;
|
|
27
27
|
const components = __importStar(require("../../components"));
|
|
28
28
|
/**
|
|
29
29
|
* @internal
|
|
@@ -61,7 +61,7 @@ function multiplyQuaternions(q1, q2) {
|
|
|
61
61
|
};
|
|
62
62
|
}
|
|
63
63
|
/**
|
|
64
|
-
* @
|
|
64
|
+
* @public
|
|
65
65
|
* Rotate a vector by a quaternion
|
|
66
66
|
* Uses the formula: v' = q * v * q^(-1), optimized version
|
|
67
67
|
*/
|
|
@@ -80,6 +80,7 @@ function rotateVectorByQuaternion(v, q) {
|
|
|
80
80
|
z: iz * qw + iw * -qz + ix * -qy - iy * -qx
|
|
81
81
|
};
|
|
82
82
|
}
|
|
83
|
+
exports.rotateVectorByQuaternion = rotateVectorByQuaternion;
|
|
83
84
|
/** @internal Identity transform values */
|
|
84
85
|
const IDENTITY_POSITION = { x: 0, y: 0, z: 0 };
|
|
85
86
|
const IDENTITY_ROTATION = { x: 0, y: 0, z: 0, w: 1 };
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Vector3 = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Lightweight Vector3 math utilities for internal use.
|
|
6
|
+
* Mirrors the subset of @dcl/ecs-math Vector3 API used by the physics helpers.
|
|
7
|
+
*
|
|
8
|
+
* TEMPORARY WORKAROUND: @dcl/ecs-math ships ESM-only, which breaks the dist-cjs build.
|
|
9
|
+
* The proper fix is to add a CJS build to @dcl/ecs-math upstream, then replace this
|
|
10
|
+
* file with `import { Vector3 } from '@dcl/ecs-math'`.
|
|
11
|
+
*
|
|
12
|
+
* @internal
|
|
13
|
+
*/
|
|
14
|
+
exports.Vector3 = {
|
|
15
|
+
add(a, b) {
|
|
16
|
+
return { x: a.x + b.x, y: a.y + b.y, z: a.z + b.z };
|
|
17
|
+
},
|
|
18
|
+
subtract(a, b) {
|
|
19
|
+
return { x: a.x - b.x, y: a.y - b.y, z: a.z - b.z };
|
|
20
|
+
},
|
|
21
|
+
scale(v, s) {
|
|
22
|
+
return { x: v.x * s, y: v.y * s, z: v.z * s };
|
|
23
|
+
},
|
|
24
|
+
length(v) {
|
|
25
|
+
return Math.sqrt(v.x * v.x + v.y * v.y + v.z * v.z);
|
|
26
|
+
},
|
|
27
|
+
normalize(v) {
|
|
28
|
+
const len = exports.Vector3.length(v);
|
|
29
|
+
if (len === 0)
|
|
30
|
+
return { x: 0, y: 0, z: 0 };
|
|
31
|
+
return { x: v.x / len, y: v.y / len, z: v.z / len };
|
|
32
|
+
},
|
|
33
|
+
equals(a, b) {
|
|
34
|
+
return a.x === b.x && a.y === b.y && a.z === b.z;
|
|
35
|
+
},
|
|
36
|
+
equalsToFloats(v, x, y, z) {
|
|
37
|
+
return v.x === x && v.y === y && v.z === z;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
@@ -12,6 +12,7 @@ import { AssetLoadLoadingStateSystem } from '../../systems/assetLoad';
|
|
|
12
12
|
import { TweenSystem } from '../../systems/tween';
|
|
13
13
|
import { TriggerAreaEventsSystem } from '../../systems/triggerArea';
|
|
14
14
|
import { createTimers, Timers } from '../helpers/timers';
|
|
15
|
+
import { PhysicsSystem } from '../../systems/physics';
|
|
15
16
|
/**
|
|
16
17
|
* @public
|
|
17
18
|
* The engine is the part of the scene that sits in the middle and manages all of the other parts.
|
|
@@ -77,6 +78,12 @@ export { TriggerAreaEventsSystem };
|
|
|
77
78
|
*/
|
|
78
79
|
export declare const timers: Timers;
|
|
79
80
|
export { Timers, createTimers };
|
|
81
|
+
/**
|
|
82
|
+
* @public
|
|
83
|
+
* Physics helpers for applying impulses and forces to the player.
|
|
84
|
+
*/
|
|
85
|
+
export declare const Physics: PhysicsSystem;
|
|
86
|
+
export { PhysicsSystem };
|
|
80
87
|
/**
|
|
81
88
|
* @public
|
|
82
89
|
* Runs an async function
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* init and it'll be changing.
|
|
5
5
|
*/
|
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.executeTask = exports.createTimers = exports.timers = exports.triggerAreaEventsSystem = exports.tweenSystem = exports.assetLoadLoadingStateSystem = exports.videoEventsSystem = exports.raycastSystem = exports.pointerEventsSystem = exports.inputSystem = exports.engine = void 0;
|
|
7
|
+
exports.executeTask = exports.Physics = exports.createTimers = exports.timers = exports.triggerAreaEventsSystem = exports.tweenSystem = exports.assetLoadLoadingStateSystem = exports.videoEventsSystem = exports.raycastSystem = exports.pointerEventsSystem = exports.inputSystem = exports.engine = void 0;
|
|
8
8
|
const engine_1 = require("../../engine");
|
|
9
9
|
const async_task_1 = require("../../systems/async-task");
|
|
10
10
|
const events_1 = require("../../systems/events");
|
|
@@ -18,6 +18,7 @@ const triggerArea_1 = require("../../systems/triggerArea");
|
|
|
18
18
|
const timers_1 = require("../helpers/timers");
|
|
19
19
|
Object.defineProperty(exports, "createTimers", { enumerable: true, get: function () { return timers_1.createTimers; } });
|
|
20
20
|
const globals_1 = require("../globals");
|
|
21
|
+
const physics_1 = require("../../systems/physics");
|
|
21
22
|
/**
|
|
22
23
|
* @public
|
|
23
24
|
* The engine is the part of the scene that sits in the middle and manages all of the other parts.
|
|
@@ -80,6 +81,11 @@ exports.timers = (0, timers_1.createTimers)(exports.engine);
|
|
|
80
81
|
(0, globals_1.setGlobalPolyfill)('clearTimeout', exports.timers.clearTimeout);
|
|
81
82
|
(0, globals_1.setGlobalPolyfill)('setInterval', exports.timers.setInterval);
|
|
82
83
|
(0, globals_1.setGlobalPolyfill)('clearInterval', exports.timers.clearInterval);
|
|
84
|
+
/**
|
|
85
|
+
* @public
|
|
86
|
+
* Physics helpers for applying impulses and forces to the player.
|
|
87
|
+
*/
|
|
88
|
+
exports.Physics = (0, physics_1.createPhysicsSystem)(exports.engine);
|
|
83
89
|
/**
|
|
84
90
|
* Adds pointer event collider system only in DEV env
|
|
85
91
|
*/
|
|
@@ -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
|
+
}
|