@dcl/hammurabi-server 1.0.0-17268386187.commit-b609629
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/CLAUDE.md +90 -0
- package/LICENSE +201 -0
- package/README.md +125 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +79 -0
- package/dist/cli.js.map +1 -0
- package/dist/lib/babylon/avatar-rendering-system.d.ts +16 -0
- package/dist/lib/babylon/avatar-rendering-system.d.ts.map +1 -0
- package/dist/lib/babylon/avatar-rendering-system.js +96 -0
- package/dist/lib/babylon/avatar-rendering-system.js.map +1 -0
- package/dist/lib/babylon/avatars/AvatarRenderer.d.ts +40 -0
- package/dist/lib/babylon/avatars/AvatarRenderer.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/AvatarRenderer.js +260 -0
- package/dist/lib/babylon/avatars/AvatarRenderer.js.map +1 -0
- package/dist/lib/babylon/avatars/CharacterController.d.ts +88 -0
- package/dist/lib/babylon/avatars/CharacterController.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/CharacterController.js +463 -0
- package/dist/lib/babylon/avatars/CharacterController.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/body.d.ts +4 -0
- package/dist/lib/babylon/avatars/adr-65/body.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/body.js +47 -0
- package/dist/lib/babylon/avatars/adr-65/body.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/customizations.d.ts +11 -0
- package/dist/lib/babylon/avatars/adr-65/customizations.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/customizations.js +111 -0
- package/dist/lib/babylon/avatars/adr-65/customizations.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/emote.d.ts +9 -0
- package/dist/lib/babylon/avatars/adr-65/emote.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/emote.js +46 -0
- package/dist/lib/babylon/avatars/adr-65/emote.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/loader.d.ts +8 -0
- package/dist/lib/babylon/avatars/adr-65/loader.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/loader.js +54 -0
- package/dist/lib/babylon/avatars/adr-65/loader.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/representation.d.ts +12 -0
- package/dist/lib/babylon/avatars/adr-65/representation.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/representation.js +77 -0
- package/dist/lib/babylon/avatars/adr-65/representation.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/slots.d.ts +5 -0
- package/dist/lib/babylon/avatars/adr-65/slots.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/slots.js +62 -0
- package/dist/lib/babylon/avatars/adr-65/slots.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/types.d.ts +17 -0
- package/dist/lib/babylon/avatars/adr-65/types.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/types.js +3 -0
- package/dist/lib/babylon/avatars/adr-65/types.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/utils.d.ts +8 -0
- package/dist/lib/babylon/avatars/adr-65/utils.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/utils.js +29 -0
- package/dist/lib/babylon/avatars/adr-65/utils.js.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/wearable.d.ts +7 -0
- package/dist/lib/babylon/avatars/adr-65/wearable.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/adr-65/wearable.js +64 -0
- package/dist/lib/babylon/avatars/adr-65/wearable.js.map +1 -0
- package/dist/lib/babylon/avatars/avatar-asset-manager.d.ts +12 -0
- package/dist/lib/babylon/avatars/avatar-asset-manager.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/avatar-asset-manager.js +31 -0
- package/dist/lib/babylon/avatars/avatar-asset-manager.js.map +1 -0
- package/dist/lib/babylon/avatars/loader.d.ts +6 -0
- package/dist/lib/babylon/avatars/loader.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/loader.js +108 -0
- package/dist/lib/babylon/avatars/loader.js.map +1 -0
- package/dist/lib/babylon/avatars/urn.d.ts +2 -0
- package/dist/lib/babylon/avatars/urn.d.ts.map +1 -0
- package/dist/lib/babylon/avatars/urn.js +9 -0
- package/dist/lib/babylon/avatars/urn.js.map +1 -0
- package/dist/lib/babylon/index.d.ts +6 -0
- package/dist/lib/babylon/index.d.ts.map +1 -0
- package/dist/lib/babylon/index.js +85 -0
- package/dist/lib/babylon/index.js.map +1 -0
- package/dist/lib/babylon/input.d.ts +35 -0
- package/dist/lib/babylon/input.d.ts.map +1 -0
- package/dist/lib/babylon/input.js +137 -0
- package/dist/lib/babylon/input.js.map +1 -0
- package/dist/lib/babylon/scene/AssetManager.d.ts +19 -0
- package/dist/lib/babylon/scene/AssetManager.d.ts.map +1 -0
- package/dist/lib/babylon/scene/AssetManager.js +271 -0
- package/dist/lib/babylon/scene/AssetManager.js.map +1 -0
- package/dist/lib/babylon/scene/BabylonEntity.d.ts +84 -0
- package/dist/lib/babylon/scene/BabylonEntity.d.ts.map +1 -0
- package/dist/lib/babylon/scene/BabylonEntity.js +174 -0
- package/dist/lib/babylon/scene/BabylonEntity.js.map +1 -0
- package/dist/lib/babylon/scene/connect-context-rpc.d.ts +8 -0
- package/dist/lib/babylon/scene/connect-context-rpc.d.ts.map +1 -0
- package/dist/lib/babylon/scene/connect-context-rpc.js +210 -0
- package/dist/lib/babylon/scene/connect-context-rpc.js.map +1 -0
- package/dist/lib/babylon/scene/coordinates.d.ts +5 -0
- package/dist/lib/babylon/scene/coordinates.d.ts.map +1 -0
- package/dist/lib/babylon/scene/coordinates.js +17 -0
- package/dist/lib/babylon/scene/coordinates.js.map +1 -0
- package/dist/lib/babylon/scene/hot-reload.d.ts +9 -0
- package/dist/lib/babylon/scene/hot-reload.d.ts.map +1 -0
- package/dist/lib/babylon/scene/hot-reload.js +65 -0
- package/dist/lib/babylon/scene/hot-reload.js.map +1 -0
- package/dist/lib/babylon/scene/load.d.ts +54 -0
- package/dist/lib/babylon/scene/load.d.ts.map +1 -0
- package/dist/lib/babylon/scene/load.js +154 -0
- package/dist/lib/babylon/scene/load.js.map +1 -0
- package/dist/lib/babylon/scene/logic/apply-animations.d.ts +3 -0
- package/dist/lib/babylon/scene/logic/apply-animations.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/apply-animations.js +50 -0
- package/dist/lib/babylon/scene/logic/apply-animations.js.map +1 -0
- package/dist/lib/babylon/scene/logic/billboards.d.ts +3 -0
- package/dist/lib/babylon/scene/logic/billboards.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/billboards.js +12 -0
- package/dist/lib/babylon/scene/logic/billboards.js.map +1 -0
- package/dist/lib/babylon/scene/logic/camera-follows-player.d.ts +7 -0
- package/dist/lib/babylon/scene/logic/camera-follows-player.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/camera-follows-player.js +35 -0
- package/dist/lib/babylon/scene/logic/camera-follows-player.js.map +1 -0
- package/dist/lib/babylon/scene/logic/colliders.d.ts +9 -0
- package/dist/lib/babylon/scene/logic/colliders.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/colliders.js +79 -0
- package/dist/lib/babylon/scene/logic/colliders.js.map +1 -0
- package/dist/lib/babylon/scene/logic/cyclic-transform.d.ts +12 -0
- package/dist/lib/babylon/scene/logic/cyclic-transform.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/cyclic-transform.js +67 -0
- package/dist/lib/babylon/scene/logic/cyclic-transform.js.map +1 -0
- package/dist/lib/babylon/scene/logic/delayed-interpolation.d.ts +27 -0
- package/dist/lib/babylon/scene/logic/delayed-interpolation.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/delayed-interpolation.js +49 -0
- package/dist/lib/babylon/scene/logic/delayed-interpolation.js.map +1 -0
- package/dist/lib/babylon/scene/logic/easings.d.ts +7 -0
- package/dist/lib/babylon/scene/logic/easings.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/easings.js +100 -0
- package/dist/lib/babylon/scene/logic/easings.js.map +1 -0
- package/dist/lib/babylon/scene/logic/hide-camera-obstuction-system.d.ts +5 -0
- package/dist/lib/babylon/scene/logic/hide-camera-obstuction-system.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/hide-camera-obstuction-system.js +145 -0
- package/dist/lib/babylon/scene/logic/hide-camera-obstuction-system.js.map +1 -0
- package/dist/lib/babylon/scene/logic/local-avatar-scene.d.ts +10 -0
- package/dist/lib/babylon/scene/logic/local-avatar-scene.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/local-avatar-scene.js +50 -0
- package/dist/lib/babylon/scene/logic/local-avatar-scene.js.map +1 -0
- package/dist/lib/babylon/scene/logic/pointer-events.d.ts +12 -0
- package/dist/lib/babylon/scene/logic/pointer-events.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/pointer-events.js +199 -0
- package/dist/lib/babylon/scene/logic/pointer-events.js.map +1 -0
- package/dist/lib/babylon/scene/logic/raycasts.d.ts +21 -0
- package/dist/lib/babylon/scene/logic/raycasts.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/raycasts.js +142 -0
- package/dist/lib/babylon/scene/logic/raycasts.js.map +1 -0
- package/dist/lib/babylon/scene/logic/static-entities.d.ts +18 -0
- package/dist/lib/babylon/scene/logic/static-entities.d.ts.map +1 -0
- package/dist/lib/babylon/scene/logic/static-entities.js +64 -0
- package/dist/lib/babylon/scene/logic/static-entities.js.map +1 -0
- package/dist/lib/babylon/scene/nodejs-runtime.d.ts +4 -0
- package/dist/lib/babylon/scene/nodejs-runtime.d.ts.map +1 -0
- package/dist/lib/babylon/scene/nodejs-runtime.js +100 -0
- package/dist/lib/babylon/scene/nodejs-runtime.js.map +1 -0
- package/dist/lib/babylon/scene/scene-context.d.ts +116 -0
- package/dist/lib/babylon/scene/scene-context.d.ts.map +1 -0
- package/dist/lib/babylon/scene/scene-context.js +492 -0
- package/dist/lib/babylon/scene/scene-context.js.map +1 -0
- package/dist/lib/babylon/scene/scene-culling.d.ts +6 -0
- package/dist/lib/babylon/scene/scene-culling.d.ts.map +1 -0
- package/dist/lib/babylon/scene/scene-culling.js +23 -0
- package/dist/lib/babylon/scene/scene-culling.js.map +1 -0
- package/dist/lib/babylon/scene/update-scheduler.d.ts +7 -0
- package/dist/lib/babylon/scene/update-scheduler.d.ts.map +1 -0
- package/dist/lib/babylon/scene/update-scheduler.js +40 -0
- package/dist/lib/babylon/scene/update-scheduler.js.map +1 -0
- package/dist/lib/babylon/time-based-animation.d.ts +13 -0
- package/dist/lib/babylon/time-based-animation.d.ts.map +1 -0
- package/dist/lib/babylon/time-based-animation.js +35 -0
- package/dist/lib/babylon/time-based-animation.js.map +1 -0
- package/dist/lib/babylon/visual/ambientLights.d.ts +6 -0
- package/dist/lib/babylon/visual/ambientLights.d.ts.map +1 -0
- package/dist/lib/babylon/visual/ambientLights.js +65 -0
- package/dist/lib/babylon/visual/ambientLights.js.map +1 -0
- package/dist/lib/babylon/visual/glowLayer.d.ts +6 -0
- package/dist/lib/babylon/visual/glowLayer.d.ts.map +1 -0
- package/dist/lib/babylon/visual/glowLayer.js +59 -0
- package/dist/lib/babylon/visual/glowLayer.js.map +1 -0
- package/dist/lib/babylon/visual/parcelOutline.d.ts +7 -0
- package/dist/lib/babylon/visual/parcelOutline.d.ts.map +1 -0
- package/dist/lib/babylon/visual/parcelOutline.js +88 -0
- package/dist/lib/babylon/visual/parcelOutline.js.map +1 -0
- package/dist/lib/babylon/visual/reticle.d.ts +3 -0
- package/dist/lib/babylon/visual/reticle.d.ts.map +1 -0
- package/dist/lib/babylon/visual/reticle.js +60 -0
- package/dist/lib/babylon/visual/reticle.js.map +1 -0
- package/dist/lib/babylon/visual/ui.d.ts +8 -0
- package/dist/lib/babylon/visual/ui.d.ts.map +1 -0
- package/dist/lib/babylon/visual/ui.js +54 -0
- package/dist/lib/babylon/visual/ui.js.map +1 -0
- package/dist/lib/common-runtime/game-loop.d.ts +4 -0
- package/dist/lib/common-runtime/game-loop.d.ts.map +1 -0
- package/dist/lib/common-runtime/game-loop.js +31 -0
- package/dist/lib/common-runtime/game-loop.js.map +1 -0
- package/dist/lib/common-runtime/modules.d.ts +244 -0
- package/dist/lib/common-runtime/modules.d.ts.map +1 -0
- package/dist/lib/common-runtime/modules.js +74 -0
- package/dist/lib/common-runtime/modules.js.map +1 -0
- package/dist/lib/common-runtime/startup.d.ts +8 -0
- package/dist/lib/common-runtime/startup.d.ts.map +1 -0
- package/dist/lib/common-runtime/startup.js +45 -0
- package/dist/lib/common-runtime/startup.js.map +1 -0
- package/dist/lib/common-runtime/types.d.ts +15 -0
- package/dist/lib/common-runtime/types.d.ts.map +1 -0
- package/dist/lib/common-runtime/types.js +7 -0
- package/dist/lib/common-runtime/types.js.map +1 -0
- package/dist/lib/decentraland/ByteBuffer/index.d.ts +75 -0
- package/dist/lib/decentraland/ByteBuffer/index.d.ts.map +1 -0
- package/dist/lib/decentraland/ByteBuffer/index.js +279 -0
- package/dist/lib/decentraland/ByteBuffer/index.js.map +1 -0
- package/dist/lib/decentraland/ByteBuffer/types.d.ts +109 -0
- package/dist/lib/decentraland/ByteBuffer/types.d.ts.map +1 -0
- package/dist/lib/decentraland/ByteBuffer/types.js +3 -0
- package/dist/lib/decentraland/ByteBuffer/types.js.map +1 -0
- package/dist/lib/decentraland/communications/CommsTransportWrapper.d.ts +45 -0
- package/dist/lib/decentraland/communications/CommsTransportWrapper.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/CommsTransportWrapper.js +174 -0
- package/dist/lib/decentraland/communications/CommsTransportWrapper.js.map +1 -0
- package/dist/lib/decentraland/communications/avatar-communication-system.d.ts +18 -0
- package/dist/lib/decentraland/communications/avatar-communication-system.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/avatar-communication-system.js +203 -0
- package/dist/lib/decentraland/communications/avatar-communication-system.js.map +1 -0
- package/dist/lib/decentraland/communications/connect-adapter.d.ts +5 -0
- package/dist/lib/decentraland/communications/connect-adapter.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/connect-adapter.js +110 -0
- package/dist/lib/decentraland/communications/connect-adapter.js.map +1 -0
- package/dist/lib/decentraland/communications/connect-transport.d.ts +5 -0
- package/dist/lib/decentraland/communications/connect-transport.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/connect-transport.js +32 -0
- package/dist/lib/decentraland/communications/connect-transport.js.map +1 -0
- package/dist/lib/decentraland/communications/networked-profile-system.d.ts +10 -0
- package/dist/lib/decentraland/communications/networked-profile-system.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/networked-profile-system.js +73 -0
- package/dist/lib/decentraland/communications/networked-profile-system.js.map +1 -0
- package/dist/lib/decentraland/communications/player-entity-manager.d.ts +55 -0
- package/dist/lib/decentraland/communications/player-entity-manager.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/player-entity-manager.js +167 -0
- package/dist/lib/decentraland/communications/player-entity-manager.js.map +1 -0
- package/dist/lib/decentraland/communications/position-report-system.d.ts +8 -0
- package/dist/lib/decentraland/communications/position-report-system.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/position-report-system.js +51 -0
- package/dist/lib/decentraland/communications/position-report-system.js.map +1 -0
- package/dist/lib/decentraland/communications/realm-communications-system.d.ts +17 -0
- package/dist/lib/decentraland/communications/realm-communications-system.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/realm-communications-system.js +111 -0
- package/dist/lib/decentraland/communications/realm-communications-system.js.map +1 -0
- package/dist/lib/decentraland/communications/scene-comms.d.ts +9 -0
- package/dist/lib/decentraland/communications/scene-comms.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/scene-comms.js +20 -0
- package/dist/lib/decentraland/communications/scene-comms.js.map +1 -0
- package/dist/lib/decentraland/communications/transports/livekit.d.ts +27 -0
- package/dist/lib/decentraland/communications/transports/livekit.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/transports/livekit.js +135 -0
- package/dist/lib/decentraland/communications/transports/livekit.js.map +1 -0
- package/dist/lib/decentraland/communications/transports/ws-room.d.ts +26 -0
- package/dist/lib/decentraland/communications/transports/ws-room.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/transports/ws-room.js +235 -0
- package/dist/lib/decentraland/communications/transports/ws-room.js.map +1 -0
- package/dist/lib/decentraland/communications/types.d.ts +76 -0
- package/dist/lib/decentraland/communications/types.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/types.js +6 -0
- package/dist/lib/decentraland/communications/types.js.map +1 -0
- package/dist/lib/decentraland/communications/ws-async-channel.d.ts +6 -0
- package/dist/lib/decentraland/communications/ws-async-channel.d.ts.map +1 -0
- package/dist/lib/decentraland/communications/ws-async-channel.js +52 -0
- package/dist/lib/decentraland/communications/ws-async-channel.js.map +1 -0
- package/dist/lib/decentraland/crdt-internal/components.d.ts +156 -0
- package/dist/lib/decentraland/crdt-internal/components.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-internal/components.js +8 -0
- package/dist/lib/decentraland/crdt-internal/components.js.map +1 -0
- package/dist/lib/decentraland/crdt-internal/conflict-resolution.d.ts +45 -0
- package/dist/lib/decentraland/crdt-internal/conflict-resolution.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-internal/conflict-resolution.js +49 -0
- package/dist/lib/decentraland/crdt-internal/conflict-resolution.js.map +1 -0
- package/dist/lib/decentraland/crdt-internal/dataCompare.d.ts +6 -0
- package/dist/lib/decentraland/crdt-internal/dataCompare.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-internal/dataCompare.js +34 -0
- package/dist/lib/decentraland/crdt-internal/dataCompare.js.map +1 -0
- package/dist/lib/decentraland/crdt-internal/generational-index-pool.d.ts +22 -0
- package/dist/lib/decentraland/crdt-internal/generational-index-pool.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-internal/generational-index-pool.js +91 -0
- package/dist/lib/decentraland/crdt-internal/generational-index-pool.js.map +1 -0
- package/dist/lib/decentraland/crdt-internal/grow-only-set.d.ts +10 -0
- package/dist/lib/decentraland/crdt-internal/grow-only-set.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-internal/grow-only-set.js +129 -0
- package/dist/lib/decentraland/crdt-internal/grow-only-set.js.map +1 -0
- package/dist/lib/decentraland/crdt-internal/last-write-win-element-set.d.ts +11 -0
- package/dist/lib/decentraland/crdt-internal/last-write-win-element-set.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-internal/last-write-win-element-set.js +224 -0
- package/dist/lib/decentraland/crdt-internal/last-write-win-element-set.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/appendValue.d.ts +15 -0
- package/dist/lib/decentraland/crdt-wire-protocol/appendValue.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/appendValue.js +50 -0
- package/dist/lib/decentraland/crdt-wire-protocol/appendValue.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/crdtMessageProtocol.d.ts +31 -0
- package/dist/lib/decentraland/crdt-wire-protocol/crdtMessageProtocol.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/crdtMessageProtocol.js +72 -0
- package/dist/lib/decentraland/crdt-wire-protocol/crdtMessageProtocol.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteComponent.d.ts +14 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteComponent.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteComponent.js +44 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteComponent.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteEntity.d.ts +11 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteEntity.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteEntity.js +35 -0
- package/dist/lib/decentraland/crdt-wire-protocol/deleteEntity.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/index.d.ts +8 -0
- package/dist/lib/decentraland/crdt-wire-protocol/index.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/index.js +24 -0
- package/dist/lib/decentraland/crdt-wire-protocol/index.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/message.d.ts +17 -0
- package/dist/lib/decentraland/crdt-wire-protocol/message.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/message.js +49 -0
- package/dist/lib/decentraland/crdt-wire-protocol/message.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/prettyPrint.d.ts +4 -0
- package/dist/lib/decentraland/crdt-wire-protocol/prettyPrint.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/prettyPrint.js +26 -0
- package/dist/lib/decentraland/crdt-wire-protocol/prettyPrint.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/putComponent.d.ts +15 -0
- package/dist/lib/decentraland/crdt-wire-protocol/putComponent.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/putComponent.js +48 -0
- package/dist/lib/decentraland/crdt-wire-protocol/putComponent.js.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/types.d.ts +80 -0
- package/dist/lib/decentraland/crdt-wire-protocol/types.d.ts.map +1 -0
- package/dist/lib/decentraland/crdt-wire-protocol/types.js +15 -0
- package/dist/lib/decentraland/crdt-wire-protocol/types.js.map +1 -0
- package/dist/lib/decentraland/identifiers.d.ts +6 -0
- package/dist/lib/decentraland/identifiers.d.ts.map +1 -0
- package/dist/lib/decentraland/identifiers.js +22 -0
- package/dist/lib/decentraland/identifiers.js.map +1 -0
- package/dist/lib/decentraland/identity/avatar.d.ts +4 -0
- package/dist/lib/decentraland/identity/avatar.d.ts.map +1 -0
- package/dist/lib/decentraland/identity/avatar.js +57 -0
- package/dist/lib/decentraland/identity/avatar.js.map +1 -0
- package/dist/lib/decentraland/identity/login.d.ts +8 -0
- package/dist/lib/decentraland/identity/login.d.ts.map +1 -0
- package/dist/lib/decentraland/identity/login.js +121 -0
- package/dist/lib/decentraland/identity/login.js.map +1 -0
- package/dist/lib/decentraland/identity/signed-fetch.d.ts +17 -0
- package/dist/lib/decentraland/identity/signed-fetch.d.ts.map +1 -0
- package/dist/lib/decentraland/identity/signed-fetch.js +47 -0
- package/dist/lib/decentraland/identity/signed-fetch.js.map +1 -0
- package/dist/lib/decentraland/identity/types.d.ts +11 -0
- package/dist/lib/decentraland/identity/types.d.ts.map +1 -0
- package/dist/lib/decentraland/identity/types.js +3 -0
- package/dist/lib/decentraland/identity/types.js.map +1 -0
- package/dist/lib/decentraland/positions.d.ts +15 -0
- package/dist/lib/decentraland/positions.d.ts.map +1 -0
- package/dist/lib/decentraland/positions.js +40 -0
- package/dist/lib/decentraland/positions.js.map +1 -0
- package/dist/lib/decentraland/realm/resolution.d.ts +2 -0
- package/dist/lib/decentraland/realm/resolution.d.ts.map +1 -0
- package/dist/lib/decentraland/realm/resolution.js +39 -0
- package/dist/lib/decentraland/realm/resolution.js.map +1 -0
- package/dist/lib/decentraland/scene/content-server-entity.d.ts +34 -0
- package/dist/lib/decentraland/scene/content-server-entity.d.ts.map +1 -0
- package/dist/lib/decentraland/scene/content-server-entity.js +22 -0
- package/dist/lib/decentraland/scene/content-server-entity.js.map +1 -0
- package/dist/lib/decentraland/scene/spawn-points.d.ts +16 -0
- package/dist/lib/decentraland/scene/spawn-points.d.ts.map +1 -0
- package/dist/lib/decentraland/scene/spawn-points.js +78 -0
- package/dist/lib/decentraland/scene/spawn-points.js.map +1 -0
- package/dist/lib/decentraland/scene/types.d.ts +38 -0
- package/dist/lib/decentraland/scene/types.d.ts.map +1 -0
- package/dist/lib/decentraland/scene/types.js +3 -0
- package/dist/lib/decentraland/scene/types.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/animator-component.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/animator-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/animator-component.js +12 -0
- package/dist/lib/decentraland/sdk-components/animator-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/avatar-base.d.ts +5 -0
- package/dist/lib/decentraland/sdk-components/avatar-base.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/avatar-base.js +40 -0
- package/dist/lib/decentraland/sdk-components/avatar-base.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/avatar-customizations.d.ts +5 -0
- package/dist/lib/decentraland/sdk-components/avatar-customizations.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/avatar-customizations.js +9 -0
- package/dist/lib/decentraland/sdk-components/avatar-customizations.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/avatar-shape.d.ts +5 -0
- package/dist/lib/decentraland/sdk-components/avatar-shape.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/avatar-shape.js +33 -0
- package/dist/lib/decentraland/sdk-components/avatar-shape.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/billboard-component.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/billboard-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/billboard-component.js +15 -0
- package/dist/lib/decentraland/sdk-components/billboard-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/delayed-interpolation.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/delayed-interpolation.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/delayed-interpolation.js +15 -0
- package/dist/lib/decentraland/sdk-components/delayed-interpolation.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/engine-info.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/engine-info.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/engine-info.js +7 -0
- package/dist/lib/decentraland/sdk-components/engine-info.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/gltf-component.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/gltf-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/gltf-component.js +114 -0
- package/dist/lib/decentraland/sdk-components/gltf-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/gltf-loading-state.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/gltf-loading-state.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/gltf-loading-state.js +7 -0
- package/dist/lib/decentraland/sdk-components/gltf-loading-state.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/material-component.d.ts +5 -0
- package/dist/lib/decentraland/sdk-components/material-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/material-component.js +92 -0
- package/dist/lib/decentraland/sdk-components/material-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/mesh-collider-component.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/mesh-collider-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/mesh-collider-component.js +37 -0
- package/dist/lib/decentraland/sdk-components/mesh-collider-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/mesh-renderer-component.d.ts +5 -0
- package/dist/lib/decentraland/sdk-components/mesh-renderer-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/mesh-renderer-component.js +111 -0
- package/dist/lib/decentraland/sdk-components/mesh-renderer-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/pb-based-component-helper.d.ts +10 -0
- package/dist/lib/decentraland/sdk-components/pb-based-component-helper.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/pb-based-component-helper.js +23 -0
- package/dist/lib/decentraland/sdk-components/pb-based-component-helper.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/player-identity-data.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/player-identity-data.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/player-identity-data.js +7 -0
- package/dist/lib/decentraland/sdk-components/player-identity-data.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/pointer-events-result.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/pointer-events-result.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/pointer-events-result.js +7 -0
- package/dist/lib/decentraland/sdk-components/pointer-events-result.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/pointer-events.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/pointer-events.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/pointer-events.js +15 -0
- package/dist/lib/decentraland/sdk-components/pointer-events.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/raycast-component.d.ts +5 -0
- package/dist/lib/decentraland/sdk-components/raycast-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/raycast-component.js +66 -0
- package/dist/lib/decentraland/sdk-components/raycast-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/transform-component.d.ts +13 -0
- package/dist/lib/decentraland/sdk-components/transform-component.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/transform-component.js +84 -0
- package/dist/lib/decentraland/sdk-components/transform-component.js.map +1 -0
- package/dist/lib/decentraland/sdk-components/tween.d.ts +3 -0
- package/dist/lib/decentraland/sdk-components/tween.d.ts.map +1 -0
- package/dist/lib/decentraland/sdk-components/tween.js +15 -0
- package/dist/lib/decentraland/sdk-components/tween.js.map +1 -0
- package/dist/lib/decentraland/state.d.ts +24 -0
- package/dist/lib/decentraland/state.d.ts.map +1 -0
- package/dist/lib/decentraland/state.js +16 -0
- package/dist/lib/decentraland/state.js.map +1 -0
- package/dist/lib/decentraland/system.d.ts +7 -0
- package/dist/lib/decentraland/system.d.ts.map +1 -0
- package/dist/lib/decentraland/system.js +13 -0
- package/dist/lib/decentraland/system.js.map +1 -0
- package/dist/lib/decentraland/types.d.ts +9 -0
- package/dist/lib/decentraland/types.d.ts.map +1 -0
- package/dist/lib/decentraland/types.js +3 -0
- package/dist/lib/decentraland/types.js.map +1 -0
- package/dist/lib/decentraland/virtual-scene.d.ts +12 -0
- package/dist/lib/decentraland/virtual-scene.d.ts.map +1 -0
- package/dist/lib/decentraland/virtual-scene.js +3 -0
- package/dist/lib/decentraland/virtual-scene.js.map +1 -0
- package/dist/lib/engine-main.d.ts +8 -0
- package/dist/lib/engine-main.d.ts.map +1 -0
- package/dist/lib/engine-main.js +103 -0
- package/dist/lib/engine-main.js.map +1 -0
- package/dist/lib/misc/atom.d.ts +13 -0
- package/dist/lib/misc/atom.d.ts.map +1 -0
- package/dist/lib/misc/atom.js +66 -0
- package/dist/lib/misc/atom.js.map +1 -0
- package/dist/lib/misc/bit-operations.d.ts +3 -0
- package/dist/lib/misc/bit-operations.d.ts.map +1 -0
- package/dist/lib/misc/bit-operations.js +14 -0
- package/dist/lib/misc/bit-operations.js.map +1 -0
- package/dist/lib/misc/flat-fetch.d.ts +16 -0
- package/dist/lib/misc/flat-fetch.d.ts.map +1 -0
- package/dist/lib/misc/flat-fetch.js +26 -0
- package/dist/lib/misc/flat-fetch.js.map +1 -0
- package/dist/lib/misc/json.d.ts +3 -0
- package/dist/lib/misc/json.d.ts.map +1 -0
- package/dist/lib/misc/json.js +24 -0
- package/dist/lib/misc/json.js.map +1 -0
- package/dist/lib/misc/logger.d.ts +6 -0
- package/dist/lib/misc/logger.d.ts.map +1 -0
- package/dist/lib/misc/logger.js +24 -0
- package/dist/lib/misc/logger.js.map +1 -0
- package/dist/lib/misc/memoize.d.ts +2 -0
- package/dist/lib/misc/memoize.d.ts.map +1 -0
- package/dist/lib/misc/memoize.js +16 -0
- package/dist/lib/misc/memoize.js.map +1 -0
- package/dist/lib/misc/promises.d.ts +3 -0
- package/dist/lib/misc/promises.d.ts.map +1 -0
- package/dist/lib/misc/promises.js +14 -0
- package/dist/lib/misc/promises.js.map +1 -0
- package/dist/lib/polyfills/xmlhttprequest.d.ts +6 -0
- package/dist/lib/polyfills/xmlhttprequest.d.ts.map +1 -0
- package/dist/lib/polyfills/xmlhttprequest.js +127 -0
- package/dist/lib/polyfills/xmlhttprequest.js.map +1 -0
- package/dist/lib/quick-js/convert-handles.d.ts +14 -0
- package/dist/lib/quick-js/convert-handles.d.ts.map +1 -0
- package/dist/lib/quick-js/convert-handles.js +83 -0
- package/dist/lib/quick-js/convert-handles.js.map +1 -0
- package/dist/lib/quick-js/index.d.ts +12 -0
- package/dist/lib/quick-js/index.d.ts.map +1 -0
- package/dist/lib/quick-js/index.js +159 -0
- package/dist/lib/quick-js/index.js.map +1 -0
- package/dist/lib/quick-js/rpc-scene-runtime.d.ts +13 -0
- package/dist/lib/quick-js/rpc-scene-runtime.d.ts.map +1 -0
- package/dist/lib/quick-js/rpc-scene-runtime.js +32 -0
- package/dist/lib/quick-js/rpc-scene-runtime.js.map +1 -0
- package/dist/lib/quick-js/types.d.ts +35 -0
- package/dist/lib/quick-js/types.d.ts.map +1 -0
- package/dist/lib/quick-js/types.js +3 -0
- package/dist/lib/quick-js/types.js.map +1 -0
- package/dist/lib/web-worker-runtime/context.d.ts +12 -0
- package/dist/lib/web-worker-runtime/context.d.ts.map +1 -0
- package/dist/lib/web-worker-runtime/context.js +97 -0
- package/dist/lib/web-worker-runtime/context.js.map +1 -0
- package/dist/lib/web-worker-runtime/sandbox.d.ts +9 -0
- package/dist/lib/web-worker-runtime/sandbox.d.ts.map +1 -0
- package/dist/lib/web-worker-runtime/sandbox.js +98 -0
- package/dist/lib/web-worker-runtime/sandbox.js.map +1 -0
- package/dist/lib/web-worker-runtime/web-worker-scene-runtime.d.ts +13 -0
- package/dist/lib/web-worker-runtime/web-worker-scene-runtime.d.ts.map +1 -0
- package/dist/lib/web-worker-runtime/web-worker-scene-runtime.js +32 -0
- package/dist/lib/web-worker-runtime/web-worker-scene-runtime.js.map +1 -0
- package/package.json +73 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProcessMessageResultType = void 0;
|
|
4
|
+
var ProcessMessageResultType;
|
|
5
|
+
(function (ProcessMessageResultType) {
|
|
6
|
+
/**
|
|
7
|
+
* Typical message and new state set.
|
|
8
|
+
* @state CHANGE
|
|
9
|
+
* @reason Incoming message has a timestamp greater
|
|
10
|
+
*/
|
|
11
|
+
ProcessMessageResultType[ProcessMessageResultType["StateUpdatedTimestamp"] = 1] = "StateUpdatedTimestamp";
|
|
12
|
+
/**
|
|
13
|
+
* Typical message when it is considered old.
|
|
14
|
+
* @state it does NOT CHANGE.
|
|
15
|
+
* @reason incoming message has a timestamp lower.
|
|
16
|
+
*/
|
|
17
|
+
ProcessMessageResultType[ProcessMessageResultType["StateOutdatedTimestamp"] = 2] = "StateOutdatedTimestamp";
|
|
18
|
+
/**
|
|
19
|
+
* Weird message, same timestamp and data.
|
|
20
|
+
* @state it does NOT CHANGE.
|
|
21
|
+
* @reason consistent state between peers.
|
|
22
|
+
*/
|
|
23
|
+
ProcessMessageResultType[ProcessMessageResultType["NoChanges"] = 3] = "NoChanges";
|
|
24
|
+
/**
|
|
25
|
+
* Less but typical message, same timestamp, resolution by data.
|
|
26
|
+
* @state it does NOT CHANGE.
|
|
27
|
+
* @reason incoming message has a LOWER data.
|
|
28
|
+
*/
|
|
29
|
+
ProcessMessageResultType[ProcessMessageResultType["StateOutdatedData"] = 4] = "StateOutdatedData";
|
|
30
|
+
/**
|
|
31
|
+
* Less but typical message, same timestamp, resolution by data.
|
|
32
|
+
* @state CHANGE.
|
|
33
|
+
* @reason incoming message has a GREATER data.
|
|
34
|
+
*/
|
|
35
|
+
ProcessMessageResultType[ProcessMessageResultType["StateUpdatedData"] = 5] = "StateUpdatedData";
|
|
36
|
+
/**
|
|
37
|
+
* Entity was previously deleted.
|
|
38
|
+
* @state it does NOT CHANGE.
|
|
39
|
+
* @reason The message is considered old.
|
|
40
|
+
*/
|
|
41
|
+
ProcessMessageResultType[ProcessMessageResultType["EntityWasDeleted"] = 6] = "EntityWasDeleted";
|
|
42
|
+
/**
|
|
43
|
+
* Entity should be deleted.
|
|
44
|
+
* @state CHANGE.
|
|
45
|
+
* @reason the state is storing old entities
|
|
46
|
+
*/
|
|
47
|
+
ProcessMessageResultType[ProcessMessageResultType["EntityDeleted"] = 7] = "EntityDeleted";
|
|
48
|
+
})(ProcessMessageResultType = exports.ProcessMessageResultType || (exports.ProcessMessageResultType = {}));
|
|
49
|
+
//# sourceMappingURL=conflict-resolution.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conflict-resolution.js","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/conflict-resolution.ts"],"names":[],"mappings":";;;AACA,IAAY,wBAiDX;AAjDD,WAAY,wBAAwB;IAClC;;;;OAIG;IACH,yGAAyB,CAAA;IAEzB;;;;OAIG;IACH,2GAA0B,CAAA;IAE1B;;;;OAIG;IACH,iFAAa,CAAA;IAEb;;;;OAIG;IACH,iGAAqB,CAAA;IAErB;;;;OAIG;IACH,+FAAoB,CAAA;IAEpB;;;;OAIG;IACH,+FAAoB,CAAA;IAEpB;;;;OAIG;IACH,yFAAiB,CAAA;AACnB,CAAC,EAjDW,wBAAwB,GAAxB,gCAAwB,KAAxB,gCAAwB,QAiDnC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dataCompare.d.ts","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/dataCompare.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,MAAM,CAwBjD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.dataCompare = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Compare raw data.
|
|
6
|
+
* @returns 0 if is the same data, 1 if a > b, -1 if b > a
|
|
7
|
+
*/
|
|
8
|
+
function dataCompare(a, b) {
|
|
9
|
+
// At reference level
|
|
10
|
+
if (a === b)
|
|
11
|
+
return 0;
|
|
12
|
+
if (a === null && b !== null)
|
|
13
|
+
return -1;
|
|
14
|
+
if (a !== null && b === null)
|
|
15
|
+
return 1;
|
|
16
|
+
if (a instanceof Uint8Array && b instanceof Uint8Array) {
|
|
17
|
+
let res;
|
|
18
|
+
const n = a.byteLength > b.byteLength ? b.byteLength : a.byteLength;
|
|
19
|
+
for (let i = 0; i < n; i++) {
|
|
20
|
+
res = a[i] - b[i];
|
|
21
|
+
if (res !== 0) {
|
|
22
|
+
return res > 0 ? 1 : -1;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
res = a.byteLength - b.byteLength;
|
|
26
|
+
return res > 0 ? 1 : res < 0 ? -1 : 0;
|
|
27
|
+
}
|
|
28
|
+
if (typeof a === 'string') {
|
|
29
|
+
return a.localeCompare(b);
|
|
30
|
+
}
|
|
31
|
+
return a > b ? 1 : -1;
|
|
32
|
+
}
|
|
33
|
+
exports.dataCompare = dataCompare;
|
|
34
|
+
//# sourceMappingURL=dataCompare.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dataCompare.js","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/dataCompare.ts"],"names":[],"mappings":";;;AAAA;;;GAGG;AACH,SAAgB,WAAW,CAAI,CAAI,EAAE,CAAI;IACvC,qBAAqB;IACrB,IAAI,CAAC,KAAK,CAAC;QAAE,OAAO,CAAC,CAAA;IACrB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI;QAAE,OAAO,CAAC,CAAC,CAAA;IACvC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI;QAAE,OAAO,CAAC,CAAA;IAEtC,IAAI,CAAC,YAAY,UAAU,IAAI,CAAC,YAAY,UAAU,EAAE;QACtD,IAAI,GAAW,CAAA;QACf,MAAM,CAAC,GAAG,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAA;QACnE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1B,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;YACjB,IAAI,GAAG,KAAK,CAAC,EAAE;gBACb,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;aACxB;SACF;QACD,GAAG,GAAG,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAA;QACjC,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;KACtC;IAED,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;QACzB,OAAO,CAAC,CAAC,aAAa,CAAC,CAAW,CAAC,CAAA;KACpC;IAED,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;AACvB,CAAC;AAxBD,kCAwBC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { ByteBuffer } from "../ByteBuffer";
|
|
2
|
+
import { Entity } from "../types";
|
|
3
|
+
export declare const MAX_U16 = 65535;
|
|
4
|
+
export declare const MAX_ENTITY_NUMBER = 65535;
|
|
5
|
+
export declare namespace EntityUtils {
|
|
6
|
+
/**
|
|
7
|
+
* @returns [entityNumber, entityVersion]
|
|
8
|
+
*/
|
|
9
|
+
function fromEntityId(entityId: Entity): [number, number];
|
|
10
|
+
/**
|
|
11
|
+
* @returns compound number from entityNumber and entityVerison
|
|
12
|
+
*/
|
|
13
|
+
function toEntityId(entityNumber: number, entityVersion: number): Entity;
|
|
14
|
+
}
|
|
15
|
+
export declare function createGenerationalIndexPool(from: Entity, to: Entity): {
|
|
16
|
+
getFreeEntity(): number;
|
|
17
|
+
hasFreeEntities(): boolean;
|
|
18
|
+
runTick(): void;
|
|
19
|
+
deleteEntity(entity: Entity): void;
|
|
20
|
+
getCrdtUpdates(outBuffer: ByteBuffer, fromTick: number): number;
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=generational-index-pool.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generational-index-pool.d.ts","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/generational-index-pool.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AAEjC,eAAO,MAAM,OAAO,QAAS,CAAA;AAC7B,eAAO,MAAM,iBAAiB,QAAU,CAAA;AAGxC,yBAAiB,WAAW,CAAC;IAC3B;;OAEG;IACH,SAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAE/D;IAED;;OAEG;IACH,SAAgB,UAAU,CAAC,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,CAE9E;CACF;AAID,wBAAgB,2BAA2B,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM;;;;yBAyC3C,MAAM;8BAcD,UAAU,YAAY,MAAM,GAAG,MAAM;EAYlE"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createGenerationalIndexPool = exports.EntityUtils = exports.MAX_ENTITY_NUMBER = exports.MAX_U16 = void 0;
|
|
4
|
+
const crdt_wire_protocol_1 = require("../crdt-wire-protocol");
|
|
5
|
+
exports.MAX_U16 = 0xffff;
|
|
6
|
+
exports.MAX_ENTITY_NUMBER = exports.MAX_U16;
|
|
7
|
+
const MASK_UPPER_16_ON_32 = 0xffff0000;
|
|
8
|
+
var EntityUtils;
|
|
9
|
+
(function (EntityUtils) {
|
|
10
|
+
/**
|
|
11
|
+
* @returns [entityNumber, entityVersion]
|
|
12
|
+
*/
|
|
13
|
+
function fromEntityId(entityId) {
|
|
14
|
+
return [(entityId & exports.MAX_U16) >>> 0, (((entityId & MASK_UPPER_16_ON_32) >> 16) & exports.MAX_U16) >>> 0];
|
|
15
|
+
}
|
|
16
|
+
EntityUtils.fromEntityId = fromEntityId;
|
|
17
|
+
/**
|
|
18
|
+
* @returns compound number from entityNumber and entityVerison
|
|
19
|
+
*/
|
|
20
|
+
function toEntityId(entityNumber, entityVersion) {
|
|
21
|
+
return (((entityNumber & exports.MAX_U16) | ((entityVersion & exports.MAX_U16) << 16)) >>> 0);
|
|
22
|
+
}
|
|
23
|
+
EntityUtils.toEntityId = toEntityId;
|
|
24
|
+
})(EntityUtils = exports.EntityUtils || (exports.EntityUtils = {}));
|
|
25
|
+
// creates a pool of used entity numbers and exposes functions to get
|
|
26
|
+
// and release entities using their generational index
|
|
27
|
+
function createGenerationalIndexPool(from, to) {
|
|
28
|
+
// this is a stack
|
|
29
|
+
const freeEntityNumbers = [];
|
|
30
|
+
const usedEntityNumbers = new Set();
|
|
31
|
+
const generations = new Map();
|
|
32
|
+
const deletedAtTick = new Map();
|
|
33
|
+
let currentTick = 0;
|
|
34
|
+
// prepopulating the pool may not be the best idea in terms of performance and memory
|
|
35
|
+
// but it is the clearest implementation possible
|
|
36
|
+
for (let i = from; i < to; i++) {
|
|
37
|
+
freeEntityNumbers.push(i);
|
|
38
|
+
generations.set(i, -1);
|
|
39
|
+
}
|
|
40
|
+
// increments the generation of an entity number and returns the new generation
|
|
41
|
+
function incrementGeneration(num) {
|
|
42
|
+
const curGen = generations.get(num);
|
|
43
|
+
const newGen = curGen + 1;
|
|
44
|
+
generations.set(num, newGen);
|
|
45
|
+
return newGen;
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
getFreeEntity() {
|
|
49
|
+
if (freeEntityNumbers.length === 0) {
|
|
50
|
+
throw new Error('No free entities available');
|
|
51
|
+
}
|
|
52
|
+
const entityNumber = freeEntityNumbers.pop();
|
|
53
|
+
usedEntityNumbers.add(entityNumber);
|
|
54
|
+
const gen = incrementGeneration(entityNumber);
|
|
55
|
+
return EntityUtils.toEntityId(entityNumber, gen);
|
|
56
|
+
},
|
|
57
|
+
hasFreeEntities() {
|
|
58
|
+
return freeEntityNumbers.length > 0;
|
|
59
|
+
},
|
|
60
|
+
runTick() {
|
|
61
|
+
currentTick++;
|
|
62
|
+
},
|
|
63
|
+
deleteEntity(entity) {
|
|
64
|
+
const [num, gen] = EntityUtils.fromEntityId(entity);
|
|
65
|
+
const curGen = generations.get(num) ?? 0;
|
|
66
|
+
if (curGen <= gen) {
|
|
67
|
+
// save the bigger generation for this number
|
|
68
|
+
generations.set(num, gen);
|
|
69
|
+
}
|
|
70
|
+
// only free the number if the generation matches
|
|
71
|
+
if (curGen == gen && usedEntityNumbers.has(num)) {
|
|
72
|
+
freeEntityNumbers.push(num);
|
|
73
|
+
usedEntityNumbers.delete(num);
|
|
74
|
+
deletedAtTick.set(entity, currentTick);
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
getCrdtUpdates(outBuffer, fromTick) {
|
|
78
|
+
let biggestTick = fromTick;
|
|
79
|
+
for (const [entityId, tick] of deletedAtTick) {
|
|
80
|
+
if (tick <= fromTick)
|
|
81
|
+
continue;
|
|
82
|
+
if (biggestTick < tick)
|
|
83
|
+
biggestTick = tick;
|
|
84
|
+
crdt_wire_protocol_1.DeleteEntity.write({ entityId }, outBuffer);
|
|
85
|
+
}
|
|
86
|
+
return biggestTick;
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
exports.createGenerationalIndexPool = createGenerationalIndexPool;
|
|
91
|
+
//# sourceMappingURL=generational-index-pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generational-index-pool.js","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/generational-index-pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ComponentDeclaration, GrowOnlyValueSetComponentDefinition } from "./components";
|
|
2
|
+
/**
|
|
3
|
+
* @public
|
|
4
|
+
*/
|
|
5
|
+
export type ValueSetOptions<T> = {
|
|
6
|
+
timestampFunction: (value: Readonly<T>) => number;
|
|
7
|
+
maxElements: number;
|
|
8
|
+
};
|
|
9
|
+
export declare function createValueSetComponentStore<T, ComponentNumber extends number>(declaration: ComponentDeclaration<T, ComponentNumber>, options: ValueSetOptions<T>): GrowOnlyValueSetComponentDefinition<T>;
|
|
10
|
+
//# sourceMappingURL=grow-only-set.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grow-only-set.d.ts","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/grow-only-set.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAiB,mCAAmC,EAAE,MAAM,cAAc,CAAC;AAmBxG;;GAEG;AACH,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI;IAE/B,iBAAiB,EAAE,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,MAAM,CAAA;IAEjD,WAAW,EAAE,MAAM,CAAA;CACpB,CAAA;AAED,wBAAgB,4BAA4B,CAAC,CAAC,EAAE,eAAe,SAAS,MAAM,EAC5E,WAAW,EAAE,oBAAoB,CAAC,CAAC,EAAE,eAAe,CAAC,EACrD,OAAO,EAAE,eAAe,CAAC,CAAC,CAAC,GAC1B,mCAAmC,CAAC,CAAC,CAAC,CAmHxC"}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createValueSetComponentStore = void 0;
|
|
4
|
+
const ByteBuffer_1 = require("../ByteBuffer");
|
|
5
|
+
const crdt_wire_protocol_1 = require("../crdt-wire-protocol");
|
|
6
|
+
function frozenError() {
|
|
7
|
+
throw new Error('The set is frozen');
|
|
8
|
+
}
|
|
9
|
+
function freezeSet(set) {
|
|
10
|
+
;
|
|
11
|
+
set.add = frozenError;
|
|
12
|
+
set.clear = frozenError;
|
|
13
|
+
return set;
|
|
14
|
+
}
|
|
15
|
+
const emptyReadonlySet = freezeSet(new Set());
|
|
16
|
+
function sortByTimestamp(a, b) {
|
|
17
|
+
return a.timestamp > b.timestamp ? 1 : -1;
|
|
18
|
+
}
|
|
19
|
+
function createValueSetComponentStore(declaration, options) {
|
|
20
|
+
const data = new Map();
|
|
21
|
+
const dirtyIterator = new Set();
|
|
22
|
+
const queuedCommands = [];
|
|
23
|
+
// only sort the array if the latest (N) element has a timestamp <= N-1
|
|
24
|
+
function shouldSort(row) {
|
|
25
|
+
const len = row.raw.length;
|
|
26
|
+
if (len > 1 && row.raw[len - 1].timestamp <= row.raw[len - 2].timestamp) {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
function gotUpdated(entity) {
|
|
32
|
+
const row = data.get(entity);
|
|
33
|
+
if (row) {
|
|
34
|
+
if (shouldSort(row)) {
|
|
35
|
+
row.raw.sort(sortByTimestamp);
|
|
36
|
+
}
|
|
37
|
+
while (row.raw.length > options.maxElements) {
|
|
38
|
+
row.raw.shift();
|
|
39
|
+
}
|
|
40
|
+
const frozenSet = freezeSet(new Set(row?.raw.map(($) => Object.freeze($.value))));
|
|
41
|
+
row.frozenSet = frozenSet;
|
|
42
|
+
return frozenSet;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
/* istanbul ignore next */
|
|
46
|
+
return emptyReadonlySet;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
function append(entity, value) {
|
|
50
|
+
let row = data.get(entity);
|
|
51
|
+
if (!row) {
|
|
52
|
+
row = { raw: [], frozenSet: emptyReadonlySet };
|
|
53
|
+
data.set(entity, row);
|
|
54
|
+
}
|
|
55
|
+
const timestamp = options.timestampFunction(value);
|
|
56
|
+
// this is an expensive operation, but this explorer should prioritize correctness over performance
|
|
57
|
+
Object.freeze(value);
|
|
58
|
+
row.raw.push({ value, timestamp });
|
|
59
|
+
return { set: gotUpdated(entity), value };
|
|
60
|
+
}
|
|
61
|
+
const ret = {
|
|
62
|
+
get componentId() {
|
|
63
|
+
return declaration.componentId;
|
|
64
|
+
},
|
|
65
|
+
get componentType() {
|
|
66
|
+
// a getter is used here to prevent accidental changes
|
|
67
|
+
return 1 /* ComponentType.GrowOnlyValueSet */;
|
|
68
|
+
},
|
|
69
|
+
declaration,
|
|
70
|
+
has(entity) {
|
|
71
|
+
return data.has(entity);
|
|
72
|
+
},
|
|
73
|
+
entityDeleted(entity) {
|
|
74
|
+
data.delete(entity);
|
|
75
|
+
},
|
|
76
|
+
get(entity) {
|
|
77
|
+
const values = data.get(entity);
|
|
78
|
+
if (values) {
|
|
79
|
+
return values.frozenSet;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
return emptyReadonlySet;
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
addValue(entity, rawValue) {
|
|
86
|
+
const { set, value } = append(entity, rawValue);
|
|
87
|
+
dirtyIterator.add(entity);
|
|
88
|
+
const buf = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
89
|
+
declaration.serialize(value, buf);
|
|
90
|
+
queuedCommands.push({
|
|
91
|
+
componentId: declaration.componentId,
|
|
92
|
+
data: buf.toBinary(),
|
|
93
|
+
entityId: entity,
|
|
94
|
+
timestamp: 0,
|
|
95
|
+
type: crdt_wire_protocol_1.CrdtMessageType.APPEND_VALUE
|
|
96
|
+
});
|
|
97
|
+
return set;
|
|
98
|
+
},
|
|
99
|
+
*iterator() {
|
|
100
|
+
for (const [entity, component] of data) {
|
|
101
|
+
yield [entity, component.frozenSet];
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
dirtyIterator() {
|
|
105
|
+
return Array.from(dirtyIterator);
|
|
106
|
+
},
|
|
107
|
+
dumpCrdtUpdates(outBuffer) {
|
|
108
|
+
dirtyIterator.clear();
|
|
109
|
+
for (const command of queuedCommands) {
|
|
110
|
+
crdt_wire_protocol_1.AppendValueOperation.write(command, outBuffer);
|
|
111
|
+
}
|
|
112
|
+
queuedCommands.length = 0;
|
|
113
|
+
},
|
|
114
|
+
dumpCrdtDeltas(outBuffer, fromTimestamp) {
|
|
115
|
+
// not implemented for GOVS component
|
|
116
|
+
return 0;
|
|
117
|
+
},
|
|
118
|
+
updateFromCrdt(body, _conflictResolutionByteBuffer) {
|
|
119
|
+
if (body.type === crdt_wire_protocol_1.CrdtMessageType.APPEND_VALUE) {
|
|
120
|
+
const buf = new ByteBuffer_1.ReadWriteByteBuffer(body.data);
|
|
121
|
+
append(body.entityId, declaration.deserialize(buf));
|
|
122
|
+
}
|
|
123
|
+
return true;
|
|
124
|
+
}
|
|
125
|
+
};
|
|
126
|
+
return ret;
|
|
127
|
+
}
|
|
128
|
+
exports.createValueSetComponentStore = createValueSetComponentStore;
|
|
129
|
+
//# sourceMappingURL=grow-only-set.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grow-only-set.js","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/grow-only-set.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Atom } from "../../misc/atom";
|
|
2
|
+
import { ByteBuffer } from "../ByteBuffer";
|
|
3
|
+
import { CrdtMessageBody } from "../crdt-wire-protocol";
|
|
4
|
+
import { Entity } from "../types";
|
|
5
|
+
import { ComponentDeclaration, LastWriteWinElementSetComponentDefinition, SerDe } from "./components";
|
|
6
|
+
export declare function incrementTimestamp(entity: Entity, timestamps: Map<Entity, number>): number;
|
|
7
|
+
export declare function createUpdateLwwFromCrdt<T>(componentId: number, timestamps: Map<Entity, number>, schema: SerDe<T>, data: Map<Entity, T>): (msg: CrdtMessageBody, conflictResolutionByteBuffer: ByteBuffer) => boolean;
|
|
8
|
+
export declare function createGetCrdtMessagesForLww<T>(componentId: number, updatedAtTick: Map<Entity, number>, timestamps: Map<Entity, number>, dirtyIterator: Set<Entity>, serde: SerDe<T>, data: Map<Entity, T>, currentTick: Atom<number>): (outBuffer: ByteBuffer) => void;
|
|
9
|
+
export declare function createGetCrdtMessagesForLwwWithTick<T>(componentId: number, updatedAtTick: Map<Entity, number>, timestamps: Map<Entity, number>, serde: SerDe<T>, data: Map<Entity, T>): (outBuffer: ByteBuffer, fromTick: number) => number;
|
|
10
|
+
export declare function createLwwStore<T, Num extends number>(componentDeclaration: ComponentDeclaration<T, Num>): LastWriteWinElementSetComponentDefinition<T>;
|
|
11
|
+
//# sourceMappingURL=last-write-win-element-set.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"last-write-win-element-set.d.ts","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/last-write-win-element-set.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AACtC,OAAO,EAAE,UAAU,EAAuB,MAAM,eAAe,CAAA;AAC/D,OAAO,EAAgH,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACrK,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AACjC,OAAO,EAAE,oBAAoB,EAAiB,yCAAyC,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AAIpH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,MAAM,CAI1F;AAED,wBAAgB,uBAAuB,CAAC,CAAC,EACvC,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAC/B,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,EAChB,IAAI,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,SAsDP,eAAe,gCAAgC,UAAU,KAAG,OAAO,CA2CjF;AAED,wBAAgB,2BAA2B,CAAC,CAAC,EAC3C,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAClC,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAC/B,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,EAC1B,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,EACf,IAAI,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,EACpB,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,eAEG,UAAU,UAiBvC;AAID,wBAAgB,mCAAmC,CAAC,CAAC,EACnD,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAClC,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAC/B,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,EACf,IAAI,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,eAEQ,UAAU,YAAY,MAAM,YAkBzD;AAED,wBAAgB,cAAc,CAAC,CAAC,EAAE,GAAG,SAAS,MAAM,EAAE,oBAAoB,EAAE,oBAAoB,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,yCAAyC,CAAC,CAAC,CAAC,CA8EtJ"}
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createLwwStore = exports.createGetCrdtMessagesForLwwWithTick = exports.createGetCrdtMessagesForLww = exports.createUpdateLwwFromCrdt = exports.incrementTimestamp = void 0;
|
|
4
|
+
const atom_1 = require("../../misc/atom");
|
|
5
|
+
const ByteBuffer_1 = require("../ByteBuffer");
|
|
6
|
+
const crdt_wire_protocol_1 = require("../crdt-wire-protocol");
|
|
7
|
+
const conflict_resolution_1 = require("./conflict-resolution");
|
|
8
|
+
const dataCompare_1 = require("./dataCompare");
|
|
9
|
+
function incrementTimestamp(entity, timestamps) {
|
|
10
|
+
const newTimestamp = (timestamps.get(entity) || 0) + 1;
|
|
11
|
+
timestamps.set(entity, newTimestamp);
|
|
12
|
+
return newTimestamp;
|
|
13
|
+
}
|
|
14
|
+
exports.incrementTimestamp = incrementTimestamp;
|
|
15
|
+
function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
16
|
+
/**
|
|
17
|
+
* Process the received message only if the lamport number recieved is higher
|
|
18
|
+
* than the stored one. If its lower, we spread it to the network to correct the peer.
|
|
19
|
+
* If they are equal, the bigger raw data wins.
|
|
20
|
+
|
|
21
|
+
* Returns the recieved data if the lamport number was bigger than ours.
|
|
22
|
+
* If it was an outdated message, then we return void
|
|
23
|
+
* @public
|
|
24
|
+
*/
|
|
25
|
+
function crdtRuleForCurrentState(message) {
|
|
26
|
+
const { entityId, timestamp } = message;
|
|
27
|
+
const currentTimestamp = timestamps.get(entityId);
|
|
28
|
+
// The received message is > than our current value, update our state.components.
|
|
29
|
+
if (currentTimestamp === undefined || currentTimestamp < timestamp) {
|
|
30
|
+
return conflict_resolution_1.ProcessMessageResultType.StateUpdatedTimestamp;
|
|
31
|
+
}
|
|
32
|
+
// Outdated Message. Resend our state message through the wire.
|
|
33
|
+
if (currentTimestamp > timestamp) {
|
|
34
|
+
return conflict_resolution_1.ProcessMessageResultType.StateOutdatedTimestamp;
|
|
35
|
+
}
|
|
36
|
+
// Deletes are idempotent
|
|
37
|
+
if (message.type === crdt_wire_protocol_1.CrdtMessageType.DELETE_COMPONENT && !data.has(entityId)) {
|
|
38
|
+
return conflict_resolution_1.ProcessMessageResultType.NoChanges;
|
|
39
|
+
}
|
|
40
|
+
let currentDataGreater = 0;
|
|
41
|
+
if (data.has(entityId)) {
|
|
42
|
+
const writeBuffer = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
43
|
+
schema.serialize(data.get(entityId), writeBuffer);
|
|
44
|
+
currentDataGreater = (0, dataCompare_1.dataCompare)(writeBuffer.toBinary(), message.data || null);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
currentDataGreater = (0, dataCompare_1.dataCompare)(null, message.data);
|
|
48
|
+
}
|
|
49
|
+
if (currentDataGreater === 0) {
|
|
50
|
+
// Same data, same timestamp.
|
|
51
|
+
return conflict_resolution_1.ProcessMessageResultType.NoChanges;
|
|
52
|
+
}
|
|
53
|
+
else if (currentDataGreater > 0) {
|
|
54
|
+
// Current data is greater
|
|
55
|
+
return conflict_resolution_1.ProcessMessageResultType.StateOutdatedData;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
// Curent data is lower
|
|
59
|
+
return conflict_resolution_1.ProcessMessageResultType.StateUpdatedData;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return (msg, conflictResolutionByteBuffer) => {
|
|
63
|
+
if (msg.type !== crdt_wire_protocol_1.CrdtMessageType.PUT_COMPONENT && msg.type !== crdt_wire_protocol_1.CrdtMessageType.DELETE_COMPONENT)
|
|
64
|
+
return true;
|
|
65
|
+
const action = crdtRuleForCurrentState(msg);
|
|
66
|
+
const entityId = msg.entityId;
|
|
67
|
+
switch (action) {
|
|
68
|
+
case conflict_resolution_1.ProcessMessageResultType.StateUpdatedData:
|
|
69
|
+
case conflict_resolution_1.ProcessMessageResultType.StateUpdatedTimestamp: {
|
|
70
|
+
timestamps.set(entityId, msg.timestamp);
|
|
71
|
+
if (msg.type === crdt_wire_protocol_1.CrdtMessageType.PUT_COMPONENT) {
|
|
72
|
+
const buf = new ByteBuffer_1.ReadWriteByteBuffer(msg.data);
|
|
73
|
+
data.set(entityId, schema.deserialize(buf));
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
data.delete(entityId);
|
|
77
|
+
}
|
|
78
|
+
return true; // change accepted
|
|
79
|
+
}
|
|
80
|
+
case conflict_resolution_1.ProcessMessageResultType.StateOutdatedTimestamp:
|
|
81
|
+
case conflict_resolution_1.ProcessMessageResultType.StateOutdatedData: {
|
|
82
|
+
const timestamp = timestamps.get(entityId);
|
|
83
|
+
if (data.has(entityId)) {
|
|
84
|
+
const writeBuffer = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
85
|
+
schema.serialize(data.get(entityId), writeBuffer);
|
|
86
|
+
// post conflict resolution update
|
|
87
|
+
crdt_wire_protocol_1.PutComponentOperation.write({ entityId, componentId, timestamp, data: writeBuffer.toBinary(), }, conflictResolutionByteBuffer);
|
|
88
|
+
return false; // change not accepted
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
// post conflict resolution update
|
|
92
|
+
crdt_wire_protocol_1.DeleteComponent.write({ entityId, componentId, timestamp }, conflictResolutionByteBuffer);
|
|
93
|
+
return false; // change not accepted
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return true; // change accepted
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
exports.createUpdateLwwFromCrdt = createUpdateLwwFromCrdt;
|
|
101
|
+
function createGetCrdtMessagesForLww(componentId, updatedAtTick, timestamps, dirtyIterator, serde, data, currentTick) {
|
|
102
|
+
return function (outBuffer) {
|
|
103
|
+
const tick = 1 + (currentTick.getOrNull() ?? 0);
|
|
104
|
+
currentTick.swap(tick);
|
|
105
|
+
for (const entityId of dirtyIterator) {
|
|
106
|
+
const timestamp = incrementTimestamp(entityId, timestamps);
|
|
107
|
+
updatedAtTick.set(entityId, tick);
|
|
108
|
+
if (data.has(entityId)) {
|
|
109
|
+
const writeBuffer = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
110
|
+
serde.serialize(data.get(entityId), writeBuffer);
|
|
111
|
+
crdt_wire_protocol_1.PutComponentOperation.write({ entityId, componentId, timestamp, data: writeBuffer.toBinary(), }, outBuffer);
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
crdt_wire_protocol_1.DeleteComponent.write({ entityId, componentId, timestamp }, outBuffer);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
dirtyIterator.clear();
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
exports.createGetCrdtMessagesForLww = createGetCrdtMessagesForLww;
|
|
121
|
+
// this function writes the updates for the LWW component to the outBuffer using
|
|
122
|
+
// the entities that were updated after the fromTick value.
|
|
123
|
+
function createGetCrdtMessagesForLwwWithTick(componentId, updatedAtTick, timestamps, serde, data) {
|
|
124
|
+
return function (outBuffer, fromTick) {
|
|
125
|
+
let biggestTick = fromTick;
|
|
126
|
+
for (const [entityId, tick] of updatedAtTick) {
|
|
127
|
+
if (tick <= fromTick)
|
|
128
|
+
continue;
|
|
129
|
+
if (biggestTick < tick)
|
|
130
|
+
biggestTick = tick;
|
|
131
|
+
const timestamp = timestamps.get(entityId) ?? 0;
|
|
132
|
+
if (data.has(entityId)) {
|
|
133
|
+
const writeBuffer = new ByteBuffer_1.ReadWriteByteBuffer();
|
|
134
|
+
serde.serialize(data.get(entityId), writeBuffer);
|
|
135
|
+
crdt_wire_protocol_1.PutComponentOperation.write({ entityId, componentId, timestamp, data: writeBuffer.toBinary(), }, outBuffer);
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
crdt_wire_protocol_1.DeleteComponent.write({ entityId, componentId, timestamp }, outBuffer);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
return biggestTick;
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
exports.createGetCrdtMessagesForLwwWithTick = createGetCrdtMessagesForLwwWithTick;
|
|
145
|
+
function createLwwStore(componentDeclaration) {
|
|
146
|
+
const data = new Map();
|
|
147
|
+
const dirtyIterator = new Set();
|
|
148
|
+
const timestamps = new Map();
|
|
149
|
+
const updatedAtTick = new Map();
|
|
150
|
+
const currentTick = (0, atom_1.Atom)(0);
|
|
151
|
+
return {
|
|
152
|
+
get componentId() {
|
|
153
|
+
return componentDeclaration.componentId;
|
|
154
|
+
},
|
|
155
|
+
get componentType() {
|
|
156
|
+
// a getter is used here to prevent accidental changes
|
|
157
|
+
return 0 /* ComponentType.LastWriteWinElementSet */;
|
|
158
|
+
},
|
|
159
|
+
declaration: componentDeclaration,
|
|
160
|
+
has(entity) {
|
|
161
|
+
return data.has(entity);
|
|
162
|
+
},
|
|
163
|
+
deleteFrom(entity, markAsDirty = true) {
|
|
164
|
+
const component = data.get(entity);
|
|
165
|
+
if (data.delete(entity) && markAsDirty) {
|
|
166
|
+
dirtyIterator.add(entity);
|
|
167
|
+
}
|
|
168
|
+
return component || null;
|
|
169
|
+
},
|
|
170
|
+
entityDeleted(entity, markAsDirty) {
|
|
171
|
+
if (data.delete(entity) && markAsDirty) {
|
|
172
|
+
dirtyIterator.add(entity);
|
|
173
|
+
}
|
|
174
|
+
},
|
|
175
|
+
getOrNull(entity) {
|
|
176
|
+
return data.get(entity) ?? null;
|
|
177
|
+
},
|
|
178
|
+
get(entity) {
|
|
179
|
+
return data.has(entity) ? data.get(entity) : undefined;
|
|
180
|
+
},
|
|
181
|
+
create(entity, value) {
|
|
182
|
+
const component = data.get(entity);
|
|
183
|
+
if (component) {
|
|
184
|
+
throw new Error(`[create] Component ${componentDeclaration.componentId} for ${entity} already exists`);
|
|
185
|
+
}
|
|
186
|
+
data.set(entity, value);
|
|
187
|
+
dirtyIterator.add(entity);
|
|
188
|
+
return value;
|
|
189
|
+
},
|
|
190
|
+
createOrReplace(entity, value) {
|
|
191
|
+
data.set(entity, value);
|
|
192
|
+
dirtyIterator.add(entity);
|
|
193
|
+
return value;
|
|
194
|
+
},
|
|
195
|
+
getMutableOrNull(entity) {
|
|
196
|
+
const component = data.get(entity);
|
|
197
|
+
if (!component) {
|
|
198
|
+
return null;
|
|
199
|
+
}
|
|
200
|
+
dirtyIterator.add(entity);
|
|
201
|
+
return component;
|
|
202
|
+
},
|
|
203
|
+
getMutable(entity) {
|
|
204
|
+
const component = this.getMutableOrNull(entity);
|
|
205
|
+
if (component === null) {
|
|
206
|
+
throw new Error(`[mutable] Component ${componentDeclaration.componentId} for ${entity} not found`);
|
|
207
|
+
}
|
|
208
|
+
return component;
|
|
209
|
+
},
|
|
210
|
+
*iterator() {
|
|
211
|
+
for (const [entity, component] of data) {
|
|
212
|
+
yield [entity, component];
|
|
213
|
+
}
|
|
214
|
+
},
|
|
215
|
+
dirtyIterator() {
|
|
216
|
+
return Array.from(dirtyIterator);
|
|
217
|
+
},
|
|
218
|
+
dumpCrdtDeltas: createGetCrdtMessagesForLwwWithTick(componentDeclaration.componentId, updatedAtTick, timestamps, componentDeclaration, data),
|
|
219
|
+
dumpCrdtUpdates: createGetCrdtMessagesForLww(componentDeclaration.componentId, updatedAtTick, timestamps, dirtyIterator, componentDeclaration, data, currentTick),
|
|
220
|
+
updateFromCrdt: createUpdateLwwFromCrdt(componentDeclaration.componentId, timestamps, componentDeclaration, data),
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
exports.createLwwStore = createLwwStore;
|
|
224
|
+
//# sourceMappingURL=last-write-win-element-set.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"last-write-win-element-set.js","sourceRoot":"","sources":["../../../../src/lib/decentraland/crdt-internal/last-write-win-element-set.ts"],"names":[],"mappings":"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"}
|